blob: 2310b3e2aeff59f2a07f9d49a251af3aeabd2996 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/* init table sorter defaults */
if ( $.tablesorter ) {
$.tablesorter.defaults.cssAsc = 'headerSortUp ui-state-focus';
$.tablesorter.defaults.cssDesc = 'headerSortDown ui-state-focus';
$.tablesorter.defaults.header = 'header ui-widget-header';
$.tablesorter.defaults.widgets = ['zebra'];
$.tablesorter.defaults.widgetZebra = {
css : ["odd", "even ui-state-default"]
};
}
/* initializes static widgets */
function initStaticWidgets(elem) {
// hover states on the static widgets - form elements
var el = elem ? $(elem) : $(document);
el.find('button, input[type!=checkbox], .dynhover').hover(
function() { $(this).addClass('ui-state-hover'); },
function() { $(this).removeClass('ui-state-hover'); }
).addClass('ui-state-default ui-corner-all');
// fix attribute selector in IE
el.find('input[type=text], input[type=password], input[type=file]').addClass('inputText');
// make buttones nicer by applying equal width - not working in IE ;(
el.find('button, input[type=submit], input[type=reset], input[type=button]').each(function(i) {
var txt = $(this).text();
var apply = txt && txt.length > 1;
if (apply) $(this).css('min-width', '8em');
});
// add default table styling - colors and fonts from the theme
el.find('table.nicetable').addClass('ui-widget');
el.find('table.nicetable th').addClass('ui-widget-header');
// add default styling for table sorter
el.find("table.tablesorter tbody").addClass("ui-widget-content");
// add theme styling to the status line
el.find('.statline').addClass('ui-state-highlight')
el.find('table.tablesorter').trigger("update").trigger("applyWidgets");
}
/* automatically executed on load */
$(document).ready(function() {
// init table-sorter tables - only once!
var tables = $('table.tablesorter');
if (tables.size() > 0) tables.tablesorter();
// init navigation
$('#technav div.ui-state-default').hover(
function() { $(this).addClass('ui-state-hover'); },
function() { $(this).removeClass('ui-state-hover'); }
);
// register global ajax error handler
$(document).ajaxError( function(event, XMLHttpRequest, ajaxOptions, thrownError) {
var pre = '<br/><pre>';
for (i in event) pre += i + '=' + event[i] + '\n'
pre += '</pre>';
XAlert('The request failed: ' + thrownError + pre, 'AJAX Error');
});
initStaticWidgets();
});
/* replacement for confirm() method, needs 'action' parameter to work.
* if action is not set - then default confirm() method is used. */
function Xconfirm(text, action, title) {
if (!$.isFunction(action)) return confirm(text);
if (title === undefined) title = "";
Xdialog(text).dialog({
modal: true,
title: title,
buttons: {
"Yes": function() {
$(this).dialog('close');
action();
},
"No": function() {
$(this).dialog('close');
}
}
});
return false;
}
function Xalert(text, title) {
if (!$.isFunction(action)) return alert(text);
if (title === undefined) title = "";
Xdialog(text).dialog({
modal: true,
title: title,
buttons: {
"Ok": function() {
$(this).dialog('close');
}
}
});
return false;
}
/* a helper function used by Xconfirm & Xalert */
function Xdialog(text) {
var dialog = $('#dialog'); // use existing dialog element
if ( dialog.size() == 0 ) { // doesn't exists
var element = document.createElement( 'div' );
$('body').append(element);
dialog = $(element);
}
// init dialog
dialog.html(text).dialog('destroy'); // set text & reset dialog
return dialog;
}
/* String */ function wordWrap( /* String */ msg ) {
var userAgent = navigator.userAgent.toLowerCase();
var isMozilla = /mozilla/.test( userAgent ) && !/(compatible|webkit)/.test( userAgent );
return isMozilla ? msg.split('').join(String.fromCharCode('8203')) : msg;
}
/* content of the old ui.js */
/* Element */ function clearChildren( /* Element */ element ) {
while (element.firstChild) {
element.removeChild(element.firstChild);
}
return element;
}
/* String */ function serialize( /* Element */ element ) {
var result = "";
if (element) {
if (element.nodeValue) {
result = element.nodeValue;
} else {
result += "<" + element.tagName;
var attrs = element.attributes;
for (var i=0; i < attrs.length; i++) {
if (attrs[i].nodeValue) {
result += " " + attrs[i].nodeName + "='" + attrs[i].nodeValue + "'";
}
}
var children = element.childNodes;
if (children && children.length) {
result += ">";
for (var i=0; i < children.length; i++) {
result += serialize( children[i] );
}
result += "</" + element.tagName + ">";
} else {
result += "/>";
}
}
}
return result;
}
/* Element */ function th( /* String */ cssClass, /* Map */ attrs, /* Element[] */ children ) {
return createElement( "th", cssClass, attrs, children );
}
/* Element */ function tr( /* String */ cssClass, /* Map */ attrs, /* Element[] */ children ) {
return createElement( "tr", cssClass, attrs, children );
}
/* Element */ function td( /* String */ cssClass, /* Map */ attrs, /* Element[] */ children ) {
return createElement( "td", cssClass, attrs, children );
}
/* Element */ function text( /* String */ textValue ) {
return document.createTextNode( textValue );
}
/* Element */ function createElement( /* String */ name, /* String */ cssClass, /* Map */ attrs, /* Element[] */ children ) {
var element = document.createElement( name );
if (cssClass) {
$(element).addClass(cssClass);
}
if (attrs) {
for (var lab in attrs) {
if ("style" == lab) {
var styles = attrs[lab];
for (var styleName in styles) {
$(element).css(styleName, styles[styleName]);
}
} else {
$(element).attr( lab, attrs[lab] );
}
}
}
if (children && children.length) {
for (var i=0; i < children.length; i++) {
element.appendChild( children[i] );
}
}
return element;
}
/* Element */ function addText( /* Element */ element, /* String */ textValue ) {
if (element && textValue) {
element.appendChild( text( textValue ) );
}
return element;
}