8167 lines
631 KiB
Diff
8167 lines
631 KiB
Diff
|
diff -up cacti-0.8.8a/include/js/jquery/colorpicker.js.legal cacti-0.8.8a/include/js/jquery/colorpicker.js
|
|||
|
--- cacti-0.8.8a/include/js/jquery/colorpicker.js.legal 2013-01-04 15:44:38.025416061 -0500
|
|||
|
+++ cacti-0.8.8a/include/js/jquery/colorpicker.js 2013-01-04 15:43:12.644377988 -0500
|
|||
|
@@ -0,0 +1,484 @@
|
|||
|
+/**
|
|||
|
+ *
|
|||
|
+ * Color picker
|
|||
|
+ * Author: Stefan Petre www.eyecon.ro
|
|||
|
+ *
|
|||
|
+ * Dual licensed under the MIT and GPL licenses
|
|||
|
+ *
|
|||
|
+ */
|
|||
|
+(function ($) {
|
|||
|
+ var ColorPicker = function () {
|
|||
|
+ var
|
|||
|
+ ids = {},
|
|||
|
+ inAction,
|
|||
|
+ charMin = 65,
|
|||
|
+ visible,
|
|||
|
+ tpl = '<div class="colorpicker"><div class="colorpicker_color"><div><div></div></div></div><div class="colorpicker_hue"><div></div></div><div class="colorpicker_new_color"></div><div class="colorpicker_current_color"></div><div class="colorpicker_hex"><input type="text" maxlength="6" size="6" /></div><div class="colorpicker_rgb_r colorpicker_field"><input type="text" maxlength="3" size="3" /><span></span></div><div class="colorpicker_rgb_g colorpicker_field"><input type="text" maxlength="3" size="3" /><span></span></div><div class="colorpicker_rgb_b colorpicker_field"><input type="text" maxlength="3" size="3" /><span></span></div><div class="colorpicker_hsb_h colorpicker_field"><input type="text" maxlength="3" size="3" /><span></span></div><div class="colorpicker_hsb_s colorpicker_field"><input type="text" maxlength="3" size="3" /><span></span></div><div class="colorpicker_hsb_b colorpicker_field"><input type="text" maxlength="3" size="3" /><span></span></div><div class="colorpicker_submit"></div></div>',
|
|||
|
+ defaults = {
|
|||
|
+ eventName: 'click',
|
|||
|
+ onShow: function () {},
|
|||
|
+ onBeforeShow: function(){},
|
|||
|
+ onHide: function () {},
|
|||
|
+ onChange: function () {},
|
|||
|
+ onSubmit: function () {},
|
|||
|
+ color: 'ff0000',
|
|||
|
+ livePreview: true,
|
|||
|
+ flat: false
|
|||
|
+ },
|
|||
|
+ fillRGBFields = function (hsb, cal) {
|
|||
|
+ var rgb = HSBToRGB(hsb);
|
|||
|
+ $(cal).data('colorpicker').fields
|
|||
|
+ .eq(1).val(rgb.r).end()
|
|||
|
+ .eq(2).val(rgb.g).end()
|
|||
|
+ .eq(3).val(rgb.b).end();
|
|||
|
+ },
|
|||
|
+ fillHSBFields = function (hsb, cal) {
|
|||
|
+ $(cal).data('colorpicker').fields
|
|||
|
+ .eq(4).val(hsb.h).end()
|
|||
|
+ .eq(5).val(hsb.s).end()
|
|||
|
+ .eq(6).val(hsb.b).end();
|
|||
|
+ },
|
|||
|
+ fillHexFields = function (hsb, cal) {
|
|||
|
+ $(cal).data('colorpicker').fields
|
|||
|
+ .eq(0).val(HSBToHex(hsb)).end();
|
|||
|
+ },
|
|||
|
+ setSelector = function (hsb, cal) {
|
|||
|
+ $(cal).data('colorpicker').selector.css('backgroundColor', '#' + HSBToHex({h: hsb.h, s: 100, b: 100}));
|
|||
|
+ $(cal).data('colorpicker').selectorIndic.css({
|
|||
|
+ left: parseInt(150 * hsb.s/100, 10),
|
|||
|
+ top: parseInt(150 * (100-hsb.b)/100, 10)
|
|||
|
+ });
|
|||
|
+ },
|
|||
|
+ setHue = function (hsb, cal) {
|
|||
|
+ $(cal).data('colorpicker').hue.css('top', parseInt(150 - 150 * hsb.h/360, 10));
|
|||
|
+ },
|
|||
|
+ setCurrentColor = function (hsb, cal) {
|
|||
|
+ $(cal).data('colorpicker').currentColor.css('backgroundColor', '#' + HSBToHex(hsb));
|
|||
|
+ },
|
|||
|
+ setNewColor = function (hsb, cal) {
|
|||
|
+ $(cal).data('colorpicker').newColor.css('backgroundColor', '#' + HSBToHex(hsb));
|
|||
|
+ },
|
|||
|
+ keyDown = function (ev) {
|
|||
|
+ var pressedKey = ev.charCode || ev.keyCode || -1;
|
|||
|
+ if ((pressedKey > charMin && pressedKey <= 90) || pressedKey == 32) {
|
|||
|
+ return false;
|
|||
|
+ }
|
|||
|
+ var cal = $(this).parent().parent();
|
|||
|
+ if (cal.data('colorpicker').livePreview === true) {
|
|||
|
+ change.apply(this);
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ change = function (ev) {
|
|||
|
+ var cal = $(this).parent().parent(), col;
|
|||
|
+ if (this.parentNode.className.indexOf('_hex') > 0) {
|
|||
|
+ cal.data('colorpicker').color = col = HexToHSB(fixHex(this.value));
|
|||
|
+ } else if (this.parentNode.className.indexOf('_hsb') > 0) {
|
|||
|
+ cal.data('colorpicker').color = col = fixHSB({
|
|||
|
+ h: parseInt(cal.data('colorpicker').fields.eq(4).val(), 10),
|
|||
|
+ s: parseInt(cal.data('colorpicker').fields.eq(5).val(), 10),
|
|||
|
+ b: parseInt(cal.data('colorpicker').fields.eq(6).val(), 10)
|
|||
|
+ });
|
|||
|
+ } else {
|
|||
|
+ cal.data('colorpicker').color = col = RGBToHSB(fixRGB({
|
|||
|
+ r: parseInt(cal.data('colorpicker').fields.eq(1).val(), 10),
|
|||
|
+ g: parseInt(cal.data('colorpicker').fields.eq(2).val(), 10),
|
|||
|
+ b: parseInt(cal.data('colorpicker').fields.eq(3).val(), 10)
|
|||
|
+ }));
|
|||
|
+ }
|
|||
|
+ if (ev) {
|
|||
|
+ fillRGBFields(col, cal.get(0));
|
|||
|
+ fillHexFields(col, cal.get(0));
|
|||
|
+ fillHSBFields(col, cal.get(0));
|
|||
|
+ }
|
|||
|
+ setSelector(col, cal.get(0));
|
|||
|
+ setHue(col, cal.get(0));
|
|||
|
+ setNewColor(col, cal.get(0));
|
|||
|
+ cal.data('colorpicker').onChange.apply(cal, [col, HSBToHex(col), HSBToRGB(col)]);
|
|||
|
+ },
|
|||
|
+ blur = function (ev) {
|
|||
|
+ var cal = $(this).parent().parent();
|
|||
|
+ cal.data('colorpicker').fields.parent().removeClass('colorpicker_focus');
|
|||
|
+ },
|
|||
|
+ focus = function () {
|
|||
|
+ charMin = this.parentNode.className.indexOf('_hex') > 0 ? 70 : 65;
|
|||
|
+ $(this).parent().parent().data('colorpicker').fields.parent().removeClass('colorpicker_focus');
|
|||
|
+ $(this).parent().addClass('colorpicker_focus');
|
|||
|
+ },
|
|||
|
+ downIncrement = function (ev) {
|
|||
|
+ var field = $(this).parent().find('input').focus();
|
|||
|
+ var current = {
|
|||
|
+ el: $(this).parent().addClass('colorpicker_slider'),
|
|||
|
+ max: this.parentNode.className.indexOf('_hsb_h') > 0 ? 360 : (this.parentNode.className.indexOf('_hsb') > 0 ? 100 : 255),
|
|||
|
+ y: ev.pageY,
|
|||
|
+ field: field,
|
|||
|
+ val: parseInt(field.val(), 10),
|
|||
|
+ preview: $(this).parent().parent().data('colorpicker').livePreview
|
|||
|
+ };
|
|||
|
+ $(document).bind('mouseup', current, upIncrement);
|
|||
|
+ $(document).bind('mousemove', current, moveIncrement);
|
|||
|
+ },
|
|||
|
+ moveIncrement = function (ev) {
|
|||
|
+ ev.data.field.val(Math.max(0, Math.min(ev.data.max, parseInt(ev.data.val + ev.pageY - ev.data.y, 10))));
|
|||
|
+ if (ev.data.preview) {
|
|||
|
+ change.apply(ev.data.field.get(0), [true]);
|
|||
|
+ }
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ upIncrement = function (ev) {
|
|||
|
+ change.apply(ev.data.field.get(0), [true]);
|
|||
|
+ ev.data.el.removeClass('colorpicker_slider').find('input').focus();
|
|||
|
+ $(document).unbind('mouseup', upIncrement);
|
|||
|
+ $(document).unbind('mousemove', moveIncrement);
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ downHue = function (ev) {
|
|||
|
+ var current = {
|
|||
|
+ cal: $(this).parent(),
|
|||
|
+ y: $(this).offset().top
|
|||
|
+ };
|
|||
|
+ current.preview = current.cal.data('colorpicker').livePreview;
|
|||
|
+ $(document).bind('mouseup', current, upHue);
|
|||
|
+ $(document).bind('mousemove', current, moveHue);
|
|||
|
+ },
|
|||
|
+ moveHue = function (ev) {
|
|||
|
+ change.apply(
|
|||
|
+ ev.data.cal.data('colorpicker')
|
|||
|
+ .fields
|
|||
|
+ .eq(4)
|
|||
|
+ .val(parseInt(360*(150 - Math.max(0,Math.min(150,(ev.pageY - ev.data.y))))/150, 10))
|
|||
|
+ .get(0),
|
|||
|
+ [ev.data.preview]
|
|||
|
+ );
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ upHue = function (ev) {
|
|||
|
+ fillRGBFields(ev.data.cal.data('colorpicker').color, ev.data.cal.get(0));
|
|||
|
+ fillHexFields(ev.data.cal.data('colorpicker').color, ev.data.cal.get(0));
|
|||
|
+ $(document).unbind('mouseup', upHue);
|
|||
|
+ $(document).unbind('mousemove', moveHue);
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ downSelector = function (ev) {
|
|||
|
+ var current = {
|
|||
|
+ cal: $(this).parent(),
|
|||
|
+ pos: $(this).offset()
|
|||
|
+ };
|
|||
|
+ current.preview = current.cal.data('colorpicker').livePreview;
|
|||
|
+ $(document).bind('mouseup', current, upSelector);
|
|||
|
+ $(document).bind('mousemove', current, moveSelector);
|
|||
|
+ },
|
|||
|
+ moveSelector = function (ev) {
|
|||
|
+ change.apply(
|
|||
|
+ ev.data.cal.data('colorpicker')
|
|||
|
+ .fields
|
|||
|
+ .eq(6)
|
|||
|
+ .val(parseInt(100*(150 - Math.max(0,Math.min(150,(ev.pageY - ev.data.pos.top))))/150, 10))
|
|||
|
+ .end()
|
|||
|
+ .eq(5)
|
|||
|
+ .val(parseInt(100*(Math.max(0,Math.min(150,(ev.pageX - ev.data.pos.left))))/150, 10))
|
|||
|
+ .get(0),
|
|||
|
+ [ev.data.preview]
|
|||
|
+ );
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ upSelector = function (ev) {
|
|||
|
+ fillRGBFields(ev.data.cal.data('colorpicker').color, ev.data.cal.get(0));
|
|||
|
+ fillHexFields(ev.data.cal.data('colorpicker').color, ev.data.cal.get(0));
|
|||
|
+ $(document).unbind('mouseup', upSelector);
|
|||
|
+ $(document).unbind('mousemove', moveSelector);
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ enterSubmit = function (ev) {
|
|||
|
+ $(this).addClass('colorpicker_focus');
|
|||
|
+ },
|
|||
|
+ leaveSubmit = function (ev) {
|
|||
|
+ $(this).removeClass('colorpicker_focus');
|
|||
|
+ },
|
|||
|
+ clickSubmit = function (ev) {
|
|||
|
+ var cal = $(this).parent();
|
|||
|
+ var col = cal.data('colorpicker').color;
|
|||
|
+ cal.data('colorpicker').origColor = col;
|
|||
|
+ setCurrentColor(col, cal.get(0));
|
|||
|
+ cal.data('colorpicker').onSubmit(col, HSBToHex(col), HSBToRGB(col), cal.data('colorpicker').el);
|
|||
|
+ },
|
|||
|
+ show = function (ev) {
|
|||
|
+ var cal = $('#' + $(this).data('colorpickerId'));
|
|||
|
+ cal.data('colorpicker').onBeforeShow.apply(this, [cal.get(0)]);
|
|||
|
+ var pos = $(this).offset();
|
|||
|
+ var viewPort = getViewport();
|
|||
|
+ var top = pos.top + this.offsetHeight;
|
|||
|
+ var left = pos.left;
|
|||
|
+ if (top + 176 > viewPort.t + viewPort.h) {
|
|||
|
+ top -= this.offsetHeight + 176;
|
|||
|
+ }
|
|||
|
+ if (left + 356 > viewPort.l + viewPort.w) {
|
|||
|
+ left -= 356;
|
|||
|
+ }
|
|||
|
+ cal.css({left: left + 'px', top: top + 'px'});
|
|||
|
+ if (cal.data('colorpicker').onShow.apply(this, [cal.get(0)]) != false) {
|
|||
|
+ cal.show();
|
|||
|
+ }
|
|||
|
+ $(document).bind('mousedown', {cal: cal}, hide);
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ hide = function (ev) {
|
|||
|
+ if (!isChildOf(ev.data.cal.get(0), ev.target, ev.data.cal.get(0))) {
|
|||
|
+ if (ev.data.cal.data('colorpicker').onHide.apply(this, [ev.data.cal.get(0)]) != false) {
|
|||
|
+ ev.data.cal.hide();
|
|||
|
+ }
|
|||
|
+ $(document).unbind('mousedown', hide);
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ isChildOf = function(parentEl, el, container) {
|
|||
|
+ if (parentEl == el) {
|
|||
|
+ return true;
|
|||
|
+ }
|
|||
|
+ if (parentEl.contains) {
|
|||
|
+ return parentEl.contains(el);
|
|||
|
+ }
|
|||
|
+ if ( parentEl.compareDocumentPosition ) {
|
|||
|
+ return !!(parentEl.compareDocumentPosition(el) & 16);
|
|||
|
+ }
|
|||
|
+ var prEl = el.parentNode;
|
|||
|
+ while(prEl && prEl != container) {
|
|||
|
+ if (prEl == parentEl)
|
|||
|
+ return true;
|
|||
|
+ prEl = prEl.parentNode;
|
|||
|
+ }
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ getViewport = function () {
|
|||
|
+ var m = document.compatMode == 'CSS1Compat';
|
|||
|
+ return {
|
|||
|
+ l : window.pageXOffset || (m ? document.documentElement.scrollLeft : document.body.scrollLeft),
|
|||
|
+ t : window.pageYOffset || (m ? document.documentElement.scrollTop : document.body.scrollTop),
|
|||
|
+ w : window.innerWidth || (m ? document.documentElement.clientWidth : document.body.clientWidth),
|
|||
|
+ h : window.innerHeight || (m ? document.documentElement.clientHeight : document.body.clientHeight)
|
|||
|
+ };
|
|||
|
+ },
|
|||
|
+ fixHSB = function (hsb) {
|
|||
|
+ return {
|
|||
|
+ h: Math.min(360, Math.max(0, hsb.h)),
|
|||
|
+ s: Math.min(100, Math.max(0, hsb.s)),
|
|||
|
+ b: Math.min(100, Math.max(0, hsb.b))
|
|||
|
+ };
|
|||
|
+ },
|
|||
|
+ fixRGB = function (rgb) {
|
|||
|
+ return {
|
|||
|
+ r: Math.min(255, Math.max(0, rgb.r)),
|
|||
|
+ g: Math.min(255, Math.max(0, rgb.g)),
|
|||
|
+ b: Math.min(255, Math.max(0, rgb.b))
|
|||
|
+ };
|
|||
|
+ },
|
|||
|
+ fixHex = function (hex) {
|
|||
|
+ var len = 6 - hex.length;
|
|||
|
+ if (len > 0) {
|
|||
|
+ var o = [];
|
|||
|
+ for (var i=0; i<len; i++) {
|
|||
|
+ o.push('0');
|
|||
|
+ }
|
|||
|
+ o.push(hex);
|
|||
|
+ hex = o.join('');
|
|||
|
+ }
|
|||
|
+ return hex;
|
|||
|
+ },
|
|||
|
+ HexToRGB = function (hex) {
|
|||
|
+ var hex = parseInt(((hex.indexOf('#') > -1) ? hex.substring(1) : hex), 16);
|
|||
|
+ return {r: hex >> 16, g: (hex & 0x00FF00) >> 8, b: (hex & 0x0000FF)};
|
|||
|
+ },
|
|||
|
+ HexToHSB = function (hex) {
|
|||
|
+ return RGBToHSB(HexToRGB(hex));
|
|||
|
+ },
|
|||
|
+ RGBToHSB = function (rgb) {
|
|||
|
+ var hsb = {
|
|||
|
+ h: 0,
|
|||
|
+ s: 0,
|
|||
|
+ b: 0
|
|||
|
+ };
|
|||
|
+ var min = Math.min(rgb.r, rgb.g, rgb.b);
|
|||
|
+ var max = Math.max(rgb.r, rgb.g, rgb.b);
|
|||
|
+ var delta = max - min;
|
|||
|
+ hsb.b = max;
|
|||
|
+ if (max != 0) {
|
|||
|
+
|
|||
|
+ }
|
|||
|
+ hsb.s = max != 0 ? 255 * delta / max : 0;
|
|||
|
+ if (hsb.s != 0) {
|
|||
|
+ if (rgb.r == max) {
|
|||
|
+ hsb.h = (rgb.g - rgb.b) / delta;
|
|||
|
+ } else if (rgb.g == max) {
|
|||
|
+ hsb.h = 2 + (rgb.b - rgb.r) / delta;
|
|||
|
+ } else {
|
|||
|
+ hsb.h = 4 + (rgb.r - rgb.g) / delta;
|
|||
|
+ }
|
|||
|
+ } else {
|
|||
|
+ hsb.h = -1;
|
|||
|
+ }
|
|||
|
+ hsb.h *= 60;
|
|||
|
+ if (hsb.h < 0) {
|
|||
|
+ hsb.h += 360;
|
|||
|
+ }
|
|||
|
+ hsb.s *= 100/255;
|
|||
|
+ hsb.b *= 100/255;
|
|||
|
+ return hsb;
|
|||
|
+ },
|
|||
|
+ HSBToRGB = function (hsb) {
|
|||
|
+ var rgb = {};
|
|||
|
+ var h = Math.round(hsb.h);
|
|||
|
+ var s = Math.round(hsb.s*255/100);
|
|||
|
+ var v = Math.round(hsb.b*255/100);
|
|||
|
+ if(s == 0) {
|
|||
|
+ rgb.r = rgb.g = rgb.b = v;
|
|||
|
+ } else {
|
|||
|
+ var t1 = v;
|
|||
|
+ var t2 = (255-s)*v/255;
|
|||
|
+ var t3 = (t1-t2)*(h%60)/60;
|
|||
|
+ if(h==360) h = 0;
|
|||
|
+ if(h<60) {rgb.r=t1; rgb.b=t2; rgb.g=t2+t3}
|
|||
|
+ else if(h<120) {rgb.g=t1; rgb.b=t2; rgb.r=t1-t3}
|
|||
|
+ else if(h<180) {rgb.g=t1; rgb.r=t2; rgb.b=t2+t3}
|
|||
|
+ else if(h<240) {rgb.b=t1; rgb.r=t2; rgb.g=t1-t3}
|
|||
|
+ else if(h<300) {rgb.b=t1; rgb.g=t2; rgb.r=t2+t3}
|
|||
|
+ else if(h<360) {rgb.r=t1; rgb.g=t2; rgb.b=t1-t3}
|
|||
|
+ else {rgb.r=0; rgb.g=0; rgb.b=0}
|
|||
|
+ }
|
|||
|
+ return {r:Math.round(rgb.r), g:Math.round(rgb.g), b:Math.round(rgb.b)};
|
|||
|
+ },
|
|||
|
+ RGBToHex = function (rgb) {
|
|||
|
+ var hex = [
|
|||
|
+ rgb.r.toString(16),
|
|||
|
+ rgb.g.toString(16),
|
|||
|
+ rgb.b.toString(16)
|
|||
|
+ ];
|
|||
|
+ $.each(hex, function (nr, val) {
|
|||
|
+ if (val.length == 1) {
|
|||
|
+ hex[nr] = '0' + val;
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ return hex.join('');
|
|||
|
+ },
|
|||
|
+ HSBToHex = function (hsb) {
|
|||
|
+ return RGBToHex(HSBToRGB(hsb));
|
|||
|
+ },
|
|||
|
+ restoreOriginal = function () {
|
|||
|
+ var cal = $(this).parent();
|
|||
|
+ var col = cal.data('colorpicker').origColor;
|
|||
|
+ cal.data('colorpicker').color = col;
|
|||
|
+ fillRGBFields(col, cal.get(0));
|
|||
|
+ fillHexFields(col, cal.get(0));
|
|||
|
+ fillHSBFields(col, cal.get(0));
|
|||
|
+ setSelector(col, cal.get(0));
|
|||
|
+ setHue(col, cal.get(0));
|
|||
|
+ setNewColor(col, cal.get(0));
|
|||
|
+ };
|
|||
|
+ return {
|
|||
|
+ init: function (opt) {
|
|||
|
+ opt = $.extend({}, defaults, opt||{});
|
|||
|
+ if (typeof opt.color == 'string') {
|
|||
|
+ opt.color = HexToHSB(opt.color);
|
|||
|
+ } else if (opt.color.r != undefined && opt.color.g != undefined && opt.color.b != undefined) {
|
|||
|
+ opt.color = RGBToHSB(opt.color);
|
|||
|
+ } else if (opt.color.h != undefined && opt.color.s != undefined && opt.color.b != undefined) {
|
|||
|
+ opt.color = fixHSB(opt.color);
|
|||
|
+ } else {
|
|||
|
+ return this;
|
|||
|
+ }
|
|||
|
+ return this.each(function () {
|
|||
|
+ if (!$(this).data('colorpickerId')) {
|
|||
|
+ var options = $.extend({}, opt);
|
|||
|
+ options.origColor = opt.color;
|
|||
|
+ var id = 'collorpicker_' + parseInt(Math.random() * 1000);
|
|||
|
+ $(this).data('colorpickerId', id);
|
|||
|
+ var cal = $(tpl).attr('id', id);
|
|||
|
+ if (options.flat) {
|
|||
|
+ cal.appendTo(this).show();
|
|||
|
+ } else {
|
|||
|
+ cal.appendTo(document.body);
|
|||
|
+ }
|
|||
|
+ options.fields = cal
|
|||
|
+ .find('input')
|
|||
|
+ .bind('keyup', keyDown)
|
|||
|
+ .bind('change', change)
|
|||
|
+ .bind('blur', blur)
|
|||
|
+ .bind('focus', focus);
|
|||
|
+ cal
|
|||
|
+ .find('span').bind('mousedown', downIncrement).end()
|
|||
|
+ .find('>div.colorpicker_current_color').bind('click', restoreOriginal);
|
|||
|
+ options.selector = cal.find('div.colorpicker_color').bind('mousedown', downSelector);
|
|||
|
+ options.selectorIndic = options.selector.find('div div');
|
|||
|
+ options.el = this;
|
|||
|
+ options.hue = cal.find('div.colorpicker_hue div');
|
|||
|
+ cal.find('div.colorpicker_hue').bind('mousedown', downHue);
|
|||
|
+ options.newColor = cal.find('div.colorpicker_new_color');
|
|||
|
+ options.currentColor = cal.find('div.colorpicker_current_color');
|
|||
|
+ cal.data('colorpicker', options);
|
|||
|
+ cal.find('div.colorpicker_submit')
|
|||
|
+ .bind('mouseenter', enterSubmit)
|
|||
|
+ .bind('mouseleave', leaveSubmit)
|
|||
|
+ .bind('click', clickSubmit);
|
|||
|
+ fillRGBFields(options.color, cal.get(0));
|
|||
|
+ fillHSBFields(options.color, cal.get(0));
|
|||
|
+ fillHexFields(options.color, cal.get(0));
|
|||
|
+ setHue(options.color, cal.get(0));
|
|||
|
+ setSelector(options.color, cal.get(0));
|
|||
|
+ setCurrentColor(options.color, cal.get(0));
|
|||
|
+ setNewColor(options.color, cal.get(0));
|
|||
|
+ if (options.flat) {
|
|||
|
+ cal.css({
|
|||
|
+ position: 'relative',
|
|||
|
+ display: 'block'
|
|||
|
+ });
|
|||
|
+ } else {
|
|||
|
+ $(this).bind(options.eventName, show);
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ },
|
|||
|
+ showPicker: function() {
|
|||
|
+ return this.each( function () {
|
|||
|
+ if ($(this).data('colorpickerId')) {
|
|||
|
+ show.apply(this);
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ },
|
|||
|
+ hidePicker: function() {
|
|||
|
+ return this.each( function () {
|
|||
|
+ if ($(this).data('colorpickerId')) {
|
|||
|
+ $('#' + $(this).data('colorpickerId')).hide();
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ },
|
|||
|
+ setColor: function(col) {
|
|||
|
+ if (typeof col == 'string') {
|
|||
|
+ col = HexToHSB(col);
|
|||
|
+ } else if (col.r != undefined && col.g != undefined && col.b != undefined) {
|
|||
|
+ col = RGBToHSB(col);
|
|||
|
+ } else if (col.h != undefined && col.s != undefined && col.b != undefined) {
|
|||
|
+ col = fixHSB(col);
|
|||
|
+ } else {
|
|||
|
+ return this;
|
|||
|
+ }
|
|||
|
+ return this.each(function(){
|
|||
|
+ if ($(this).data('colorpickerId')) {
|
|||
|
+ var cal = $('#' + $(this).data('colorpickerId'));
|
|||
|
+ cal.data('colorpicker').color = col;
|
|||
|
+ cal.data('colorpicker').origColor = col;
|
|||
|
+ fillRGBFields(col, cal.get(0));
|
|||
|
+ fillHSBFields(col, cal.get(0));
|
|||
|
+ fillHexFields(col, cal.get(0));
|
|||
|
+ setHue(col, cal.get(0));
|
|||
|
+ setSelector(col, cal.get(0));
|
|||
|
+ setCurrentColor(col, cal.get(0));
|
|||
|
+ setNewColor(col, cal.get(0));
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ };
|
|||
|
+ }();
|
|||
|
+ $.fn.extend({
|
|||
|
+ ColorPicker: ColorPicker.init,
|
|||
|
+ ColorPickerHide: ColorPicker.hidePicker,
|
|||
|
+ ColorPickerShow: ColorPicker.showPicker,
|
|||
|
+ ColorPickerSetColor: ColorPicker.setColor
|
|||
|
+ });
|
|||
|
+})(jQuery)
|
|||
|
\ No newline at end of file
|
|||
|
diff -up cacti-0.8.8a/include/js/jquery/jquery.cookie.js.legal cacti-0.8.8a/include/js/jquery/jquery.cookie.js
|
|||
|
--- cacti-0.8.8a/include/js/jquery/jquery.cookie.js.legal 2013-01-04 15:44:38.027416060 -0500
|
|||
|
+++ cacti-0.8.8a/include/js/jquery/jquery.cookie.js 2013-01-04 15:43:12.644377988 -0500
|
|||
|
@@ -0,0 +1,91 @@
|
|||
|
+/*jslint browser: true */ /*global jQuery: true */
|
|||
|
+
|
|||
|
+/**
|
|||
|
+ * jQuery Cookie plugin
|
|||
|
+ *
|
|||
|
+ * Copyright (c) 2010 Klaus Hartl (stilbuero.de)
|
|||
|
+ * Dual licensed under the MIT and GPL licenses:
|
|||
|
+ * http://www.opensource.org/licenses/mit-license.php
|
|||
|
+ * http://www.gnu.org/licenses/gpl.html
|
|||
|
+ *
|
|||
|
+ */
|
|||
|
+
|
|||
|
+// TODO JsDoc
|
|||
|
+
|
|||
|
+/**
|
|||
|
+ * Create a cookie with the given key and value and other optional parameters.
|
|||
|
+ *
|
|||
|
+ * @example $.cookie('the_cookie', 'the_value');
|
|||
|
+ * @desc Set the value of a cookie.
|
|||
|
+ * @example $.cookie('the_cookie', 'the_value', { expires: 7, path: '/', domain: 'jquery.com', secure: true });
|
|||
|
+ * @desc Create a cookie with all available options.
|
|||
|
+ * @example $.cookie('the_cookie', 'the_value');
|
|||
|
+ * @desc Create a session cookie.
|
|||
|
+ * @example $.cookie('the_cookie', null);
|
|||
|
+ * @desc Delete a cookie by passing null as value. Keep in mind that you have to use the same path and domain
|
|||
|
+ * used when the cookie was set.
|
|||
|
+ *
|
|||
|
+ * @param String key The key of the cookie.
|
|||
|
+ * @param String value The value of the cookie.
|
|||
|
+ * @param Object options An object literal containing key/value pairs to provide optional cookie attributes.
|
|||
|
+ * @option Number|Date expires Either an integer specifying the expiration date from now on in days or a Date object.
|
|||
|
+ * If a negative value is specified (e.g. a date in the past), the cookie will be deleted.
|
|||
|
+ * If set to null or omitted, the cookie will be a session cookie and will not be retained
|
|||
|
+ * when the the browser exits.
|
|||
|
+ * @option String path The value of the path atribute of the cookie (default: path of page that created the cookie).
|
|||
|
+ * @option String domain The value of the domain attribute of the cookie (default: domain of page that created the cookie).
|
|||
|
+ * @option Boolean secure If true, the secure attribute of the cookie will be set and the cookie transmission will
|
|||
|
+ * require a secure protocol (like HTTPS).
|
|||
|
+ * @type undefined
|
|||
|
+ *
|
|||
|
+ * @name $.cookie
|
|||
|
+ * @cat Plugins/Cookie
|
|||
|
+ * @author Klaus Hartl/klaus.hartl@stilbuero.de
|
|||
|
+ */
|
|||
|
+
|
|||
|
+/**
|
|||
|
+ * Get the value of a cookie with the given key.
|
|||
|
+ *
|
|||
|
+ * @example $.cookie('the_cookie');
|
|||
|
+ * @desc Get the value of a cookie.
|
|||
|
+ *
|
|||
|
+ * @param String key The key of the cookie.
|
|||
|
+ * @return The value of the cookie.
|
|||
|
+ * @type String
|
|||
|
+ *
|
|||
|
+ * @name $.cookie
|
|||
|
+ * @cat Plugins/Cookie
|
|||
|
+ * @author Klaus Hartl/klaus.hartl@stilbuero.de
|
|||
|
+ */
|
|||
|
+jQuery.cookie = function (key, value, options) {
|
|||
|
+
|
|||
|
+ // key and at least value given, set cookie...
|
|||
|
+ if (arguments.length > 1 && String(value) !== "[object Object]") {
|
|||
|
+ options = jQuery.extend({}, options);
|
|||
|
+
|
|||
|
+ if (value === null || value === undefined) {
|
|||
|
+ options.expires = -1;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ if (typeof options.expires === 'number') {
|
|||
|
+ var days = options.expires, t = options.expires = new Date();
|
|||
|
+ t.setDate(t.getDate() + days);
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ value = String(value);
|
|||
|
+
|
|||
|
+ return (document.cookie = [
|
|||
|
+ encodeURIComponent(key), '=',
|
|||
|
+ options.raw ? value : encodeURIComponent(value),
|
|||
|
+ options.expires ? '; expires=' + options.expires.toUTCString() : '', // use expires attribute, max-age is not supported by IE
|
|||
|
+ options.path ? '; path=' + options.path : '',
|
|||
|
+ options.domain ? '; domain=' + options.domain : '',
|
|||
|
+ options.secure ? '; secure' : ''
|
|||
|
+ ].join(''));
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ // key and possibly options given, get cookie...
|
|||
|
+ options = value || {};
|
|||
|
+ var result, decode = options.raw ? function (s) { return s; } : decodeURIComponent;
|
|||
|
+ return (result = new RegExp('(?:^|; )' + encodeURIComponent(key) + '=([^;]*)').exec(document.cookie)) ? decode(result[1]) : null;
|
|||
|
+};
|
|||
|
diff -up cacti-0.8.8a/include/js/jquery/jquery.dd.js.legal cacti-0.8.8a/include/js/jquery/jquery.dd.js
|
|||
|
--- cacti-0.8.8a/include/js/jquery/jquery.dd.js.legal 2013-01-04 15:44:38.030416069 -0500
|
|||
|
+++ cacti-0.8.8a/include/js/jquery/jquery.dd.js 2013-01-04 15:43:12.644377988 -0500
|
|||
|
@@ -0,0 +1,11 @@
|
|||
|
+// MSDropDown - jquery.dd.js
|
|||
|
+// author: Marghoob Suleman - Search me on google
|
|||
|
+// Date: 12th Aug, 2009, {18 Dec, 2010 (2.36)}
|
|||
|
+// Version: 2.37.5 {date: 17 June, 2011}
|
|||
|
+// Revision: 34
|
|||
|
+// web: www.giftlelo.com | www.marghoobsuleman.com
|
|||
|
+/*
|
|||
|
+// msDropDown is free jQuery Plugin: you can redistribute it and/or modify
|
|||
|
+// it under the terms of the either the MIT License or the Gnu General Public License (GPL) Version 2
|
|||
|
+*/
|
|||
|
+;eval(function(p,a,c,k,e,r){e=function(c){return(c<a?'':e(parseInt(c/a)))+((c=c%a)>35?String.fromCharCode(c+29):c.toString(36))};if(!''.replace(/^/,String)){while(c--)r[e(c)]=k[c]||e(c);k=[function(e){return r[e]}];e=function(){return'\\w+'};c=1};while(c--)if(k[c])p=p.replace(new RegExp('\\b'+e(c)+'\\b','g'),k[c]);return p}(';(5($){3 1L="";3 3m=5(p,q){3 r=p;3 s=1a;3 q=$.3n({1d:4c,2q:7,3o:23,1U:6,1M:4d,3p:\'28\',1N:15,3q:\'4e\',2I:\'\',1j:\'\'},q);1a.1V=2r 3r();3 u="";3 v={};v.2J=6;v.2s=15;v.2t=1o;3 x=15;3 y={2K:\'4f\',1O:\'4g\',1H:\'4h\',29:\'4i\',1h:\'4j\',2L:\'4k\',2M:\'4l\',4m:\'4n\',2u:\'4o\',3s:\'4p\'};3 z={28:q.3p,2N:\'2N\',2O:\'2O\',2P:\'2P\',1t:\'1t\',1k:.30,2a:\'2a\',2v:\'2v\',2w:\'2w\',11:\'11\'};3 A={3t:"2x,2Q,2R,1P,2y,2z,1u,1B,2A,1Q,4q,1W,2S",18:"1C,1v,1k,4r"};1a.1R=2r 3r();3 B=$(r).18("1b");4(1w(B)=="14"||B.1c<=0){B="4s"+$.1S.3u++;$(r).2B("1b",B)};3 C=$(r).18("1j");q.1j+=(C==14)?"":C;3 D=$(r).3v();x=($(r).18("1C")>1||$(r).18("1v")==6)?6:15;4(x){q.2q=$(r).18("1C")};3 E={};3 F=0;3 G=15;3 H;3 I={};3 J=5(a){4(1w(I[a])=="14"){I[a]=1p.4t(a)}12 I[a]};3 K=5(a){12 B+y[a]};3 L=5(a){3 b=a;3 c=$(b).18("1j");12 c};3 M=5(a){3 b=$("#"+B+" 2T:11");4(b.1c>1){1D(3 i=0;i<b.1c;i++){4(a==b[i].1i){12 6}}}19 4(b.1c==1){4(b[0].1i==a){12 6}};12 15};3 N=5(a,b,c,d){3 e="";3 f=(d=="2U")?K("2M"):K("2L");3 g=(d=="2U")?f+"2V"+(b)+"2V"+(c):f+"2V"+(b);3 h="";3 i="";4(q.1N!=15){i=\' \'+q.1N+\' \'+a.3w}19{h=$(a).18("1X");h=(h.1c==0)?"":\'<3x 3y="\'+h+\'" 3z="3A" /> \'};3 j=$(a).1q();3 k=$(a).4u();3 l=($(a).18("1k")==6)?"1k":"2W";E[g]={1I:h+j,2b:k,1q:j,1i:a.1i,1b:g};3 m=L(a);4(M(a.1i)==6){e+=\'<a 3B="3C:3D(0);" 1r="\'+z.11+\' \'+l+i+\'"\'}19{e+=\'<a 3B="3C:3D(0);" 1r="\'+l+i+\'"\'};4(m!==15&&m!==14){e+=" 1j=\'"+m+"\'"};e+=\' 1b="\'+g+\'">\';e+=h+\'<1x 1r="\'+z.1t+\'">\'+j+\'</1x></a>\';12 e};3 O=5(t){3 b=t.3E();4(b.1c==0)12-1;3 a="";1D(3 i 2c E){3 c=E[i].1q.3E();4(c.3F(0,b.1c)==b){a+="#"+E[i].1b+", "}};12(a=="")?-1:a};3 P=5(){3 f=D;4(f.1c==0)12"";3 g="";3 h=K("2L");3 i=K("2M");f.2X(5(c){3 d=f[c];4(d.4v=="4w"){g+="<1y 1r=\'4x\'>";g+="<1x 1j=\'3G-4y:4z;3G-1j:4A; 4B:4C;\'>"+$(d).18("4D")+"</1x>";3 e=$(d).3v();e.2X(5(a){3 b=e[a];g+=N(b,c,a,"2U")});g+="</1y>"}19{g+=N(d,c,"","")}});12 g};3 Q=5(){3 a=K("1O");3 b=K("1h");3 c=q.1j;1Y="";1Y+=\'<1y 1b="\'+b+\'" 1r="\'+z.2P+\'"\';4(!x){1Y+=(c!="")?\' 1j="\'+c+\'"\':\'\'}19{1Y+=(c!="")?\' 1j="2C-1m:4E 4F #4G;1s:2d;1n:2Y;\'+c+\'"\':\'\'};1Y+=\'>\';12 1Y};3 R=5(){3 a=K("1H");3 b=K("2u");3 c=K("29");3 d=K("3s");3 e="";3 f="";4(J(B).1E.1c>0){e=$("#"+B+" 2T:11").1q();f=$("#"+B+" 2T:11").18("1X")};f=(f.1c==0||f==14||q.1U==15||q.1N!=15)?"":\'<3x 3y="\'+f+\'" 3z="3A" /> \';3 g=\'<1y 1b="\'+a+\'" 1r="\'+z.2N+\'"\';g+=\'>\';g+=\'<1x 1b="\'+b+\'" 1r="\'+z.2O+\'"></1x><1x 1r="\'+z.1t+\'" 1b="\'+c+\'">\'+f+\'<1x 1r="\'+z.1t+\'">\'+e+\'</1x></1x></1y>\';12 g};3 S=5(){3 c=K("1h");$("#"+c+" a.2W").1J("1P");$("#"+c+" a.2W").1e("1P",5(a){a.1Z();V(1a);21();4(!x){$("#"+c).1J("1B");X(15);3 b=(q.1U==15)?$(1a).1q():$(1a).1I();1T(b);s.2e()}})};3 T=5(){3 d=15;3 e=K("1O");3 f=K("1H");3 g=K("29");3 h=K("1h");3 i=K("2u");3 j=$("#"+B).2Z();j=j+2;3 k=q.1j;4($("#"+e).1c>0){$("#"+e).2D();d=6};3 l=\'<1y 1b="\'+e+\'" 1r="\'+z.28+\'"\';l+=(k!="")?\' 1j="\'+k+\'"\':\'\';l+=\'>\';l+=R();l+=Q();l+=P();l+="</1y>";l+="</1y>";4(d==6){3 m=K("2K");$("#"+m).31(l)}19{$("#"+B).31(l)};4(x){3 f=K("1H");$("#"+f).2f()};$("#"+e).9("2Z",j+"1z");$("#"+h).9("2Z",(j-2)+"1z");4(D.1c>q.2q){3 n=2g($("#"+h+" a:3H").9("2h-3I"))+2g($("#"+h+" a:3H").9("2h-1m"));3 o=((q.3o)*q.2q)-n;$("#"+h).9("1d",o+"1z")}19 4(x){3 o=$("#"+B).1d();$("#"+h).9("1d",o+"1z")};4(d==15){3J();W(B)};4($("#"+B).18("1k")==6){$("#"+e).9("2E",z.1k)};Z();$("#"+f).1e("1B",5(a){32(1)});$("#"+f).1e("1Q",5(a){32(0)});S();$("#"+h+" a.1k").9("2E",z.1k);4(x){$("#"+h).1e("1B",5(c){4(!v.2s){v.2s=6;$(1p).1e("1W",5(a){3 b=a.3K;v.2t=b;4(b==39||b==40){a.1Z();a.2i();33();21()};4(b==37||b==38){a.1Z();a.2i();34();21()}})}})};$("#"+h).1e("1Q",5(a){X(15);$(1p).1J("1W");v.2s=15;v.2t=1o});$("#"+f).1e("1P",5(b){X(15);4($("#"+h+":2j").1c==1){$("#"+h).1J("1B")}19{$("#"+h).1e("1B",5(a){X(6)});s.3L()}});$("#"+f).1e("1Q
|
|||
|
\ No newline at end of file
|
|||
|
diff -up cacti-0.8.8a/include/js/jquery/jquery.dropdown.js.legal cacti-0.8.8a/include/js/jquery/jquery.dropdown.js
|
|||
|
--- cacti-0.8.8a/include/js/jquery/jquery.dropdown.js.legal 2013-01-04 15:44:38.032416068 -0500
|
|||
|
+++ cacti-0.8.8a/include/js/jquery/jquery.dropdown.js 2013-01-04 15:43:12.644377988 -0500
|
|||
|
@@ -0,0 +1,227 @@
|
|||
|
+/*
|
|||
|
+ +-------------------------------------------------------------------------+
|
|||
|
+ | Copyright (C) 2004-2013 The Cacti Group |
|
|||
|
+ | |
|
|||
|
+ | This program is free software; you can redistribute it and/or |
|
|||
|
+ | modify it under the terms of the GNU General Public License |
|
|||
|
+ | as published by the Free Software Foundation; either version 2 |
|
|||
|
+ | of the License, or (at your option) any later version. |
|
|||
|
+ | |
|
|||
|
+ | This program is distributed in the hope that it will be useful, |
|
|||
|
+ | but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
|||
|
+ | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
|||
|
+ | GNU General Public License for more details. |
|
|||
|
+ +-------------------------------------------------------------------------+
|
|||
|
+ | Cacti: The Complete RRDTool-based Graphing Solution |
|
|||
|
+ +-------------------------------------------------------------------------+
|
|||
|
+ | This code is designed, written, and maintained by the Cacti Group. See |
|
|||
|
+ | about.php and/or the AUTHORS file for specific developer information. |
|
|||
|
+ +-------------------------------------------------------------------------+
|
|||
|
+ | http://www.cacti.net/ |
|
|||
|
+ +-------------------------------------------------------------------------+
|
|||
|
+*/
|
|||
|
+
|
|||
|
+(function($){
|
|||
|
+ $.fn.DropDownMenu = function(options) {
|
|||
|
+
|
|||
|
+ var defaults = {
|
|||
|
+ title: false,
|
|||
|
+ subtitle: false,
|
|||
|
+ name: 'myName',
|
|||
|
+ maxHeight: 300,
|
|||
|
+ width: 'auto',
|
|||
|
+ timeout: 500,
|
|||
|
+ auto_close: 10000,
|
|||
|
+ html: '<h6>empty</h6>',
|
|||
|
+ offsetX: 0,
|
|||
|
+ offsetY: 0,
|
|||
|
+ simultaneous: false,
|
|||
|
+ textAlign: 'left'
|
|||
|
+ };
|
|||
|
+
|
|||
|
+ var timerref = null;
|
|||
|
+ var menu = null;
|
|||
|
+ var menuHeight = 0;
|
|||
|
+ var options = $.extend(defaults, options);
|
|||
|
+ var contentHeight = 0;
|
|||
|
+
|
|||
|
+ /* do nothing if requested menu is still loaded */
|
|||
|
+ if($('#' + options.name).is(":visible")) { return; }
|
|||
|
+
|
|||
|
+ /* remove all open menus from DOM if they should not stay in front at the same time */
|
|||
|
+ var oldMenus = $(".cacti_dd_menu");
|
|||
|
+ if(options.simultaneous == false) {
|
|||
|
+ oldMenus.css({'overflow-y':'hidden'}).slideUp('200');
|
|||
|
+ oldMenus.queue(function () {
|
|||
|
+ oldMenus.remove();
|
|||
|
+ oldMenus.dequeue();
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ return this.each(function() {
|
|||
|
+ obj = $(this);
|
|||
|
+ newMenu = _init_menu(obj);
|
|||
|
+ _open_menu(newMenu);
|
|||
|
+ });
|
|||
|
+
|
|||
|
+ function _init_menu(initiator){
|
|||
|
+ /* create the main menu structure */
|
|||
|
+ $("<div id='" + options.name + "' style='display: none;' class='cacti_dd_menu ui-widget ui-corner-all'>"
|
|||
|
+ + "<div id='" + options.name + "_title' class='title ui-state-default ui-corner-top'><h6>" + options.title + "</h6></div>"
|
|||
|
+ + "<div id='" + options.name + "_back' class='back ui-state-active'></div>"
|
|||
|
+ + "<div id='" + options.name + "_content' class='content ui-widget-content ui-state-highlight " + ((options.subtitle !== false) ? "" : "ui-corner-bottom" ) + "'></div>"
|
|||
|
+ + "<div id='" + options.name + "_subtitle' class='subtitle ui-state-default ui-corner-bottom'><h6>" + options.subtitle + "</h6></div>"
|
|||
|
+ + "<div id='" + options.name + "_html' class='html'></div>"
|
|||
|
+ + "</div>").appendTo("body");
|
|||
|
+
|
|||
|
+ /* define references to the menu and its different sections */
|
|||
|
+ menu = $('#' + options.name);
|
|||
|
+ menu_head = $('#' + options.name + '_title');
|
|||
|
+ menu_content = $('#' + options.name + '_content');
|
|||
|
+ menu_back = $('#' + options.name + '_back');
|
|||
|
+ menu_subhead = $('#' + options.name + '_subtitle');
|
|||
|
+ menu_html = $('#' + options.name + '_html');
|
|||
|
+
|
|||
|
+ /* while div container "myName_html" holds the raw data ... */
|
|||
|
+ menu_html.append(options.html);
|
|||
|
+ i=1;
|
|||
|
+ menu_html.find("h6:has(div)").each(function() {
|
|||
|
+ var subMenu = $(this);
|
|||
|
+ var subMenuClass = options.name + '_' + i;
|
|||
|
+ var subMenuTitle = subMenu.find('a:first').html();
|
|||
|
+ subMenu.addClass(subMenuClass);
|
|||
|
+ $('.'+subMenuClass).die().live("click", function(){ _switch_layer( subMenuClass); } );
|
|||
|
+ subMenu.children("div").hide();
|
|||
|
+ subMenu.find('a:first').html('<span style="float:left; min-width:80%;">' + subMenuTitle + '</span><span class="ui-icon ui-icon-triangle-1-e" style="float:right;"></span>');
|
|||
|
+ i++;
|
|||
|
+ });
|
|||
|
+
|
|||
|
+ /* ... "myName_content" will have the visible menu data */
|
|||
|
+ menu_content.append(menu_html.html());
|
|||
|
+
|
|||
|
+ /* if necessary show title, subtitle ... */
|
|||
|
+ if(options.title !== false) { menu_head.show(); }
|
|||
|
+ if(options.subtitle !== false) { menu_subhead.show(); }
|
|||
|
+
|
|||
|
+ /* make content visible */
|
|||
|
+ menu_content.show();
|
|||
|
+
|
|||
|
+ /* reduce height to a minimum for best fit */
|
|||
|
+ menuHeight = (menu.outerHeight() > options.maxHeight) ? options.maxHeight : menu.outerHeight();
|
|||
|
+
|
|||
|
+ /* set the width to a fixed value */
|
|||
|
+ if(!isNaN(parseInt(options.width))) {
|
|||
|
+ menu.css({
|
|||
|
+ 'min-width' : options.width + 'px',
|
|||
|
+ 'max-width' : options.width + 'px'
|
|||
|
+ });
|
|||
|
+ menu.width(options.width);
|
|||
|
+ }else {
|
|||
|
+ // use real width plus 15 percent
|
|||
|
+ var width = menu.outerWidth(true)*1.15;
|
|||
|
+ menu.css({
|
|||
|
+ 'min-width' : width + 'px',
|
|||
|
+ 'max-width' : width + 'px'
|
|||
|
+ });
|
|||
|
+ menu.width(width);
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ /* default position of the menu container */
|
|||
|
+ menu.css({
|
|||
|
+ // x-position in relation to the initiator
|
|||
|
+ 'left' : initiator.offset().left + options.offsetX + 'px',
|
|||
|
+ // y-position in relation to the initiator
|
|||
|
+ 'top' : initiator.offset().top + initiator.height() + options.offsetY + 'px'
|
|||
|
+ });
|
|||
|
+
|
|||
|
+ /* change the orientation from right to left if width exceeds the windows size */
|
|||
|
+ if((initiator.offset().left + initiator.width() + options.offsetX + menu.outerWidth(true)) > $(window).width()) {
|
|||
|
+ menu.css({'left' : (initiator.offset().left + initiator.width() - menu.outerWidth(true)) + 'px'});
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ menu.css({'height':0, 'text-align':options.textAlign});
|
|||
|
+ menu.bind('mouseover', _cancel_timer);
|
|||
|
+ menu.bind('mouseout', _set_timer);
|
|||
|
+ return menu;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+
|
|||
|
+ function _switch_layer(subMenuClass){
|
|||
|
+ if(subMenuClass == null) {
|
|||
|
+ var content = menu_html;
|
|||
|
+ menu_back.empty().hide();
|
|||
|
+ menu_content.height(contentHeight);
|
|||
|
+ }else {
|
|||
|
+ var content = menu_html.find('.' + subMenuClass + ' div:first');
|
|||
|
+ menu_back.show();
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ parentClass = menu_html.find('.' + subMenuClass).parents('h6').attr('class');
|
|||
|
+
|
|||
|
+ menu_back.empty().append( menu_html.find('.' + subMenuClass + ' a:first').html() );
|
|||
|
+ menu_back.find('span:last').removeClass('ui-icon-triangle-1-e').addClass('ui-icon-triangle-1-s');
|
|||
|
+ menu_back.unbind('click').click( function() { _switch_layer( parentClass); });
|
|||
|
+
|
|||
|
+ menu_content.empty().append(content.html());
|
|||
|
+
|
|||
|
+ /* re-calculate content height */
|
|||
|
+ if(subMenuClass != null) {
|
|||
|
+ menu_head_height = menu_head.is(":visible") ? menu_head.outerHeight() : 0;
|
|||
|
+ menu_back_height = menu_back.is(":visible") ? menu_back.outerHeight() : 0;
|
|||
|
+ menu_subhead_height = menu_subhead.is(":visible") ? menu_subhead.outerHeight() : 0;
|
|||
|
+
|
|||
|
+ menu_content.height(menuHeight - menu_head_height - menu_back_height - menu_subhead_height);
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ /* return false to suppress unwanted click events*/
|
|||
|
+ return false;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ function _set_timer(timer){
|
|||
|
+ timer = ( typeof(timer) != 'number' ) ? options.timeout : timer;
|
|||
|
+ timerref = window.setTimeout( _close_menu, timer);
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ function _cancel_timer() {
|
|||
|
+ if(timerref) {
|
|||
|
+ window.clearTimeout(timerref);
|
|||
|
+ timerref = null;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ function _close_menu(){
|
|||
|
+ menu = $('#' + options.name);
|
|||
|
+ menu.slideUp(menuHeight*3);
|
|||
|
+ menu.queue(function () {
|
|||
|
+ menu.remove();
|
|||
|
+ menu.dequeue();
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ function _open_menu(obj){
|
|||
|
+ //wait until oldMenu is completey closed before opening a new one
|
|||
|
+ var wait = setInterval(function() {
|
|||
|
+ if( !oldMenus.is(":animated") ) {
|
|||
|
+ clearInterval(wait);
|
|||
|
+ obj.show().animate({height: menuHeight}, menuHeight*3);
|
|||
|
+
|
|||
|
+ //setup contentHeight;
|
|||
|
+ menu_head_height = menu_head.is(":visible") ? menu_head.outerHeight() : 0;
|
|||
|
+ menu_back_height = menu_back.is(":visible") ? menu_back.outerHeight() : 0;
|
|||
|
+ menu_subhead_height = menu_subhead.is(":visible") ? menu_subhead.outerHeight() : 0;
|
|||
|
+
|
|||
|
+ menu_content.height(menuHeight - menu_head_height - menu_back_height - menu_subhead_height);
|
|||
|
+
|
|||
|
+ contentHeight = $('#' + options.name + '_content').height();
|
|||
|
+ $('#' + options.name + '_content').css({'overflow-y':'auto'});
|
|||
|
+
|
|||
|
+ obj.find('h6').eq(0).focus();
|
|||
|
+ if(options.auto_close !== false) {
|
|||
|
+ _set_timer(options.auto_close);
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }, 200);
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ };
|
|||
|
+})(jQuery);
|
|||
|
\ No newline at end of file
|
|||
|
diff -up cacti-0.8.8a/include/js/jquery/jquery.js.legal cacti-0.8.8a/include/js/jquery/jquery.js
|
|||
|
--- cacti-0.8.8a/include/js/jquery/jquery.js.legal 2013-01-04 15:44:38.035416071 -0500
|
|||
|
+++ cacti-0.8.8a/include/js/jquery/jquery.js 2013-01-04 15:43:12.644377988 -0500
|
|||
|
@@ -0,0 +1,4 @@
|
|||
|
+/*! jQuery v1.7.1 jquery.com | jquery.org/license */
|
|||
|
+(function(a,b){function cy(a){return f.isWindow(a)?a:a.nodeType===9?a.defaultView||a.parentWindow:!1}function cv(a){if(!ck[a]){var b=c.body,d=f("<"+a+">").appendTo(b),e=d.css("display");d.remove();if(e==="none"||e===""){cl||(cl=c.createElement("iframe"),cl.frameBorder=cl.width=cl.height=0),b.appendChild(cl);if(!cm||!cl.createElement)cm=(cl.contentWindow||cl.contentDocument).document,cm.write((c.compatMode==="CSS1Compat"?"<!doctype html>":"")+"<html><body>"),cm.close();d=cm.createElement(a),cm.body.appendChild(d),e=f.css(d,"display"),b.removeChild(cl)}ck[a]=e}return ck[a]}function cu(a,b){var c={};f.each(cq.concat.apply([],cq.slice(0,b)),function(){c[this]=a});return c}function ct(){cr=b}function cs(){setTimeout(ct,0);return cr=f.now()}function cj(){try{return new a.ActiveXObject("Microsoft.XMLHTTP")}catch(b){}}function ci(){try{return new a.XMLHttpRequest}catch(b){}}function cc(a,c){a.dataFilter&&(c=a.dataFilter(c,a.dataType));var d=a.dataTypes,e={},g,h,i=d.length,j,k=d[0],l,m,n,o,p;for(g=1;g<i;g++){if(g===1)for(h in a.converters)typeof h=="string"&&(e[h.toLowerCase()]=a.converters[h]);l=k,k=d[g];if(k==="*")k=l;else if(l!=="*"&&l!==k){m=l+" "+k,n=e[m]||e["* "+k];if(!n){p=b;for(o in e){j=o.split(" ");if(j[0]===l||j[0]==="*"){p=e[j[1]+" "+k];if(p){o=e[o],o===!0?n=p:p===!0&&(n=o);break}}}}!n&&!p&&f.error("No conversion from "+m.replace(" "," to ")),n!==!0&&(c=n?n(c):p(o(c)))}}return c}function cb(a,c,d){var e=a.contents,f=a.dataTypes,g=a.responseFields,h,i,j,k;for(i in g)i in d&&(c[g[i]]=d[i]);while(f[0]==="*")f.shift(),h===b&&(h=a.mimeType||c.getResponseHeader("content-type"));if(h)for(i in e)if(e[i]&&e[i].test(h)){f.unshift(i);break}if(f[0]in d)j=f[0];else{for(i in d){if(!f[0]||a.converters[i+" "+f[0]]){j=i;break}k||(k=i)}j=j||k}if(j){j!==f[0]&&f.unshift(j);return d[j]}}function ca(a,b,c,d){if(f.isArray(b))f.each(b,function(b,e){c||bE.test(a)?d(a,e):ca(a+"["+(typeof e=="object"||f.isArray(e)?b:"")+"]",e,c,d)});else if(!c&&b!=null&&typeof b=="object")for(var e in b)ca(a+"["+e+"]",b[e],c,d);else d(a,b)}function b_(a,c){var d,e,g=f.ajaxSettings.flatOptions||{};for(d in c)c[d]!==b&&((g[d]?a:e||(e={}))[d]=c[d]);e&&f.extend(!0,a,e)}function b$(a,c,d,e,f,g){f=f||c.dataTypes[0],g=g||{},g[f]=!0;var h=a[f],i=0,j=h?h.length:0,k=a===bT,l;for(;i<j&&(k||!l);i++)l=h[i](c,d,e),typeof l=="string"&&(!k||g[l]?l=b:(c.dataTypes.unshift(l),l=b$(a,c,d,e,l,g)));(k||!l)&&!g["*"]&&(l=b$(a,c,d,e,"*",g));return l}function bZ(a){return function(b,c){typeof b!="string"&&(c=b,b="*");if(f.isFunction(c)){var d=b.toLowerCase().split(bP),e=0,g=d.length,h,i,j;for(;e<g;e++)h=d[e],j=/^\+/.test(h),j&&(h=h.substr(1)||"*"),i=a[h]=a[h]||[],i[j?"unshift":"push"](c)}}}function bC(a,b,c){var d=b==="width"?a.offsetWidth:a.offsetHeight,e=b==="width"?bx:by,g=0,h=e.length;if(d>0){if(c!=="border")for(;g<h;g++)c||(d-=parseFloat(f.css(a,"padding"+e[g]))||0),c==="margin"?d+=parseFloat(f.css(a,c+e[g]))||0:d-=parseFloat(f.css(a,"border"+e[g]+"Width"))||0;return d+"px"}d=bz(a,b,b);if(d<0||d==null)d=a.style[b]||0;d=parseFloat(d)||0;if(c)for(;g<h;g++)d+=parseFloat(f.css(a,"padding"+e[g]))||0,c!=="padding"&&(d+=parseFloat(f.css(a,"border"+e[g]+"Width"))||0),c==="margin"&&(d+=parseFloat(f.css(a,c+e[g]))||0);return d+"px"}function bp(a,b){b.src?f.ajax({url:b.src,async:!1,dataType:"script"}):f.globalEval((b.text||b.textContent||b.innerHTML||"").replace(bf,"/*$0*/")),b.parentNode&&b.parentNode.removeChild(b)}function bo(a){var b=c.createElement("div");bh.appendChild(b),b.innerHTML=a.outerHTML;return b.firstChild}function bn(a){var b=(a.nodeName||"").toLowerCase();b==="input"?bm(a):b!=="script"&&typeof a.getElementsByTagName!="undefined"&&f.grep(a.getElementsByTagName("input"),bm)}function bm(a){if(a.type==="checkbox"||a.type==="radio")a.defaultChecked=a.checked}function bl(a){return typeof a.getElementsByTagName!="undefined"?a.getElementsByTagName("*"):typeof a.querySelectorAll!="undefined"?a.querySelectorAll("*"):[]}function bk(a,b){var c;if(b.nodeType===1){b.clearAttributes&&b.clearAttributes(),b.mergeAttributes&&b.mergeAttributes(a),c=b.nodeName.toLowerCase();if(c==="object")b.o
|
|||
|
+f.event={add:function(a,c,d,e,g){var h,i,j,k,l,m,n,o,p,q,r,s;if(!(a.nodeType===3||a.nodeType===8||!c||!d||!(h=f._data(a)))){d.handler&&(p=d,d=p.handler),d.guid||(d.guid=f.guid++),j=h.events,j||(h.events=j={}),i=h.handle,i||(h.handle=i=function(a){return typeof f!="undefined"&&(!a||f.event.triggered!==a.type)?f.event.dispatch.apply(i.elem,arguments):b},i.elem=a),c=f.trim(I(c)).split(" ");for(k=0;k<c.length;k++){l=A.exec(c[k])||[],m=l[1],n=(l[2]||"").split(".").sort(),s=f.event.special[m]||{},m=(g?s.delegateType:s.bindType)||m,s=f.event.special[m]||{},o=f.extend({type:m,origType:l[1],data:e,handler:d,guid:d.guid,selector:g,quick:G(g),namespace:n.join(".")},p),r=j[m];if(!r){r=j[m]=[],r.delegateCount=0;if(!s.setup||s.setup.call(a,e,n,i)===!1)a.addEventListener?a.addEventListener(m,i,!1):a.attachEvent&&a.attachEvent("on"+m,i)}s.add&&(s.add.call(a,o),o.handler.guid||(o.handler.guid=d.guid)),g?r.splice(r.delegateCount++,0,o):r.push(o),f.event.global[m]=!0}a=null}},global:{},remove:function(a,b,c,d,e){var g=f.hasData(a)&&f._data(a),h,i,j,k,l,m,n,o,p,q,r,s;if(!!g&&!!(o=g.events)){b=f.trim(I(b||"")).split(" ");for(h=0;h<b.length;h++){i=A.exec(b[h])||[],j=k=i[1],l=i[2];if(!j){for(j in o)f.event.remove(a,j+b[h],c,d,!0);continue}p=f.event.special[j]||{},j=(d?p.delegateType:p.bindType)||j,r=o[j]||[],m=r.length,l=l?new RegExp("(^|\\.)"+l.split(".").sort().join("\\.(?:.*\\.)?")+"(\\.|$)"):null;for(n=0;n<r.length;n++)s=r[n],(e||k===s.origType)&&(!c||c.guid===s.guid)&&(!l||l.test(s.namespace))&&(!d||d===s.selector||d==="**"&&s.selector)&&(r.splice(n--,1),s.selector&&r.delegateCount--,p.remove&&p.remove.call(a,s));r.length===0&&m!==r.length&&((!p.teardown||p.teardown.call(a,l)===!1)&&f.removeEvent(a,j,g.handle),delete o[j])}f.isEmptyObject(o)&&(q=g.handle,q&&(q.elem=null),f.removeData(a,["events","handle"],!0))}},customEvent:{getData:!0,setData:!0,changeData:!0},trigger:function(c,d,e,g){if(!e||e.nodeType!==3&&e.nodeType!==8){var h=c.type||c,i=[],j,k,l,m,n,o,p,q,r,s;if(E.test(h+f.event.triggered))return;h.indexOf("!")>=0&&(h=h.slice(0,-1),k=!0),h.indexOf(".")>=0&&(i=h.split("."),h=i.shift(),i.sort());if((!e||f.event.customEvent[h])&&!f.event.global[h])return;c=typeof c=="object"?c[f.expando]?c:new f.Event(h,c):new f.Event(h),c.type=h,c.isTrigger=!0,c.exclusive=k,c.namespace=i.join("."),c.namespace_re=c.namespace?new RegExp("(^|\\.)"+i.join("\\.(?:.*\\.)?")+"(\\.|$)"):null,o=h.indexOf(":")<0?"on"+h:"";if(!e){j=f.cache;for(l in j)j[l].events&&j[l].events[h]&&f.event.trigger(c,d,j[l].handle.elem,!0);return}c.result=b,c.target||(c.target=e),d=d!=null?f.makeArray(d):[],d.unshift(c),p=f.event.special[h]||{};if(p.trigger&&p.trigger.apply(e,d)===!1)return;r=[[e,p.bindType||h]];if(!g&&!p.noBubble&&!f.isWindow(e)){s=p.delegateType||h,m=E.test(s+h)?e:e.parentNode,n=null;for(;m;m=m.parentNode)r.push([m,s]),n=m;n&&n===e.ownerDocument&&r.push([n.defaultView||n.parentWindow||a,s])}for(l=0;l<r.length&&!c.isPropagationStopped();l++)m=r[l][0],c.type=r[l][1],q=(f._data(m,"events")||{})[c.type]&&f._data(m,"handle"),q&&q.apply(m,d),q=o&&m[o],q&&f.acceptData(m)&&q.apply(m,d)===!1&&c.preventDefault();c.type=h,!g&&!c.isDefaultPrevented()&&(!p._default||p._default.apply(e.ownerDocument,d)===!1)&&(h!=="click"||!f.nodeName(e,"a"))&&f.acceptData(e)&&o&&e[h]&&(h!=="focus"&&h!=="blur"||c.target.offsetWidth!==0)&&!f.isWindow(e)&&(n=e[o],n&&(e[o]=null),f.event.triggered=h,e[h](),f.event.triggered=b,n&&(e[o]=n));return c.result}},dispatch:function(c){c=f.event.fix(c||a.event);var d=(f._data(this,"events")||{})[c.type]||[],e=d.delegateCount,g=[].slice.call(arguments,0),h=!c.exclusive&&!c.namespace,i=[],j,k,l,m,n,o,p,q,r,s,t;g[0]=c,c.delegateTarget=this;if(e&&!c.target.disabled&&(!c.button||c.type!=="click")){m=f(this),m.context=this.ownerDocument||this;for(l=c.target;l!=this;l=l.parentNode||this){o={},q=[],m[0]=l;for(j=0;j<e;j++)r=d[j],s=r.selector,o[s]===b&&(o[s]=r.quick?H(l,r.quick):m.is(s)),o[s]&&q.push(r);q.length&&i.push({elem:l,matches:q})}}d.length>e&&i.push({elem:this,matches:d.slice(e)});for(j=0;j<i.length&&!c.isPropagationStopped();j++){p=i[j],c.currentTarget=p
|
|||
|
+{for(var a=0,b;(b=this[a])!=null;a++){b.nodeType===1&&f.cleanData(b.getElementsByTagName("*"));while(b.firstChild)b.removeChild(b.firstChild)}return this},clone:function(a,b){a=a==null?!1:a,b=b==null?a:b;return this.map(function(){return f.clone(this,a,b)})},html:function(a){if(a===b)return this[0]&&this[0].nodeType===1?this[0].innerHTML.replace(W,""):null;if(typeof a=="string"&&!ba.test(a)&&(f.support.leadingWhitespace||!X.test(a))&&!bg[(Z.exec(a)||["",""])[1].toLowerCase()]){a=a.replace(Y,"<$1></$2>");try{for(var c=0,d=this.length;c<d;c++)this[c].nodeType===1&&(f.cleanData(this[c].getElementsByTagName("*")),this[c].innerHTML=a)}catch(e){this.empty().append(a)}}else f.isFunction(a)?this.each(function(b){var c=f(this);c.html(a.call(this,b,c.html()))}):this.empty().append(a);return this},replaceWith:function(a){if(this[0]&&this[0].parentNode){if(f.isFunction(a))return this.each(function(b){var c=f(this),d=c.html();c.replaceWith(a.call(this,b,d))});typeof a!="string"&&(a=f(a).detach());return this.each(function(){var b=this.nextSibling,c=this.parentNode;f(this).remove(),b?f(b).before(a):f(c).append(a)})}return this.length?this.pushStack(f(f.isFunction(a)?a():a),"replaceWith",a):this},detach:function(a){return this.remove(a,!0)},domManip:function(a,c,d){var e,g,h,i,j=a[0],k=[];if(!f.support.checkClone&&arguments.length===3&&typeof j=="string"&&bd.test(j))return this.each(function(){f(this).domManip(a,c,d,!0)});if(f.isFunction(j))return this.each(function(e){var g=f(this);a[0]=j.call(this,e,c?g.html():b),g.domManip(a,c,d)});if(this[0]){i=j&&j.parentNode,f.support.parentNode&&i&&i.nodeType===11&&i.childNodes.length===this.length?e={fragment:i}:e=f.buildFragment(a,this,k),h=e.fragment,h.childNodes.length===1?g=h=h.firstChild:g=h.firstChild;if(g){c=c&&f.nodeName(g,"tr");for(var l=0,m=this.length,n=m-1;l<m;l++)d.call(c?bi(this[l],g):this[l],e.cacheable||m>1&&l<n?f.clone(h,!0,!0):h)}k.length&&f.each(k,bp)}return this}}),f.buildFragment=function(a,b,d){var e,g,h,i,j=a[0];b&&b[0]&&(i=b[0].ownerDocument||b[0]),i.createDocumentFragment||(i=c),a.length===1&&typeof j=="string"&&j.length<512&&i===c&&j.charAt(0)==="<"&&!bb.test(j)&&(f.support.checkClone||!bd.test(j))&&(f.support.html5Clone||!bc.test(j))&&(g=!0,h=f.fragments[j],h&&h!==1&&(e=h)),e||(e=i.createDocumentFragment(),f.clean(a,i,e,d)),g&&(f.fragments[j]=h?e:1);return{fragment:e,cacheable:g}},f.fragments={},f.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(a,b){f.fn[a]=function(c){var d=[],e=f(c),g=this.length===1&&this[0].parentNode;if(g&&g.nodeType===11&&g.childNodes.length===1&&e.length===1){e[b](this[0]);return this}for(var h=0,i=e.length;h<i;h++){var j=(h>0?this.clone(!0):this).get();f(e[h])[b](j),d=d.concat(j)}return this.pushStack(d,a,e.selector)}}),f.extend({clone:function(a,b,c){var d,e,g,h=f.support.html5Clone||!bc.test("<"+a.nodeName)?a.cloneNode(!0):bo(a);if((!f.support.noCloneEvent||!f.support.noCloneChecked)&&(a.nodeType===1||a.nodeType===11)&&!f.isXMLDoc(a)){bk(a,h),d=bl(a),e=bl(h);for(g=0;d[g];++g)e[g]&&bk(d[g],e[g])}if(b){bj(a,h);if(c){d=bl(a),e=bl(h);for(g=0;d[g];++g)bj(d[g],e[g])}}d=e=null;return h},clean:function(a,b,d,e){var g;b=b||c,typeof b.createElement=="undefined"&&(b=b.ownerDocument||b[0]&&b[0].ownerDocument||c);var h=[],i;for(var j=0,k;(k=a[j])!=null;j++){typeof k=="number"&&(k+="");if(!k)continue;if(typeof k=="string")if(!_.test(k))k=b.createTextNode(k);else{k=k.replace(Y,"<$1></$2>");var l=(Z.exec(k)||["",""])[1].toLowerCase(),m=bg[l]||bg._default,n=m[0],o=b.createElement("div");b===c?bh.appendChild(o):U(b).appendChild(o),o.innerHTML=m[1]+k+m[2];while(n--)o=o.lastChild;if(!f.support.tbody){var p=$.test(k),q=l==="table"&&!p?o.firstChild&&o.firstChild.childNodes:m[1]==="<table>"&&!p?o.childNodes:[];for(i=q.length-1;i>=0;--i)f.nodeName(q[i],"tbody")&&!q[i].childNodes.length&&q[i].parentNode.removeChild(q[i])}!f.support.leadingWhitespace&&X.test(k)&&o.insertBefore(b.createTextNode(X.exec(k)[0]),o.firstChild),k=o.childNodes}var r;if(!f.support.appendChecked)if(k[0]&&typeof (r=k.len
|
|||
|
\ No newline at end of file
|
|||
|
diff -up cacti-0.8.8a/include/js/jquery/jquery.jstree.js.legal cacti-0.8.8a/include/js/jquery/jquery.jstree.js
|
|||
|
--- cacti-0.8.8a/include/js/jquery/jquery.jstree.js.legal 2013-01-04 15:44:38.036416073 -0500
|
|||
|
+++ cacti-0.8.8a/include/js/jquery/jquery.jstree.js 2013-01-04 15:43:12.645377988 -0500
|
|||
|
@@ -0,0 +1,4551 @@
|
|||
|
+/*
|
|||
|
+ * jsTree 1.0-rc3
|
|||
|
+ * http://jstree.com/
|
|||
|
+ *
|
|||
|
+ * Copyright (c) 2010 Ivan Bozhanov (vakata.com)
|
|||
|
+ *
|
|||
|
+ * Licensed same as jquery - under the terms of either the MIT License or the GPL Version 2 License
|
|||
|
+ * http://www.opensource.org/licenses/mit-license.php
|
|||
|
+ * http://www.gnu.org/licenses/gpl.html
|
|||
|
+ *
|
|||
|
+ * $Date: 2011-02-09 01:17:14 +0200 (ср, 09 февр 2011) $
|
|||
|
+ * $Revision: 236 $
|
|||
|
+ */
|
|||
|
+
|
|||
|
+/*jslint browser: true, onevar: true, undef: true, bitwise: true, strict: true */
|
|||
|
+/*global window : false, clearInterval: false, clearTimeout: false, document: false, setInterval: false, setTimeout: false, jQuery: false, navigator: false, XSLTProcessor: false, DOMParser: false, XMLSerializer: false*/
|
|||
|
+
|
|||
|
+"use strict";
|
|||
|
+
|
|||
|
+// top wrapper to prevent multiple inclusion (is this OK?)
|
|||
|
+(function () { if(jQuery && jQuery.jstree) { return; }
|
|||
|
+ var is_ie6 = false, is_ie7 = false, is_ff2 = false;
|
|||
|
+
|
|||
|
+/*
|
|||
|
+ * jsTree core
|
|||
|
+ */
|
|||
|
+(function ($) {
|
|||
|
+ // Common functions not related to jsTree
|
|||
|
+ // decided to move them to a `vakata` "namespace"
|
|||
|
+ $.vakata = {};
|
|||
|
+ // CSS related functions
|
|||
|
+ $.vakata.css = {
|
|||
|
+ get_css : function(rule_name, delete_flag, sheet) {
|
|||
|
+ rule_name = rule_name.toLowerCase();
|
|||
|
+ var css_rules = sheet.cssRules || sheet.rules,
|
|||
|
+ j = 0;
|
|||
|
+ do {
|
|||
|
+ if(css_rules.length && j > css_rules.length + 5) { return false; }
|
|||
|
+ if(css_rules[j].selectorText && css_rules[j].selectorText.toLowerCase() == rule_name) {
|
|||
|
+ if(delete_flag === true) {
|
|||
|
+ if(sheet.removeRule) { sheet.removeRule(j); }
|
|||
|
+ if(sheet.deleteRule) { sheet.deleteRule(j); }
|
|||
|
+ return true;
|
|||
|
+ }
|
|||
|
+ else { return css_rules[j]; }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ while (css_rules[++j]);
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ add_css : function(rule_name, sheet) {
|
|||
|
+ if($.jstree.css.get_css(rule_name, false, sheet)) { return false; }
|
|||
|
+ if(sheet.insertRule) { sheet.insertRule(rule_name + ' { }', 0); } else { sheet.addRule(rule_name, null, 0); }
|
|||
|
+ return $.vakata.css.get_css(rule_name);
|
|||
|
+ },
|
|||
|
+ remove_css : function(rule_name, sheet) {
|
|||
|
+ return $.vakata.css.get_css(rule_name, true, sheet);
|
|||
|
+ },
|
|||
|
+ add_sheet : function(opts) {
|
|||
|
+ var tmp = false, is_new = true;
|
|||
|
+ if(opts.str) {
|
|||
|
+ if(opts.title) { tmp = $("style[id='" + opts.title + "-stylesheet']")[0]; }
|
|||
|
+ if(tmp) { is_new = false; }
|
|||
|
+ else {
|
|||
|
+ tmp = document.createElement("style");
|
|||
|
+ tmp.setAttribute('type',"text/css");
|
|||
|
+ if(opts.title) { tmp.setAttribute("id", opts.title + "-stylesheet"); }
|
|||
|
+ }
|
|||
|
+ if(tmp.styleSheet) {
|
|||
|
+ if(is_new) {
|
|||
|
+ document.getElementsByTagName("head")[0].appendChild(tmp);
|
|||
|
+ tmp.styleSheet.cssText = opts.str;
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ tmp.styleSheet.cssText = tmp.styleSheet.cssText + " " + opts.str;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ tmp.appendChild(document.createTextNode(opts.str));
|
|||
|
+ document.getElementsByTagName("head")[0].appendChild(tmp);
|
|||
|
+ }
|
|||
|
+ return tmp.sheet || tmp.styleSheet;
|
|||
|
+ }
|
|||
|
+ if(opts.url) {
|
|||
|
+ if(document.createStyleSheet) {
|
|||
|
+ try { tmp = document.createStyleSheet(opts.url); } catch (e) { }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ tmp = document.createElement('link');
|
|||
|
+ tmp.rel = 'stylesheet';
|
|||
|
+ tmp.type = 'text/css';
|
|||
|
+ tmp.media = "all";
|
|||
|
+ tmp.href = opts.url;
|
|||
|
+ document.getElementsByTagName("head")[0].appendChild(tmp);
|
|||
|
+ return tmp.styleSheet;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ };
|
|||
|
+
|
|||
|
+ // private variables
|
|||
|
+ var instances = [], // instance array (used by $.jstree.reference/create/focused)
|
|||
|
+ focused_instance = -1, // the index in the instance array of the currently focused instance
|
|||
|
+ plugins = {}, // list of included plugins
|
|||
|
+ prepared_move = {}; // for the move_node function
|
|||
|
+
|
|||
|
+ // jQuery plugin wrapper (thanks to jquery UI widget function)
|
|||
|
+ $.fn.jstree = function (settings) {
|
|||
|
+ var isMethodCall = (typeof settings == 'string'), // is this a method call like $().jstree("open_node")
|
|||
|
+ args = Array.prototype.slice.call(arguments, 1),
|
|||
|
+ returnValue = this;
|
|||
|
+
|
|||
|
+ // if a method call execute the method on all selected instances
|
|||
|
+ if(isMethodCall) {
|
|||
|
+ if(settings.substring(0, 1) == '_') { return returnValue; }
|
|||
|
+ this.each(function() {
|
|||
|
+ var instance = instances[$.data(this, "jstree_instance_id")],
|
|||
|
+ methodValue = (instance && $.isFunction(instance[settings])) ? instance[settings].apply(instance, args) : instance;
|
|||
|
+ if(typeof methodValue !== "undefined" && (settings.indexOf("is_") === 0 || (methodValue !== true && methodValue !== false))) { returnValue = methodValue; return false; }
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ this.each(function() {
|
|||
|
+ // extend settings and allow for multiple hashes and $.data
|
|||
|
+ var instance_id = $.data(this, "jstree_instance_id"),
|
|||
|
+ a = [],
|
|||
|
+ b = settings ? $.extend({}, true, settings) : {},
|
|||
|
+ c = $(this),
|
|||
|
+ s = false,
|
|||
|
+ t = [];
|
|||
|
+ a = a.concat(args);
|
|||
|
+ if(c.data("jstree")) { a.push(c.data("jstree")); }
|
|||
|
+ b = a.length ? $.extend.apply(null, [true, b].concat(a)) : b;
|
|||
|
+
|
|||
|
+ // if an instance already exists, destroy it first
|
|||
|
+ if(typeof instance_id !== "undefined" && instances[instance_id]) { instances[instance_id].destroy(); }
|
|||
|
+ // push a new empty object to the instances array
|
|||
|
+ instance_id = parseInt(instances.push({}),10) - 1;
|
|||
|
+ // store the jstree instance id to the container element
|
|||
|
+ $.data(this, "jstree_instance_id", instance_id);
|
|||
|
+ // clean up all plugins
|
|||
|
+ b.plugins = $.isArray(b.plugins) ? b.plugins : $.jstree.defaults.plugins.slice();
|
|||
|
+ b.plugins.unshift("core");
|
|||
|
+ // only unique plugins
|
|||
|
+ b.plugins = b.plugins.sort().join(",,").replace(/(,|^)([^,]+)(,,\2)+(,|$)/g,"$1$2$4").replace(/,,+/g,",").replace(/,$/,"").split(",");
|
|||
|
+
|
|||
|
+ // extend defaults with passed data
|
|||
|
+ s = $.extend(true, {}, $.jstree.defaults, b);
|
|||
|
+ s.plugins = b.plugins;
|
|||
|
+ $.each(plugins, function (i, val) {
|
|||
|
+ if($.inArray(i, s.plugins) === -1) { s[i] = null; delete s[i]; }
|
|||
|
+ else { t.push(i); }
|
|||
|
+ });
|
|||
|
+ s.plugins = t;
|
|||
|
+
|
|||
|
+ // push the new object to the instances array (at the same time set the default classes to the container) and init
|
|||
|
+ instances[instance_id] = new $.jstree._instance(instance_id, $(this).addClass("jstree jstree-" + instance_id), s);
|
|||
|
+ // init all activated plugins for this instance
|
|||
|
+ $.each(instances[instance_id]._get_settings().plugins, function (i, val) { instances[instance_id].data[val] = {}; });
|
|||
|
+ $.each(instances[instance_id]._get_settings().plugins, function (i, val) { if(plugins[val]) { plugins[val].__init.apply(instances[instance_id]); } });
|
|||
|
+ // initialize the instance
|
|||
|
+ setTimeout(function() { if(instances[instance_id]) { instances[instance_id].init(); } }, 0);
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ // return the jquery selection (or if it was a method call that returned a value - the returned value)
|
|||
|
+ return returnValue;
|
|||
|
+ };
|
|||
|
+ // object to store exposed functions and objects
|
|||
|
+ $.jstree = {
|
|||
|
+ defaults : {
|
|||
|
+ plugins : []
|
|||
|
+ },
|
|||
|
+ _focused : function () { return instances[focused_instance] || null; },
|
|||
|
+ _reference : function (needle) {
|
|||
|
+ // get by instance id
|
|||
|
+ if(instances[needle]) { return instances[needle]; }
|
|||
|
+ // get by DOM (if still no luck - return null
|
|||
|
+ var o = $(needle);
|
|||
|
+ if(!o.length && typeof needle === "string") { o = $("#" + needle); }
|
|||
|
+ if(!o.length) { return null; }
|
|||
|
+ return instances[o.closest(".jstree").data("jstree_instance_id")] || null;
|
|||
|
+ },
|
|||
|
+ _instance : function (index, container, settings) {
|
|||
|
+ // for plugins to store data in
|
|||
|
+ this.data = { core : {} };
|
|||
|
+ this.get_settings = function () { return $.extend(true, {}, settings); };
|
|||
|
+ this._get_settings = function () { return settings; };
|
|||
|
+ this.get_index = function () { return index; };
|
|||
|
+ this.get_container = function () { return container; };
|
|||
|
+ this.get_container_ul = function () { return container.children("ul:eq(0)"); };
|
|||
|
+ this._set_settings = function (s) {
|
|||
|
+ settings = $.extend(true, {}, settings, s);
|
|||
|
+ };
|
|||
|
+ },
|
|||
|
+ _fn : { },
|
|||
|
+ plugin : function (pname, pdata) {
|
|||
|
+ pdata = $.extend({}, {
|
|||
|
+ __init : $.noop,
|
|||
|
+ __destroy : $.noop,
|
|||
|
+ _fn : {},
|
|||
|
+ defaults : false
|
|||
|
+ }, pdata);
|
|||
|
+ plugins[pname] = pdata;
|
|||
|
+
|
|||
|
+ $.jstree.defaults[pname] = pdata.defaults;
|
|||
|
+ $.each(pdata._fn, function (i, val) {
|
|||
|
+ val.plugin = pname;
|
|||
|
+ val.old = $.jstree._fn[i];
|
|||
|
+ $.jstree._fn[i] = function () {
|
|||
|
+ var rslt,
|
|||
|
+ func = val,
|
|||
|
+ args = Array.prototype.slice.call(arguments),
|
|||
|
+ evnt = new $.Event("before.jstree"),
|
|||
|
+ rlbk = false;
|
|||
|
+
|
|||
|
+ if(this.data.core.locked === true && i !== "unlock" && i !== "is_locked") { return; }
|
|||
|
+
|
|||
|
+ // Check if function belongs to the included plugins of this instance
|
|||
|
+ do {
|
|||
|
+ if(func && func.plugin && $.inArray(func.plugin, this._get_settings().plugins) !== -1) { break; }
|
|||
|
+ func = func.old;
|
|||
|
+ } while(func);
|
|||
|
+ if(!func) { return; }
|
|||
|
+
|
|||
|
+ // context and function to trigger events, then finally call the function
|
|||
|
+ if(i.indexOf("_") === 0) {
|
|||
|
+ rslt = func.apply(this, args);
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ rslt = this.get_container().triggerHandler(evnt, { "func" : i, "inst" : this, "args" : args, "plugin" : func.plugin });
|
|||
|
+ if(rslt === false) { return; }
|
|||
|
+ if(typeof rslt !== "undefined") { args = rslt; }
|
|||
|
+
|
|||
|
+ rslt = func.apply(
|
|||
|
+ $.extend({}, this, {
|
|||
|
+ __callback : function (data) {
|
|||
|
+ this.get_container().triggerHandler( i + '.jstree', { "inst" : this, "args" : args, "rslt" : data, "rlbk" : rlbk });
|
|||
|
+ },
|
|||
|
+ __rollback : function () {
|
|||
|
+ rlbk = this.get_rollback();
|
|||
|
+ return rlbk;
|
|||
|
+ },
|
|||
|
+ __call_old : function (replace_arguments) {
|
|||
|
+ return func.old.apply(this, (replace_arguments ? Array.prototype.slice.call(arguments, 1) : args ) );
|
|||
|
+ }
|
|||
|
+ }), args);
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ // return the result
|
|||
|
+ return rslt;
|
|||
|
+ };
|
|||
|
+ $.jstree._fn[i].old = val.old;
|
|||
|
+ $.jstree._fn[i].plugin = pname;
|
|||
|
+ });
|
|||
|
+ },
|
|||
|
+ rollback : function (rb) {
|
|||
|
+ if(rb) {
|
|||
|
+ if(!$.isArray(rb)) { rb = [ rb ]; }
|
|||
|
+ $.each(rb, function (i, val) {
|
|||
|
+ instances[val.i].set_rollback(val.h, val.d);
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ };
|
|||
|
+ // set the prototype for all instances
|
|||
|
+ $.jstree._fn = $.jstree._instance.prototype = {};
|
|||
|
+
|
|||
|
+ // load the css when DOM is ready
|
|||
|
+ $(function() {
|
|||
|
+ // code is copied from jQuery ($.browser is deprecated + there is a bug in IE)
|
|||
|
+ var u = navigator.userAgent.toLowerCase(),
|
|||
|
+ v = (u.match( /.+?(?:rv|it|ra|ie)[\/: ]([\d.]+)/ ) || [0,'0'])[1],
|
|||
|
+ css_string = '' +
|
|||
|
+ '.jstree ul, .jstree li { display:block; margin:0 0 0 0; padding:0 0 0 0; list-style-type:none; } ' +
|
|||
|
+ '.jstree li { display:block; min-height:18px; line-height:18px; white-space:nowrap; margin-left:18px; min-width:18px; } ' +
|
|||
|
+ '.jstree-rtl li { margin-left:0; margin-right:18px; } ' +
|
|||
|
+ '.jstree > ul > li { margin-left:0px; } ' +
|
|||
|
+ '.jstree-rtl > ul > li { margin-right:0px; } ' +
|
|||
|
+ '.jstree ins { display:inline-block; text-decoration:none; width:18px; height:18px; margin:0 0 0 0; padding:0; } ' +
|
|||
|
+ '.jstree a { display:inline-block; line-height:16px; height:16px; color:black; white-space:nowrap; text-decoration:none; padding:1px 2px; margin:0; } ' +
|
|||
|
+ '.jstree a:focus { outline: none; } ' +
|
|||
|
+ '.jstree a > ins { height:16px; width:16px; } ' +
|
|||
|
+ '.jstree a > .jstree-icon { margin-right:3px; } ' +
|
|||
|
+ '.jstree-rtl a > .jstree-icon { margin-left:3px; margin-right:0; } ' +
|
|||
|
+ 'li.jstree-open > ul { display:block; } ' +
|
|||
|
+ 'li.jstree-closed > ul { display:none; } ';
|
|||
|
+ // Correct IE 6 (does not support the > CSS selector)
|
|||
|
+ if(/msie/.test(u) && parseInt(v, 10) == 6) {
|
|||
|
+ is_ie6 = true;
|
|||
|
+
|
|||
|
+ // fix image flicker and lack of caching
|
|||
|
+ try {
|
|||
|
+ document.execCommand("BackgroundImageCache", false, true);
|
|||
|
+ } catch (err) { }
|
|||
|
+
|
|||
|
+ css_string += '' +
|
|||
|
+ '.jstree li { height:18px; margin-left:0; margin-right:0; } ' +
|
|||
|
+ '.jstree li li { margin-left:18px; } ' +
|
|||
|
+ '.jstree-rtl li li { margin-left:0px; margin-right:18px; } ' +
|
|||
|
+ 'li.jstree-open ul { display:block; } ' +
|
|||
|
+ 'li.jstree-closed ul { display:none !important; } ' +
|
|||
|
+ '.jstree li a { display:inline; border-width:0 !important; padding:0px 2px !important; } ' +
|
|||
|
+ '.jstree li a ins { height:16px; width:16px; margin-right:3px; } ' +
|
|||
|
+ '.jstree-rtl li a ins { margin-right:0px; margin-left:3px; } ';
|
|||
|
+ }
|
|||
|
+ // Correct IE 7 (shifts anchor nodes onhover)
|
|||
|
+ if(/msie/.test(u) && parseInt(v, 10) == 7) {
|
|||
|
+ is_ie7 = true;
|
|||
|
+ css_string += '.jstree li a { border-width:0 !important; padding:0px 2px !important; } ';
|
|||
|
+ }
|
|||
|
+ // correct ff2 lack of display:inline-block
|
|||
|
+ if(!/compatible/.test(u) && /mozilla/.test(u) && parseFloat(v, 10) < 1.9) {
|
|||
|
+ is_ff2 = true;
|
|||
|
+ css_string += '' +
|
|||
|
+ '.jstree ins { display:-moz-inline-box; } ' +
|
|||
|
+ '.jstree li { line-height:12px; } ' + // WHY??
|
|||
|
+ '.jstree a { display:-moz-inline-box; } ' +
|
|||
|
+ '.jstree .jstree-no-icons .jstree-checkbox { display:-moz-inline-stack !important; } ';
|
|||
|
+ /* this shouldn't be here as it is theme specific */
|
|||
|
+ }
|
|||
|
+ // the default stylesheet
|
|||
|
+ $.vakata.css.add_sheet({ str : css_string, title : "jstree" });
|
|||
|
+ });
|
|||
|
+
|
|||
|
+ // core functions (open, close, create, update, delete)
|
|||
|
+ $.jstree.plugin("core", {
|
|||
|
+ __init : function () {
|
|||
|
+ this.data.core.locked = false;
|
|||
|
+ this.data.core.to_open = this.get_settings().core.initially_open;
|
|||
|
+ this.data.core.to_load = this.get_settings().core.initially_load;
|
|||
|
+ },
|
|||
|
+ defaults : {
|
|||
|
+ html_titles : false,
|
|||
|
+ animation : 500,
|
|||
|
+ initially_open : [],
|
|||
|
+ initially_load : [],
|
|||
|
+ open_parents : true,
|
|||
|
+ notify_plugins : true,
|
|||
|
+ rtl : false,
|
|||
|
+ load_open : false,
|
|||
|
+ strings : {
|
|||
|
+ loading : "Loading ...",
|
|||
|
+ new_node : "New node",
|
|||
|
+ multiple_selection : "Multiple selection"
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ _fn : {
|
|||
|
+ init : function () {
|
|||
|
+ this.set_focus();
|
|||
|
+ if(this._get_settings().core.rtl) {
|
|||
|
+ this.get_container().addClass("jstree-rtl").css("direction", "rtl");
|
|||
|
+ }
|
|||
|
+ this.get_container().html("<ul><li class='jstree-last jstree-leaf'><ins> </ins><a class='jstree-loading' href='#'><ins class='jstree-icon'> </ins>" + this._get_string("loading") + "</a></li></ul>");
|
|||
|
+ this.data.core.li_height = this.get_container_ul().find("li.jstree-closed, li.jstree-leaf").eq(0).height() || 18;
|
|||
|
+
|
|||
|
+ this.get_container()
|
|||
|
+ .delegate("li > ins", "click.jstree", $.proxy(function (event) {
|
|||
|
+ var trgt = $(event.target);
|
|||
|
+ // if(trgt.is("ins") && event.pageY - trgt.offset().top < this.data.core.li_height) { this.toggle_node(trgt); }
|
|||
|
+ this.toggle_node(trgt);
|
|||
|
+ }, this))
|
|||
|
+ .bind("mousedown.jstree", $.proxy(function () {
|
|||
|
+ this.set_focus(); // This used to be setTimeout(set_focus,0) - why?
|
|||
|
+ }, this))
|
|||
|
+ .bind("dblclick.jstree", function (event) {
|
|||
|
+ var sel;
|
|||
|
+ if(document.selection && document.selection.empty) { document.selection.empty(); }
|
|||
|
+ else {
|
|||
|
+ if(window.getSelection) {
|
|||
|
+ sel = window.getSelection();
|
|||
|
+ try {
|
|||
|
+ sel.removeAllRanges();
|
|||
|
+ sel.collapse();
|
|||
|
+ } catch (err) { }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ if(this._get_settings().core.notify_plugins) {
|
|||
|
+ this.get_container()
|
|||
|
+ .bind("load_node.jstree", $.proxy(function (e, data) {
|
|||
|
+ var o = this._get_node(data.rslt.obj),
|
|||
|
+ t = this;
|
|||
|
+ if(o === -1) { o = this.get_container_ul(); }
|
|||
|
+ if(!o.length) { return; }
|
|||
|
+ o.find("li").each(function () {
|
|||
|
+ var th = $(this);
|
|||
|
+ if(th.data("jstree")) {
|
|||
|
+ $.each(th.data("jstree"), function (plugin, values) {
|
|||
|
+ if(t.data[plugin] && $.isFunction(t["_" + plugin + "_notify"])) {
|
|||
|
+ t["_" + plugin + "_notify"].call(t, th, values);
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ }, this));
|
|||
|
+ }
|
|||
|
+ if(this._get_settings().core.load_open) {
|
|||
|
+ this.get_container()
|
|||
|
+ .bind("load_node.jstree", $.proxy(function (e, data) {
|
|||
|
+ var o = this._get_node(data.rslt.obj),
|
|||
|
+ t = this;
|
|||
|
+ if(o === -1) { o = this.get_container_ul(); }
|
|||
|
+ if(!o.length) { return; }
|
|||
|
+ o.find("li.jstree-open:not(:has(ul))").each(function () {
|
|||
|
+ t.load_node(this, $.noop, $.noop);
|
|||
|
+ });
|
|||
|
+ }, this));
|
|||
|
+ }
|
|||
|
+ this.__callback();
|
|||
|
+ this.load_node(-1, function () { this.loaded(); this.reload_nodes(); });
|
|||
|
+ },
|
|||
|
+ destroy : function () {
|
|||
|
+ var i,
|
|||
|
+ n = this.get_index(),
|
|||
|
+ s = this._get_settings(),
|
|||
|
+ _this = this;
|
|||
|
+
|
|||
|
+ $.each(s.plugins, function (i, val) {
|
|||
|
+ try { plugins[val].__destroy.apply(_this); } catch(err) { }
|
|||
|
+ });
|
|||
|
+ this.__callback();
|
|||
|
+ // set focus to another instance if this one is focused
|
|||
|
+ if(this.is_focused()) {
|
|||
|
+ for(i in instances) {
|
|||
|
+ if(instances.hasOwnProperty(i) && i != n) {
|
|||
|
+ instances[i].set_focus();
|
|||
|
+ break;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ // if no other instance found
|
|||
|
+ if(n === focused_instance) { focused_instance = -1; }
|
|||
|
+ // remove all traces of jstree in the DOM (only the ones set using jstree*) and cleans all events
|
|||
|
+ this.get_container()
|
|||
|
+ .unbind(".jstree")
|
|||
|
+ .undelegate(".jstree")
|
|||
|
+ .removeData("jstree_instance_id")
|
|||
|
+ .find("[class^='jstree']")
|
|||
|
+ .andSelf()
|
|||
|
+ .attr("class", function () { return this.className.replace(/jstree[^ ]*|$/ig,''); });
|
|||
|
+ $(document)
|
|||
|
+ .unbind(".jstree-" + n)
|
|||
|
+ .undelegate(".jstree-" + n);
|
|||
|
+ // remove the actual data
|
|||
|
+ instances[n] = null;
|
|||
|
+ delete instances[n];
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ _core_notify : function (n, data) {
|
|||
|
+ if(data.opened) {
|
|||
|
+ this.open_node(n, false, true);
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ lock : function () {
|
|||
|
+ this.data.core.locked = true;
|
|||
|
+ this.get_container().children("ul").addClass("jstree-locked").css("opacity","0.7");
|
|||
|
+ this.__callback({});
|
|||
|
+ },
|
|||
|
+ unlock : function () {
|
|||
|
+ this.data.core.locked = false;
|
|||
|
+ this.get_container().children("ul").removeClass("jstree-locked").css("opacity","1");
|
|||
|
+ this.__callback({});
|
|||
|
+ },
|
|||
|
+ is_locked : function () { return this.data.core.locked; },
|
|||
|
+ save_opened : function () {
|
|||
|
+ var _this = this;
|
|||
|
+ this.data.core.to_open = [];
|
|||
|
+ this.get_container_ul().find("li.jstree-open").each(function () {
|
|||
|
+ if(this.id) { _this.data.core.to_open.push("#" + this.id.toString().replace(/^#/,"").replace(/\\\//g,"/").replace(/\//g,"\\\/").replace(/\\\./g,".").replace(/\./g,"\\.").replace(/\:/g,"\\:")); }
|
|||
|
+ });
|
|||
|
+ this.__callback(_this.data.core.to_open);
|
|||
|
+ },
|
|||
|
+ save_loaded : function () { },
|
|||
|
+ reload_nodes : function (is_callback) {
|
|||
|
+ var _this = this,
|
|||
|
+ done = true,
|
|||
|
+ current = [],
|
|||
|
+ remaining = [];
|
|||
|
+ if(!is_callback) {
|
|||
|
+ this.data.core.reopen = false;
|
|||
|
+ this.data.core.refreshing = true;
|
|||
|
+ this.data.core.to_open = $.map($.makeArray(this.data.core.to_open), function (n) { return "#" + n.toString().replace(/^#/,"").replace(/\\\//g,"/").replace(/\//g,"\\\/").replace(/\\\./g,".").replace(/\./g,"\\.").replace(/\:/g,"\\:"); });
|
|||
|
+ this.data.core.to_load = $.map($.makeArray(this.data.core.to_load), function (n) { return "#" + n.toString().replace(/^#/,"").replace(/\\\//g,"/").replace(/\//g,"\\\/").replace(/\\\./g,".").replace(/\./g,"\\.").replace(/\:/g,"\\:"); });
|
|||
|
+ if(this.data.core.to_open.length) {
|
|||
|
+ this.data.core.to_load = this.data.core.to_load.concat(this.data.core.to_open);
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ if(this.data.core.to_load.length) {
|
|||
|
+ $.each(this.data.core.to_load, function (i, val) {
|
|||
|
+ if(val == "#") { return true; }
|
|||
|
+ if($(val).length) { current.push(val); }
|
|||
|
+ else { remaining.push(val); }
|
|||
|
+ });
|
|||
|
+ if(current.length) {
|
|||
|
+ this.data.core.to_load = remaining;
|
|||
|
+ $.each(current, function (i, val) {
|
|||
|
+ if(!_this._is_loaded(val)) {
|
|||
|
+ _this.load_node(val, function () { _this.reload_nodes(true); }, function () { _this.reload_nodes(true); });
|
|||
|
+ done = false;
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ if(this.data.core.to_open.length) {
|
|||
|
+ $.each(this.data.core.to_open, function (i, val) {
|
|||
|
+ _this.open_node(val, false, true);
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ if(done) {
|
|||
|
+ // TODO: find a more elegant approach to syncronizing returning requests
|
|||
|
+ if(this.data.core.reopen) { clearTimeout(this.data.core.reopen); }
|
|||
|
+ this.data.core.reopen = setTimeout(function () { _this.__callback({}, _this); }, 50);
|
|||
|
+ this.data.core.refreshing = false;
|
|||
|
+ this.reopen();
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ reopen : function () {
|
|||
|
+ var _this = this;
|
|||
|
+ if(this.data.core.to_open.length) {
|
|||
|
+ $.each(this.data.core.to_open, function (i, val) {
|
|||
|
+ _this.open_node(val, false, true);
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ this.__callback({});
|
|||
|
+ },
|
|||
|
+ refresh : function (obj) {
|
|||
|
+ var _this = this;
|
|||
|
+ this.save_opened();
|
|||
|
+ if(!obj) { obj = -1; }
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(!obj) { obj = -1; }
|
|||
|
+ if(obj !== -1) { obj.children("UL").remove(); }
|
|||
|
+ else { this.get_container_ul().empty(); }
|
|||
|
+ this.load_node(obj, function () { _this.__callback({ "obj" : obj}); _this.reload_nodes(); });
|
|||
|
+ },
|
|||
|
+ // Dummy function to fire after the first load (so that there is a jstree.loaded event)
|
|||
|
+ loaded : function () {
|
|||
|
+ this.__callback();
|
|||
|
+ },
|
|||
|
+ // deal with focus
|
|||
|
+ set_focus : function () {
|
|||
|
+ if(this.is_focused()) { return; }
|
|||
|
+ var f = $.jstree._focused();
|
|||
|
+ if(f) { f.unset_focus(); }
|
|||
|
+
|
|||
|
+ this.get_container().addClass("jstree-focused");
|
|||
|
+ focused_instance = this.get_index();
|
|||
|
+ this.__callback();
|
|||
|
+ },
|
|||
|
+ is_focused : function () {
|
|||
|
+ return focused_instance == this.get_index();
|
|||
|
+ },
|
|||
|
+ unset_focus : function () {
|
|||
|
+ if(this.is_focused()) {
|
|||
|
+ this.get_container().removeClass("jstree-focused");
|
|||
|
+ focused_instance = -1;
|
|||
|
+ }
|
|||
|
+ this.__callback();
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ // traverse
|
|||
|
+ _get_node : function (obj) {
|
|||
|
+ var $obj = $(obj, this.get_container());
|
|||
|
+ if($obj.is(".jstree") || obj == -1) { return -1; }
|
|||
|
+ $obj = $obj.closest("li", this.get_container());
|
|||
|
+ return $obj.length ? $obj : false;
|
|||
|
+ },
|
|||
|
+ _get_next : function (obj, strict) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(obj === -1) { return this.get_container().find("> ul > li:first-child"); }
|
|||
|
+ if(!obj.length) { return false; }
|
|||
|
+ if(strict) { return (obj.nextAll("li").size() > 0) ? obj.nextAll("li:eq(0)") : false; }
|
|||
|
+
|
|||
|
+ if(obj.hasClass("jstree-open")) { return obj.find("li:eq(0)"); }
|
|||
|
+ else if(obj.nextAll("li").size() > 0) { return obj.nextAll("li:eq(0)"); }
|
|||
|
+ else { return obj.parentsUntil(".jstree","li").next("li").eq(0); }
|
|||
|
+ },
|
|||
|
+ _get_prev : function (obj, strict) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(obj === -1) { return this.get_container().find("> ul > li:last-child"); }
|
|||
|
+ if(!obj.length) { return false; }
|
|||
|
+ if(strict) { return (obj.prevAll("li").length > 0) ? obj.prevAll("li:eq(0)") : false; }
|
|||
|
+
|
|||
|
+ if(obj.prev("li").length) {
|
|||
|
+ obj = obj.prev("li").eq(0);
|
|||
|
+ while(obj.hasClass("jstree-open")) { obj = obj.children("ul:eq(0)").children("li:last"); }
|
|||
|
+ return obj;
|
|||
|
+ }
|
|||
|
+ else { var o = obj.parentsUntil(".jstree","li:eq(0)"); return o.length ? o : false; }
|
|||
|
+ },
|
|||
|
+ _get_parent : function (obj) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(obj == -1 || !obj.length) { return false; }
|
|||
|
+ var o = obj.parentsUntil(".jstree", "li:eq(0)");
|
|||
|
+ return o.length ? o : -1;
|
|||
|
+ },
|
|||
|
+ _get_children : function (obj) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(obj === -1) { return this.get_container().children("ul:eq(0)").children("li"); }
|
|||
|
+ if(!obj.length) { return false; }
|
|||
|
+ return obj.children("ul:eq(0)").children("li");
|
|||
|
+ },
|
|||
|
+ get_path : function (obj, id_mode) {
|
|||
|
+ var p = [],
|
|||
|
+ _this = this;
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(obj === -1 || !obj || !obj.length) { return false; }
|
|||
|
+ obj.parentsUntil(".jstree", "li").each(function () {
|
|||
|
+ p.push( id_mode ? this.id : _this.get_text(this) );
|
|||
|
+ });
|
|||
|
+ p.reverse();
|
|||
|
+ p.push( id_mode ? obj.attr("id") : this.get_text(obj) );
|
|||
|
+ return p;
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ // string functions
|
|||
|
+ _get_string : function (key) {
|
|||
|
+ return this._get_settings().core.strings[key] || key;
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ is_open : function (obj) { obj = this._get_node(obj); return obj && obj !== -1 && obj.hasClass("jstree-open"); },
|
|||
|
+ is_closed : function (obj) { obj = this._get_node(obj); return obj && obj !== -1 && obj.hasClass("jstree-closed"); },
|
|||
|
+ is_leaf : function (obj) { obj = this._get_node(obj); return obj && obj !== -1 && obj.hasClass("jstree-leaf"); },
|
|||
|
+ correct_state : function (obj) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(!obj || obj === -1) { return false; }
|
|||
|
+ obj.removeClass("jstree-closed jstree-open").addClass("jstree-leaf").children("ul").remove();
|
|||
|
+ this.__callback({ "obj" : obj });
|
|||
|
+ },
|
|||
|
+ // open/close
|
|||
|
+ open_node : function (obj, callback, skip_animation) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(!obj.length) { return false; }
|
|||
|
+ if(!obj.hasClass("jstree-closed")) { if(callback) { callback.call(); } return false; }
|
|||
|
+ var s = skip_animation || is_ie6 ? 0 : this._get_settings().core.animation,
|
|||
|
+ t = this;
|
|||
|
+ if(!this._is_loaded(obj)) {
|
|||
|
+ obj.children("a").addClass("jstree-loading");
|
|||
|
+ this.load_node(obj, function () { t.open_node(obj, callback, skip_animation); }, callback);
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(this._get_settings().core.open_parents) {
|
|||
|
+ obj.parentsUntil(".jstree",".jstree-closed").each(function () {
|
|||
|
+ t.open_node(this, false, true);
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ if(s) { obj.children("ul").css("display","none"); }
|
|||
|
+ obj.removeClass("jstree-closed").addClass("jstree-open").children("a").removeClass("jstree-loading");
|
|||
|
+ if(s) { obj.children("ul").stop(true, true).slideDown(s, function () { this.style.display = ""; t.after_open(obj); }); }
|
|||
|
+ else { t.after_open(obj); }
|
|||
|
+ this.__callback({ "obj" : obj });
|
|||
|
+ if(callback) { callback.call(); }
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ after_open : function (obj) { this.__callback({ "obj" : obj }); },
|
|||
|
+ close_node : function (obj, skip_animation) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ var s = skip_animation || is_ie6 ? 0 : this._get_settings().core.animation,
|
|||
|
+ t = this;
|
|||
|
+ if(!obj.length || !obj.hasClass("jstree-open")) { return false; }
|
|||
|
+ if(s) { obj.children("ul").attr("style","display:block !important"); }
|
|||
|
+ obj.removeClass("jstree-open").addClass("jstree-closed");
|
|||
|
+ if(s) { obj.children("ul").stop(true, true).slideUp(s, function () { this.style.display = ""; t.after_close(obj); }); }
|
|||
|
+ else { t.after_close(obj); }
|
|||
|
+ this.__callback({ "obj" : obj });
|
|||
|
+ },
|
|||
|
+ after_close : function (obj) { this.__callback({ "obj" : obj }); },
|
|||
|
+ toggle_node : function (obj) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(obj.hasClass("jstree-closed")) { return this.open_node(obj); }
|
|||
|
+ if(obj.hasClass("jstree-open")) { return this.close_node(obj); }
|
|||
|
+ },
|
|||
|
+ open_all : function (obj, do_animation, original_obj) {
|
|||
|
+ obj = obj ? this._get_node(obj) : -1;
|
|||
|
+ if(!obj || obj === -1) { obj = this.get_container_ul(); }
|
|||
|
+ if(original_obj) {
|
|||
|
+ obj = obj.find("li.jstree-closed");
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ original_obj = obj;
|
|||
|
+ if(obj.is(".jstree-closed")) { obj = obj.find("li.jstree-closed").andSelf(); }
|
|||
|
+ else { obj = obj.find("li.jstree-closed"); }
|
|||
|
+ }
|
|||
|
+ var _this = this;
|
|||
|
+ obj.each(function () {
|
|||
|
+ var __this = this;
|
|||
|
+ if(!_this._is_loaded(this)) { _this.open_node(this, function() { _this.open_all(__this, do_animation, original_obj); }, !do_animation); }
|
|||
|
+ else { _this.open_node(this, false, !do_animation); }
|
|||
|
+ });
|
|||
|
+ // so that callback is fired AFTER all nodes are open
|
|||
|
+ if(original_obj.find('li.jstree-closed').length === 0) { this.__callback({ "obj" : original_obj }); }
|
|||
|
+ },
|
|||
|
+ close_all : function (obj, do_animation) {
|
|||
|
+ var _this = this;
|
|||
|
+ obj = obj ? this._get_node(obj) : this.get_container();
|
|||
|
+ if(!obj || obj === -1) { obj = this.get_container_ul(); }
|
|||
|
+ obj.find("li.jstree-open").andSelf().each(function () { _this.close_node(this, !do_animation); });
|
|||
|
+ this.__callback({ "obj" : obj });
|
|||
|
+ },
|
|||
|
+ clean_node : function (obj) {
|
|||
|
+ obj = obj && obj != -1 ? $(obj) : this.get_container_ul();
|
|||
|
+ obj = obj.is("li") ? obj.find("li").andSelf() : obj.find("li");
|
|||
|
+ obj.removeClass("jstree-last")
|
|||
|
+ .filter("li:last-child").addClass("jstree-last").end()
|
|||
|
+ .filter(":has(li)")
|
|||
|
+ .not(".jstree-open").removeClass("jstree-leaf").addClass("jstree-closed");
|
|||
|
+ obj.not(".jstree-open, .jstree-closed").addClass("jstree-leaf").children("ul").remove();
|
|||
|
+ this.__callback({ "obj" : obj });
|
|||
|
+ },
|
|||
|
+ // rollback
|
|||
|
+ get_rollback : function () {
|
|||
|
+ this.__callback();
|
|||
|
+ return { i : this.get_index(), h : this.get_container().children("ul").clone(true), d : this.data };
|
|||
|
+ },
|
|||
|
+ set_rollback : function (html, data) {
|
|||
|
+ this.get_container().empty().append(html);
|
|||
|
+ this.data = data;
|
|||
|
+ this.__callback();
|
|||
|
+ },
|
|||
|
+ // Dummy functions to be overwritten by any datastore plugin included
|
|||
|
+ load_node : function (obj, s_call, e_call) { this.__callback({ "obj" : obj }); },
|
|||
|
+ _is_loaded : function (obj) { return true; },
|
|||
|
+
|
|||
|
+ // Basic operations: create
|
|||
|
+ create_node : function (obj, position, js, callback, is_loaded) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ position = typeof position === "undefined" ? "last" : position;
|
|||
|
+ var d = $("<li />"),
|
|||
|
+ s = this._get_settings().core,
|
|||
|
+ tmp;
|
|||
|
+
|
|||
|
+ if(obj !== -1 && !obj.length) { return false; }
|
|||
|
+ if(!is_loaded && !this._is_loaded(obj)) { this.load_node(obj, function () { this.create_node(obj, position, js, callback, true); }); return false; }
|
|||
|
+
|
|||
|
+ this.__rollback();
|
|||
|
+
|
|||
|
+ if(typeof js === "string") { js = { "data" : js }; }
|
|||
|
+ if(!js) { js = {}; }
|
|||
|
+ if(js.attr) { d.attr(js.attr); }
|
|||
|
+ if(js.metadata) { d.data(js.metadata); }
|
|||
|
+ if(js.state) { d.addClass("jstree-" + js.state); }
|
|||
|
+ if(!js.data) { js.data = this._get_string("new_node"); }
|
|||
|
+ if(!$.isArray(js.data)) { tmp = js.data; js.data = []; js.data.push(tmp); }
|
|||
|
+ $.each(js.data, function (i, m) {
|
|||
|
+ tmp = $("<a />");
|
|||
|
+ if($.isFunction(m)) { m = m.call(this, js); }
|
|||
|
+ if(typeof m == "string") { tmp.attr('href','#')[ s.html_titles ? "html" : "text" ](m); }
|
|||
|
+ else {
|
|||
|
+ if(!m.attr) { m.attr = {}; }
|
|||
|
+ if(!m.attr.href) { m.attr.href = '#'; }
|
|||
|
+ tmp.attr(m.attr)[ s.html_titles ? "html" : "text" ](m.title);
|
|||
|
+ if(m.language) { tmp.addClass(m.language); }
|
|||
|
+ }
|
|||
|
+ tmp.prepend("<ins class='jstree-icon'> </ins>");
|
|||
|
+ if(!m.icon && js.icon) { m.icon = js.icon; }
|
|||
|
+ if(m.icon) {
|
|||
|
+ if(m.icon.indexOf("/") === -1) { tmp.children("ins").addClass(m.icon); }
|
|||
|
+ else { tmp.children("ins").css("background","url('" + m.icon + "') center center no-repeat"); }
|
|||
|
+ }
|
|||
|
+ d.append(tmp);
|
|||
|
+ });
|
|||
|
+ d.prepend("<ins class='jstree-icon'> </ins>");
|
|||
|
+ if(obj === -1) {
|
|||
|
+ obj = this.get_container();
|
|||
|
+ if(position === "before") { position = "first"; }
|
|||
|
+ if(position === "after") { position = "last"; }
|
|||
|
+ }
|
|||
|
+ switch(position) {
|
|||
|
+ case "before": obj.before(d); tmp = this._get_parent(obj); break;
|
|||
|
+ case "after" : obj.after(d); tmp = this._get_parent(obj); break;
|
|||
|
+ case "inside":
|
|||
|
+ case "first" :
|
|||
|
+ if(!obj.children("ul").length) { obj.append("<ul />"); }
|
|||
|
+ obj.children("ul").prepend(d);
|
|||
|
+ tmp = obj;
|
|||
|
+ break;
|
|||
|
+ case "last":
|
|||
|
+ if(!obj.children("ul").length) { obj.append("<ul />"); }
|
|||
|
+ obj.children("ul").append(d);
|
|||
|
+ tmp = obj;
|
|||
|
+ break;
|
|||
|
+ default:
|
|||
|
+ if(!obj.children("ul").length) { obj.append("<ul />"); }
|
|||
|
+ if(!position) { position = 0; }
|
|||
|
+ tmp = obj.children("ul").children("li").eq(position);
|
|||
|
+ if(tmp.length) { tmp.before(d); }
|
|||
|
+ else { obj.children("ul").append(d); }
|
|||
|
+ tmp = obj;
|
|||
|
+ break;
|
|||
|
+ }
|
|||
|
+ if(tmp === -1 || tmp.get(0) === this.get_container().get(0)) { tmp = -1; }
|
|||
|
+ this.clean_node(tmp);
|
|||
|
+ this.__callback({ "obj" : d, "parent" : tmp });
|
|||
|
+ if(callback) { callback.call(this, d); }
|
|||
|
+ return d;
|
|||
|
+ },
|
|||
|
+ // Basic operations: rename (deal with text)
|
|||
|
+ get_text : function (obj) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(!obj.length) { return false; }
|
|||
|
+ var s = this._get_settings().core.html_titles;
|
|||
|
+ obj = obj.children("a:eq(0)");
|
|||
|
+ if(s) {
|
|||
|
+ obj = obj.clone();
|
|||
|
+ obj.children("INS").remove();
|
|||
|
+ return obj.html();
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ obj = obj.contents().filter(function() { return this.nodeType == 3; })[0];
|
|||
|
+ return obj.nodeValue;
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ set_text : function (obj, val) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(!obj.length) { return false; }
|
|||
|
+ obj = obj.children("a:eq(0)");
|
|||
|
+ if(this._get_settings().core.html_titles) {
|
|||
|
+ var tmp = obj.children("INS").clone();
|
|||
|
+ obj.html(val).prepend(tmp);
|
|||
|
+ this.__callback({ "obj" : obj, "name" : val });
|
|||
|
+ return true;
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ obj = obj.contents().filter(function() { return this.nodeType == 3; })[0];
|
|||
|
+ this.__callback({ "obj" : obj, "name" : val });
|
|||
|
+ return (obj.nodeValue = val);
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ rename_node : function (obj, val) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ this.__rollback();
|
|||
|
+ if(obj && obj.length && this.set_text.apply(this, Array.prototype.slice.call(arguments))) { this.__callback({ "obj" : obj, "name" : val }); }
|
|||
|
+ },
|
|||
|
+ // Basic operations: deleting nodes
|
|||
|
+ delete_node : function (obj) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(!obj.length) { return false; }
|
|||
|
+ this.__rollback();
|
|||
|
+ var p = this._get_parent(obj), prev = $([]), t = this;
|
|||
|
+ obj.each(function () {
|
|||
|
+ prev = prev.add(t._get_prev(this));
|
|||
|
+ });
|
|||
|
+ obj = obj.detach();
|
|||
|
+ if(p !== -1 && p.find("> ul > li").length === 0) {
|
|||
|
+ p.removeClass("jstree-open jstree-closed").addClass("jstree-leaf");
|
|||
|
+ }
|
|||
|
+ this.clean_node(p);
|
|||
|
+ this.__callback({ "obj" : obj, "prev" : prev, "parent" : p });
|
|||
|
+ return obj;
|
|||
|
+ },
|
|||
|
+ prepare_move : function (o, r, pos, cb, is_cb) {
|
|||
|
+ var p = {};
|
|||
|
+
|
|||
|
+ p.ot = $.jstree._reference(o) || this;
|
|||
|
+ p.o = p.ot._get_node(o);
|
|||
|
+ p.r = r === - 1 ? -1 : this._get_node(r);
|
|||
|
+ p.p = (typeof pos === "undefined" || pos === false) ? "last" : pos; // TODO: move to a setting
|
|||
|
+ if(!is_cb && prepared_move.o && prepared_move.o[0] === p.o[0] && prepared_move.r[0] === p.r[0] && prepared_move.p === p.p) {
|
|||
|
+ this.__callback(prepared_move);
|
|||
|
+ if(cb) { cb.call(this, prepared_move); }
|
|||
|
+ return;
|
|||
|
+ }
|
|||
|
+ p.ot = $.jstree._reference(p.o) || this;
|
|||
|
+ p.rt = $.jstree._reference(p.r) || this; // r === -1 ? p.ot : $.jstree._reference(p.r) || this
|
|||
|
+ if(p.r === -1 || !p.r) {
|
|||
|
+ p.cr = -1;
|
|||
|
+ switch(p.p) {
|
|||
|
+ case "first":
|
|||
|
+ case "before":
|
|||
|
+ case "inside":
|
|||
|
+ p.cp = 0;
|
|||
|
+ break;
|
|||
|
+ case "after":
|
|||
|
+ case "last":
|
|||
|
+ p.cp = p.rt.get_container().find(" > ul > li").length;
|
|||
|
+ break;
|
|||
|
+ default:
|
|||
|
+ p.cp = p.p;
|
|||
|
+ break;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(!/^(before|after)$/.test(p.p) && !this._is_loaded(p.r)) {
|
|||
|
+ return this.load_node(p.r, function () { this.prepare_move(o, r, pos, cb, true); });
|
|||
|
+ }
|
|||
|
+ switch(p.p) {
|
|||
|
+ case "before":
|
|||
|
+ p.cp = p.r.index();
|
|||
|
+ p.cr = p.rt._get_parent(p.r);
|
|||
|
+ break;
|
|||
|
+ case "after":
|
|||
|
+ p.cp = p.r.index() + 1;
|
|||
|
+ p.cr = p.rt._get_parent(p.r);
|
|||
|
+ break;
|
|||
|
+ case "inside":
|
|||
|
+ case "first":
|
|||
|
+ p.cp = 0;
|
|||
|
+ p.cr = p.r;
|
|||
|
+ break;
|
|||
|
+ case "last":
|
|||
|
+ p.cp = p.r.find(" > ul > li").length;
|
|||
|
+ p.cr = p.r;
|
|||
|
+ break;
|
|||
|
+ default:
|
|||
|
+ p.cp = p.p;
|
|||
|
+ p.cr = p.r;
|
|||
|
+ break;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ p.np = p.cr == -1 ? p.rt.get_container() : p.cr;
|
|||
|
+ p.op = p.ot._get_parent(p.o);
|
|||
|
+ p.cop = p.o.index();
|
|||
|
+ if(p.op === -1) { p.op = p.ot ? p.ot.get_container() : this.get_container(); }
|
|||
|
+ if(!/^(before|after)$/.test(p.p) && p.op && p.np && p.op[0] === p.np[0] && p.o.index() < p.cp) { p.cp++; }
|
|||
|
+ //if(p.p === "before" && p.op && p.np && p.op[0] === p.np[0] && p.o.index() < p.cp) { p.cp--; }
|
|||
|
+ p.or = p.np.find(" > ul > li:nth-child(" + (p.cp + 1) + ")");
|
|||
|
+ prepared_move = p;
|
|||
|
+ this.__callback(prepared_move);
|
|||
|
+ if(cb) { cb.call(this, prepared_move); }
|
|||
|
+ },
|
|||
|
+ check_move : function () {
|
|||
|
+ var obj = prepared_move, ret = true, r = obj.r === -1 ? this.get_container() : obj.r;
|
|||
|
+ if(!obj || !obj.o || obj.or[0] === obj.o[0]) { return false; }
|
|||
|
+ if(obj.op && obj.np && obj.op[0] === obj.np[0] && obj.cp - 1 === obj.o.index()) { return false; }
|
|||
|
+ obj.o.each(function () {
|
|||
|
+ if(r.parentsUntil(".jstree", "li").andSelf().index(this) !== -1) { ret = false; return false; }
|
|||
|
+ });
|
|||
|
+ return ret;
|
|||
|
+ },
|
|||
|
+ move_node : function (obj, ref, position, is_copy, is_prepared, skip_check) {
|
|||
|
+ if(!is_prepared) {
|
|||
|
+ return this.prepare_move(obj, ref, position, function (p) {
|
|||
|
+ this.move_node(p, false, false, is_copy, true, skip_check);
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ if(is_copy) {
|
|||
|
+ prepared_move.cy = true;
|
|||
|
+ }
|
|||
|
+ if(!skip_check && !this.check_move()) { return false; }
|
|||
|
+
|
|||
|
+ this.__rollback();
|
|||
|
+ var o = false;
|
|||
|
+ if(is_copy) {
|
|||
|
+ o = obj.o.clone(true);
|
|||
|
+ o.find("*[id]").andSelf().each(function () {
|
|||
|
+ if(this.id) { this.id = "copy_" + this.id; }
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ else { o = obj.o; }
|
|||
|
+
|
|||
|
+ if(obj.or.length) { obj.or.before(o); }
|
|||
|
+ else {
|
|||
|
+ if(!obj.np.children("ul").length) { $("<ul />").appendTo(obj.np); }
|
|||
|
+ obj.np.children("ul:eq(0)").append(o);
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ try {
|
|||
|
+ obj.ot.clean_node(obj.op);
|
|||
|
+ obj.rt.clean_node(obj.np);
|
|||
|
+ if(!obj.op.find("> ul > li").length) {
|
|||
|
+ obj.op.removeClass("jstree-open jstree-closed").addClass("jstree-leaf").children("ul").remove();
|
|||
|
+ }
|
|||
|
+ } catch (e) { }
|
|||
|
+
|
|||
|
+ if(is_copy) {
|
|||
|
+ prepared_move.cy = true;
|
|||
|
+ prepared_move.oc = o;
|
|||
|
+ }
|
|||
|
+ this.__callback(prepared_move);
|
|||
|
+ return prepared_move;
|
|||
|
+ },
|
|||
|
+ _get_move : function () { return prepared_move; }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+})(jQuery);
|
|||
|
+//*/
|
|||
|
+
|
|||
|
+/*
|
|||
|
+ * jsTree ui plugin
|
|||
|
+ * This plugins handles selecting/deselecting/hovering/dehovering nodes
|
|||
|
+ */
|
|||
|
+(function ($) {
|
|||
|
+ var scrollbar_width, e1, e2;
|
|||
|
+ $(function() {
|
|||
|
+ if (/msie/.test(navigator.userAgent.toLowerCase())) {
|
|||
|
+ e1 = $('<textarea cols="10" rows="2"></textarea>').css({ position: 'absolute', top: -1000, left: 0 }).appendTo('body');
|
|||
|
+ e2 = $('<textarea cols="10" rows="2" style="overflow: hidden;"></textarea>').css({ position: 'absolute', top: -1000, left: 0 }).appendTo('body');
|
|||
|
+ scrollbar_width = e1.width() - e2.width();
|
|||
|
+ e1.add(e2).remove();
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ e1 = $('<div />').css({ width: 100, height: 100, overflow: 'auto', position: 'absolute', top: -1000, left: 0 })
|
|||
|
+ .prependTo('body').append('<div />').find('div').css({ width: '100%', height: 200 });
|
|||
|
+ scrollbar_width = 100 - e1.width();
|
|||
|
+ e1.parent().remove();
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ $.jstree.plugin("ui", {
|
|||
|
+ __init : function () {
|
|||
|
+ this.data.ui.selected = $();
|
|||
|
+ this.data.ui.last_selected = false;
|
|||
|
+ this.data.ui.hovered = null;
|
|||
|
+ this.data.ui.to_select = this.get_settings().ui.initially_select;
|
|||
|
+
|
|||
|
+ this.get_container()
|
|||
|
+ .delegate("a", "click.jstree", $.proxy(function (event) {
|
|||
|
+ event.preventDefault();
|
|||
|
+ event.currentTarget.blur();
|
|||
|
+ if(!$(event.currentTarget).hasClass("jstree-loading")) {
|
|||
|
+ this.select_node(event.currentTarget, true, event);
|
|||
|
+ }
|
|||
|
+ }, this))
|
|||
|
+ .delegate("a", "mouseenter.jstree", $.proxy(function (event) {
|
|||
|
+ if(!$(event.currentTarget).hasClass("jstree-loading")) {
|
|||
|
+ this.hover_node(event.target);
|
|||
|
+ }
|
|||
|
+ }, this))
|
|||
|
+ .delegate("a", "mouseleave.jstree", $.proxy(function (event) {
|
|||
|
+ if(!$(event.currentTarget).hasClass("jstree-loading")) {
|
|||
|
+ this.dehover_node(event.target);
|
|||
|
+ }
|
|||
|
+ }, this))
|
|||
|
+ .bind("reopen.jstree", $.proxy(function () {
|
|||
|
+ this.reselect();
|
|||
|
+ }, this))
|
|||
|
+ .bind("get_rollback.jstree", $.proxy(function () {
|
|||
|
+ this.dehover_node();
|
|||
|
+ this.save_selected();
|
|||
|
+ }, this))
|
|||
|
+ .bind("set_rollback.jstree", $.proxy(function () {
|
|||
|
+ this.reselect();
|
|||
|
+ }, this))
|
|||
|
+ .bind("close_node.jstree", $.proxy(function (event, data) {
|
|||
|
+ var s = this._get_settings().ui,
|
|||
|
+ obj = this._get_node(data.rslt.obj),
|
|||
|
+ clk = (obj && obj.length) ? obj.children("ul").find("a.jstree-clicked") : $(),
|
|||
|
+ _this = this;
|
|||
|
+ if(s.selected_parent_close === false || !clk.length) { return; }
|
|||
|
+ clk.each(function () {
|
|||
|
+ _this.deselect_node(this);
|
|||
|
+ if(s.selected_parent_close === "select_parent") { _this.select_node(obj); }
|
|||
|
+ });
|
|||
|
+ }, this))
|
|||
|
+ .bind("delete_node.jstree", $.proxy(function (event, data) {
|
|||
|
+ var s = this._get_settings().ui.select_prev_on_delete,
|
|||
|
+ obj = this._get_node(data.rslt.obj),
|
|||
|
+ clk = (obj && obj.length) ? obj.find("a.jstree-clicked") : [],
|
|||
|
+ _this = this;
|
|||
|
+ clk.each(function () { _this.deselect_node(this); });
|
|||
|
+ if(s && clk.length) {
|
|||
|
+ data.rslt.prev.each(function () {
|
|||
|
+ if(this.parentNode) { _this.select_node(this); return false; /* if return false is removed all prev nodes will be selected */}
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ }, this))
|
|||
|
+ .bind("move_node.jstree", $.proxy(function (event, data) {
|
|||
|
+ if(data.rslt.cy) {
|
|||
|
+ data.rslt.oc.find("a.jstree-clicked").removeClass("jstree-clicked");
|
|||
|
+ }
|
|||
|
+ }, this));
|
|||
|
+ },
|
|||
|
+ defaults : {
|
|||
|
+ select_limit : -1, // 0, 1, 2 ... or -1 for unlimited
|
|||
|
+ select_multiple_modifier : "ctrl", // on, or ctrl, shift, alt
|
|||
|
+ select_range_modifier : "shift",
|
|||
|
+ selected_parent_close : "select_parent", // false, "deselect", "select_parent"
|
|||
|
+ selected_parent_open : true,
|
|||
|
+ select_prev_on_delete : true,
|
|||
|
+ disable_selecting_children : false,
|
|||
|
+ initially_select : []
|
|||
|
+ },
|
|||
|
+ _fn : {
|
|||
|
+ _get_node : function (obj, allow_multiple) {
|
|||
|
+ if(typeof obj === "undefined" || obj === null) { return allow_multiple ? this.data.ui.selected : this.data.ui.last_selected; }
|
|||
|
+ var $obj = $(obj, this.get_container());
|
|||
|
+ if($obj.is(".jstree") || obj == -1) { return -1; }
|
|||
|
+ $obj = $obj.closest("li", this.get_container());
|
|||
|
+ return $obj.length ? $obj : false;
|
|||
|
+ },
|
|||
|
+ _ui_notify : function (n, data) {
|
|||
|
+ if(data.selected) {
|
|||
|
+ this.select_node(n, false);
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ save_selected : function () {
|
|||
|
+ var _this = this;
|
|||
|
+ this.data.ui.to_select = [];
|
|||
|
+ this.data.ui.selected.each(function () { if(this.id) { _this.data.ui.to_select.push("#" + this.id.toString().replace(/^#/,"").replace(/\\\//g,"/").replace(/\//g,"\\\/").replace(/\\\./g,".").replace(/\./g,"\\.").replace(/\:/g,"\\:")); } });
|
|||
|
+ this.__callback(this.data.ui.to_select);
|
|||
|
+ },
|
|||
|
+ reselect : function () {
|
|||
|
+ var _this = this,
|
|||
|
+ s = this.data.ui.to_select;
|
|||
|
+ s = $.map($.makeArray(s), function (n) { return "#" + n.toString().replace(/^#/,"").replace(/\\\//g,"/").replace(/\//g,"\\\/").replace(/\\\./g,".").replace(/\./g,"\\.").replace(/\:/g,"\\:"); });
|
|||
|
+ // this.deselect_all(); WHY deselect, breaks plugin state notifier?
|
|||
|
+ $.each(s, function (i, val) { if(val && val !== "#") { _this.select_node(val); } });
|
|||
|
+ this.data.ui.selected = this.data.ui.selected.filter(function () { return this.parentNode; });
|
|||
|
+ this.__callback();
|
|||
|
+ },
|
|||
|
+ refresh : function (obj) {
|
|||
|
+ this.save_selected();
|
|||
|
+ return this.__call_old();
|
|||
|
+ },
|
|||
|
+ hover_node : function (obj) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(!obj.length) { return false; }
|
|||
|
+ //if(this.data.ui.hovered && obj.get(0) === this.data.ui.hovered.get(0)) { return; }
|
|||
|
+ if(!obj.hasClass("jstree-hovered")) { this.dehover_node(); }
|
|||
|
+ this.data.ui.hovered = obj.children("a").addClass("jstree-hovered").parent();
|
|||
|
+ this._fix_scroll(obj);
|
|||
|
+ this.__callback({ "obj" : obj });
|
|||
|
+ },
|
|||
|
+ dehover_node : function () {
|
|||
|
+ var obj = this.data.ui.hovered, p;
|
|||
|
+ if(!obj || !obj.length) { return false; }
|
|||
|
+ p = obj.children("a").removeClass("jstree-hovered").parent();
|
|||
|
+ if(this.data.ui.hovered[0] === p[0]) { this.data.ui.hovered = null; }
|
|||
|
+ this.__callback({ "obj" : obj });
|
|||
|
+ },
|
|||
|
+ select_node : function (obj, check, e) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(obj == -1 || !obj || !obj.length) { return false; }
|
|||
|
+ var s = this._get_settings().ui,
|
|||
|
+ is_multiple = (s.select_multiple_modifier == "on" || (s.select_multiple_modifier !== false && e && e[s.select_multiple_modifier + "Key"])),
|
|||
|
+ is_range = (s.select_range_modifier !== false && e && e[s.select_range_modifier + "Key"] && this.data.ui.last_selected && this.data.ui.last_selected[0] !== obj[0] && this.data.ui.last_selected.parent()[0] === obj.parent()[0]),
|
|||
|
+ is_selected = this.is_selected(obj),
|
|||
|
+ proceed = true,
|
|||
|
+ t = this;
|
|||
|
+ if(check) {
|
|||
|
+ if(s.disable_selecting_children && is_multiple &&
|
|||
|
+ (
|
|||
|
+ (obj.parentsUntil(".jstree","li").children("a.jstree-clicked").length) ||
|
|||
|
+ (obj.children("ul").find("a.jstree-clicked:eq(0)").length)
|
|||
|
+ )
|
|||
|
+ ) {
|
|||
|
+ return false;
|
|||
|
+ }
|
|||
|
+ proceed = false;
|
|||
|
+ switch(!0) {
|
|||
|
+ case (is_range):
|
|||
|
+ this.data.ui.last_selected.addClass("jstree-last-selected");
|
|||
|
+ obj = obj[ obj.index() < this.data.ui.last_selected.index() ? "nextUntil" : "prevUntil" ](".jstree-last-selected").andSelf();
|
|||
|
+ if(s.select_limit == -1 || obj.length < s.select_limit) {
|
|||
|
+ this.data.ui.last_selected.removeClass("jstree-last-selected");
|
|||
|
+ this.data.ui.selected.each(function () {
|
|||
|
+ if(this !== t.data.ui.last_selected[0]) { t.deselect_node(this); }
|
|||
|
+ });
|
|||
|
+ is_selected = false;
|
|||
|
+ proceed = true;
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ proceed = false;
|
|||
|
+ }
|
|||
|
+ break;
|
|||
|
+ case (is_selected && !is_multiple):
|
|||
|
+ this.deselect_all();
|
|||
|
+ is_selected = false;
|
|||
|
+ proceed = true;
|
|||
|
+ break;
|
|||
|
+ case (!is_selected && !is_multiple):
|
|||
|
+ if(s.select_limit == -1 || s.select_limit > 0) {
|
|||
|
+ this.deselect_all();
|
|||
|
+ proceed = true;
|
|||
|
+ }
|
|||
|
+ break;
|
|||
|
+ case (is_selected && is_multiple):
|
|||
|
+ this.deselect_node(obj);
|
|||
|
+ break;
|
|||
|
+ case (!is_selected && is_multiple):
|
|||
|
+ if(s.select_limit == -1 || this.data.ui.selected.length + 1 <= s.select_limit) {
|
|||
|
+ proceed = true;
|
|||
|
+ }
|
|||
|
+ break;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ if(proceed && !is_selected) {
|
|||
|
+ if(!is_range) { this.data.ui.last_selected = obj; }
|
|||
|
+ obj.children("a").addClass("jstree-clicked");
|
|||
|
+ if(s.selected_parent_open) {
|
|||
|
+ obj.parents(".jstree-closed").each(function () { t.open_node(this, false, true); });
|
|||
|
+ }
|
|||
|
+ this.data.ui.selected = this.data.ui.selected.add(obj);
|
|||
|
+ this._fix_scroll(obj.eq(0));
|
|||
|
+ this.__callback({ "obj" : obj, "e" : e });
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ _fix_scroll : function (obj) {
|
|||
|
+ var c = this.get_container()[0], t;
|
|||
|
+ if(c.scrollHeight > c.offsetHeight) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(!obj || obj === -1 || !obj.length || !obj.is(":visible")) { return; }
|
|||
|
+ t = obj.offset().top - this.get_container().offset().top;
|
|||
|
+ if(t < 0) {
|
|||
|
+ c.scrollTop = c.scrollTop + t - 1;
|
|||
|
+ }
|
|||
|
+ if(t + this.data.core.li_height + (c.scrollWidth > c.offsetWidth ? scrollbar_width : 0) > c.offsetHeight) {
|
|||
|
+ c.scrollTop = c.scrollTop + (t - c.offsetHeight + this.data.core.li_height + 1 + (c.scrollWidth > c.offsetWidth ? scrollbar_width : 0));
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ deselect_node : function (obj) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(!obj.length) { return false; }
|
|||
|
+ if(this.is_selected(obj)) {
|
|||
|
+ obj.children("a").removeClass("jstree-clicked");
|
|||
|
+ this.data.ui.selected = this.data.ui.selected.not(obj);
|
|||
|
+ if(this.data.ui.last_selected.get(0) === obj.get(0)) { this.data.ui.last_selected = this.data.ui.selected.eq(0); }
|
|||
|
+ this.__callback({ "obj" : obj });
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ toggle_select : function (obj) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(!obj.length) { return false; }
|
|||
|
+ if(this.is_selected(obj)) { this.deselect_node(obj); }
|
|||
|
+ else { this.select_node(obj); }
|
|||
|
+ },
|
|||
|
+ is_selected : function (obj) { return this.data.ui.selected.index(this._get_node(obj)) >= 0; },
|
|||
|
+ get_selected : function (context) {
|
|||
|
+ return context ? $(context).find("a.jstree-clicked").parent() : this.data.ui.selected;
|
|||
|
+ },
|
|||
|
+ deselect_all : function (context) {
|
|||
|
+ var ret = context ? $(context).find("a.jstree-clicked").parent() : this.get_container().find("a.jstree-clicked").parent();
|
|||
|
+ ret.children("a.jstree-clicked").removeClass("jstree-clicked");
|
|||
|
+ this.data.ui.selected = $([]);
|
|||
|
+ this.data.ui.last_selected = false;
|
|||
|
+ this.__callback({ "obj" : ret });
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ // include the selection plugin by default
|
|||
|
+ $.jstree.defaults.plugins.push("ui");
|
|||
|
+})(jQuery);
|
|||
|
+//*/
|
|||
|
+
|
|||
|
+/*
|
|||
|
+ * jsTree CRRM plugin
|
|||
|
+ * Handles creating/renaming/removing/moving nodes by user interaction.
|
|||
|
+ */
|
|||
|
+(function ($) {
|
|||
|
+ $.jstree.plugin("crrm", {
|
|||
|
+ __init : function () {
|
|||
|
+ this.get_container()
|
|||
|
+ .bind("move_node.jstree", $.proxy(function (e, data) {
|
|||
|
+ if(this._get_settings().crrm.move.open_onmove) {
|
|||
|
+ var t = this;
|
|||
|
+ data.rslt.np.parentsUntil(".jstree").andSelf().filter(".jstree-closed").each(function () {
|
|||
|
+ t.open_node(this, false, true);
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ }, this));
|
|||
|
+ },
|
|||
|
+ defaults : {
|
|||
|
+ input_width_limit : 200,
|
|||
|
+ move : {
|
|||
|
+ always_copy : false, // false, true or "multitree"
|
|||
|
+ open_onmove : true,
|
|||
|
+ default_position : "last",
|
|||
|
+ check_move : function (m) { return true; }
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ _fn : {
|
|||
|
+ _show_input : function (obj, callback) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ var rtl = this._get_settings().core.rtl,
|
|||
|
+ w = this._get_settings().crrm.input_width_limit,
|
|||
|
+ w1 = obj.children("ins").width(),
|
|||
|
+ w2 = obj.find("> a:visible > ins").width() * obj.find("> a:visible > ins").length,
|
|||
|
+ t = this.get_text(obj),
|
|||
|
+ h1 = $("<div />", { css : { "position" : "absolute", "top" : "-200px", "left" : (rtl ? "0px" : "-1000px"), "visibility" : "hidden" } }).appendTo("body"),
|
|||
|
+ h2 = obj.css("position","relative").append(
|
|||
|
+ $("<input />", {
|
|||
|
+ "value" : t,
|
|||
|
+ "class" : "jstree-rename-input",
|
|||
|
+ // "size" : t.length,
|
|||
|
+ "css" : {
|
|||
|
+ "padding" : "0",
|
|||
|
+ "border" : "1px solid silver",
|
|||
|
+ "position" : "absolute",
|
|||
|
+ "left" : (rtl ? "auto" : (w1 + w2 + 4) + "px"),
|
|||
|
+ "right" : (rtl ? (w1 + w2 + 4) + "px" : "auto"),
|
|||
|
+ "top" : "0px",
|
|||
|
+ "height" : (this.data.core.li_height - 2) + "px",
|
|||
|
+ "lineHeight" : (this.data.core.li_height - 2) + "px",
|
|||
|
+ "width" : "150px" // will be set a bit further down
|
|||
|
+ },
|
|||
|
+ "blur" : $.proxy(function () {
|
|||
|
+ var i = obj.children(".jstree-rename-input"),
|
|||
|
+ v = i.val();
|
|||
|
+ if(v === "") { v = t; }
|
|||
|
+ h1.remove();
|
|||
|
+ i.remove(); // rollback purposes
|
|||
|
+ this.set_text(obj,t); // rollback purposes
|
|||
|
+ this.rename_node(obj, v);
|
|||
|
+ callback.call(this, obj, v, t);
|
|||
|
+ obj.css("position","");
|
|||
|
+ }, this),
|
|||
|
+ "keyup" : function (event) {
|
|||
|
+ var key = event.keyCode || event.which;
|
|||
|
+ if(key == 27) { this.value = t; this.blur(); return; }
|
|||
|
+ else if(key == 13) { this.blur(); return; }
|
|||
|
+ else {
|
|||
|
+ h2.width(Math.min(h1.text("pW" + this.value).width(),w));
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ "keypress" : function(event) {
|
|||
|
+ var key = event.keyCode || event.which;
|
|||
|
+ if(key == 13) { return false; }
|
|||
|
+ }
|
|||
|
+ })
|
|||
|
+ ).children(".jstree-rename-input");
|
|||
|
+ this.set_text(obj, "");
|
|||
|
+ h1.css({
|
|||
|
+ fontFamily : h2.css('fontFamily') || '',
|
|||
|
+ fontSize : h2.css('fontSize') || '',
|
|||
|
+ fontWeight : h2.css('fontWeight') || '',
|
|||
|
+ fontStyle : h2.css('fontStyle') || '',
|
|||
|
+ fontStretch : h2.css('fontStretch') || '',
|
|||
|
+ fontVariant : h2.css('fontVariant') || '',
|
|||
|
+ letterSpacing : h2.css('letterSpacing') || '',
|
|||
|
+ wordSpacing : h2.css('wordSpacing') || ''
|
|||
|
+ });
|
|||
|
+ h2.width(Math.min(h1.text("pW" + h2[0].value).width(),w))[0].select();
|
|||
|
+ },
|
|||
|
+ rename : function (obj) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ this.__rollback();
|
|||
|
+ var f = this.__callback;
|
|||
|
+ this._show_input(obj, function (obj, new_name, old_name) {
|
|||
|
+ f.call(this, { "obj" : obj, "new_name" : new_name, "old_name" : old_name });
|
|||
|
+ });
|
|||
|
+ },
|
|||
|
+ create : function (obj, position, js, callback, skip_rename) {
|
|||
|
+ var t, _this = this;
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(!obj) { obj = -1; }
|
|||
|
+ this.__rollback();
|
|||
|
+ t = this.create_node(obj, position, js, function (t) {
|
|||
|
+ var p = this._get_parent(t),
|
|||
|
+ pos = $(t).index();
|
|||
|
+ if(callback) { callback.call(this, t); }
|
|||
|
+ if(p.length && p.hasClass("jstree-closed")) { this.open_node(p, false, true); }
|
|||
|
+ if(!skip_rename) {
|
|||
|
+ this._show_input(t, function (obj, new_name, old_name) {
|
|||
|
+ _this.__callback({ "obj" : obj, "name" : new_name, "parent" : p, "position" : pos });
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ else { _this.__callback({ "obj" : t, "name" : this.get_text(t), "parent" : p, "position" : pos }); }
|
|||
|
+ });
|
|||
|
+ return t;
|
|||
|
+ },
|
|||
|
+ remove : function (obj) {
|
|||
|
+ obj = this._get_node(obj, true);
|
|||
|
+ var p = this._get_parent(obj), prev = this._get_prev(obj);
|
|||
|
+ this.__rollback();
|
|||
|
+ obj = this.delete_node(obj);
|
|||
|
+ if(obj !== false) { this.__callback({ "obj" : obj, "prev" : prev, "parent" : p }); }
|
|||
|
+ },
|
|||
|
+ check_move : function () {
|
|||
|
+ if(!this.__call_old()) { return false; }
|
|||
|
+ var s = this._get_settings().crrm.move;
|
|||
|
+ if(!s.check_move.call(this, this._get_move())) { return false; }
|
|||
|
+ return true;
|
|||
|
+ },
|
|||
|
+ move_node : function (obj, ref, position, is_copy, is_prepared, skip_check) {
|
|||
|
+ var s = this._get_settings().crrm.move;
|
|||
|
+ if(!is_prepared) {
|
|||
|
+ if(typeof position === "undefined") { position = s.default_position; }
|
|||
|
+ if(position === "inside" && !s.default_position.match(/^(before|after)$/)) { position = s.default_position; }
|
|||
|
+ return this.__call_old(true, obj, ref, position, is_copy, false, skip_check);
|
|||
|
+ }
|
|||
|
+ // if the move is already prepared
|
|||
|
+ if(s.always_copy === true || (s.always_copy === "multitree" && obj.rt.get_index() !== obj.ot.get_index() )) {
|
|||
|
+ is_copy = true;
|
|||
|
+ }
|
|||
|
+ this.__call_old(true, obj, ref, position, is_copy, true, skip_check);
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ cut : function (obj) {
|
|||
|
+ obj = this._get_node(obj, true);
|
|||
|
+ if(!obj || !obj.length) { return false; }
|
|||
|
+ this.data.crrm.cp_nodes = false;
|
|||
|
+ this.data.crrm.ct_nodes = obj;
|
|||
|
+ this.__callback({ "obj" : obj });
|
|||
|
+ },
|
|||
|
+ copy : function (obj) {
|
|||
|
+ obj = this._get_node(obj, true);
|
|||
|
+ if(!obj || !obj.length) { return false; }
|
|||
|
+ this.data.crrm.ct_nodes = false;
|
|||
|
+ this.data.crrm.cp_nodes = obj;
|
|||
|
+ this.__callback({ "obj" : obj });
|
|||
|
+ },
|
|||
|
+ paste : function (obj) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(!obj || !obj.length) { return false; }
|
|||
|
+ var nodes = this.data.crrm.ct_nodes ? this.data.crrm.ct_nodes : this.data.crrm.cp_nodes;
|
|||
|
+ if(!this.data.crrm.ct_nodes && !this.data.crrm.cp_nodes) { return false; }
|
|||
|
+ if(this.data.crrm.ct_nodes) { this.move_node(this.data.crrm.ct_nodes, obj); this.data.crrm.ct_nodes = false; }
|
|||
|
+ if(this.data.crrm.cp_nodes) { this.move_node(this.data.crrm.cp_nodes, obj, false, true); }
|
|||
|
+ this.__callback({ "obj" : obj, "nodes" : nodes });
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ // include the crr plugin by default
|
|||
|
+ // $.jstree.defaults.plugins.push("crrm");
|
|||
|
+})(jQuery);
|
|||
|
+//*/
|
|||
|
+
|
|||
|
+/*
|
|||
|
+ * jsTree themes plugin
|
|||
|
+ * Handles loading and setting themes, as well as detecting path to themes, etc.
|
|||
|
+ */
|
|||
|
+(function ($) {
|
|||
|
+ var themes_loaded = [];
|
|||
|
+ // this variable stores the path to the themes folder - if left as false - it will be autodetected
|
|||
|
+ $.jstree._themes = false;
|
|||
|
+ $.jstree.plugin("themes", {
|
|||
|
+ __init : function () {
|
|||
|
+ this.get_container()
|
|||
|
+ .bind("init.jstree", $.proxy(function () {
|
|||
|
+ var s = this._get_settings().themes;
|
|||
|
+ this.data.themes.dots = s.dots;
|
|||
|
+ this.data.themes.icons = s.icons;
|
|||
|
+ this.set_theme(s.theme, s.url);
|
|||
|
+ }, this))
|
|||
|
+ .bind("loaded.jstree", $.proxy(function () {
|
|||
|
+ // bound here too, as simple HTML tree's won't honor dots & icons otherwise
|
|||
|
+ if(!this.data.themes.dots) { this.hide_dots(); }
|
|||
|
+ else { this.show_dots(); }
|
|||
|
+ if(!this.data.themes.icons) { this.hide_icons(); }
|
|||
|
+ else { this.show_icons(); }
|
|||
|
+ }, this));
|
|||
|
+ },
|
|||
|
+ defaults : {
|
|||
|
+ theme : "default",
|
|||
|
+ url : false,
|
|||
|
+ dots : true,
|
|||
|
+ icons : true
|
|||
|
+ },
|
|||
|
+ _fn : {
|
|||
|
+ set_theme : function (theme_name, theme_url) {
|
|||
|
+ if(!theme_name) { return false; }
|
|||
|
+ if(!theme_url) { theme_url = $.jstree._themes + theme_name + '/style.css'; }
|
|||
|
+ if($.inArray(theme_url, themes_loaded) == -1) {
|
|||
|
+ $.vakata.css.add_sheet({ "url" : theme_url });
|
|||
|
+ themes_loaded.push(theme_url);
|
|||
|
+ }
|
|||
|
+ if(this.data.themes.theme != theme_name) {
|
|||
|
+ this.get_container().removeClass('jstree-' + this.data.themes.theme);
|
|||
|
+ this.data.themes.theme = theme_name;
|
|||
|
+ }
|
|||
|
+ this.get_container().addClass('jstree-' + theme_name);
|
|||
|
+ if(!this.data.themes.dots) { this.hide_dots(); }
|
|||
|
+ else { this.show_dots(); }
|
|||
|
+ if(!this.data.themes.icons) { this.hide_icons(); }
|
|||
|
+ else { this.show_icons(); }
|
|||
|
+ this.__callback();
|
|||
|
+ },
|
|||
|
+ get_theme : function () { return this.data.themes.theme; },
|
|||
|
+
|
|||
|
+ show_dots : function () { this.data.themes.dots = true; this.get_container().children("ul").removeClass("jstree-no-dots"); },
|
|||
|
+ hide_dots : function () { this.data.themes.dots = false; this.get_container().children("ul").addClass("jstree-no-dots"); },
|
|||
|
+ toggle_dots : function () { if(this.data.themes.dots) { this.hide_dots(); } else { this.show_dots(); } },
|
|||
|
+
|
|||
|
+ show_icons : function () { this.data.themes.icons = true; this.get_container().children("ul").removeClass("jstree-no-icons"); },
|
|||
|
+ hide_icons : function () { this.data.themes.icons = false; this.get_container().children("ul").addClass("jstree-no-icons"); },
|
|||
|
+ toggle_icons: function () { if(this.data.themes.icons) { this.hide_icons(); } else { this.show_icons(); } }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ // autodetect themes path
|
|||
|
+ $(function () {
|
|||
|
+ if($.jstree._themes === false) {
|
|||
|
+ $("script").each(function () {
|
|||
|
+ if(this.src.toString().match(/jquery\.jstree[^\/]*?\.js(\?.*)?$/)) {
|
|||
|
+ $.jstree._themes = this.src.toString().replace(/jquery\.jstree[^\/]*?\.js(\?.*)?$/, "") + 'themes/';
|
|||
|
+ return false;
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ if($.jstree._themes === false) { $.jstree._themes = "themes/"; }
|
|||
|
+ });
|
|||
|
+ // include the themes plugin by default
|
|||
|
+ $.jstree.defaults.plugins.push("themes");
|
|||
|
+})(jQuery);
|
|||
|
+//*/
|
|||
|
+
|
|||
|
+/*
|
|||
|
+ * jsTree hotkeys plugin
|
|||
|
+ * Enables keyboard navigation for all tree instances
|
|||
|
+ * Depends on the jstree ui & jquery hotkeys plugins
|
|||
|
+ */
|
|||
|
+(function ($) {
|
|||
|
+ var bound = [];
|
|||
|
+ function exec(i, event) {
|
|||
|
+ var f = $.jstree._focused(), tmp;
|
|||
|
+ if(f && f.data && f.data.hotkeys && f.data.hotkeys.enabled) {
|
|||
|
+ tmp = f._get_settings().hotkeys[i];
|
|||
|
+ if(tmp) { return tmp.call(f, event); }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ $.jstree.plugin("hotkeys", {
|
|||
|
+ __init : function () {
|
|||
|
+ if(typeof $.hotkeys === "undefined") { throw "jsTree hotkeys: jQuery hotkeys plugin not included."; }
|
|||
|
+ if(!this.data.ui) { throw "jsTree hotkeys: jsTree UI plugin not included."; }
|
|||
|
+ $.each(this._get_settings().hotkeys, function (i, v) {
|
|||
|
+ if(v !== false && $.inArray(i, bound) == -1) {
|
|||
|
+ $(document).bind("keydown", i, function (event) { return exec(i, event); });
|
|||
|
+ bound.push(i);
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ this.get_container()
|
|||
|
+ .bind("lock.jstree", $.proxy(function () {
|
|||
|
+ if(this.data.hotkeys.enabled) { this.data.hotkeys.enabled = false; this.data.hotkeys.revert = true; }
|
|||
|
+ }, this))
|
|||
|
+ .bind("unlock.jstree", $.proxy(function () {
|
|||
|
+ if(this.data.hotkeys.revert) { this.data.hotkeys.enabled = true; }
|
|||
|
+ }, this));
|
|||
|
+ this.enable_hotkeys();
|
|||
|
+ },
|
|||
|
+ defaults : {
|
|||
|
+ "up" : function () {
|
|||
|
+ var o = this.data.ui.hovered || this.data.ui.last_selected || -1;
|
|||
|
+ this.hover_node(this._get_prev(o));
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ "ctrl+up" : function () {
|
|||
|
+ var o = this.data.ui.hovered || this.data.ui.last_selected || -1;
|
|||
|
+ this.hover_node(this._get_prev(o));
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ "shift+up" : function () {
|
|||
|
+ var o = this.data.ui.hovered || this.data.ui.last_selected || -1;
|
|||
|
+ this.hover_node(this._get_prev(o));
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ "down" : function () {
|
|||
|
+ var o = this.data.ui.hovered || this.data.ui.last_selected || -1;
|
|||
|
+ this.hover_node(this._get_next(o));
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ "ctrl+down" : function () {
|
|||
|
+ var o = this.data.ui.hovered || this.data.ui.last_selected || -1;
|
|||
|
+ this.hover_node(this._get_next(o));
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ "shift+down" : function () {
|
|||
|
+ var o = this.data.ui.hovered || this.data.ui.last_selected || -1;
|
|||
|
+ this.hover_node(this._get_next(o));
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ "left" : function () {
|
|||
|
+ var o = this.data.ui.hovered || this.data.ui.last_selected;
|
|||
|
+ if(o) {
|
|||
|
+ if(o.hasClass("jstree-open")) { this.close_node(o); }
|
|||
|
+ else { this.hover_node(this._get_prev(o)); }
|
|||
|
+ }
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ "ctrl+left" : function () {
|
|||
|
+ var o = this.data.ui.hovered || this.data.ui.last_selected;
|
|||
|
+ if(o) {
|
|||
|
+ if(o.hasClass("jstree-open")) { this.close_node(o); }
|
|||
|
+ else { this.hover_node(this._get_prev(o)); }
|
|||
|
+ }
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ "shift+left" : function () {
|
|||
|
+ var o = this.data.ui.hovered || this.data.ui.last_selected;
|
|||
|
+ if(o) {
|
|||
|
+ if(o.hasClass("jstree-open")) { this.close_node(o); }
|
|||
|
+ else { this.hover_node(this._get_prev(o)); }
|
|||
|
+ }
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ "right" : function () {
|
|||
|
+ var o = this.data.ui.hovered || this.data.ui.last_selected;
|
|||
|
+ if(o && o.length) {
|
|||
|
+ if(o.hasClass("jstree-closed")) { this.open_node(o); }
|
|||
|
+ else { this.hover_node(this._get_next(o)); }
|
|||
|
+ }
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ "ctrl+right" : function () {
|
|||
|
+ var o = this.data.ui.hovered || this.data.ui.last_selected;
|
|||
|
+ if(o && o.length) {
|
|||
|
+ if(o.hasClass("jstree-closed")) { this.open_node(o); }
|
|||
|
+ else { this.hover_node(this._get_next(o)); }
|
|||
|
+ }
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ "shift+right" : function () {
|
|||
|
+ var o = this.data.ui.hovered || this.data.ui.last_selected;
|
|||
|
+ if(o && o.length) {
|
|||
|
+ if(o.hasClass("jstree-closed")) { this.open_node(o); }
|
|||
|
+ else { this.hover_node(this._get_next(o)); }
|
|||
|
+ }
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ "space" : function () {
|
|||
|
+ if(this.data.ui.hovered) { this.data.ui.hovered.children("a:eq(0)").click(); }
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ "ctrl+space" : function (event) {
|
|||
|
+ event.type = "click";
|
|||
|
+ if(this.data.ui.hovered) { this.data.ui.hovered.children("a:eq(0)").trigger(event); }
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ "shift+space" : function (event) {
|
|||
|
+ event.type = "click";
|
|||
|
+ if(this.data.ui.hovered) { this.data.ui.hovered.children("a:eq(0)").trigger(event); }
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ "f2" : function () { this.rename(this.data.ui.hovered || this.data.ui.last_selected); },
|
|||
|
+ "del" : function () { this.remove(this.data.ui.hovered || this._get_node(null)); }
|
|||
|
+ },
|
|||
|
+ _fn : {
|
|||
|
+ enable_hotkeys : function () {
|
|||
|
+ this.data.hotkeys.enabled = true;
|
|||
|
+ },
|
|||
|
+ disable_hotkeys : function () {
|
|||
|
+ this.data.hotkeys.enabled = false;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+})(jQuery);
|
|||
|
+//*/
|
|||
|
+
|
|||
|
+/*
|
|||
|
+ * jsTree JSON plugin
|
|||
|
+ * The JSON data store. Datastores are build by overriding the `load_node` and `_is_loaded` functions.
|
|||
|
+ */
|
|||
|
+(function ($) {
|
|||
|
+ $.jstree.plugin("json_data", {
|
|||
|
+ __init : function() {
|
|||
|
+ var s = this._get_settings().json_data;
|
|||
|
+ if(s.progressive_unload) {
|
|||
|
+ this.get_container().bind("after_close.jstree", function (e, data) {
|
|||
|
+ data.rslt.obj.children("ul").remove();
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ defaults : {
|
|||
|
+ // `data` can be a function:
|
|||
|
+ // * accepts two arguments - node being loaded and a callback to pass the result to
|
|||
|
+ // * will be executed in the current tree's scope & ajax won't be supported
|
|||
|
+ data : false,
|
|||
|
+ ajax : false,
|
|||
|
+ correct_state : true,
|
|||
|
+ progressive_render : false,
|
|||
|
+ progressive_unload : false
|
|||
|
+ },
|
|||
|
+ _fn : {
|
|||
|
+ load_node : function (obj, s_call, e_call) { var _this = this; this.load_node_json(obj, function () { _this.__callback({ "obj" : _this._get_node(obj) }); s_call.call(this); }, e_call); },
|
|||
|
+ _is_loaded : function (obj) {
|
|||
|
+ var s = this._get_settings().json_data;
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ return obj == -1 || !obj || (!s.ajax && !s.progressive_render && !$.isFunction(s.data)) || obj.is(".jstree-open, .jstree-leaf") || obj.children("ul").children("li").length > 0;
|
|||
|
+ },
|
|||
|
+ refresh : function (obj) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ var s = this._get_settings().json_data;
|
|||
|
+ if(obj && obj !== -1 && s.progressive_unload && ($.isFunction(s.data) || !!s.ajax)) {
|
|||
|
+ obj.removeData("jstree_children");
|
|||
|
+ }
|
|||
|
+ return this.__call_old();
|
|||
|
+ },
|
|||
|
+ load_node_json : function (obj, s_call, e_call) {
|
|||
|
+ var s = this.get_settings().json_data, d,
|
|||
|
+ error_func = function () {},
|
|||
|
+ success_func = function () {};
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+
|
|||
|
+ if(obj && obj !== -1 && (s.progressive_render || s.progressive_unload) && !obj.is(".jstree-open, .jstree-leaf") && obj.children("ul").children("li").length === 0 && obj.data("jstree_children")) {
|
|||
|
+ d = this._parse_json(obj.data("jstree_children"), obj);
|
|||
|
+ if(d) {
|
|||
|
+ obj.append(d);
|
|||
|
+ if(!s.progressive_unload) { obj.removeData("jstree_children"); }
|
|||
|
+ }
|
|||
|
+ this.clean_node(obj);
|
|||
|
+ if(s_call) { s_call.call(this); }
|
|||
|
+ return;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ if(obj && obj !== -1) {
|
|||
|
+ if(obj.data("jstree_is_loading")) { return; }
|
|||
|
+ else { obj.data("jstree_is_loading",true); }
|
|||
|
+ }
|
|||
|
+ switch(!0) {
|
|||
|
+ case (!s.data && !s.ajax): throw "Neither data nor ajax settings supplied.";
|
|||
|
+ // function option added here for easier model integration (also supporting async - see callback)
|
|||
|
+ case ($.isFunction(s.data)):
|
|||
|
+ s.data.call(this, obj, $.proxy(function (d) {
|
|||
|
+ d = this._parse_json(d, obj);
|
|||
|
+ if(!d) {
|
|||
|
+ if(obj === -1 || !obj) {
|
|||
|
+ if(s.correct_state) { this.get_container().children("ul").empty(); }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ obj.children("a.jstree-loading").removeClass("jstree-loading");
|
|||
|
+ obj.removeData("jstree_is_loading");
|
|||
|
+ if(s.correct_state) { this.correct_state(obj); }
|
|||
|
+ }
|
|||
|
+ if(e_call) { e_call.call(this); }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(obj === -1 || !obj) { this.get_container().children("ul").empty().append(d.children()); }
|
|||
|
+ else { obj.append(d).children("a.jstree-loading").removeClass("jstree-loading"); obj.removeData("jstree_is_loading"); }
|
|||
|
+ this.clean_node(obj);
|
|||
|
+ if(s_call) { s_call.call(this); }
|
|||
|
+ }
|
|||
|
+ }, this));
|
|||
|
+ break;
|
|||
|
+ case (!!s.data && !s.ajax) || (!!s.data && !!s.ajax && (!obj || obj === -1)):
|
|||
|
+ if(!obj || obj == -1) {
|
|||
|
+ d = this._parse_json(s.data, obj);
|
|||
|
+ if(d) {
|
|||
|
+ this.get_container().children("ul").empty().append(d.children());
|
|||
|
+ this.clean_node();
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(s.correct_state) { this.get_container().children("ul").empty(); }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ if(s_call) { s_call.call(this); }
|
|||
|
+ break;
|
|||
|
+ case (!s.data && !!s.ajax) || (!!s.data && !!s.ajax && obj && obj !== -1):
|
|||
|
+ error_func = function (x, t, e) {
|
|||
|
+ var ef = this.get_settings().json_data.ajax.error;
|
|||
|
+ if(ef) { ef.call(this, x, t, e); }
|
|||
|
+ if(obj != -1 && obj.length) {
|
|||
|
+ obj.children("a.jstree-loading").removeClass("jstree-loading");
|
|||
|
+ obj.removeData("jstree_is_loading");
|
|||
|
+ if(t === "success" && s.correct_state) { this.correct_state(obj); }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(t === "success" && s.correct_state) { this.get_container().children("ul").empty(); }
|
|||
|
+ }
|
|||
|
+ if(e_call) { e_call.call(this); }
|
|||
|
+ };
|
|||
|
+ success_func = function (d, t, x) {
|
|||
|
+ var sf = this.get_settings().json_data.ajax.success;
|
|||
|
+ if(sf) { d = sf.call(this,d,t,x) || d; }
|
|||
|
+ if(d === "" || (d && d.toString && d.toString().replace(/^[\s\n]+$/,"") === "") || (!$.isArray(d) && !$.isPlainObject(d))) {
|
|||
|
+ return error_func.call(this, x, t, "");
|
|||
|
+ }
|
|||
|
+ d = this._parse_json(d, obj);
|
|||
|
+ if(d) {
|
|||
|
+ if(obj === -1 || !obj) { this.get_container().children("ul").empty().append(d.children()); }
|
|||
|
+ else { obj.append(d).children("a.jstree-loading").removeClass("jstree-loading"); obj.removeData("jstree_is_loading"); }
|
|||
|
+ this.clean_node(obj);
|
|||
|
+ if(s_call) { s_call.call(this); }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(obj === -1 || !obj) {
|
|||
|
+ if(s.correct_state) {
|
|||
|
+ this.get_container().children("ul").empty();
|
|||
|
+ if(s_call) { s_call.call(this); }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ obj.children("a.jstree-loading").removeClass("jstree-loading");
|
|||
|
+ obj.removeData("jstree_is_loading");
|
|||
|
+ if(s.correct_state) {
|
|||
|
+ this.correct_state(obj);
|
|||
|
+ if(s_call) { s_call.call(this); }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ };
|
|||
|
+ s.ajax.context = this;
|
|||
|
+ s.ajax.error = error_func;
|
|||
|
+ s.ajax.success = success_func;
|
|||
|
+ if(!s.ajax.dataType) { s.ajax.dataType = "json"; }
|
|||
|
+ if($.isFunction(s.ajax.url)) { s.ajax.url = s.ajax.url.call(this, obj); }
|
|||
|
+ if($.isFunction(s.ajax.data)) { s.ajax.data = s.ajax.data.call(this, obj); }
|
|||
|
+ $.ajax(s.ajax);
|
|||
|
+ break;
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ _parse_json : function (js, obj, is_callback) {
|
|||
|
+ var d = false,
|
|||
|
+ p = this._get_settings(),
|
|||
|
+ s = p.json_data,
|
|||
|
+ t = p.core.html_titles,
|
|||
|
+ tmp, i, j, ul1, ul2;
|
|||
|
+
|
|||
|
+ if(!js) { return d; }
|
|||
|
+ if(s.progressive_unload && obj && obj !== -1) {
|
|||
|
+ obj.data("jstree_children", d);
|
|||
|
+ }
|
|||
|
+ if($.isArray(js)) {
|
|||
|
+ d = $();
|
|||
|
+ if(!js.length) { return false; }
|
|||
|
+ for(i = 0, j = js.length; i < j; i++) {
|
|||
|
+ tmp = this._parse_json(js[i], obj, true);
|
|||
|
+ if(tmp.length) { d = d.add(tmp); }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(typeof js == "string") { js = { data : js }; }
|
|||
|
+ if(!js.data && js.data !== "") { return d; }
|
|||
|
+ d = $("<li />");
|
|||
|
+ if(js.attr) { d.attr(js.attr); }
|
|||
|
+ if(js.metadata) { d.data(js.metadata); }
|
|||
|
+ if(js.state) { d.addClass("jstree-" + js.state); }
|
|||
|
+ if(!$.isArray(js.data)) { tmp = js.data; js.data = []; js.data.push(tmp); }
|
|||
|
+ $.each(js.data, function (i, m) {
|
|||
|
+ tmp = $("<a />");
|
|||
|
+ if($.isFunction(m)) { m = m.call(this, js); }
|
|||
|
+ if(typeof m == "string") { tmp.attr('href','#')[ t ? "html" : "text" ](m); }
|
|||
|
+ else {
|
|||
|
+ if(!m.attr) { m.attr = {}; }
|
|||
|
+ if(!m.attr.href) { m.attr.href = '#'; }
|
|||
|
+ tmp.attr(m.attr)[ t ? "html" : "text" ](m.title);
|
|||
|
+ if(m.language) { tmp.addClass(m.language); }
|
|||
|
+ }
|
|||
|
+ tmp.prepend("<ins class='jstree-icon'> </ins>");
|
|||
|
+ if(!m.icon && js.icon) { m.icon = js.icon; }
|
|||
|
+ if(m.icon) {
|
|||
|
+ if(m.icon.indexOf("/") === -1) { tmp.children("ins").addClass(m.icon); }
|
|||
|
+ else { tmp.children("ins").css("background","url('" + m.icon + "') center center no-repeat"); }
|
|||
|
+ }
|
|||
|
+ d.append(tmp);
|
|||
|
+ });
|
|||
|
+ d.prepend("<ins class='jstree-icon'> </ins>");
|
|||
|
+ if(js.children) {
|
|||
|
+ if(s.progressive_render && js.state !== "open") {
|
|||
|
+ d.addClass("jstree-closed").data("jstree_children", js.children);
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(s.progressive_unload) { d.data("jstree_children", js.children); }
|
|||
|
+ if($.isArray(js.children) && js.children.length) {
|
|||
|
+ tmp = this._parse_json(js.children, obj, true);
|
|||
|
+ if(tmp.length) {
|
|||
|
+ ul2 = $("<ul />");
|
|||
|
+ ul2.append(tmp);
|
|||
|
+ d.append(ul2);
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ if(!is_callback) {
|
|||
|
+ ul1 = $("<ul />");
|
|||
|
+ ul1.append(d);
|
|||
|
+ d = ul1;
|
|||
|
+ }
|
|||
|
+ return d;
|
|||
|
+ },
|
|||
|
+ get_json : function (obj, li_attr, a_attr, is_callback) {
|
|||
|
+ var result = [],
|
|||
|
+ s = this._get_settings(),
|
|||
|
+ _this = this,
|
|||
|
+ tmp1, tmp2, li, a, t, lang;
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(!obj || obj === -1) { obj = this.get_container().find("> ul > li"); }
|
|||
|
+ li_attr = $.isArray(li_attr) ? li_attr : [ "id", "class" ];
|
|||
|
+ if(!is_callback && this.data.types) { li_attr.push(s.types.type_attr); }
|
|||
|
+ a_attr = $.isArray(a_attr) ? a_attr : [ ];
|
|||
|
+
|
|||
|
+ obj.each(function () {
|
|||
|
+ li = $(this);
|
|||
|
+ tmp1 = { data : [] };
|
|||
|
+ if(li_attr.length) { tmp1.attr = { }; }
|
|||
|
+ $.each(li_attr, function (i, v) {
|
|||
|
+ tmp2 = li.attr(v);
|
|||
|
+ if(tmp2 && tmp2.length && tmp2.replace(/jstree[^ ]*/ig,'').length) {
|
|||
|
+ tmp1.attr[v] = (" " + tmp2).replace(/ jstree[^ ]*/ig,'').replace(/\s+$/ig," ").replace(/^ /,"").replace(/ $/,"");
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ if(li.hasClass("jstree-open")) { tmp1.state = "open"; }
|
|||
|
+ if(li.hasClass("jstree-closed")) { tmp1.state = "closed"; }
|
|||
|
+ if(li.data()) { tmp1.metadata = li.data(); }
|
|||
|
+ a = li.children("a");
|
|||
|
+ a.each(function () {
|
|||
|
+ t = $(this);
|
|||
|
+ if(
|
|||
|
+ a_attr.length ||
|
|||
|
+ $.inArray("languages", s.plugins) !== -1 ||
|
|||
|
+ t.children("ins").get(0).style.backgroundImage.length ||
|
|||
|
+ (t.children("ins").get(0).className && t.children("ins").get(0).className.replace(/jstree[^ ]*|$/ig,'').length)
|
|||
|
+ ) {
|
|||
|
+ lang = false;
|
|||
|
+ if($.inArray("languages", s.plugins) !== -1 && $.isArray(s.languages) && s.languages.length) {
|
|||
|
+ $.each(s.languages, function (l, lv) {
|
|||
|
+ if(t.hasClass(lv)) {
|
|||
|
+ lang = lv;
|
|||
|
+ return false;
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ tmp2 = { attr : { }, title : _this.get_text(t, lang) };
|
|||
|
+ $.each(a_attr, function (k, z) {
|
|||
|
+ tmp2.attr[z] = (" " + (t.attr(z) || "")).replace(/ jstree[^ ]*/ig,'').replace(/\s+$/ig," ").replace(/^ /,"").replace(/ $/,"");
|
|||
|
+ });
|
|||
|
+ if($.inArray("languages", s.plugins) !== -1 && $.isArray(s.languages) && s.languages.length) {
|
|||
|
+ $.each(s.languages, function (k, z) {
|
|||
|
+ if(t.hasClass(z)) { tmp2.language = z; return true; }
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ if(t.children("ins").get(0).className.replace(/jstree[^ ]*|$/ig,'').replace(/^\s+$/ig,"").length) {
|
|||
|
+ tmp2.icon = t.children("ins").get(0).className.replace(/jstree[^ ]*|$/ig,'').replace(/\s+$/ig," ").replace(/^ /,"").replace(/ $/,"");
|
|||
|
+ }
|
|||
|
+ if(t.children("ins").get(0).style.backgroundImage.length) {
|
|||
|
+ tmp2.icon = t.children("ins").get(0).style.backgroundImage.replace("url(","").replace(")","");
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ tmp2 = _this.get_text(t);
|
|||
|
+ }
|
|||
|
+ if(a.length > 1) { tmp1.data.push(tmp2); }
|
|||
|
+ else { tmp1.data = tmp2; }
|
|||
|
+ });
|
|||
|
+ li = li.find("> ul > li");
|
|||
|
+ if(li.length) { tmp1.children = _this.get_json(li, li_attr, a_attr, true); }
|
|||
|
+ result.push(tmp1);
|
|||
|
+ });
|
|||
|
+ return result;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+})(jQuery);
|
|||
|
+//*/
|
|||
|
+
|
|||
|
+/*
|
|||
|
+ * jsTree languages plugin
|
|||
|
+ * Adds support for multiple language versions in one tree
|
|||
|
+ * This basically allows for many titles coexisting in one node, but only one of them being visible at any given time
|
|||
|
+ * This is useful for maintaining the same structure in many languages (hence the name of the plugin)
|
|||
|
+ */
|
|||
|
+(function ($) {
|
|||
|
+ $.jstree.plugin("languages", {
|
|||
|
+ __init : function () { this._load_css(); },
|
|||
|
+ defaults : [],
|
|||
|
+ _fn : {
|
|||
|
+ set_lang : function (i) {
|
|||
|
+ var langs = this._get_settings().languages,
|
|||
|
+ st = false,
|
|||
|
+ selector = ".jstree-" + this.get_index() + ' a';
|
|||
|
+ if(!$.isArray(langs) || langs.length === 0) { return false; }
|
|||
|
+ if($.inArray(i,langs) == -1) {
|
|||
|
+ if(!!langs[i]) { i = langs[i]; }
|
|||
|
+ else { return false; }
|
|||
|
+ }
|
|||
|
+ if(i == this.data.languages.current_language) { return true; }
|
|||
|
+ st = $.vakata.css.get_css(selector + "." + this.data.languages.current_language, false, this.data.languages.language_css);
|
|||
|
+ if(st !== false) { st.style.display = "none"; }
|
|||
|
+ st = $.vakata.css.get_css(selector + "." + i, false, this.data.languages.language_css);
|
|||
|
+ if(st !== false) { st.style.display = ""; }
|
|||
|
+ this.data.languages.current_language = i;
|
|||
|
+ this.__callback(i);
|
|||
|
+ return true;
|
|||
|
+ },
|
|||
|
+ get_lang : function () {
|
|||
|
+ return this.data.languages.current_language;
|
|||
|
+ },
|
|||
|
+ _get_string : function (key, lang) {
|
|||
|
+ var langs = this._get_settings().languages,
|
|||
|
+ s = this._get_settings().core.strings;
|
|||
|
+ if($.isArray(langs) && langs.length) {
|
|||
|
+ lang = (lang && $.inArray(lang,langs) != -1) ? lang : this.data.languages.current_language;
|
|||
|
+ }
|
|||
|
+ if(s[lang] && s[lang][key]) { return s[lang][key]; }
|
|||
|
+ if(s[key]) { return s[key]; }
|
|||
|
+ return key;
|
|||
|
+ },
|
|||
|
+ get_text : function (obj, lang) {
|
|||
|
+ obj = this._get_node(obj) || this.data.ui.last_selected;
|
|||
|
+ if(!obj.size()) { return false; }
|
|||
|
+ var langs = this._get_settings().languages,
|
|||
|
+ s = this._get_settings().core.html_titles;
|
|||
|
+ if($.isArray(langs) && langs.length) {
|
|||
|
+ lang = (lang && $.inArray(lang,langs) != -1) ? lang : this.data.languages.current_language;
|
|||
|
+ obj = obj.children("a." + lang);
|
|||
|
+ }
|
|||
|
+ else { obj = obj.children("a:eq(0)"); }
|
|||
|
+ if(s) {
|
|||
|
+ obj = obj.clone();
|
|||
|
+ obj.children("INS").remove();
|
|||
|
+ return obj.html();
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ obj = obj.contents().filter(function() { return this.nodeType == 3; })[0];
|
|||
|
+ return obj.nodeValue;
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ set_text : function (obj, val, lang) {
|
|||
|
+ obj = this._get_node(obj) || this.data.ui.last_selected;
|
|||
|
+ if(!obj.size()) { return false; }
|
|||
|
+ var langs = this._get_settings().languages,
|
|||
|
+ s = this._get_settings().core.html_titles,
|
|||
|
+ tmp;
|
|||
|
+ if($.isArray(langs) && langs.length) {
|
|||
|
+ lang = (lang && $.inArray(lang,langs) != -1) ? lang : this.data.languages.current_language;
|
|||
|
+ obj = obj.children("a." + lang);
|
|||
|
+ }
|
|||
|
+ else { obj = obj.children("a:eq(0)"); }
|
|||
|
+ if(s) {
|
|||
|
+ tmp = obj.children("INS").clone();
|
|||
|
+ obj.html(val).prepend(tmp);
|
|||
|
+ this.__callback({ "obj" : obj, "name" : val, "lang" : lang });
|
|||
|
+ return true;
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ obj = obj.contents().filter(function() { return this.nodeType == 3; })[0];
|
|||
|
+ this.__callback({ "obj" : obj, "name" : val, "lang" : lang });
|
|||
|
+ return (obj.nodeValue = val);
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ _load_css : function () {
|
|||
|
+ var langs = this._get_settings().languages,
|
|||
|
+ str = "/* languages css */",
|
|||
|
+ selector = ".jstree-" + this.get_index() + ' a',
|
|||
|
+ ln;
|
|||
|
+ if($.isArray(langs) && langs.length) {
|
|||
|
+ this.data.languages.current_language = langs[0];
|
|||
|
+ for(ln = 0; ln < langs.length; ln++) {
|
|||
|
+ str += selector + "." + langs[ln] + " {";
|
|||
|
+ if(langs[ln] != this.data.languages.current_language) { str += " display:none; "; }
|
|||
|
+ str += " } ";
|
|||
|
+ }
|
|||
|
+ this.data.languages.language_css = $.vakata.css.add_sheet({ 'str' : str, 'title' : "jstree-languages" });
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ create_node : function (obj, position, js, callback) {
|
|||
|
+ var t = this.__call_old(true, obj, position, js, function (t) {
|
|||
|
+ var langs = this._get_settings().languages,
|
|||
|
+ a = t.children("a"),
|
|||
|
+ ln;
|
|||
|
+ if($.isArray(langs) && langs.length) {
|
|||
|
+ for(ln = 0; ln < langs.length; ln++) {
|
|||
|
+ if(!a.is("." + langs[ln])) {
|
|||
|
+ t.append(a.eq(0).clone().removeClass(langs.join(" ")).addClass(langs[ln]));
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ a.not("." + langs.join(", .")).remove();
|
|||
|
+ }
|
|||
|
+ if(callback) { callback.call(this, t); }
|
|||
|
+ });
|
|||
|
+ return t;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+})(jQuery);
|
|||
|
+//*/
|
|||
|
+
|
|||
|
+/*
|
|||
|
+ * jsTree cookies plugin
|
|||
|
+ * Stores the currently opened/selected nodes in a cookie and then restores them
|
|||
|
+ * Depends on the jquery.cookie plugin
|
|||
|
+ */
|
|||
|
+(function ($) {
|
|||
|
+ $.jstree.plugin("cookies", {
|
|||
|
+ __init : function () {
|
|||
|
+ if(typeof $.cookie === "undefined") { throw "jsTree cookie: jQuery cookie plugin not included."; }
|
|||
|
+
|
|||
|
+ var s = this._get_settings().cookies,
|
|||
|
+ tmp;
|
|||
|
+ if(!!s.save_loaded) {
|
|||
|
+ tmp = $.cookie(s.save_loaded);
|
|||
|
+ if(tmp && tmp.length) { this.data.core.to_load = tmp.split(","); }
|
|||
|
+ }
|
|||
|
+ if(!!s.save_opened) {
|
|||
|
+ tmp = $.cookie(s.save_opened);
|
|||
|
+ if(tmp && tmp.length) { this.data.core.to_open = tmp.split(","); }
|
|||
|
+ }
|
|||
|
+ if(!!s.save_selected) {
|
|||
|
+ tmp = $.cookie(s.save_selected);
|
|||
|
+ if(tmp && tmp.length && this.data.ui) { this.data.ui.to_select = tmp.split(","); }
|
|||
|
+ }
|
|||
|
+ this.get_container()
|
|||
|
+ .one( ( this.data.ui ? "reselect" : "reopen" ) + ".jstree", $.proxy(function () {
|
|||
|
+ this.get_container()
|
|||
|
+ .bind("open_node.jstree close_node.jstree select_node.jstree deselect_node.jstree", $.proxy(function (e) {
|
|||
|
+ if(this._get_settings().cookies.auto_save) { this.save_cookie((e.handleObj.namespace + e.handleObj.type).replace("jstree","")); }
|
|||
|
+ }, this));
|
|||
|
+ }, this));
|
|||
|
+ },
|
|||
|
+ defaults : {
|
|||
|
+ save_loaded : "jstree_load",
|
|||
|
+ save_opened : "jstree_open",
|
|||
|
+ save_selected : "jstree_select",
|
|||
|
+ auto_save : true,
|
|||
|
+ cookie_options : {}
|
|||
|
+ },
|
|||
|
+ _fn : {
|
|||
|
+ save_cookie : function (c) {
|
|||
|
+ if(this.data.core.refreshing) { return; }
|
|||
|
+ var s = this._get_settings().cookies;
|
|||
|
+ if(!c) { // if called manually and not by event
|
|||
|
+ if(s.save_loaded) {
|
|||
|
+ this.save_loaded();
|
|||
|
+ $.cookie(s.save_loaded, this.data.core.to_load.join(","), s.cookie_options);
|
|||
|
+ }
|
|||
|
+ if(s.save_opened) {
|
|||
|
+ this.save_opened();
|
|||
|
+ $.cookie(s.save_opened, this.data.core.to_open.join(","), s.cookie_options);
|
|||
|
+ }
|
|||
|
+ if(s.save_selected && this.data.ui) {
|
|||
|
+ this.save_selected();
|
|||
|
+ $.cookie(s.save_selected, this.data.ui.to_select.join(","), s.cookie_options);
|
|||
|
+ }
|
|||
|
+ return;
|
|||
|
+ }
|
|||
|
+ switch(c) {
|
|||
|
+ case "open_node":
|
|||
|
+ case "close_node":
|
|||
|
+ if(!!s.save_opened) {
|
|||
|
+ this.save_opened();
|
|||
|
+ $.cookie(s.save_opened, this.data.core.to_open.join(","), s.cookie_options);
|
|||
|
+ }
|
|||
|
+ if(!!s.save_loaded) {
|
|||
|
+ this.save_loaded();
|
|||
|
+ $.cookie(s.save_loaded, this.data.core.to_load.join(","), s.cookie_options);
|
|||
|
+ }
|
|||
|
+ break;
|
|||
|
+ case "select_node":
|
|||
|
+ case "deselect_node":
|
|||
|
+ if(!!s.save_selected && this.data.ui) {
|
|||
|
+ this.save_selected();
|
|||
|
+ $.cookie(s.save_selected, this.data.ui.to_select.join(","), s.cookie_options);
|
|||
|
+ }
|
|||
|
+ break;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ // include cookies by default
|
|||
|
+ // $.jstree.defaults.plugins.push("cookies");
|
|||
|
+})(jQuery);
|
|||
|
+//*/
|
|||
|
+
|
|||
|
+/*
|
|||
|
+ * jsTree sort plugin
|
|||
|
+ * Sorts items alphabetically (or using any other function)
|
|||
|
+ */
|
|||
|
+(function ($) {
|
|||
|
+ $.jstree.plugin("sort", {
|
|||
|
+ __init : function () {
|
|||
|
+ this.get_container()
|
|||
|
+ .bind("load_node.jstree", $.proxy(function (e, data) {
|
|||
|
+ var obj = this._get_node(data.rslt.obj);
|
|||
|
+ obj = obj === -1 ? this.get_container().children("ul") : obj.children("ul");
|
|||
|
+ this.sort(obj);
|
|||
|
+ }, this))
|
|||
|
+ .bind("rename_node.jstree create_node.jstree create.jstree", $.proxy(function (e, data) {
|
|||
|
+ this.sort(data.rslt.obj.parent());
|
|||
|
+ }, this))
|
|||
|
+ .bind("move_node.jstree", $.proxy(function (e, data) {
|
|||
|
+ var m = data.rslt.np == -1 ? this.get_container() : data.rslt.np;
|
|||
|
+ this.sort(m.children("ul"));
|
|||
|
+ }, this));
|
|||
|
+ },
|
|||
|
+ defaults : function (a, b) { return this.get_text(a) > this.get_text(b) ? 1 : -1; },
|
|||
|
+ _fn : {
|
|||
|
+ sort : function (obj) {
|
|||
|
+ var s = this._get_settings().sort,
|
|||
|
+ t = this;
|
|||
|
+ obj.append($.makeArray(obj.children("li")).sort($.proxy(s, t)));
|
|||
|
+ obj.find("> li > ul").each(function() { t.sort($(this)); });
|
|||
|
+ this.clean_node(obj);
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+})(jQuery);
|
|||
|
+//*/
|
|||
|
+
|
|||
|
+/*
|
|||
|
+ * jsTree DND plugin
|
|||
|
+ * Drag and drop plugin for moving/copying nodes
|
|||
|
+ */
|
|||
|
+(function ($) {
|
|||
|
+ var o = false,
|
|||
|
+ r = false,
|
|||
|
+ m = false,
|
|||
|
+ ml = false,
|
|||
|
+ sli = false,
|
|||
|
+ sti = false,
|
|||
|
+ dir1 = false,
|
|||
|
+ dir2 = false,
|
|||
|
+ last_pos = false;
|
|||
|
+ $.vakata.dnd = {
|
|||
|
+ is_down : false,
|
|||
|
+ is_drag : false,
|
|||
|
+ helper : false,
|
|||
|
+ scroll_spd : 10,
|
|||
|
+ init_x : 0,
|
|||
|
+ init_y : 0,
|
|||
|
+ threshold : 5,
|
|||
|
+ helper_left : 5,
|
|||
|
+ helper_top : 10,
|
|||
|
+ user_data : {},
|
|||
|
+
|
|||
|
+ drag_start : function (e, data, html) {
|
|||
|
+ if($.vakata.dnd.is_drag) { $.vakata.drag_stop({}); }
|
|||
|
+ try {
|
|||
|
+ e.currentTarget.unselectable = "on";
|
|||
|
+ e.currentTarget.onselectstart = function() { return false; };
|
|||
|
+ if(e.currentTarget.style) { e.currentTarget.style.MozUserSelect = "none"; }
|
|||
|
+ } catch(err) { }
|
|||
|
+ $.vakata.dnd.init_x = e.pageX;
|
|||
|
+ $.vakata.dnd.init_y = e.pageY;
|
|||
|
+ $.vakata.dnd.user_data = data;
|
|||
|
+ $.vakata.dnd.is_down = true;
|
|||
|
+ $.vakata.dnd.helper = $("<div id='vakata-dragged' />").html(html); //.fadeTo(10,0.25);
|
|||
|
+ $(document).bind("mousemove", $.vakata.dnd.drag);
|
|||
|
+ $(document).bind("mouseup", $.vakata.dnd.drag_stop);
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+ drag : function (e) {
|
|||
|
+ if(!$.vakata.dnd.is_down) { return; }
|
|||
|
+ if(!$.vakata.dnd.is_drag) {
|
|||
|
+ if(Math.abs(e.pageX - $.vakata.dnd.init_x) > 5 || Math.abs(e.pageY - $.vakata.dnd.init_y) > 5) {
|
|||
|
+ $.vakata.dnd.helper.appendTo("body");
|
|||
|
+ $.vakata.dnd.is_drag = true;
|
|||
|
+ $(document).triggerHandler("drag_start.vakata", { "event" : e, "data" : $.vakata.dnd.user_data });
|
|||
|
+ }
|
|||
|
+ else { return; }
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ // maybe use a scrolling parent element instead of document?
|
|||
|
+ if(e.type === "mousemove") { // thought of adding scroll in order to move the helper, but mouse poisition is n/a
|
|||
|
+ var d = $(document), t = d.scrollTop(), l = d.scrollLeft();
|
|||
|
+ if(e.pageY - t < 20) {
|
|||
|
+ if(sti && dir1 === "down") { clearInterval(sti); sti = false; }
|
|||
|
+ if(!sti) { dir1 = "up"; sti = setInterval(function () { $(document).scrollTop($(document).scrollTop() - $.vakata.dnd.scroll_spd); }, 150); }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(sti && dir1 === "up") { clearInterval(sti); sti = false; }
|
|||
|
+ }
|
|||
|
+ if($(window).height() - (e.pageY - t) < 20) {
|
|||
|
+ if(sti && dir1 === "up") { clearInterval(sti); sti = false; }
|
|||
|
+ if(!sti) { dir1 = "down"; sti = setInterval(function () { $(document).scrollTop($(document).scrollTop() + $.vakata.dnd.scroll_spd); }, 150); }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(sti && dir1 === "down") { clearInterval(sti); sti = false; }
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ if(e.pageX - l < 20) {
|
|||
|
+ if(sli && dir2 === "right") { clearInterval(sli); sli = false; }
|
|||
|
+ if(!sli) { dir2 = "left"; sli = setInterval(function () { $(document).scrollLeft($(document).scrollLeft() - $.vakata.dnd.scroll_spd); }, 150); }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(sli && dir2 === "left") { clearInterval(sli); sli = false; }
|
|||
|
+ }
|
|||
|
+ if($(window).width() - (e.pageX - l) < 20) {
|
|||
|
+ if(sli && dir2 === "left") { clearInterval(sli); sli = false; }
|
|||
|
+ if(!sli) { dir2 = "right"; sli = setInterval(function () { $(document).scrollLeft($(document).scrollLeft() + $.vakata.dnd.scroll_spd); }, 150); }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(sli && dir2 === "right") { clearInterval(sli); sli = false; }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ $.vakata.dnd.helper.css({ left : (e.pageX + $.vakata.dnd.helper_left) + "px", top : (e.pageY + $.vakata.dnd.helper_top) + "px" });
|
|||
|
+ $(document).triggerHandler("drag.vakata", { "event" : e, "data" : $.vakata.dnd.user_data });
|
|||
|
+ },
|
|||
|
+ drag_stop : function (e) {
|
|||
|
+ if(sli) { clearInterval(sli); }
|
|||
|
+ if(sti) { clearInterval(sti); }
|
|||
|
+ $(document).unbind("mousemove", $.vakata.dnd.drag);
|
|||
|
+ $(document).unbind("mouseup", $.vakata.dnd.drag_stop);
|
|||
|
+ $(document).triggerHandler("drag_stop.vakata", { "event" : e, "data" : $.vakata.dnd.user_data });
|
|||
|
+ $.vakata.dnd.helper.remove();
|
|||
|
+ $.vakata.dnd.init_x = 0;
|
|||
|
+ $.vakata.dnd.init_y = 0;
|
|||
|
+ $.vakata.dnd.user_data = {};
|
|||
|
+ $.vakata.dnd.is_down = false;
|
|||
|
+ $.vakata.dnd.is_drag = false;
|
|||
|
+ }
|
|||
|
+ };
|
|||
|
+ $(function() {
|
|||
|
+ var css_string = '#vakata-dragged { display:block; margin:0 0 0 0; padding:4px 4px 4px 24px; position:absolute; top:-2000px; line-height:16px; z-index:10000; } ';
|
|||
|
+ $.vakata.css.add_sheet({ str : css_string, title : "vakata" });
|
|||
|
+ });
|
|||
|
+
|
|||
|
+ $.jstree.plugin("dnd", {
|
|||
|
+ __init : function () {
|
|||
|
+ this.data.dnd = {
|
|||
|
+ active : false,
|
|||
|
+ after : false,
|
|||
|
+ inside : false,
|
|||
|
+ before : false,
|
|||
|
+ off : false,
|
|||
|
+ prepared : false,
|
|||
|
+ w : 0,
|
|||
|
+ to1 : false,
|
|||
|
+ to2 : false,
|
|||
|
+ cof : false,
|
|||
|
+ cw : false,
|
|||
|
+ ch : false,
|
|||
|
+ i1 : false,
|
|||
|
+ i2 : false,
|
|||
|
+ mto : false
|
|||
|
+ };
|
|||
|
+ this.get_container()
|
|||
|
+ .bind("mouseenter.jstree", $.proxy(function (e) {
|
|||
|
+ if($.vakata.dnd.is_drag && $.vakata.dnd.user_data.jstree) {
|
|||
|
+ if(this.data.themes) {
|
|||
|
+ m.attr("class", "jstree-" + this.data.themes.theme);
|
|||
|
+ if(ml) { ml.attr("class", "jstree-" + this.data.themes.theme); }
|
|||
|
+ $.vakata.dnd.helper.attr("class", "jstree-dnd-helper jstree-" + this.data.themes.theme);
|
|||
|
+ }
|
|||
|
+ //if($(e.currentTarget).find("> ul > li").length === 0) {
|
|||
|
+ if(e.currentTarget === e.target && $.vakata.dnd.user_data.obj && $($.vakata.dnd.user_data.obj).length && $($.vakata.dnd.user_data.obj).parents(".jstree:eq(0)")[0] !== e.target) { // node should not be from the same tree
|
|||
|
+ var tr = $.jstree._reference(e.target), dc;
|
|||
|
+ if(tr.data.dnd.foreign) {
|
|||
|
+ dc = tr._get_settings().dnd.drag_check.call(this, { "o" : o, "r" : tr.get_container(), is_root : true });
|
|||
|
+ if(dc === true || dc.inside === true || dc.before === true || dc.after === true) {
|
|||
|
+ $.vakata.dnd.helper.children("ins").attr("class","jstree-ok");
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ tr.prepare_move(o, tr.get_container(), "last");
|
|||
|
+ if(tr.check_move()) {
|
|||
|
+ $.vakata.dnd.helper.children("ins").attr("class","jstree-ok");
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }, this))
|
|||
|
+ .bind("mouseup.jstree", $.proxy(function (e) {
|
|||
|
+ //if($.vakata.dnd.is_drag && $.vakata.dnd.user_data.jstree && $(e.currentTarget).find("> ul > li").length === 0) {
|
|||
|
+ if($.vakata.dnd.is_drag && $.vakata.dnd.user_data.jstree && e.currentTarget === e.target && $.vakata.dnd.user_data.obj && $($.vakata.dnd.user_data.obj).length && $($.vakata.dnd.user_data.obj).parents(".jstree:eq(0)")[0] !== e.target) { // node should not be from the same tree
|
|||
|
+ var tr = $.jstree._reference(e.currentTarget), dc;
|
|||
|
+ if(tr.data.dnd.foreign) {
|
|||
|
+ dc = tr._get_settings().dnd.drag_check.call(this, { "o" : o, "r" : tr.get_container(), is_root : true });
|
|||
|
+ if(dc === true || dc.inside === true || dc.before === true || dc.after === true) {
|
|||
|
+ tr._get_settings().dnd.drag_finish.call(this, { "o" : o, "r" : tr.get_container(), is_root : true });
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ tr.move_node(o, tr.get_container(), "last", e[tr._get_settings().dnd.copy_modifier + "Key"]);
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }, this))
|
|||
|
+ .bind("mouseleave.jstree", $.proxy(function (e) {
|
|||
|
+ if(e.relatedTarget && e.relatedTarget.id && e.relatedTarget.id === "jstree-marker-line") {
|
|||
|
+ return false;
|
|||
|
+ }
|
|||
|
+ if($.vakata.dnd.is_drag && $.vakata.dnd.user_data.jstree) {
|
|||
|
+ if(this.data.dnd.i1) { clearInterval(this.data.dnd.i1); }
|
|||
|
+ if(this.data.dnd.i2) { clearInterval(this.data.dnd.i2); }
|
|||
|
+ if(this.data.dnd.to1) { clearTimeout(this.data.dnd.to1); }
|
|||
|
+ if(this.data.dnd.to2) { clearTimeout(this.data.dnd.to2); }
|
|||
|
+ if($.vakata.dnd.helper.children("ins").hasClass("jstree-ok")) {
|
|||
|
+ $.vakata.dnd.helper.children("ins").attr("class","jstree-invalid");
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }, this))
|
|||
|
+ .bind("mousemove.jstree", $.proxy(function (e) {
|
|||
|
+ if($.vakata.dnd.is_drag && $.vakata.dnd.user_data.jstree) {
|
|||
|
+ var cnt = this.get_container()[0];
|
|||
|
+
|
|||
|
+ // Horizontal scroll
|
|||
|
+ if(e.pageX + 24 > this.data.dnd.cof.left + this.data.dnd.cw) {
|
|||
|
+ if(this.data.dnd.i1) { clearInterval(this.data.dnd.i1); }
|
|||
|
+ this.data.dnd.i1 = setInterval($.proxy(function () { this.scrollLeft += $.vakata.dnd.scroll_spd; }, cnt), 100);
|
|||
|
+ }
|
|||
|
+ else if(e.pageX - 24 < this.data.dnd.cof.left) {
|
|||
|
+ if(this.data.dnd.i1) { clearInterval(this.data.dnd.i1); }
|
|||
|
+ this.data.dnd.i1 = setInterval($.proxy(function () { this.scrollLeft -= $.vakata.dnd.scroll_spd; }, cnt), 100);
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(this.data.dnd.i1) { clearInterval(this.data.dnd.i1); }
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ // Vertical scroll
|
|||
|
+ if(e.pageY + 24 > this.data.dnd.cof.top + this.data.dnd.ch) {
|
|||
|
+ if(this.data.dnd.i2) { clearInterval(this.data.dnd.i2); }
|
|||
|
+ this.data.dnd.i2 = setInterval($.proxy(function () { this.scrollTop += $.vakata.dnd.scroll_spd; }, cnt), 100);
|
|||
|
+ }
|
|||
|
+ else if(e.pageY - 24 < this.data.dnd.cof.top) {
|
|||
|
+ if(this.data.dnd.i2) { clearInterval(this.data.dnd.i2); }
|
|||
|
+ this.data.dnd.i2 = setInterval($.proxy(function () { this.scrollTop -= $.vakata.dnd.scroll_spd; }, cnt), 100);
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(this.data.dnd.i2) { clearInterval(this.data.dnd.i2); }
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ }
|
|||
|
+ }, this))
|
|||
|
+ .bind("scroll.jstree", $.proxy(function (e) {
|
|||
|
+ if($.vakata.dnd.is_drag && $.vakata.dnd.user_data.jstree && m && ml) {
|
|||
|
+ m.hide();
|
|||
|
+ ml.hide();
|
|||
|
+ }
|
|||
|
+ }, this))
|
|||
|
+ .delegate("a", "mousedown.jstree", $.proxy(function (e) {
|
|||
|
+ if(e.which === 1) {
|
|||
|
+ this.start_drag(e.currentTarget, e);
|
|||
|
+ return false;
|
|||
|
+ }
|
|||
|
+ }, this))
|
|||
|
+ .delegate("a", "mouseenter.jstree", $.proxy(function (e) {
|
|||
|
+ if($.vakata.dnd.is_drag && $.vakata.dnd.user_data.jstree) {
|
|||
|
+ this.dnd_enter(e.currentTarget);
|
|||
|
+ }
|
|||
|
+ }, this))
|
|||
|
+ .delegate("a", "mousemove.jstree", $.proxy(function (e) {
|
|||
|
+ if($.vakata.dnd.is_drag && $.vakata.dnd.user_data.jstree) {
|
|||
|
+ if(!r || !r.length || r.children("a")[0] !== e.currentTarget) {
|
|||
|
+ this.dnd_enter(e.currentTarget);
|
|||
|
+ }
|
|||
|
+ if(typeof this.data.dnd.off.top === "undefined") { this.data.dnd.off = $(e.target).offset(); }
|
|||
|
+ this.data.dnd.w = (e.pageY - (this.data.dnd.off.top || 0)) % this.data.core.li_height;
|
|||
|
+ if(this.data.dnd.w < 0) { this.data.dnd.w += this.data.core.li_height; }
|
|||
|
+ this.dnd_show();
|
|||
|
+ }
|
|||
|
+ }, this))
|
|||
|
+ .delegate("a", "mouseleave.jstree", $.proxy(function (e) {
|
|||
|
+ if($.vakata.dnd.is_drag && $.vakata.dnd.user_data.jstree) {
|
|||
|
+ if(e.relatedTarget && e.relatedTarget.id && e.relatedTarget.id === "jstree-marker-line") {
|
|||
|
+ return false;
|
|||
|
+ }
|
|||
|
+ if(m) { m.hide(); }
|
|||
|
+ if(ml) { ml.hide(); }
|
|||
|
+ /*
|
|||
|
+ var ec = $(e.currentTarget).closest("li"),
|
|||
|
+ er = $(e.relatedTarget).closest("li");
|
|||
|
+ if(er[0] !== ec.prev()[0] && er[0] !== ec.next()[0]) {
|
|||
|
+ if(m) { m.hide(); }
|
|||
|
+ if(ml) { ml.hide(); }
|
|||
|
+ }
|
|||
|
+ */
|
|||
|
+ this.data.dnd.mto = setTimeout(
|
|||
|
+ (function (t) { return function () { t.dnd_leave(e); }; })(this),
|
|||
|
+ 0);
|
|||
|
+ }
|
|||
|
+ }, this))
|
|||
|
+ .delegate("a", "mouseup.jstree", $.proxy(function (e) {
|
|||
|
+ if($.vakata.dnd.is_drag && $.vakata.dnd.user_data.jstree) {
|
|||
|
+ this.dnd_finish(e);
|
|||
|
+ }
|
|||
|
+ }, this));
|
|||
|
+
|
|||
|
+ $(document)
|
|||
|
+ .bind("drag_stop.vakata", $.proxy(function () {
|
|||
|
+ if(this.data.dnd.to1) { clearTimeout(this.data.dnd.to1); }
|
|||
|
+ if(this.data.dnd.to2) { clearTimeout(this.data.dnd.to2); }
|
|||
|
+ if(this.data.dnd.i1) { clearInterval(this.data.dnd.i1); }
|
|||
|
+ if(this.data.dnd.i2) { clearInterval(this.data.dnd.i2); }
|
|||
|
+ this.data.dnd.after = false;
|
|||
|
+ this.data.dnd.before = false;
|
|||
|
+ this.data.dnd.inside = false;
|
|||
|
+ this.data.dnd.off = false;
|
|||
|
+ this.data.dnd.prepared = false;
|
|||
|
+ this.data.dnd.w = false;
|
|||
|
+ this.data.dnd.to1 = false;
|
|||
|
+ this.data.dnd.to2 = false;
|
|||
|
+ this.data.dnd.i1 = false;
|
|||
|
+ this.data.dnd.i2 = false;
|
|||
|
+ this.data.dnd.active = false;
|
|||
|
+ this.data.dnd.foreign = false;
|
|||
|
+ if(m) { m.css({ "top" : "-2000px" }); }
|
|||
|
+ if(ml) { ml.css({ "top" : "-2000px" }); }
|
|||
|
+ }, this))
|
|||
|
+ .bind("drag_start.vakata", $.proxy(function (e, data) {
|
|||
|
+ if(data.data.jstree) {
|
|||
|
+ var et = $(data.event.target);
|
|||
|
+ if(et.closest(".jstree").hasClass("jstree-" + this.get_index())) {
|
|||
|
+ this.dnd_enter(et);
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }, this));
|
|||
|
+ /*
|
|||
|
+ .bind("keydown.jstree-" + this.get_index() + " keyup.jstree-" + this.get_index(), $.proxy(function(e) {
|
|||
|
+ if($.vakata.dnd.is_drag && $.vakata.dnd.user_data.jstree && !this.data.dnd.foreign) {
|
|||
|
+ var h = $.vakata.dnd.helper.children("ins");
|
|||
|
+ if(e[this._get_settings().dnd.copy_modifier + "Key"] && h.hasClass("jstree-ok")) {
|
|||
|
+ h.parent().html(h.parent().html().replace(/ \(Copy\)$/, "") + " (Copy)");
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ h.parent().html(h.parent().html().replace(/ \(Copy\)$/, ""));
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }, this)); */
|
|||
|
+
|
|||
|
+
|
|||
|
+
|
|||
|
+ var s = this._get_settings().dnd;
|
|||
|
+ if(s.drag_target) {
|
|||
|
+ $(document)
|
|||
|
+ .delegate(s.drag_target, "mousedown.jstree-" + this.get_index(), $.proxy(function (e) {
|
|||
|
+ o = e.target;
|
|||
|
+ $.vakata.dnd.drag_start(e, { jstree : true, obj : e.target }, "<ins class='jstree-icon'></ins>" + $(e.target).text() );
|
|||
|
+ if(this.data.themes) {
|
|||
|
+ if(m) { m.attr("class", "jstree-" + this.data.themes.theme); }
|
|||
|
+ if(ml) { ml.attr("class", "jstree-" + this.data.themes.theme); }
|
|||
|
+ $.vakata.dnd.helper.attr("class", "jstree-dnd-helper jstree-" + this.data.themes.theme);
|
|||
|
+ }
|
|||
|
+ $.vakata.dnd.helper.children("ins").attr("class","jstree-invalid");
|
|||
|
+ var cnt = this.get_container();
|
|||
|
+ this.data.dnd.cof = cnt.offset();
|
|||
|
+ this.data.dnd.cw = parseInt(cnt.width(),10);
|
|||
|
+ this.data.dnd.ch = parseInt(cnt.height(),10);
|
|||
|
+ this.data.dnd.foreign = true;
|
|||
|
+ e.preventDefault();
|
|||
|
+ }, this));
|
|||
|
+ }
|
|||
|
+ if(s.drop_target) {
|
|||
|
+ $(document)
|
|||
|
+ .delegate(s.drop_target, "mouseenter.jstree-" + this.get_index(), $.proxy(function (e) {
|
|||
|
+ if(this.data.dnd.active && this._get_settings().dnd.drop_check.call(this, { "o" : o, "r" : $(e.target), "e" : e })) {
|
|||
|
+ $.vakata.dnd.helper.children("ins").attr("class","jstree-ok");
|
|||
|
+ }
|
|||
|
+ }, this))
|
|||
|
+ .delegate(s.drop_target, "mouseleave.jstree-" + this.get_index(), $.proxy(function (e) {
|
|||
|
+ if(this.data.dnd.active) {
|
|||
|
+ $.vakata.dnd.helper.children("ins").attr("class","jstree-invalid");
|
|||
|
+ }
|
|||
|
+ }, this))
|
|||
|
+ .delegate(s.drop_target, "mouseup.jstree-" + this.get_index(), $.proxy(function (e) {
|
|||
|
+ if(this.data.dnd.active && $.vakata.dnd.helper.children("ins").hasClass("jstree-ok")) {
|
|||
|
+ this._get_settings().dnd.drop_finish.call(this, { "o" : o, "r" : $(e.target), "e" : e });
|
|||
|
+ }
|
|||
|
+ }, this));
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ defaults : {
|
|||
|
+ copy_modifier : "ctrl",
|
|||
|
+ check_timeout : 100,
|
|||
|
+ open_timeout : 500,
|
|||
|
+ drop_target : ".jstree-drop",
|
|||
|
+ drop_check : function (data) { return true; },
|
|||
|
+ drop_finish : $.noop,
|
|||
|
+ drag_target : ".jstree-draggable",
|
|||
|
+ drag_finish : $.noop,
|
|||
|
+ drag_check : function (data) { return { after : false, before : false, inside : true }; }
|
|||
|
+ },
|
|||
|
+ _fn : {
|
|||
|
+ dnd_prepare : function () {
|
|||
|
+ if(!r || !r.length) { return; }
|
|||
|
+ this.data.dnd.off = r.offset();
|
|||
|
+ if(this._get_settings().core.rtl) {
|
|||
|
+ this.data.dnd.off.right = this.data.dnd.off.left + r.width();
|
|||
|
+ }
|
|||
|
+ if(this.data.dnd.foreign) {
|
|||
|
+ var a = this._get_settings().dnd.drag_check.call(this, { "o" : o, "r" : r });
|
|||
|
+ this.data.dnd.after = a.after;
|
|||
|
+ this.data.dnd.before = a.before;
|
|||
|
+ this.data.dnd.inside = a.inside;
|
|||
|
+ this.data.dnd.prepared = true;
|
|||
|
+ return this.dnd_show();
|
|||
|
+ }
|
|||
|
+ this.prepare_move(o, r, "before");
|
|||
|
+ this.data.dnd.before = this.check_move();
|
|||
|
+ this.prepare_move(o, r, "after");
|
|||
|
+ this.data.dnd.after = this.check_move();
|
|||
|
+ if(this._is_loaded(r)) {
|
|||
|
+ this.prepare_move(o, r, "inside");
|
|||
|
+ this.data.dnd.inside = this.check_move();
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ this.data.dnd.inside = false;
|
|||
|
+ }
|
|||
|
+ this.data.dnd.prepared = true;
|
|||
|
+ return this.dnd_show();
|
|||
|
+ },
|
|||
|
+ dnd_show : function () {
|
|||
|
+ if(!this.data.dnd.prepared) { return; }
|
|||
|
+ var o = ["before","inside","after"],
|
|||
|
+ r = false,
|
|||
|
+ rtl = this._get_settings().core.rtl,
|
|||
|
+ pos;
|
|||
|
+ if(this.data.dnd.w < this.data.core.li_height/3) { o = ["before","inside","after"]; }
|
|||
|
+ else if(this.data.dnd.w <= this.data.core.li_height*2/3) {
|
|||
|
+ o = this.data.dnd.w < this.data.core.li_height/2 ? ["inside","before","after"] : ["inside","after","before"];
|
|||
|
+ }
|
|||
|
+ else { o = ["after","inside","before"]; }
|
|||
|
+ $.each(o, $.proxy(function (i, val) {
|
|||
|
+ if(this.data.dnd[val]) {
|
|||
|
+ $.vakata.dnd.helper.children("ins").attr("class","jstree-ok");
|
|||
|
+ r = val;
|
|||
|
+ return false;
|
|||
|
+ }
|
|||
|
+ }, this));
|
|||
|
+ if(r === false) { $.vakata.dnd.helper.children("ins").attr("class","jstree-invalid"); }
|
|||
|
+
|
|||
|
+ pos = rtl ? (this.data.dnd.off.right - 18) : (this.data.dnd.off.left + 10);
|
|||
|
+ switch(r) {
|
|||
|
+ case "before":
|
|||
|
+ m.css({ "left" : pos + "px", "top" : (this.data.dnd.off.top - 6) + "px" }).show();
|
|||
|
+ if(ml) { ml.css({ "left" : (pos + 8) + "px", "top" : (this.data.dnd.off.top - 1) + "px" }).show(); }
|
|||
|
+ break;
|
|||
|
+ case "after":
|
|||
|
+ m.css({ "left" : pos + "px", "top" : (this.data.dnd.off.top + this.data.core.li_height - 6) + "px" }).show();
|
|||
|
+ if(ml) { ml.css({ "left" : (pos + 8) + "px", "top" : (this.data.dnd.off.top + this.data.core.li_height - 1) + "px" }).show(); }
|
|||
|
+ break;
|
|||
|
+ case "inside":
|
|||
|
+ m.css({ "left" : pos + ( rtl ? -4 : 4) + "px", "top" : (this.data.dnd.off.top + this.data.core.li_height/2 - 5) + "px" }).show();
|
|||
|
+ if(ml) { ml.hide(); }
|
|||
|
+ break;
|
|||
|
+ default:
|
|||
|
+ m.hide();
|
|||
|
+ if(ml) { ml.hide(); }
|
|||
|
+ break;
|
|||
|
+ }
|
|||
|
+ last_pos = r;
|
|||
|
+ return r;
|
|||
|
+ },
|
|||
|
+ dnd_open : function () {
|
|||
|
+ this.data.dnd.to2 = false;
|
|||
|
+ this.open_node(r, $.proxy(this.dnd_prepare,this), true);
|
|||
|
+ },
|
|||
|
+ dnd_finish : function (e) {
|
|||
|
+ if(this.data.dnd.foreign) {
|
|||
|
+ if(this.data.dnd.after || this.data.dnd.before || this.data.dnd.inside) {
|
|||
|
+ this._get_settings().dnd.drag_finish.call(this, { "o" : o, "r" : r, "p" : last_pos });
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ this.dnd_prepare();
|
|||
|
+ this.move_node(o, r, last_pos, e[this._get_settings().dnd.copy_modifier + "Key"]);
|
|||
|
+ }
|
|||
|
+ o = false;
|
|||
|
+ r = false;
|
|||
|
+ m.hide();
|
|||
|
+ if(ml) { ml.hide(); }
|
|||
|
+ },
|
|||
|
+ dnd_enter : function (obj) {
|
|||
|
+ if(this.data.dnd.mto) {
|
|||
|
+ clearTimeout(this.data.dnd.mto);
|
|||
|
+ this.data.dnd.mto = false;
|
|||
|
+ }
|
|||
|
+ var s = this._get_settings().dnd;
|
|||
|
+ this.data.dnd.prepared = false;
|
|||
|
+ r = this._get_node(obj);
|
|||
|
+ if(s.check_timeout) {
|
|||
|
+ // do the calculations after a minimal timeout (users tend to drag quickly to the desired location)
|
|||
|
+ if(this.data.dnd.to1) { clearTimeout(this.data.dnd.to1); }
|
|||
|
+ this.data.dnd.to1 = setTimeout($.proxy(this.dnd_prepare, this), s.check_timeout);
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ this.dnd_prepare();
|
|||
|
+ }
|
|||
|
+ if(s.open_timeout) {
|
|||
|
+ if(this.data.dnd.to2) { clearTimeout(this.data.dnd.to2); }
|
|||
|
+ if(r && r.length && r.hasClass("jstree-closed")) {
|
|||
|
+ // if the node is closed - open it, then recalculate
|
|||
|
+ this.data.dnd.to2 = setTimeout($.proxy(this.dnd_open, this), s.open_timeout);
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(r && r.length && r.hasClass("jstree-closed")) {
|
|||
|
+ this.dnd_open();
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ dnd_leave : function (e) {
|
|||
|
+ this.data.dnd.after = false;
|
|||
|
+ this.data.dnd.before = false;
|
|||
|
+ this.data.dnd.inside = false;
|
|||
|
+ $.vakata.dnd.helper.children("ins").attr("class","jstree-invalid");
|
|||
|
+ m.hide();
|
|||
|
+ if(ml) { ml.hide(); }
|
|||
|
+ if(r && r[0] === e.target.parentNode) {
|
|||
|
+ if(this.data.dnd.to1) {
|
|||
|
+ clearTimeout(this.data.dnd.to1);
|
|||
|
+ this.data.dnd.to1 = false;
|
|||
|
+ }
|
|||
|
+ if(this.data.dnd.to2) {
|
|||
|
+ clearTimeout(this.data.dnd.to2);
|
|||
|
+ this.data.dnd.to2 = false;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ start_drag : function (obj, e) {
|
|||
|
+ o = this._get_node(obj);
|
|||
|
+ if(this.data.ui && this.is_selected(o)) { o = this._get_node(null, true); }
|
|||
|
+ var dt = o.length > 1 ? this._get_string("multiple_selection") : this.get_text(o),
|
|||
|
+ cnt = this.get_container();
|
|||
|
+ if(!this._get_settings().core.html_titles) { dt = dt.replace(/</ig,"<").replace(/>/ig,">"); }
|
|||
|
+ $.vakata.dnd.drag_start(e, { jstree : true, obj : o }, "<ins class='jstree-icon'></ins>" + dt );
|
|||
|
+ if(this.data.themes) {
|
|||
|
+ if(m) { m.attr("class", "jstree-" + this.data.themes.theme); }
|
|||
|
+ if(ml) { ml.attr("class", "jstree-" + this.data.themes.theme); }
|
|||
|
+ $.vakata.dnd.helper.attr("class", "jstree-dnd-helper jstree-" + this.data.themes.theme);
|
|||
|
+ }
|
|||
|
+ this.data.dnd.cof = cnt.offset();
|
|||
|
+ this.data.dnd.cw = parseInt(cnt.width(),10);
|
|||
|
+ this.data.dnd.ch = parseInt(cnt.height(),10);
|
|||
|
+ this.data.dnd.active = true;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ $(function() {
|
|||
|
+ var css_string = '' +
|
|||
|
+ '#vakata-dragged ins { display:block; text-decoration:none; width:16px; height:16px; margin:0 0 0 0; padding:0; position:absolute; top:4px; left:4px; ' +
|
|||
|
+ ' -moz-border-radius:4px; border-radius:4px; -webkit-border-radius:4px; ' +
|
|||
|
+ '} ' +
|
|||
|
+ '#vakata-dragged .jstree-ok { background:green; } ' +
|
|||
|
+ '#vakata-dragged .jstree-invalid { background:red; } ' +
|
|||
|
+ '#jstree-marker { padding:0; margin:0; font-size:12px; overflow:hidden; height:12px; width:8px; position:absolute; top:-30px; z-index:10001; background-repeat:no-repeat; display:none; background-color:transparent; text-shadow:1px 1px 1px white; color:black; line-height:10px; } ' +
|
|||
|
+ '#jstree-marker-line { padding:0; margin:0; line-height:0%; font-size:1px; overflow:hidden; height:1px; width:100px; position:absolute; top:-30px; z-index:10000; background-repeat:no-repeat; display:none; background-color:#456c43; ' +
|
|||
|
+ ' cursor:pointer; border:1px solid #eeeeee; border-left:0; -moz-box-shadow: 0px 0px 2px #666; -webkit-box-shadow: 0px 0px 2px #666; box-shadow: 0px 0px 2px #666; ' +
|
|||
|
+ ' -moz-border-radius:1px; border-radius:1px; -webkit-border-radius:1px; ' +
|
|||
|
+ '}' +
|
|||
|
+ '';
|
|||
|
+ $.vakata.css.add_sheet({ str : css_string, title : "jstree" });
|
|||
|
+ m = $("<div />").attr({ id : "jstree-marker" }).hide().html("»")
|
|||
|
+ .bind("mouseleave mouseenter", function (e) {
|
|||
|
+ m.hide();
|
|||
|
+ ml.hide();
|
|||
|
+ e.preventDefault();
|
|||
|
+ e.stopImmediatePropagation();
|
|||
|
+ return false;
|
|||
|
+ })
|
|||
|
+ .appendTo("body");
|
|||
|
+ ml = $("<div />").attr({ id : "jstree-marker-line" }).hide()
|
|||
|
+ .bind("mouseup", function (e) {
|
|||
|
+ if(r && r.length) {
|
|||
|
+ r.children("a").trigger(e);
|
|||
|
+ e.preventDefault();
|
|||
|
+ e.stopImmediatePropagation();
|
|||
|
+ return false;
|
|||
|
+ }
|
|||
|
+ })
|
|||
|
+ .bind("mouseleave", function (e) {
|
|||
|
+ var rt = $(e.relatedTarget);
|
|||
|
+ if(rt.is(".jstree") || rt.closest(".jstree").length === 0) {
|
|||
|
+ if(r && r.length) {
|
|||
|
+ r.children("a").trigger(e);
|
|||
|
+ m.hide();
|
|||
|
+ ml.hide();
|
|||
|
+ e.preventDefault();
|
|||
|
+ e.stopImmediatePropagation();
|
|||
|
+ return false;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ })
|
|||
|
+ .appendTo("body");
|
|||
|
+ $(document).bind("drag_start.vakata", function (e, data) {
|
|||
|
+ if(data.data.jstree) { m.show(); if(ml) { ml.show(); } }
|
|||
|
+ });
|
|||
|
+ $(document).bind("drag_stop.vakata", function (e, data) {
|
|||
|
+ if(data.data.jstree) { m.hide(); if(ml) { ml.hide(); } }
|
|||
|
+ });
|
|||
|
+ });
|
|||
|
+})(jQuery);
|
|||
|
+//*/
|
|||
|
+
|
|||
|
+/*
|
|||
|
+ * jsTree checkbox plugin
|
|||
|
+ * Inserts checkboxes in front of every node
|
|||
|
+ * Depends on the ui plugin
|
|||
|
+ * DOES NOT WORK NICELY WITH MULTITREE DRAG'N'DROP
|
|||
|
+ */
|
|||
|
+(function ($) {
|
|||
|
+ $.jstree.plugin("checkbox", {
|
|||
|
+ __init : function () {
|
|||
|
+ this.data.checkbox.noui = this._get_settings().checkbox.override_ui;
|
|||
|
+ if(this.data.ui && this.data.checkbox.noui) {
|
|||
|
+ this.select_node = this.deselect_node = this.deselect_all = $.noop;
|
|||
|
+ this.get_selected = this.get_checked;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ this.get_container()
|
|||
|
+ .bind("open_node.jstree create_node.jstree clean_node.jstree refresh.jstree", $.proxy(function (e, data) {
|
|||
|
+ this._prepare_checkboxes(data.rslt.obj);
|
|||
|
+ }, this))
|
|||
|
+ .bind("loaded.jstree", $.proxy(function (e) {
|
|||
|
+ this._prepare_checkboxes();
|
|||
|
+ }, this))
|
|||
|
+ .delegate( (this.data.ui && this.data.checkbox.noui ? "a" : "ins.jstree-checkbox") , "click.jstree", $.proxy(function (e) {
|
|||
|
+ e.preventDefault();
|
|||
|
+ if(this._get_node(e.target).hasClass("jstree-checked")) { this.uncheck_node(e.target); }
|
|||
|
+ else { this.check_node(e.target); }
|
|||
|
+ if(this.data.ui && this.data.checkbox.noui) {
|
|||
|
+ this.save_selected();
|
|||
|
+ if(this.data.cookies) { this.save_cookie("select_node"); }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ e.stopImmediatePropagation();
|
|||
|
+ return false;
|
|||
|
+ }
|
|||
|
+ }, this));
|
|||
|
+ },
|
|||
|
+ defaults : {
|
|||
|
+ override_ui : false,
|
|||
|
+ two_state : false,
|
|||
|
+ real_checkboxes : false,
|
|||
|
+ checked_parent_open : true,
|
|||
|
+ real_checkboxes_names : function (n) { return [ ("check_" + (n[0].id || Math.ceil(Math.random() * 10000))) , 1]; }
|
|||
|
+ },
|
|||
|
+ __destroy : function () {
|
|||
|
+ this.get_container()
|
|||
|
+ .find("input.jstree-real-checkbox").removeClass("jstree-real-checkbox").end()
|
|||
|
+ .find("ins.jstree-checkbox").remove();
|
|||
|
+ },
|
|||
|
+ _fn : {
|
|||
|
+ _checkbox_notify : function (n, data) {
|
|||
|
+ if(data.checked) {
|
|||
|
+ this.check_node(n, false);
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ _prepare_checkboxes : function (obj) {
|
|||
|
+ obj = !obj || obj == -1 ? this.get_container().find("> ul > li") : this._get_node(obj);
|
|||
|
+ if(obj === false) { return; } // added for removing root nodes
|
|||
|
+ var c, _this = this, t, ts = this._get_settings().checkbox.two_state, rc = this._get_settings().checkbox.real_checkboxes, rcn = this._get_settings().checkbox.real_checkboxes_names;
|
|||
|
+ obj.each(function () {
|
|||
|
+ t = $(this);
|
|||
|
+ c = t.is("li") && (t.hasClass("jstree-checked") || (rc && t.children(":checked").length)) ? "jstree-checked" : "jstree-unchecked";
|
|||
|
+ t.find("li").andSelf().each(function () {
|
|||
|
+ var $t = $(this), nm;
|
|||
|
+ $t.children("a" + (_this.data.languages ? "" : ":eq(0)") ).not(":has(.jstree-checkbox)").prepend("<ins class='jstree-checkbox'> </ins>").parent().not(".jstree-checked, .jstree-unchecked").addClass( ts ? "jstree-unchecked" : c );
|
|||
|
+ if(rc) {
|
|||
|
+ if(!$t.children(":checkbox").length) {
|
|||
|
+ nm = rcn.call(_this, $t);
|
|||
|
+ $t.prepend("<input type='checkbox' class='jstree-real-checkbox' id='" + nm[0] + "' name='" + nm[0] + "' value='" + nm[1] + "' />");
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ $t.children(":checkbox").addClass("jstree-real-checkbox");
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ if(!ts) {
|
|||
|
+ if(c === "jstree-checked" || $t.hasClass("jstree-checked") || $t.children(':checked').length) {
|
|||
|
+ $t.find("li").andSelf().addClass("jstree-checked").children(":checkbox").prop("checked", true);
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if($t.hasClass("jstree-checked") || $t.children(':checked').length) {
|
|||
|
+ $t.addClass("jstree-checked").children(":checkbox").prop("checked", true);
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ });
|
|||
|
+ if(!ts) {
|
|||
|
+ obj.find(".jstree-checked").parent().parent().each(function () { _this._repair_state(this); });
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ change_state : function (obj, state) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ var coll = false, rc = this._get_settings().checkbox.real_checkboxes;
|
|||
|
+ if(!obj || obj === -1) { return false; }
|
|||
|
+ state = (state === false || state === true) ? state : obj.hasClass("jstree-checked");
|
|||
|
+ if(this._get_settings().checkbox.two_state) {
|
|||
|
+ if(state) {
|
|||
|
+ obj.removeClass("jstree-checked").addClass("jstree-unchecked");
|
|||
|
+ if(rc) { obj.children(":checkbox").prop("checked", false); }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ obj.removeClass("jstree-unchecked").addClass("jstree-checked");
|
|||
|
+ if(rc) { obj.children(":checkbox").prop("checked", true); }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(state) {
|
|||
|
+ coll = obj.find("li").andSelf();
|
|||
|
+ if(!coll.filter(".jstree-checked, .jstree-undetermined").length) { return false; }
|
|||
|
+ coll.removeClass("jstree-checked jstree-undetermined").addClass("jstree-unchecked");
|
|||
|
+ if(rc) { coll.children(":checkbox").prop("checked", false); }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ coll = obj.find("li").andSelf();
|
|||
|
+ if(!coll.filter(".jstree-unchecked, .jstree-undetermined").length) { return false; }
|
|||
|
+ coll.removeClass("jstree-unchecked jstree-undetermined").addClass("jstree-checked");
|
|||
|
+ if(rc) { coll.children(":checkbox").prop("checked", true); }
|
|||
|
+ if(this.data.ui) { this.data.ui.last_selected = obj; }
|
|||
|
+ this.data.checkbox.last_selected = obj;
|
|||
|
+ }
|
|||
|
+ obj.parentsUntil(".jstree", "li").each(function () {
|
|||
|
+ var $this = $(this);
|
|||
|
+ if(state) {
|
|||
|
+ if($this.children("ul").children("li.jstree-checked, li.jstree-undetermined").length) {
|
|||
|
+ $this.parentsUntil(".jstree", "li").andSelf().removeClass("jstree-checked jstree-unchecked").addClass("jstree-undetermined");
|
|||
|
+ if(rc) { $this.parentsUntil(".jstree", "li").andSelf().children(":checkbox").prop("checked", false); }
|
|||
|
+ return false;
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ $this.removeClass("jstree-checked jstree-undetermined").addClass("jstree-unchecked");
|
|||
|
+ if(rc) { $this.children(":checkbox").prop("checked", false); }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if($this.children("ul").children("li.jstree-unchecked, li.jstree-undetermined").length) {
|
|||
|
+ $this.parentsUntil(".jstree", "li").andSelf().removeClass("jstree-checked jstree-unchecked").addClass("jstree-undetermined");
|
|||
|
+ if(rc) { $this.parentsUntil(".jstree", "li").andSelf().children(":checkbox").prop("checked", false); }
|
|||
|
+ return false;
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ $this.removeClass("jstree-unchecked jstree-undetermined").addClass("jstree-checked");
|
|||
|
+ if(rc) { $this.children(":checkbox").prop("checked", true); }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ if(this.data.ui && this.data.checkbox.noui) { this.data.ui.selected = this.get_checked(); }
|
|||
|
+ this.__callback(obj);
|
|||
|
+ return true;
|
|||
|
+ },
|
|||
|
+ check_node : function (obj) {
|
|||
|
+ if(this.change_state(obj, false)) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(this._get_settings().checkbox.checked_parent_open) {
|
|||
|
+ var t = this;
|
|||
|
+ obj.parents(".jstree-closed").each(function () { t.open_node(this, false, true); });
|
|||
|
+ }
|
|||
|
+ this.__callback({ "obj" : obj });
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ uncheck_node : function (obj) {
|
|||
|
+ if(this.change_state(obj, true)) { this.__callback({ "obj" : this._get_node(obj) }); }
|
|||
|
+ },
|
|||
|
+ check_all : function () {
|
|||
|
+ var _this = this,
|
|||
|
+ coll = this._get_settings().checkbox.two_state ? this.get_container_ul().find("li") : this.get_container_ul().children("li");
|
|||
|
+ coll.each(function () {
|
|||
|
+ _this.change_state(this, false);
|
|||
|
+ });
|
|||
|
+ this.__callback();
|
|||
|
+ },
|
|||
|
+ uncheck_all : function () {
|
|||
|
+ var _this = this,
|
|||
|
+ coll = this._get_settings().checkbox.two_state ? this.get_container_ul().find("li") : this.get_container_ul().children("li");
|
|||
|
+ coll.each(function () {
|
|||
|
+ _this.change_state(this, true);
|
|||
|
+ });
|
|||
|
+ this.__callback();
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ is_checked : function(obj) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ return obj.length ? obj.is(".jstree-checked") : false;
|
|||
|
+ },
|
|||
|
+ get_checked : function (obj, get_all) {
|
|||
|
+ obj = !obj || obj === -1 ? this.get_container() : this._get_node(obj);
|
|||
|
+ return get_all || this._get_settings().checkbox.two_state ? obj.find(".jstree-checked") : obj.find("> ul > .jstree-checked, .jstree-undetermined > ul > .jstree-checked");
|
|||
|
+ },
|
|||
|
+ get_unchecked : function (obj, get_all) {
|
|||
|
+ obj = !obj || obj === -1 ? this.get_container() : this._get_node(obj);
|
|||
|
+ return get_all || this._get_settings().checkbox.two_state ? obj.find(".jstree-unchecked") : obj.find("> ul > .jstree-unchecked, .jstree-undetermined > ul > .jstree-unchecked");
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ show_checkboxes : function () { this.get_container().children("ul").removeClass("jstree-no-checkboxes"); },
|
|||
|
+ hide_checkboxes : function () { this.get_container().children("ul").addClass("jstree-no-checkboxes"); },
|
|||
|
+
|
|||
|
+ _repair_state : function (obj) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(!obj.length) { return; }
|
|||
|
+ if(this._get_settings().checkbox.two_state) {
|
|||
|
+ obj.find('li').andSelf().not('.jstree-checked').removeClass('jstree-undetermined').addClass('jstree-unchecked').children(':checkbox').prop('checked', true);
|
|||
|
+ return;
|
|||
|
+ }
|
|||
|
+ var rc = this._get_settings().checkbox.real_checkboxes,
|
|||
|
+ a = obj.find("> ul > .jstree-checked").length,
|
|||
|
+ b = obj.find("> ul > .jstree-undetermined").length,
|
|||
|
+ c = obj.find("> ul > li").length;
|
|||
|
+ if(c === 0) { if(obj.hasClass("jstree-undetermined")) { this.change_state(obj, false); } }
|
|||
|
+ else if(a === 0 && b === 0) { this.change_state(obj, true); }
|
|||
|
+ else if(a === c) { this.change_state(obj, false); }
|
|||
|
+ else {
|
|||
|
+ obj.parentsUntil(".jstree","li").andSelf().removeClass("jstree-checked jstree-unchecked").addClass("jstree-undetermined");
|
|||
|
+ if(rc) { obj.parentsUntil(".jstree", "li").andSelf().children(":checkbox").prop("checked", false); }
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ reselect : function () {
|
|||
|
+ if(this.data.ui && this.data.checkbox.noui) {
|
|||
|
+ var _this = this,
|
|||
|
+ s = this.data.ui.to_select;
|
|||
|
+ s = $.map($.makeArray(s), function (n) { return "#" + n.toString().replace(/^#/,"").replace(/\\\//g,"/").replace(/\//g,"\\\/").replace(/\\\./g,".").replace(/\./g,"\\.").replace(/\:/g,"\\:"); });
|
|||
|
+ this.deselect_all();
|
|||
|
+ $.each(s, function (i, val) { _this.check_node(val); });
|
|||
|
+ this.__callback();
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ this.__call_old();
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ save_loaded : function () {
|
|||
|
+ var _this = this;
|
|||
|
+ this.data.core.to_load = [];
|
|||
|
+ this.get_container_ul().find("li.jstree-closed.jstree-undetermined").each(function () {
|
|||
|
+ if(this.id) { _this.data.core.to_load.push("#" + this.id); }
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ $(function() {
|
|||
|
+ var css_string = '.jstree .jstree-real-checkbox { display:none; } ';
|
|||
|
+ $.vakata.css.add_sheet({ str : css_string, title : "jstree" });
|
|||
|
+ });
|
|||
|
+})(jQuery);
|
|||
|
+//*/
|
|||
|
+
|
|||
|
+/*
|
|||
|
+ * jsTree XML plugin
|
|||
|
+ * The XML data store. Datastores are build by overriding the `load_node` and `_is_loaded` functions.
|
|||
|
+ */
|
|||
|
+(function ($) {
|
|||
|
+ $.vakata.xslt = function (xml, xsl, callback) {
|
|||
|
+ var rs = "", xm, xs, processor, support;
|
|||
|
+ // TODO: IE9 no XSLTProcessor, no document.recalc
|
|||
|
+ if(document.recalc) {
|
|||
|
+ xm = document.createElement('xml');
|
|||
|
+ xs = document.createElement('xml');
|
|||
|
+ xm.innerHTML = xml;
|
|||
|
+ xs.innerHTML = xsl;
|
|||
|
+ $("body").append(xm).append(xs);
|
|||
|
+ setTimeout( (function (xm, xs, callback) {
|
|||
|
+ return function () {
|
|||
|
+ callback.call(null, xm.transformNode(xs.XMLDocument));
|
|||
|
+ setTimeout( (function (xm, xs) { return function () { $(xm).remove(); $(xs).remove(); }; })(xm, xs), 200);
|
|||
|
+ };
|
|||
|
+ })(xm, xs, callback), 100);
|
|||
|
+ return true;
|
|||
|
+ }
|
|||
|
+ if(typeof window.DOMParser !== "undefined" && typeof window.XMLHttpRequest !== "undefined" && typeof window.XSLTProcessor === "undefined") {
|
|||
|
+ xml = new DOMParser().parseFromString(xml, "text/xml");
|
|||
|
+ xsl = new DOMParser().parseFromString(xsl, "text/xml");
|
|||
|
+ // alert(xml.transformNode());
|
|||
|
+ // callback.call(null, new XMLSerializer().serializeToString(rs));
|
|||
|
+
|
|||
|
+ }
|
|||
|
+ if(typeof window.DOMParser !== "undefined" && typeof window.XMLHttpRequest !== "undefined" && typeof window.XSLTProcessor !== "undefined") {
|
|||
|
+ processor = new XSLTProcessor();
|
|||
|
+ support = $.isFunction(processor.transformDocument) ? (typeof window.XMLSerializer !== "undefined") : true;
|
|||
|
+ if(!support) { return false; }
|
|||
|
+ xml = new DOMParser().parseFromString(xml, "text/xml");
|
|||
|
+ xsl = new DOMParser().parseFromString(xsl, "text/xml");
|
|||
|
+ if($.isFunction(processor.transformDocument)) {
|
|||
|
+ rs = document.implementation.createDocument("", "", null);
|
|||
|
+ processor.transformDocument(xml, xsl, rs, null);
|
|||
|
+ callback.call(null, new XMLSerializer().serializeToString(rs));
|
|||
|
+ return true;
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ processor.importStylesheet(xsl);
|
|||
|
+ rs = processor.transformToFragment(xml, document);
|
|||
|
+ callback.call(null, $("<div />").append(rs).html());
|
|||
|
+ return true;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ return false;
|
|||
|
+ };
|
|||
|
+ var xsl = {
|
|||
|
+ 'nest' : '<' + '?xml version="1.0" encoding="utf-8" ?>' +
|
|||
|
+ '<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" >' +
|
|||
|
+ '<xsl:output method="html" encoding="utf-8" omit-xml-declaration="yes" standalone="no" indent="no" media-type="text/html" />' +
|
|||
|
+ '<xsl:template match="/">' +
|
|||
|
+ ' <xsl:call-template name="nodes">' +
|
|||
|
+ ' <xsl:with-param name="node" select="/root" />' +
|
|||
|
+ ' </xsl:call-template>' +
|
|||
|
+ '</xsl:template>' +
|
|||
|
+ '<xsl:template name="nodes">' +
|
|||
|
+ ' <xsl:param name="node" />' +
|
|||
|
+ ' <ul>' +
|
|||
|
+ ' <xsl:for-each select="$node/item">' +
|
|||
|
+ ' <xsl:variable name="children" select="count(./item) > 0" />' +
|
|||
|
+ ' <li>' +
|
|||
|
+ ' <xsl:attribute name="class">' +
|
|||
|
+ ' <xsl:if test="position() = last()">jstree-last </xsl:if>' +
|
|||
|
+ ' <xsl:choose>' +
|
|||
|
+ ' <xsl:when test="@state = \'open\'">jstree-open </xsl:when>' +
|
|||
|
+ ' <xsl:when test="$children or @hasChildren or @state = \'closed\'">jstree-closed </xsl:when>' +
|
|||
|
+ ' <xsl:otherwise>jstree-leaf </xsl:otherwise>' +
|
|||
|
+ ' </xsl:choose>' +
|
|||
|
+ ' <xsl:value-of select="@class" />' +
|
|||
|
+ ' </xsl:attribute>' +
|
|||
|
+ ' <xsl:for-each select="@*">' +
|
|||
|
+ ' <xsl:if test="name() != \'class\' and name() != \'state\' and name() != \'hasChildren\'">' +
|
|||
|
+ ' <xsl:attribute name="{name()}"><xsl:value-of select="." /></xsl:attribute>' +
|
|||
|
+ ' </xsl:if>' +
|
|||
|
+ ' </xsl:for-each>' +
|
|||
|
+ ' <ins class="jstree-icon"><xsl:text> </xsl:text></ins>' +
|
|||
|
+ ' <xsl:for-each select="content/name">' +
|
|||
|
+ ' <a>' +
|
|||
|
+ ' <xsl:attribute name="href">' +
|
|||
|
+ ' <xsl:choose>' +
|
|||
|
+ ' <xsl:when test="@href"><xsl:value-of select="@href" /></xsl:when>' +
|
|||
|
+ ' <xsl:otherwise>#</xsl:otherwise>' +
|
|||
|
+ ' </xsl:choose>' +
|
|||
|
+ ' </xsl:attribute>' +
|
|||
|
+ ' <xsl:attribute name="class"><xsl:value-of select="@lang" /> <xsl:value-of select="@class" /></xsl:attribute>' +
|
|||
|
+ ' <xsl:attribute name="style"><xsl:value-of select="@style" /></xsl:attribute>' +
|
|||
|
+ ' <xsl:for-each select="@*">' +
|
|||
|
+ ' <xsl:if test="name() != \'style\' and name() != \'class\' and name() != \'href\'">' +
|
|||
|
+ ' <xsl:attribute name="{name()}"><xsl:value-of select="." /></xsl:attribute>' +
|
|||
|
+ ' </xsl:if>' +
|
|||
|
+ ' </xsl:for-each>' +
|
|||
|
+ ' <ins>' +
|
|||
|
+ ' <xsl:attribute name="class">jstree-icon ' +
|
|||
|
+ ' <xsl:if test="string-length(attribute::icon) > 0 and not(contains(@icon,\'/\'))"><xsl:value-of select="@icon" /></xsl:if>' +
|
|||
|
+ ' </xsl:attribute>' +
|
|||
|
+ ' <xsl:if test="string-length(attribute::icon) > 0 and contains(@icon,\'/\')"><xsl:attribute name="style">background:url(<xsl:value-of select="@icon" />) center center no-repeat;</xsl:attribute></xsl:if>' +
|
|||
|
+ ' <xsl:text> </xsl:text>' +
|
|||
|
+ ' </ins>' +
|
|||
|
+ ' <xsl:copy-of select="./child::node()" />' +
|
|||
|
+ ' </a>' +
|
|||
|
+ ' </xsl:for-each>' +
|
|||
|
+ ' <xsl:if test="$children or @hasChildren"><xsl:call-template name="nodes"><xsl:with-param name="node" select="current()" /></xsl:call-template></xsl:if>' +
|
|||
|
+ ' </li>' +
|
|||
|
+ ' </xsl:for-each>' +
|
|||
|
+ ' </ul>' +
|
|||
|
+ '</xsl:template>' +
|
|||
|
+ '</xsl:stylesheet>',
|
|||
|
+
|
|||
|
+ 'flat' : '<' + '?xml version="1.0" encoding="utf-8" ?>' +
|
|||
|
+ '<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" >' +
|
|||
|
+ '<xsl:output method="html" encoding="utf-8" omit-xml-declaration="yes" standalone="no" indent="no" media-type="text/xml" />' +
|
|||
|
+ '<xsl:template match="/">' +
|
|||
|
+ ' <ul>' +
|
|||
|
+ ' <xsl:for-each select="//item[not(@parent_id) or @parent_id=0 or not(@parent_id = //item/@id)]">' + /* the last `or` may be removed */
|
|||
|
+ ' <xsl:call-template name="nodes">' +
|
|||
|
+ ' <xsl:with-param name="node" select="." />' +
|
|||
|
+ ' <xsl:with-param name="is_last" select="number(position() = last())" />' +
|
|||
|
+ ' </xsl:call-template>' +
|
|||
|
+ ' </xsl:for-each>' +
|
|||
|
+ ' </ul>' +
|
|||
|
+ '</xsl:template>' +
|
|||
|
+ '<xsl:template name="nodes">' +
|
|||
|
+ ' <xsl:param name="node" />' +
|
|||
|
+ ' <xsl:param name="is_last" />' +
|
|||
|
+ ' <xsl:variable name="children" select="count(//item[@parent_id=$node/attribute::id]) > 0" />' +
|
|||
|
+ ' <li>' +
|
|||
|
+ ' <xsl:attribute name="class">' +
|
|||
|
+ ' <xsl:if test="$is_last = true()">jstree-last </xsl:if>' +
|
|||
|
+ ' <xsl:choose>' +
|
|||
|
+ ' <xsl:when test="@state = \'open\'">jstree-open </xsl:when>' +
|
|||
|
+ ' <xsl:when test="$children or @hasChildren or @state = \'closed\'">jstree-closed </xsl:when>' +
|
|||
|
+ ' <xsl:otherwise>jstree-leaf </xsl:otherwise>' +
|
|||
|
+ ' </xsl:choose>' +
|
|||
|
+ ' <xsl:value-of select="@class" />' +
|
|||
|
+ ' </xsl:attribute>' +
|
|||
|
+ ' <xsl:for-each select="@*">' +
|
|||
|
+ ' <xsl:if test="name() != \'parent_id\' and name() != \'hasChildren\' and name() != \'class\' and name() != \'state\'">' +
|
|||
|
+ ' <xsl:attribute name="{name()}"><xsl:value-of select="." /></xsl:attribute>' +
|
|||
|
+ ' </xsl:if>' +
|
|||
|
+ ' </xsl:for-each>' +
|
|||
|
+ ' <ins class="jstree-icon"><xsl:text> </xsl:text></ins>' +
|
|||
|
+ ' <xsl:for-each select="content/name">' +
|
|||
|
+ ' <a>' +
|
|||
|
+ ' <xsl:attribute name="href">' +
|
|||
|
+ ' <xsl:choose>' +
|
|||
|
+ ' <xsl:when test="@href"><xsl:value-of select="@href" /></xsl:when>' +
|
|||
|
+ ' <xsl:otherwise>#</xsl:otherwise>' +
|
|||
|
+ ' </xsl:choose>' +
|
|||
|
+ ' </xsl:attribute>' +
|
|||
|
+ ' <xsl:attribute name="class"><xsl:value-of select="@lang" /> <xsl:value-of select="@class" /></xsl:attribute>' +
|
|||
|
+ ' <xsl:attribute name="style"><xsl:value-of select="@style" /></xsl:attribute>' +
|
|||
|
+ ' <xsl:for-each select="@*">' +
|
|||
|
+ ' <xsl:if test="name() != \'style\' and name() != \'class\' and name() != \'href\'">' +
|
|||
|
+ ' <xsl:attribute name="{name()}"><xsl:value-of select="." /></xsl:attribute>' +
|
|||
|
+ ' </xsl:if>' +
|
|||
|
+ ' </xsl:for-each>' +
|
|||
|
+ ' <ins>' +
|
|||
|
+ ' <xsl:attribute name="class">jstree-icon ' +
|
|||
|
+ ' <xsl:if test="string-length(attribute::icon) > 0 and not(contains(@icon,\'/\'))"><xsl:value-of select="@icon" /></xsl:if>' +
|
|||
|
+ ' </xsl:attribute>' +
|
|||
|
+ ' <xsl:if test="string-length(attribute::icon) > 0 and contains(@icon,\'/\')"><xsl:attribute name="style">background:url(<xsl:value-of select="@icon" />) center center no-repeat;</xsl:attribute></xsl:if>' +
|
|||
|
+ ' <xsl:text> </xsl:text>' +
|
|||
|
+ ' </ins>' +
|
|||
|
+ ' <xsl:copy-of select="./child::node()" />' +
|
|||
|
+ ' </a>' +
|
|||
|
+ ' </xsl:for-each>' +
|
|||
|
+ ' <xsl:if test="$children">' +
|
|||
|
+ ' <ul>' +
|
|||
|
+ ' <xsl:for-each select="//item[@parent_id=$node/attribute::id]">' +
|
|||
|
+ ' <xsl:call-template name="nodes">' +
|
|||
|
+ ' <xsl:with-param name="node" select="." />' +
|
|||
|
+ ' <xsl:with-param name="is_last" select="number(position() = last())" />' +
|
|||
|
+ ' </xsl:call-template>' +
|
|||
|
+ ' </xsl:for-each>' +
|
|||
|
+ ' </ul>' +
|
|||
|
+ ' </xsl:if>' +
|
|||
|
+ ' </li>' +
|
|||
|
+ '</xsl:template>' +
|
|||
|
+ '</xsl:stylesheet>'
|
|||
|
+ },
|
|||
|
+ escape_xml = function(string) {
|
|||
|
+ return string
|
|||
|
+ .toString()
|
|||
|
+ .replace(/&/g, '&')
|
|||
|
+ .replace(/</g, '<')
|
|||
|
+ .replace(/>/g, '>')
|
|||
|
+ .replace(/"/g, '"')
|
|||
|
+ .replace(/'/g, ''');
|
|||
|
+ };
|
|||
|
+ $.jstree.plugin("xml_data", {
|
|||
|
+ defaults : {
|
|||
|
+ data : false,
|
|||
|
+ ajax : false,
|
|||
|
+ xsl : "flat",
|
|||
|
+ clean_node : false,
|
|||
|
+ correct_state : true,
|
|||
|
+ get_skip_empty : false,
|
|||
|
+ get_include_preamble : true
|
|||
|
+ },
|
|||
|
+ _fn : {
|
|||
|
+ load_node : function (obj, s_call, e_call) { var _this = this; this.load_node_xml(obj, function () { _this.__callback({ "obj" : _this._get_node(obj) }); s_call.call(this); }, e_call); },
|
|||
|
+ _is_loaded : function (obj) {
|
|||
|
+ var s = this._get_settings().xml_data;
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ return obj == -1 || !obj || (!s.ajax && !$.isFunction(s.data)) || obj.is(".jstree-open, .jstree-leaf") || obj.children("ul").children("li").size() > 0;
|
|||
|
+ },
|
|||
|
+ load_node_xml : function (obj, s_call, e_call) {
|
|||
|
+ var s = this.get_settings().xml_data,
|
|||
|
+ error_func = function () {},
|
|||
|
+ success_func = function () {};
|
|||
|
+
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(obj && obj !== -1) {
|
|||
|
+ if(obj.data("jstree_is_loading")) { return; }
|
|||
|
+ else { obj.data("jstree_is_loading",true); }
|
|||
|
+ }
|
|||
|
+ switch(!0) {
|
|||
|
+ case (!s.data && !s.ajax): throw "Neither data nor ajax settings supplied.";
|
|||
|
+ case ($.isFunction(s.data)):
|
|||
|
+ s.data.call(this, obj, $.proxy(function (d) {
|
|||
|
+ this.parse_xml(d, $.proxy(function (d) {
|
|||
|
+ if(d) {
|
|||
|
+ d = d.replace(/ ?xmlns="[^"]*"/ig, "");
|
|||
|
+ if(d.length > 10) {
|
|||
|
+ d = $(d);
|
|||
|
+ if(obj === -1 || !obj) { this.get_container().children("ul").empty().append(d.children()); }
|
|||
|
+ else { obj.children("a.jstree-loading").removeClass("jstree-loading"); obj.append(d); obj.removeData("jstree_is_loading"); }
|
|||
|
+ if(s.clean_node) { this.clean_node(obj); }
|
|||
|
+ if(s_call) { s_call.call(this); }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(obj && obj !== -1) {
|
|||
|
+ obj.children("a.jstree-loading").removeClass("jstree-loading");
|
|||
|
+ obj.removeData("jstree_is_loading");
|
|||
|
+ if(s.correct_state) {
|
|||
|
+ this.correct_state(obj);
|
|||
|
+ if(s_call) { s_call.call(this); }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(s.correct_state) {
|
|||
|
+ this.get_container().children("ul").empty();
|
|||
|
+ if(s_call) { s_call.call(this); }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }, this));
|
|||
|
+ }, this));
|
|||
|
+ break;
|
|||
|
+ case (!!s.data && !s.ajax) || (!!s.data && !!s.ajax && (!obj || obj === -1)):
|
|||
|
+ if(!obj || obj == -1) {
|
|||
|
+ this.parse_xml(s.data, $.proxy(function (d) {
|
|||
|
+ if(d) {
|
|||
|
+ d = d.replace(/ ?xmlns="[^"]*"/ig, "");
|
|||
|
+ if(d.length > 10) {
|
|||
|
+ d = $(d);
|
|||
|
+ this.get_container().children("ul").empty().append(d.children());
|
|||
|
+ if(s.clean_node) { this.clean_node(obj); }
|
|||
|
+ if(s_call) { s_call.call(this); }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(s.correct_state) {
|
|||
|
+ this.get_container().children("ul").empty();
|
|||
|
+ if(s_call) { s_call.call(this); }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }, this));
|
|||
|
+ }
|
|||
|
+ break;
|
|||
|
+ case (!s.data && !!s.ajax) || (!!s.data && !!s.ajax && obj && obj !== -1):
|
|||
|
+ error_func = function (x, t, e) {
|
|||
|
+ var ef = this.get_settings().xml_data.ajax.error;
|
|||
|
+ if(ef) { ef.call(this, x, t, e); }
|
|||
|
+ if(obj !== -1 && obj.length) {
|
|||
|
+ obj.children("a.jstree-loading").removeClass("jstree-loading");
|
|||
|
+ obj.removeData("jstree_is_loading");
|
|||
|
+ if(t === "success" && s.correct_state) { this.correct_state(obj); }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(t === "success" && s.correct_state) { this.get_container().children("ul").empty(); }
|
|||
|
+ }
|
|||
|
+ if(e_call) { e_call.call(this); }
|
|||
|
+ };
|
|||
|
+ success_func = function (d, t, x) {
|
|||
|
+ d = x.responseText;
|
|||
|
+ var sf = this.get_settings().xml_data.ajax.success;
|
|||
|
+ if(sf) { d = sf.call(this,d,t,x) || d; }
|
|||
|
+ if(d === "" || (d && d.toString && d.toString().replace(/^[\s\n]+$/,"") === "")) {
|
|||
|
+ return error_func.call(this, x, t, "");
|
|||
|
+ }
|
|||
|
+ this.parse_xml(d, $.proxy(function (d) {
|
|||
|
+ if(d) {
|
|||
|
+ d = d.replace(/ ?xmlns="[^"]*"/ig, "");
|
|||
|
+ if(d.length > 10) {
|
|||
|
+ d = $(d);
|
|||
|
+ if(obj === -1 || !obj) { this.get_container().children("ul").empty().append(d.children()); }
|
|||
|
+ else { obj.children("a.jstree-loading").removeClass("jstree-loading"); obj.append(d); obj.removeData("jstree_is_loading"); }
|
|||
|
+ if(s.clean_node) { this.clean_node(obj); }
|
|||
|
+ if(s_call) { s_call.call(this); }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(obj && obj !== -1) {
|
|||
|
+ obj.children("a.jstree-loading").removeClass("jstree-loading");
|
|||
|
+ obj.removeData("jstree_is_loading");
|
|||
|
+ if(s.correct_state) {
|
|||
|
+ this.correct_state(obj);
|
|||
|
+ if(s_call) { s_call.call(this); }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(s.correct_state) {
|
|||
|
+ this.get_container().children("ul").empty();
|
|||
|
+ if(s_call) { s_call.call(this); }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }, this));
|
|||
|
+ };
|
|||
|
+ s.ajax.context = this;
|
|||
|
+ s.ajax.error = error_func;
|
|||
|
+ s.ajax.success = success_func;
|
|||
|
+ if(!s.ajax.dataType) { s.ajax.dataType = "xml"; }
|
|||
|
+ if($.isFunction(s.ajax.url)) { s.ajax.url = s.ajax.url.call(this, obj); }
|
|||
|
+ if($.isFunction(s.ajax.data)) { s.ajax.data = s.ajax.data.call(this, obj); }
|
|||
|
+ $.ajax(s.ajax);
|
|||
|
+ break;
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ parse_xml : function (xml, callback) {
|
|||
|
+ var s = this._get_settings().xml_data;
|
|||
|
+ $.vakata.xslt(xml, xsl[s.xsl], callback);
|
|||
|
+ },
|
|||
|
+ get_xml : function (tp, obj, li_attr, a_attr, is_callback) {
|
|||
|
+ var result = "",
|
|||
|
+ s = this._get_settings(),
|
|||
|
+ _this = this,
|
|||
|
+ tmp1, tmp2, li, a, lang;
|
|||
|
+ if(!tp) { tp = "flat"; }
|
|||
|
+ if(!is_callback) { is_callback = 0; }
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(!obj || obj === -1) { obj = this.get_container().find("> ul > li"); }
|
|||
|
+ li_attr = $.isArray(li_attr) ? li_attr : [ "id", "class" ];
|
|||
|
+ if(!is_callback && this.data.types && $.inArray(s.types.type_attr, li_attr) === -1) { li_attr.push(s.types.type_attr); }
|
|||
|
+
|
|||
|
+ a_attr = $.isArray(a_attr) ? a_attr : [ ];
|
|||
|
+
|
|||
|
+ if(!is_callback) {
|
|||
|
+ if(s.xml_data.get_include_preamble) {
|
|||
|
+ result += '<' + '?xml version="1.0" encoding="UTF-8"?' + '>';
|
|||
|
+ }
|
|||
|
+ result += "<root>";
|
|||
|
+ }
|
|||
|
+ obj.each(function () {
|
|||
|
+ result += "<item";
|
|||
|
+ li = $(this);
|
|||
|
+ $.each(li_attr, function (i, v) {
|
|||
|
+ var t = li.attr(v);
|
|||
|
+ if(!s.xml_data.get_skip_empty || typeof t !== "undefined") {
|
|||
|
+ result += " " + v + "=\"" + escape_xml((" " + (t || "")).replace(/ jstree[^ ]*/ig,'').replace(/\s+$/ig," ").replace(/^ /,"").replace(/ $/,"")) + "\"";
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ if(li.hasClass("jstree-open")) { result += " state=\"open\""; }
|
|||
|
+ if(li.hasClass("jstree-closed")) { result += " state=\"closed\""; }
|
|||
|
+ if(tp === "flat") { result += " parent_id=\"" + escape_xml(is_callback) + "\""; }
|
|||
|
+ result += ">";
|
|||
|
+ result += "<content>";
|
|||
|
+ a = li.children("a");
|
|||
|
+ a.each(function () {
|
|||
|
+ tmp1 = $(this);
|
|||
|
+ lang = false;
|
|||
|
+ result += "<name";
|
|||
|
+ if($.inArray("languages", s.plugins) !== -1) {
|
|||
|
+ $.each(s.languages, function (k, z) {
|
|||
|
+ if(tmp1.hasClass(z)) { result += " lang=\"" + escape_xml(z) + "\""; lang = z; return false; }
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ if(a_attr.length) {
|
|||
|
+ $.each(a_attr, function (k, z) {
|
|||
|
+ var t = tmp1.attr(z);
|
|||
|
+ if(!s.xml_data.get_skip_empty || typeof t !== "undefined") {
|
|||
|
+ result += " " + z + "=\"" + escape_xml((" " + t || "").replace(/ jstree[^ ]*/ig,'').replace(/\s+$/ig," ").replace(/^ /,"").replace(/ $/,"")) + "\"";
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ if(tmp1.children("ins").get(0).className.replace(/jstree[^ ]*|$/ig,'').replace(/^\s+$/ig,"").length) {
|
|||
|
+ result += ' icon="' + escape_xml(tmp1.children("ins").get(0).className.replace(/jstree[^ ]*|$/ig,'').replace(/\s+$/ig," ").replace(/^ /,"").replace(/ $/,"")) + '"';
|
|||
|
+ }
|
|||
|
+ if(tmp1.children("ins").get(0).style.backgroundImage.length) {
|
|||
|
+ result += ' icon="' + escape_xml(tmp1.children("ins").get(0).style.backgroundImage.replace("url(","").replace(")","").replace(/'/ig,"").replace(/"/ig,"")) + '"';
|
|||
|
+ }
|
|||
|
+ result += ">";
|
|||
|
+ result += "<![CDATA[" + _this.get_text(tmp1, lang) + "]]>";
|
|||
|
+ result += "</name>";
|
|||
|
+ });
|
|||
|
+ result += "</content>";
|
|||
|
+ tmp2 = li[0].id || true;
|
|||
|
+ li = li.find("> ul > li");
|
|||
|
+ if(li.length) { tmp2 = _this.get_xml(tp, li, li_attr, a_attr, tmp2); }
|
|||
|
+ else { tmp2 = ""; }
|
|||
|
+ if(tp == "nest") { result += tmp2; }
|
|||
|
+ result += "</item>";
|
|||
|
+ if(tp == "flat") { result += tmp2; }
|
|||
|
+ });
|
|||
|
+ if(!is_callback) { result += "</root>"; }
|
|||
|
+ return result;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+})(jQuery);
|
|||
|
+//*/
|
|||
|
+
|
|||
|
+/*
|
|||
|
+ * jsTree search plugin
|
|||
|
+ * Enables both sync and async search on the tree
|
|||
|
+ * DOES NOT WORK WITH JSON PROGRESSIVE RENDER
|
|||
|
+ */
|
|||
|
+(function ($) {
|
|||
|
+ $.expr[':'].jstree_contains = function(a,i,m){
|
|||
|
+ return (a.textContent || a.innerText || "").toLowerCase().indexOf(m[3].toLowerCase())>=0;
|
|||
|
+ };
|
|||
|
+ $.expr[':'].jstree_title_contains = function(a,i,m) {
|
|||
|
+ return (a.getAttribute("title") || "").toLowerCase().indexOf(m[3].toLowerCase())>=0;
|
|||
|
+ };
|
|||
|
+ $.jstree.plugin("search", {
|
|||
|
+ __init : function () {
|
|||
|
+ this.data.search.str = "";
|
|||
|
+ this.data.search.result = $();
|
|||
|
+ if(this._get_settings().search.show_only_matches) {
|
|||
|
+ this.get_container()
|
|||
|
+ .bind("search.jstree", function (e, data) {
|
|||
|
+ $(this).children("ul").find("li").hide().removeClass("jstree-last");
|
|||
|
+ data.rslt.nodes.parentsUntil(".jstree").andSelf().show()
|
|||
|
+ .filter("ul").each(function () { $(this).children("li:visible").eq(-1).addClass("jstree-last"); });
|
|||
|
+ })
|
|||
|
+ .bind("clear_search.jstree", function () {
|
|||
|
+ $(this).children("ul").find("li").css("display","").end().end().jstree("clean_node", -1);
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ defaults : {
|
|||
|
+ ajax : false,
|
|||
|
+ search_method : "jstree_contains", // for case insensitive - jstree_contains
|
|||
|
+ show_only_matches : false
|
|||
|
+ },
|
|||
|
+ _fn : {
|
|||
|
+ search : function (str, skip_async) {
|
|||
|
+ if($.trim(str) === "") { this.clear_search(); return; }
|
|||
|
+ var s = this.get_settings().search,
|
|||
|
+ t = this,
|
|||
|
+ error_func = function () { },
|
|||
|
+ success_func = function () { };
|
|||
|
+ this.data.search.str = str;
|
|||
|
+
|
|||
|
+ if(!skip_async && s.ajax !== false && this.get_container_ul().find("li.jstree-closed:not(:has(ul)):eq(0)").length > 0) {
|
|||
|
+ this.search.supress_callback = true;
|
|||
|
+ error_func = function () { };
|
|||
|
+ success_func = function (d, t, x) {
|
|||
|
+ var sf = this.get_settings().search.ajax.success;
|
|||
|
+ if(sf) { d = sf.call(this,d,t,x) || d; }
|
|||
|
+ this.data.search.to_open = d;
|
|||
|
+ this._search_open();
|
|||
|
+ };
|
|||
|
+ s.ajax.context = this;
|
|||
|
+ s.ajax.error = error_func;
|
|||
|
+ s.ajax.success = success_func;
|
|||
|
+ if($.isFunction(s.ajax.url)) { s.ajax.url = s.ajax.url.call(this, str); }
|
|||
|
+ if($.isFunction(s.ajax.data)) { s.ajax.data = s.ajax.data.call(this, str); }
|
|||
|
+ if(!s.ajax.data) { s.ajax.data = { "search_string" : str }; }
|
|||
|
+ if(!s.ajax.dataType || /^json/.exec(s.ajax.dataType)) { s.ajax.dataType = "json"; }
|
|||
|
+ $.ajax(s.ajax);
|
|||
|
+ return;
|
|||
|
+ }
|
|||
|
+ if(this.data.search.result.length) { this.clear_search(); }
|
|||
|
+ this.data.search.result = this.get_container().find("a" + (this.data.languages ? "." + this.get_lang() : "" ) + ":" + (s.search_method) + "(" + this.data.search.str + ")");
|
|||
|
+ this.data.search.result.addClass("jstree-search").parent().parents(".jstree-closed").each(function () {
|
|||
|
+ t.open_node(this, false, true);
|
|||
|
+ });
|
|||
|
+ this.__callback({ nodes : this.data.search.result, str : str });
|
|||
|
+ },
|
|||
|
+ clear_search : function (str) {
|
|||
|
+ this.data.search.result.removeClass("jstree-search");
|
|||
|
+ this.__callback(this.data.search.result);
|
|||
|
+ this.data.search.result = $();
|
|||
|
+ },
|
|||
|
+ _search_open : function (is_callback) {
|
|||
|
+ var _this = this,
|
|||
|
+ done = true,
|
|||
|
+ current = [],
|
|||
|
+ remaining = [];
|
|||
|
+ if(this.data.search.to_open.length) {
|
|||
|
+ $.each(this.data.search.to_open, function (i, val) {
|
|||
|
+ if(val == "#") { return true; }
|
|||
|
+ if($(val).length && $(val).is(".jstree-closed")) { current.push(val); }
|
|||
|
+ else { remaining.push(val); }
|
|||
|
+ });
|
|||
|
+ if(current.length) {
|
|||
|
+ this.data.search.to_open = remaining;
|
|||
|
+ $.each(current, function (i, val) {
|
|||
|
+ _this.open_node(val, function () { _this._search_open(true); });
|
|||
|
+ });
|
|||
|
+ done = false;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ if(done) { this.search(this.data.search.str, true); }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+})(jQuery);
|
|||
|
+//*/
|
|||
|
+
|
|||
|
+/*
|
|||
|
+ * jsTree contextmenu plugin
|
|||
|
+ */
|
|||
|
+(function ($) {
|
|||
|
+ $.vakata.context = {
|
|||
|
+ hide_on_mouseleave : false,
|
|||
|
+
|
|||
|
+ cnt : $("<div id='vakata-contextmenu' />"),
|
|||
|
+ vis : false,
|
|||
|
+ tgt : false,
|
|||
|
+ par : false,
|
|||
|
+ func : false,
|
|||
|
+ data : false,
|
|||
|
+ rtl : false,
|
|||
|
+ show : function (s, t, x, y, d, p, rtl) {
|
|||
|
+ $.vakata.context.rtl = !!rtl;
|
|||
|
+ var html = $.vakata.context.parse(s), h, w;
|
|||
|
+ if(!html) { return; }
|
|||
|
+ $.vakata.context.vis = true;
|
|||
|
+ $.vakata.context.tgt = t;
|
|||
|
+ $.vakata.context.par = p || t || null;
|
|||
|
+ $.vakata.context.data = d || null;
|
|||
|
+ $.vakata.context.cnt
|
|||
|
+ .html(html)
|
|||
|
+ .css({ "visibility" : "hidden", "display" : "block", "left" : 0, "top" : 0 });
|
|||
|
+
|
|||
|
+ if($.vakata.context.hide_on_mouseleave) {
|
|||
|
+ $.vakata.context.cnt
|
|||
|
+ .one("mouseleave", function(e) { $.vakata.context.hide(); });
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ h = $.vakata.context.cnt.height();
|
|||
|
+ w = $.vakata.context.cnt.width();
|
|||
|
+ if(x + w > $(document).width()) {
|
|||
|
+ x = $(document).width() - (w + 5);
|
|||
|
+ $.vakata.context.cnt.find("li > ul").addClass("right");
|
|||
|
+ }
|
|||
|
+ if(y + h > $(document).height()) {
|
|||
|
+ y = y - (h + t[0].offsetHeight);
|
|||
|
+ $.vakata.context.cnt.find("li > ul").addClass("bottom");
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ $.vakata.context.cnt
|
|||
|
+ .css({ "left" : x, "top" : y })
|
|||
|
+ .find("li:has(ul)")
|
|||
|
+ .bind("mouseenter", function (e) {
|
|||
|
+ var w = $(document).width(),
|
|||
|
+ h = $(document).height(),
|
|||
|
+ ul = $(this).children("ul").show();
|
|||
|
+ if(w !== $(document).width()) { ul.toggleClass("right"); }
|
|||
|
+ if(h !== $(document).height()) { ul.toggleClass("bottom"); }
|
|||
|
+ })
|
|||
|
+ .bind("mouseleave", function (e) {
|
|||
|
+ $(this).children("ul").hide();
|
|||
|
+ })
|
|||
|
+ .end()
|
|||
|
+ .css({ "visibility" : "visible" })
|
|||
|
+ .show();
|
|||
|
+ $(document).triggerHandler("context_show.vakata");
|
|||
|
+ },
|
|||
|
+ hide : function () {
|
|||
|
+ $.vakata.context.vis = false;
|
|||
|
+ $.vakata.context.cnt.attr("class","").css({ "visibility" : "hidden" });
|
|||
|
+ $(document).triggerHandler("context_hide.vakata");
|
|||
|
+ },
|
|||
|
+ parse : function (s, is_callback) {
|
|||
|
+ if(!s) { return false; }
|
|||
|
+ var str = "",
|
|||
|
+ tmp = false,
|
|||
|
+ was_sep = true;
|
|||
|
+ if(!is_callback) { $.vakata.context.func = {}; }
|
|||
|
+ str += "<ul>";
|
|||
|
+ $.each(s, function (i, val) {
|
|||
|
+ if(!val) { return true; }
|
|||
|
+ $.vakata.context.func[i] = val.action;
|
|||
|
+ if(!was_sep && val.separator_before) {
|
|||
|
+ str += "<li class='vakata-separator vakata-separator-before'></li>";
|
|||
|
+ }
|
|||
|
+ was_sep = false;
|
|||
|
+ str += "<li class='" + (val._class || "") + (val._disabled ? " jstree-contextmenu-disabled " : "") + "'><ins ";
|
|||
|
+ if(val.icon && val.icon.indexOf("/") === -1) { str += " class='" + val.icon + "' "; }
|
|||
|
+ if(val.icon && val.icon.indexOf("/") !== -1) { str += " style='background:url(" + val.icon + ") center center no-repeat;' "; }
|
|||
|
+ str += "> </ins><a href='#' rel='" + i + "'>";
|
|||
|
+ if(val.submenu) {
|
|||
|
+ str += "<span style='float:" + ($.vakata.context.rtl ? "left" : "right") + ";'>»</span>";
|
|||
|
+ }
|
|||
|
+ str += val.label + "</a>";
|
|||
|
+ if(val.submenu) {
|
|||
|
+ tmp = $.vakata.context.parse(val.submenu, true);
|
|||
|
+ if(tmp) { str += tmp; }
|
|||
|
+ }
|
|||
|
+ str += "</li>";
|
|||
|
+ if(val.separator_after) {
|
|||
|
+ str += "<li class='vakata-separator vakata-separator-after'></li>";
|
|||
|
+ was_sep = true;
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ str = str.replace(/<li class\='vakata-separator vakata-separator-after'\><\/li\>$/,"");
|
|||
|
+ str += "</ul>";
|
|||
|
+ $(document).triggerHandler("context_parse.vakata");
|
|||
|
+ return str.length > 10 ? str : false;
|
|||
|
+ },
|
|||
|
+ exec : function (i) {
|
|||
|
+ if($.isFunction($.vakata.context.func[i])) {
|
|||
|
+ // if is string - eval and call it!
|
|||
|
+ $.vakata.context.func[i].call($.vakata.context.data, $.vakata.context.par);
|
|||
|
+ return true;
|
|||
|
+ }
|
|||
|
+ else { return false; }
|
|||
|
+ }
|
|||
|
+ };
|
|||
|
+ $(function () {
|
|||
|
+ var css_string = '' +
|
|||
|
+ '#vakata-contextmenu { display:block; visibility:hidden; left:0; top:-200px; position:absolute; margin:0; padding:0; min-width:180px; background:#ebebeb; border:1px solid silver; z-index:10000; *width:180px; } ' +
|
|||
|
+ '#vakata-contextmenu ul { min-width:180px; *width:180px; } ' +
|
|||
|
+ '#vakata-contextmenu ul, #vakata-contextmenu li { margin:0; padding:0; list-style-type:none; display:block; } ' +
|
|||
|
+ '#vakata-contextmenu li { line-height:20px; min-height:20px; position:relative; padding:0px; } ' +
|
|||
|
+ '#vakata-contextmenu li a { padding:1px 6px; line-height:17px; display:block; text-decoration:none; margin:1px 1px 0 1px; } ' +
|
|||
|
+ '#vakata-contextmenu li ins { float:left; width:16px; height:16px; text-decoration:none; margin-right:2px; } ' +
|
|||
|
+ '#vakata-contextmenu li a:hover, #vakata-contextmenu li.vakata-hover > a { background:gray; color:white; } ' +
|
|||
|
+ '#vakata-contextmenu li ul { display:none; position:absolute; top:-2px; left:100%; background:#ebebeb; border:1px solid gray; } ' +
|
|||
|
+ '#vakata-contextmenu .right { right:100%; left:auto; } ' +
|
|||
|
+ '#vakata-contextmenu .bottom { bottom:-1px; top:auto; } ' +
|
|||
|
+ '#vakata-contextmenu li.vakata-separator { min-height:0; height:1px; line-height:1px; font-size:1px; overflow:hidden; margin:0 2px; background:silver; /* border-top:1px solid #fefefe; */ padding:0; } ';
|
|||
|
+ $.vakata.css.add_sheet({ str : css_string, title : "vakata" });
|
|||
|
+ $.vakata.context.cnt
|
|||
|
+ .delegate("a","click", function (e) { e.preventDefault(); })
|
|||
|
+ .delegate("a","mouseup", function (e) {
|
|||
|
+ if(!$(this).parent().hasClass("jstree-contextmenu-disabled") && $.vakata.context.exec($(this).attr("rel"))) {
|
|||
|
+ $.vakata.context.hide();
|
|||
|
+ }
|
|||
|
+ else { $(this).blur(); }
|
|||
|
+ })
|
|||
|
+ .delegate("a","mouseover", function () {
|
|||
|
+ $.vakata.context.cnt.find(".vakata-hover").removeClass("vakata-hover");
|
|||
|
+ })
|
|||
|
+ .appendTo("body");
|
|||
|
+ $(document).bind("mousedown", function (e) { if($.vakata.context.vis && !$.contains($.vakata.context.cnt[0], e.target)) { $.vakata.context.hide(); } });
|
|||
|
+ if(typeof $.hotkeys !== "undefined") {
|
|||
|
+ $(document)
|
|||
|
+ .bind("keydown", "up", function (e) {
|
|||
|
+ if($.vakata.context.vis) {
|
|||
|
+ var o = $.vakata.context.cnt.find("ul:visible").last().children(".vakata-hover").removeClass("vakata-hover").prevAll("li:not(.vakata-separator)").first();
|
|||
|
+ if(!o.length) { o = $.vakata.context.cnt.find("ul:visible").last().children("li:not(.vakata-separator)").last(); }
|
|||
|
+ o.addClass("vakata-hover");
|
|||
|
+ e.stopImmediatePropagation();
|
|||
|
+ e.preventDefault();
|
|||
|
+ }
|
|||
|
+ })
|
|||
|
+ .bind("keydown", "down", function (e) {
|
|||
|
+ if($.vakata.context.vis) {
|
|||
|
+ var o = $.vakata.context.cnt.find("ul:visible").last().children(".vakata-hover").removeClass("vakata-hover").nextAll("li:not(.vakata-separator)").first();
|
|||
|
+ if(!o.length) { o = $.vakata.context.cnt.find("ul:visible").last().children("li:not(.vakata-separator)").first(); }
|
|||
|
+ o.addClass("vakata-hover");
|
|||
|
+ e.stopImmediatePropagation();
|
|||
|
+ e.preventDefault();
|
|||
|
+ }
|
|||
|
+ })
|
|||
|
+ .bind("keydown", "right", function (e) {
|
|||
|
+ if($.vakata.context.vis) {
|
|||
|
+ $.vakata.context.cnt.find(".vakata-hover").children("ul").show().children("li:not(.vakata-separator)").removeClass("vakata-hover").first().addClass("vakata-hover");
|
|||
|
+ e.stopImmediatePropagation();
|
|||
|
+ e.preventDefault();
|
|||
|
+ }
|
|||
|
+ })
|
|||
|
+ .bind("keydown", "left", function (e) {
|
|||
|
+ if($.vakata.context.vis) {
|
|||
|
+ $.vakata.context.cnt.find(".vakata-hover").children("ul").hide().children(".vakata-separator").removeClass("vakata-hover");
|
|||
|
+ e.stopImmediatePropagation();
|
|||
|
+ e.preventDefault();
|
|||
|
+ }
|
|||
|
+ })
|
|||
|
+ .bind("keydown", "esc", function (e) {
|
|||
|
+ $.vakata.context.hide();
|
|||
|
+ e.preventDefault();
|
|||
|
+ })
|
|||
|
+ .bind("keydown", "space", function (e) {
|
|||
|
+ $.vakata.context.cnt.find(".vakata-hover").last().children("a").click();
|
|||
|
+ e.preventDefault();
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+
|
|||
|
+ $.jstree.plugin("contextmenu", {
|
|||
|
+ __init : function () {
|
|||
|
+ this.get_container()
|
|||
|
+ .delegate("a", "contextmenu.jstree", $.proxy(function (e) {
|
|||
|
+ e.preventDefault();
|
|||
|
+ if(!$(e.currentTarget).hasClass("jstree-loading")) {
|
|||
|
+ this.show_contextmenu(e.currentTarget, e.pageX, e.pageY);
|
|||
|
+ }
|
|||
|
+ }, this))
|
|||
|
+ .delegate("a", "click.jstree", $.proxy(function (e) {
|
|||
|
+ if(this.data.contextmenu) {
|
|||
|
+ $.vakata.context.hide();
|
|||
|
+ }
|
|||
|
+ }, this))
|
|||
|
+ .bind("destroy.jstree", $.proxy(function () {
|
|||
|
+ // TODO: move this to descruct method
|
|||
|
+ if(this.data.contextmenu) {
|
|||
|
+ $.vakata.context.hide();
|
|||
|
+ }
|
|||
|
+ }, this));
|
|||
|
+ $(document).bind("context_hide.vakata", $.proxy(function () { this.data.contextmenu = false; }, this));
|
|||
|
+ },
|
|||
|
+ defaults : {
|
|||
|
+ select_node : false, // requires UI plugin
|
|||
|
+ show_at_node : true,
|
|||
|
+ items : { // Could be a function that should return an object like this one
|
|||
|
+ "create" : {
|
|||
|
+ "separator_before" : false,
|
|||
|
+ "separator_after" : true,
|
|||
|
+ "label" : "Create",
|
|||
|
+ "action" : function (obj) { this.create(obj); }
|
|||
|
+ },
|
|||
|
+ "rename" : {
|
|||
|
+ "separator_before" : false,
|
|||
|
+ "separator_after" : false,
|
|||
|
+ "label" : "Rename",
|
|||
|
+ "action" : function (obj) { this.rename(obj); }
|
|||
|
+ },
|
|||
|
+ "remove" : {
|
|||
|
+ "separator_before" : false,
|
|||
|
+ "icon" : false,
|
|||
|
+ "separator_after" : false,
|
|||
|
+ "label" : "Delete",
|
|||
|
+ "action" : function (obj) { if(this.is_selected(obj)) { this.remove(); } else { this.remove(obj); } }
|
|||
|
+ },
|
|||
|
+ "ccp" : {
|
|||
|
+ "separator_before" : true,
|
|||
|
+ "icon" : false,
|
|||
|
+ "separator_after" : false,
|
|||
|
+ "label" : "Edit",
|
|||
|
+ "action" : false,
|
|||
|
+ "submenu" : {
|
|||
|
+ "cut" : {
|
|||
|
+ "separator_before" : false,
|
|||
|
+ "separator_after" : false,
|
|||
|
+ "label" : "Cut",
|
|||
|
+ "action" : function (obj) { this.cut(obj); }
|
|||
|
+ },
|
|||
|
+ "copy" : {
|
|||
|
+ "separator_before" : false,
|
|||
|
+ "icon" : false,
|
|||
|
+ "separator_after" : false,
|
|||
|
+ "label" : "Copy",
|
|||
|
+ "action" : function (obj) { this.copy(obj); }
|
|||
|
+ },
|
|||
|
+ "paste" : {
|
|||
|
+ "separator_before" : false,
|
|||
|
+ "icon" : false,
|
|||
|
+ "separator_after" : false,
|
|||
|
+ "label" : "Paste",
|
|||
|
+ "action" : function (obj) { this.paste(obj); }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ _fn : {
|
|||
|
+ show_contextmenu : function (obj, x, y) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ var s = this.get_settings().contextmenu,
|
|||
|
+ a = obj.children("a:visible:eq(0)"),
|
|||
|
+ o = false,
|
|||
|
+ i = false;
|
|||
|
+ if(s.select_node && this.data.ui && !this.is_selected(obj)) {
|
|||
|
+ this.deselect_all();
|
|||
|
+ this.select_node(obj, true);
|
|||
|
+ }
|
|||
|
+ if(s.show_at_node || typeof x === "undefined" || typeof y === "undefined") {
|
|||
|
+ o = a.offset();
|
|||
|
+ x = o.left;
|
|||
|
+ y = o.top + this.data.core.li_height;
|
|||
|
+ }
|
|||
|
+ i = obj.data("jstree") && obj.data("jstree").contextmenu ? obj.data("jstree").contextmenu : s.items;
|
|||
|
+ if($.isFunction(i)) { i = i.call(this, obj); }
|
|||
|
+ this.data.contextmenu = true;
|
|||
|
+ $.vakata.context.show(i, a, x, y, this, obj, this._get_settings().core.rtl);
|
|||
|
+ if(this.data.themes) { $.vakata.context.cnt.attr("class", "jstree-" + this.data.themes.theme + "-context"); }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+})(jQuery);
|
|||
|
+//*/
|
|||
|
+
|
|||
|
+/*
|
|||
|
+ * jsTree types plugin
|
|||
|
+ * Adds support types of nodes
|
|||
|
+ * You can set an attribute on each li node, that represents its type.
|
|||
|
+ * According to the type setting the node may get custom icon/validation rules
|
|||
|
+ */
|
|||
|
+(function ($) {
|
|||
|
+ $.jstree.plugin("types", {
|
|||
|
+ __init : function () {
|
|||
|
+ var s = this._get_settings().types;
|
|||
|
+ this.data.types.attach_to = [];
|
|||
|
+ this.get_container()
|
|||
|
+ .bind("init.jstree", $.proxy(function () {
|
|||
|
+ var types = s.types,
|
|||
|
+ attr = s.type_attr,
|
|||
|
+ icons_css = "",
|
|||
|
+ _this = this;
|
|||
|
+
|
|||
|
+ $.each(types, function (i, tp) {
|
|||
|
+ $.each(tp, function (k, v) {
|
|||
|
+ if(!/^(max_depth|max_children|icon|valid_children)$/.test(k)) { _this.data.types.attach_to.push(k); }
|
|||
|
+ });
|
|||
|
+ if(!tp.icon) { return true; }
|
|||
|
+ if( tp.icon.image || tp.icon.position) {
|
|||
|
+ if(i == "default") { icons_css += '.jstree-' + _this.get_index() + ' a > .jstree-icon { '; }
|
|||
|
+ else { icons_css += '.jstree-' + _this.get_index() + ' li[' + attr + '="' + i + '"] > a > .jstree-icon { '; }
|
|||
|
+ if(tp.icon.image) { icons_css += ' background-image:url(' + tp.icon.image + '); '; }
|
|||
|
+ if(tp.icon.position){ icons_css += ' background-position:' + tp.icon.position + '; '; }
|
|||
|
+ else { icons_css += ' background-position:0 0; '; }
|
|||
|
+ icons_css += '} ';
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ if(icons_css !== "") { $.vakata.css.add_sheet({ 'str' : icons_css, title : "jstree-types" }); }
|
|||
|
+ }, this))
|
|||
|
+ .bind("before.jstree", $.proxy(function (e, data) {
|
|||
|
+ var s, t,
|
|||
|
+ o = this._get_settings().types.use_data ? this._get_node(data.args[0]) : false,
|
|||
|
+ d = o && o !== -1 && o.length ? o.data("jstree") : false;
|
|||
|
+ if(d && d.types && d.types[data.func] === false) { e.stopImmediatePropagation(); return false; }
|
|||
|
+ if($.inArray(data.func, this.data.types.attach_to) !== -1) {
|
|||
|
+ if(!data.args[0] || (!data.args[0].tagName && !data.args[0].jquery)) { return; }
|
|||
|
+ s = this._get_settings().types.types;
|
|||
|
+ t = this._get_type(data.args[0]);
|
|||
|
+ if(
|
|||
|
+ (
|
|||
|
+ (s[t] && typeof s[t][data.func] !== "undefined") ||
|
|||
|
+ (s["default"] && typeof s["default"][data.func] !== "undefined")
|
|||
|
+ ) && this._check(data.func, data.args[0]) === false
|
|||
|
+ ) {
|
|||
|
+ e.stopImmediatePropagation();
|
|||
|
+ return false;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }, this));
|
|||
|
+ if(is_ie6) {
|
|||
|
+ this.get_container()
|
|||
|
+ .bind("load_node.jstree set_type.jstree", $.proxy(function (e, data) {
|
|||
|
+ var r = data && data.rslt && data.rslt.obj && data.rslt.obj !== -1 ? this._get_node(data.rslt.obj).parent() : this.get_container_ul(),
|
|||
|
+ c = false,
|
|||
|
+ s = this._get_settings().types;
|
|||
|
+ $.each(s.types, function (i, tp) {
|
|||
|
+ if(tp.icon && (tp.icon.image || tp.icon.position)) {
|
|||
|
+ c = i === "default" ? r.find("li > a > .jstree-icon") : r.find("li[" + s.type_attr + "='" + i + "'] > a > .jstree-icon");
|
|||
|
+ if(tp.icon.image) { c.css("backgroundImage","url(" + tp.icon.image + ")"); }
|
|||
|
+ c.css("backgroundPosition", tp.icon.position || "0 0");
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ }, this));
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ defaults : {
|
|||
|
+ // defines maximum number of root nodes (-1 means unlimited, -2 means disable max_children checking)
|
|||
|
+ max_children : -1,
|
|||
|
+ // defines the maximum depth of the tree (-1 means unlimited, -2 means disable max_depth checking)
|
|||
|
+ max_depth : -1,
|
|||
|
+ // defines valid node types for the root nodes
|
|||
|
+ valid_children : "all",
|
|||
|
+
|
|||
|
+ // whether to use $.data
|
|||
|
+ use_data : false,
|
|||
|
+ // where is the type stores (the rel attribute of the LI element)
|
|||
|
+ type_attr : "rel",
|
|||
|
+ // a list of types
|
|||
|
+ types : {
|
|||
|
+ // the default type
|
|||
|
+ "default" : {
|
|||
|
+ "max_children" : -1,
|
|||
|
+ "max_depth" : -1,
|
|||
|
+ "valid_children": "all"
|
|||
|
+
|
|||
|
+ // Bound functions - you can bind any other function here (using boolean or function)
|
|||
|
+ //"select_node" : true
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ _fn : {
|
|||
|
+ _types_notify : function (n, data) {
|
|||
|
+ if(data.type && this._get_settings().types.use_data) {
|
|||
|
+ this.set_type(data.type, n);
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ _get_type : function (obj) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ return (!obj || !obj.length) ? false : obj.attr(this._get_settings().types.type_attr) || "default";
|
|||
|
+ },
|
|||
|
+ set_type : function (str, obj) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ var ret = (!obj.length || !str) ? false : obj.attr(this._get_settings().types.type_attr, str);
|
|||
|
+ if(ret) { this.__callback({ obj : obj, type : str}); }
|
|||
|
+ return ret;
|
|||
|
+ },
|
|||
|
+ _check : function (rule, obj, opts) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ var v = false, t = this._get_type(obj), d = 0, _this = this, s = this._get_settings().types, data = false;
|
|||
|
+ if(obj === -1) {
|
|||
|
+ if(!!s[rule]) { v = s[rule]; }
|
|||
|
+ else { return; }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(t === false) { return; }
|
|||
|
+ data = s.use_data ? obj.data("jstree") : false;
|
|||
|
+ if(data && data.types && typeof data.types[rule] !== "undefined") { v = data.types[rule]; }
|
|||
|
+ else if(!!s.types[t] && typeof s.types[t][rule] !== "undefined") { v = s.types[t][rule]; }
|
|||
|
+ else if(!!s.types["default"] && typeof s.types["default"][rule] !== "undefined") { v = s.types["default"][rule]; }
|
|||
|
+ }
|
|||
|
+ if($.isFunction(v)) { v = v.call(this, obj); }
|
|||
|
+ if(rule === "max_depth" && obj !== -1 && opts !== false && s.max_depth !== -2 && v !== 0) {
|
|||
|
+ // also include the node itself - otherwise if root node it is not checked
|
|||
|
+ obj.children("a:eq(0)").parentsUntil(".jstree","li").each(function (i) {
|
|||
|
+ // check if current depth already exceeds global tree depth
|
|||
|
+ if(s.max_depth !== -1 && s.max_depth - (i + 1) <= 0) { v = 0; return false; }
|
|||
|
+ d = (i === 0) ? v : _this._check(rule, this, false);
|
|||
|
+ // check if current node max depth is already matched or exceeded
|
|||
|
+ if(d !== -1 && d - (i + 1) <= 0) { v = 0; return false; }
|
|||
|
+ // otherwise - set the max depth to the current value minus current depth
|
|||
|
+ if(d >= 0 && (d - (i + 1) < v || v < 0) ) { v = d - (i + 1); }
|
|||
|
+ // if the global tree depth exists and it minus the nodes calculated so far is less than `v` or `v` is unlimited
|
|||
|
+ if(s.max_depth >= 0 && (s.max_depth - (i + 1) < v || v < 0) ) { v = s.max_depth - (i + 1); }
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ return v;
|
|||
|
+ },
|
|||
|
+ check_move : function () {
|
|||
|
+ if(!this.__call_old()) { return false; }
|
|||
|
+ var m = this._get_move(),
|
|||
|
+ s = m.rt._get_settings().types,
|
|||
|
+ mc = m.rt._check("max_children", m.cr),
|
|||
|
+ md = m.rt._check("max_depth", m.cr),
|
|||
|
+ vc = m.rt._check("valid_children", m.cr),
|
|||
|
+ ch = 0, d = 1, t;
|
|||
|
+
|
|||
|
+ if(vc === "none") { return false; }
|
|||
|
+ if($.isArray(vc) && m.ot && m.ot._get_type) {
|
|||
|
+ m.o.each(function () {
|
|||
|
+ if($.inArray(m.ot._get_type(this), vc) === -1) { d = false; return false; }
|
|||
|
+ });
|
|||
|
+ if(d === false) { return false; }
|
|||
|
+ }
|
|||
|
+ if(s.max_children !== -2 && mc !== -1) {
|
|||
|
+ ch = m.cr === -1 ? this.get_container().find("> ul > li").not(m.o).length : m.cr.find("> ul > li").not(m.o).length;
|
|||
|
+ if(ch + m.o.length > mc) { return false; }
|
|||
|
+ }
|
|||
|
+ if(s.max_depth !== -2 && md !== -1) {
|
|||
|
+ d = 0;
|
|||
|
+ if(md === 0) { return false; }
|
|||
|
+ if(typeof m.o.d === "undefined") {
|
|||
|
+ // TODO: deal with progressive rendering and async when checking max_depth (how to know the depth of the moved node)
|
|||
|
+ t = m.o;
|
|||
|
+ while(t.length > 0) {
|
|||
|
+ t = t.find("> ul > li");
|
|||
|
+ d ++;
|
|||
|
+ }
|
|||
|
+ m.o.d = d;
|
|||
|
+ }
|
|||
|
+ if(md - m.o.d < 0) { return false; }
|
|||
|
+ }
|
|||
|
+ return true;
|
|||
|
+ },
|
|||
|
+ create_node : function (obj, position, js, callback, is_loaded, skip_check) {
|
|||
|
+ if(!skip_check && (is_loaded || this._is_loaded(obj))) {
|
|||
|
+ var p = (typeof position == "string" && position.match(/^before|after$/i) && obj !== -1) ? this._get_parent(obj) : this._get_node(obj),
|
|||
|
+ s = this._get_settings().types,
|
|||
|
+ mc = this._check("max_children", p),
|
|||
|
+ md = this._check("max_depth", p),
|
|||
|
+ vc = this._check("valid_children", p),
|
|||
|
+ ch;
|
|||
|
+ if(typeof js === "string") { js = { data : js }; }
|
|||
|
+ if(!js) { js = {}; }
|
|||
|
+ if(vc === "none") { return false; }
|
|||
|
+ if($.isArray(vc)) {
|
|||
|
+ if(!js.attr || !js.attr[s.type_attr]) {
|
|||
|
+ if(!js.attr) { js.attr = {}; }
|
|||
|
+ js.attr[s.type_attr] = vc[0];
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if($.inArray(js.attr[s.type_attr], vc) === -1) { return false; }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ if(s.max_children !== -2 && mc !== -1) {
|
|||
|
+ ch = p === -1 ? this.get_container().find("> ul > li").length : p.find("> ul > li").length;
|
|||
|
+ if(ch + 1 > mc) { return false; }
|
|||
|
+ }
|
|||
|
+ if(s.max_depth !== -2 && md !== -1 && (md - 1) < 0) { return false; }
|
|||
|
+ }
|
|||
|
+ return this.__call_old(true, obj, position, js, callback, is_loaded, skip_check);
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+})(jQuery);
|
|||
|
+//*/
|
|||
|
+
|
|||
|
+/*
|
|||
|
+ * jsTree HTML plugin
|
|||
|
+ * The HTML data store. Datastores are build by replacing the `load_node` and `_is_loaded` functions.
|
|||
|
+ */
|
|||
|
+(function ($) {
|
|||
|
+ $.jstree.plugin("html_data", {
|
|||
|
+ __init : function () {
|
|||
|
+ // this used to use html() and clean the whitespace, but this way any attached data was lost
|
|||
|
+ this.data.html_data.original_container_html = this.get_container().find(" > ul > li").clone(true);
|
|||
|
+ // remove white space from LI node - otherwise nodes appear a bit to the right
|
|||
|
+ this.data.html_data.original_container_html.find("li").andSelf().contents().filter(function() { return this.nodeType == 3; }).remove();
|
|||
|
+ },
|
|||
|
+ defaults : {
|
|||
|
+ data : false,
|
|||
|
+ ajax : false,
|
|||
|
+ correct_state : true
|
|||
|
+ },
|
|||
|
+ _fn : {
|
|||
|
+ load_node : function (obj, s_call, e_call) { var _this = this; this.load_node_html(obj, function () { _this.__callback({ "obj" : _this._get_node(obj) }); s_call.call(this); }, e_call); },
|
|||
|
+ _is_loaded : function (obj) {
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ return obj == -1 || !obj || (!this._get_settings().html_data.ajax && !$.isFunction(this._get_settings().html_data.data)) || obj.is(".jstree-open, .jstree-leaf") || obj.children("ul").children("li").size() > 0;
|
|||
|
+ },
|
|||
|
+ load_node_html : function (obj, s_call, e_call) {
|
|||
|
+ var d,
|
|||
|
+ s = this.get_settings().html_data,
|
|||
|
+ error_func = function () {},
|
|||
|
+ success_func = function () {};
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ if(obj && obj !== -1) {
|
|||
|
+ if(obj.data("jstree_is_loading")) { return; }
|
|||
|
+ else { obj.data("jstree_is_loading",true); }
|
|||
|
+ }
|
|||
|
+ switch(!0) {
|
|||
|
+ case ($.isFunction(s.data)):
|
|||
|
+ s.data.call(this, obj, $.proxy(function (d) {
|
|||
|
+ if(d && d !== "" && d.toString && d.toString().replace(/^[\s\n]+$/,"") !== "") {
|
|||
|
+ d = $(d);
|
|||
|
+ if(!d.is("ul")) { d = $("<ul />").append(d); }
|
|||
|
+ if(obj == -1 || !obj) { this.get_container().children("ul").empty().append(d.children()).find("li, a").filter(function () { return !this.firstChild || !this.firstChild.tagName || this.firstChild.tagName !== "INS"; }).prepend("<ins class='jstree-icon'> </ins>").end().filter("a").children("ins:first-child").not(".jstree-icon").addClass("jstree-icon"); }
|
|||
|
+ else { obj.children("a.jstree-loading").removeClass("jstree-loading"); obj.append(d).children("ul").find("li, a").filter(function () { return !this.firstChild || !this.firstChild.tagName || this.firstChild.tagName !== "INS"; }).prepend("<ins class='jstree-icon'> </ins>").end().filter("a").children("ins:first-child").not(".jstree-icon").addClass("jstree-icon"); obj.removeData("jstree_is_loading"); }
|
|||
|
+ this.clean_node(obj);
|
|||
|
+ if(s_call) { s_call.call(this); }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(obj && obj !== -1) {
|
|||
|
+ obj.children("a.jstree-loading").removeClass("jstree-loading");
|
|||
|
+ obj.removeData("jstree_is_loading");
|
|||
|
+ if(s.correct_state) {
|
|||
|
+ this.correct_state(obj);
|
|||
|
+ if(s_call) { s_call.call(this); }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(s.correct_state) {
|
|||
|
+ this.get_container().children("ul").empty();
|
|||
|
+ if(s_call) { s_call.call(this); }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }, this));
|
|||
|
+ break;
|
|||
|
+ case (!s.data && !s.ajax):
|
|||
|
+ if(!obj || obj == -1) {
|
|||
|
+ this.get_container()
|
|||
|
+ .children("ul").empty()
|
|||
|
+ .append(this.data.html_data.original_container_html)
|
|||
|
+ .find("li, a").filter(function () { return !this.firstChild || !this.firstChild.tagName || this.firstChild.tagName !== "INS"; }).prepend("<ins class='jstree-icon'> </ins>").end()
|
|||
|
+ .filter("a").children("ins:first-child").not(".jstree-icon").addClass("jstree-icon");
|
|||
|
+ this.clean_node();
|
|||
|
+ }
|
|||
|
+ if(s_call) { s_call.call(this); }
|
|||
|
+ break;
|
|||
|
+ case (!!s.data && !s.ajax) || (!!s.data && !!s.ajax && (!obj || obj === -1)):
|
|||
|
+ if(!obj || obj == -1) {
|
|||
|
+ d = $(s.data);
|
|||
|
+ if(!d.is("ul")) { d = $("<ul />").append(d); }
|
|||
|
+ this.get_container()
|
|||
|
+ .children("ul").empty().append(d.children())
|
|||
|
+ .find("li, a").filter(function () { return !this.firstChild || !this.firstChild.tagName || this.firstChild.tagName !== "INS"; }).prepend("<ins class='jstree-icon'> </ins>").end()
|
|||
|
+ .filter("a").children("ins:first-child").not(".jstree-icon").addClass("jstree-icon");
|
|||
|
+ this.clean_node();
|
|||
|
+ }
|
|||
|
+ if(s_call) { s_call.call(this); }
|
|||
|
+ break;
|
|||
|
+ case (!s.data && !!s.ajax) || (!!s.data && !!s.ajax && obj && obj !== -1):
|
|||
|
+ obj = this._get_node(obj);
|
|||
|
+ error_func = function (x, t, e) {
|
|||
|
+ var ef = this.get_settings().html_data.ajax.error;
|
|||
|
+ if(ef) { ef.call(this, x, t, e); }
|
|||
|
+ if(obj != -1 && obj.length) {
|
|||
|
+ obj.children("a.jstree-loading").removeClass("jstree-loading");
|
|||
|
+ obj.removeData("jstree_is_loading");
|
|||
|
+ if(t === "success" && s.correct_state) { this.correct_state(obj); }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(t === "success" && s.correct_state) { this.get_container().children("ul").empty(); }
|
|||
|
+ }
|
|||
|
+ if(e_call) { e_call.call(this); }
|
|||
|
+ };
|
|||
|
+ success_func = function (d, t, x) {
|
|||
|
+ var sf = this.get_settings().html_data.ajax.success;
|
|||
|
+ if(sf) { d = sf.call(this,d,t,x) || d; }
|
|||
|
+ if(d === "" || (d && d.toString && d.toString().replace(/^[\s\n]+$/,"") === "")) {
|
|||
|
+ return error_func.call(this, x, t, "");
|
|||
|
+ }
|
|||
|
+ if(d) {
|
|||
|
+ d = $(d);
|
|||
|
+ if(!d.is("ul")) { d = $("<ul />").append(d); }
|
|||
|
+ if(obj == -1 || !obj) { this.get_container().children("ul").empty().append(d.children()).find("li, a").filter(function () { return !this.firstChild || !this.firstChild.tagName || this.firstChild.tagName !== "INS"; }).prepend("<ins class='jstree-icon'> </ins>").end().filter("a").children("ins:first-child").not(".jstree-icon").addClass("jstree-icon"); }
|
|||
|
+ else { obj.children("a.jstree-loading").removeClass("jstree-loading"); obj.append(d).children("ul").find("li, a").filter(function () { return !this.firstChild || !this.firstChild.tagName || this.firstChild.tagName !== "INS"; }).prepend("<ins class='jstree-icon'> </ins>").end().filter("a").children("ins:first-child").not(".jstree-icon").addClass("jstree-icon"); obj.removeData("jstree_is_loading"); }
|
|||
|
+ this.clean_node(obj);
|
|||
|
+ if(s_call) { s_call.call(this); }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(obj && obj !== -1) {
|
|||
|
+ obj.children("a.jstree-loading").removeClass("jstree-loading");
|
|||
|
+ obj.removeData("jstree_is_loading");
|
|||
|
+ if(s.correct_state) {
|
|||
|
+ this.correct_state(obj);
|
|||
|
+ if(s_call) { s_call.call(this); }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ if(s.correct_state) {
|
|||
|
+ this.get_container().children("ul").empty();
|
|||
|
+ if(s_call) { s_call.call(this); }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ };
|
|||
|
+ s.ajax.context = this;
|
|||
|
+ s.ajax.error = error_func;
|
|||
|
+ s.ajax.success = success_func;
|
|||
|
+ if(!s.ajax.dataType) { s.ajax.dataType = "html"; }
|
|||
|
+ if($.isFunction(s.ajax.url)) { s.ajax.url = s.ajax.url.call(this, obj); }
|
|||
|
+ if($.isFunction(s.ajax.data)) { s.ajax.data = s.ajax.data.call(this, obj); }
|
|||
|
+ $.ajax(s.ajax);
|
|||
|
+ break;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ // include the HTML data plugin by default
|
|||
|
+ $.jstree.defaults.plugins.push("html_data");
|
|||
|
+})(jQuery);
|
|||
|
+//*/
|
|||
|
+
|
|||
|
+/*
|
|||
|
+ * jsTree themeroller plugin
|
|||
|
+ * Adds support for jQuery UI themes. Include this at the end of your plugins list, also make sure "themes" is not included.
|
|||
|
+ */
|
|||
|
+(function ($) {
|
|||
|
+ $.jstree.plugin("themeroller", {
|
|||
|
+ __init : function () {
|
|||
|
+ var s = this._get_settings().themeroller;
|
|||
|
+ this.get_container()
|
|||
|
+ .addClass("ui-widget-content")
|
|||
|
+ .addClass("jstree-themeroller")
|
|||
|
+ .delegate("a","mouseenter.jstree", function (e) {
|
|||
|
+ if(!$(e.currentTarget).hasClass("jstree-loading")) {
|
|||
|
+ $(this).addClass(s.item_h);
|
|||
|
+ }
|
|||
|
+ })
|
|||
|
+ .delegate("a","mouseleave.jstree", function () {
|
|||
|
+ $(this).removeClass(s.item_h);
|
|||
|
+ })
|
|||
|
+ .bind("init.jstree", $.proxy(function (e, data) {
|
|||
|
+ data.inst.get_container().find("> ul > li > .jstree-loading > ins").addClass("ui-icon-refresh");
|
|||
|
+ this._themeroller(data.inst.get_container().find("> ul > li"));
|
|||
|
+ }, this))
|
|||
|
+ .bind("open_node.jstree create_node.jstree", $.proxy(function (e, data) {
|
|||
|
+ this._themeroller(data.rslt.obj);
|
|||
|
+ }, this))
|
|||
|
+ .bind("loaded.jstree refresh.jstree", $.proxy(function (e) {
|
|||
|
+ this._themeroller();
|
|||
|
+ }, this))
|
|||
|
+ .bind("close_node.jstree", $.proxy(function (e, data) {
|
|||
|
+ this._themeroller(data.rslt.obj);
|
|||
|
+ }, this))
|
|||
|
+ .bind("delete_node.jstree", $.proxy(function (e, data) {
|
|||
|
+ this._themeroller(data.rslt.parent);
|
|||
|
+ }, this))
|
|||
|
+ .bind("correct_state.jstree", $.proxy(function (e, data) {
|
|||
|
+ data.rslt.obj
|
|||
|
+ .children("ins.jstree-icon").removeClass(s.opened + " " + s.closed + " ui-icon").end()
|
|||
|
+ .find("> a > ins.ui-icon")
|
|||
|
+ .filter(function() {
|
|||
|
+ return this.className.toString()
|
|||
|
+ .replace(s.item_clsd,"").replace(s.item_open,"").replace(s.item_leaf,"")
|
|||
|
+ .indexOf("ui-icon-") === -1;
|
|||
|
+ }).removeClass(s.item_open + " " + s.item_clsd).addClass(s.item_leaf || "jstree-no-icon");
|
|||
|
+ }, this))
|
|||
|
+ .bind("select_node.jstree", $.proxy(function (e, data) {
|
|||
|
+ data.rslt.obj.children("a").addClass(s.item_a);
|
|||
|
+ }, this))
|
|||
|
+ .bind("deselect_node.jstree deselect_all.jstree", $.proxy(function (e, data) {
|
|||
|
+ this.get_container()
|
|||
|
+ .find("a." + s.item_a).removeClass(s.item_a).end()
|
|||
|
+ .find("a.jstree-clicked").addClass(s.item_a);
|
|||
|
+ }, this))
|
|||
|
+ .bind("dehover_node.jstree", $.proxy(function (e, data) {
|
|||
|
+ data.rslt.obj.children("a").removeClass(s.item_h);
|
|||
|
+ }, this))
|
|||
|
+ .bind("hover_node.jstree", $.proxy(function (e, data) {
|
|||
|
+ this.get_container()
|
|||
|
+ .find("a." + s.item_h).not(data.rslt.obj).removeClass(s.item_h);
|
|||
|
+ data.rslt.obj.children("a").addClass(s.item_h);
|
|||
|
+ }, this))
|
|||
|
+ .bind("move_node.jstree", $.proxy(function (e, data) {
|
|||
|
+ this._themeroller(data.rslt.o);
|
|||
|
+ this._themeroller(data.rslt.op);
|
|||
|
+ }, this));
|
|||
|
+ },
|
|||
|
+ __destroy : function () {
|
|||
|
+ var s = this._get_settings().themeroller,
|
|||
|
+ c = [ "ui-icon" ];
|
|||
|
+ $.each(s, function (i, v) {
|
|||
|
+ v = v.split(" ");
|
|||
|
+ if(v.length) { c = c.concat(v); }
|
|||
|
+ });
|
|||
|
+ this.get_container()
|
|||
|
+ .removeClass("ui-widget-content")
|
|||
|
+ .find("." + c.join(", .")).removeClass(c.join(" "));
|
|||
|
+ },
|
|||
|
+ _fn : {
|
|||
|
+ _themeroller : function (obj) {
|
|||
|
+ var s = this._get_settings().themeroller;
|
|||
|
+ obj = !obj || obj == -1 ? this.get_container_ul() : this._get_node(obj).parent();
|
|||
|
+ obj
|
|||
|
+ .find("li.jstree-closed")
|
|||
|
+ .children("ins.jstree-icon").removeClass(s.opened).addClass("ui-icon " + s.closed).end()
|
|||
|
+ .children("a").addClass(s.item)
|
|||
|
+ .children("ins.jstree-icon").addClass("ui-icon")
|
|||
|
+ .filter(function() {
|
|||
|
+ return this.className.toString()
|
|||
|
+ .replace(s.item_clsd,"").replace(s.item_open,"").replace(s.item_leaf,"")
|
|||
|
+ .indexOf("ui-icon-") === -1;
|
|||
|
+ }).removeClass(s.item_leaf + " " + s.item_open).addClass(s.item_clsd || "jstree-no-icon")
|
|||
|
+ .end()
|
|||
|
+ .end()
|
|||
|
+ .end()
|
|||
|
+ .end()
|
|||
|
+ .find("li.jstree-open")
|
|||
|
+ .children("ins.jstree-icon").removeClass(s.closed).addClass("ui-icon " + s.opened).end()
|
|||
|
+ .children("a").addClass(s.item)
|
|||
|
+ .children("ins.jstree-icon").addClass("ui-icon")
|
|||
|
+ .filter(function() {
|
|||
|
+ return this.className.toString()
|
|||
|
+ .replace(s.item_clsd,"").replace(s.item_open,"").replace(s.item_leaf,"")
|
|||
|
+ .indexOf("ui-icon-") === -1;
|
|||
|
+ }).removeClass(s.item_leaf + " " + s.item_clsd).addClass(s.item_open || "jstree-no-icon")
|
|||
|
+ .end()
|
|||
|
+ .end()
|
|||
|
+ .end()
|
|||
|
+ .end()
|
|||
|
+ .find("li.jstree-leaf")
|
|||
|
+ .children("ins.jstree-icon").removeClass(s.closed + " ui-icon " + s.opened).end()
|
|||
|
+ .children("a").addClass(s.item)
|
|||
|
+ .children("ins.jstree-icon").addClass("ui-icon")
|
|||
|
+ .filter(function() {
|
|||
|
+ return this.className.toString()
|
|||
|
+ .replace(s.item_clsd,"").replace(s.item_open,"").replace(s.item_leaf,"")
|
|||
|
+ .indexOf("ui-icon-") === -1;
|
|||
|
+ }).removeClass(s.item_clsd + " " + s.item_open).addClass(s.item_leaf || "jstree-no-icon");
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ defaults : {
|
|||
|
+ "opened" : "ui-icon-triangle-1-se",
|
|||
|
+ "closed" : "ui-icon-triangle-1-e",
|
|||
|
+ "item" : "ui-state-default",
|
|||
|
+ "item_h" : "ui-state-hover",
|
|||
|
+ "item_a" : "ui-state-active",
|
|||
|
+ "item_open" : "ui-icon-folder-open",
|
|||
|
+ "item_clsd" : "ui-icon-folder-collapsed",
|
|||
|
+ "item_leaf" : "ui-icon-document"
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ $(function() {
|
|||
|
+ var css_string = '' +
|
|||
|
+ '.jstree-themeroller .ui-icon { overflow:visible; } ' +
|
|||
|
+ '.jstree-themeroller a { padding:0 2px; } ' +
|
|||
|
+ '.jstree-themeroller .jstree-no-icon { display:none; }';
|
|||
|
+ $.vakata.css.add_sheet({ str : css_string, title : "jstree" });
|
|||
|
+ });
|
|||
|
+})(jQuery);
|
|||
|
+//*/
|
|||
|
+
|
|||
|
+/*
|
|||
|
+ * jsTree unique plugin
|
|||
|
+ * Forces different names amongst siblings (still a bit experimental)
|
|||
|
+ * NOTE: does not check language versions (it will not be possible to have nodes with the same title, even in different languages)
|
|||
|
+ */
|
|||
|
+(function ($) {
|
|||
|
+ $.jstree.plugin("unique", {
|
|||
|
+ __init : function () {
|
|||
|
+ this.get_container()
|
|||
|
+ .bind("before.jstree", $.proxy(function (e, data) {
|
|||
|
+ var nms = [], res = true, p, t;
|
|||
|
+ if(data.func == "move_node") {
|
|||
|
+ // obj, ref, position, is_copy, is_prepared, skip_check
|
|||
|
+ if(data.args[4] === true) {
|
|||
|
+ if(data.args[0].o && data.args[0].o.length) {
|
|||
|
+ data.args[0].o.children("a").each(function () { nms.push($(this).text().replace(/^\s+/g,"")); });
|
|||
|
+ res = this._check_unique(nms, data.args[0].np.find("> ul > li").not(data.args[0].o), "move_node");
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ if(data.func == "create_node") {
|
|||
|
+ // obj, position, js, callback, is_loaded
|
|||
|
+ if(data.args[4] || this._is_loaded(data.args[0])) {
|
|||
|
+ p = this._get_node(data.args[0]);
|
|||
|
+ if(data.args[1] && (data.args[1] === "before" || data.args[1] === "after")) {
|
|||
|
+ p = this._get_parent(data.args[0]);
|
|||
|
+ if(!p || p === -1) { p = this.get_container(); }
|
|||
|
+ }
|
|||
|
+ if(typeof data.args[2] === "string") { nms.push(data.args[2]); }
|
|||
|
+ else if(!data.args[2] || !data.args[2].data) { nms.push(this._get_string("new_node")); }
|
|||
|
+ else { nms.push(data.args[2].data); }
|
|||
|
+ res = this._check_unique(nms, p.find("> ul > li"), "create_node");
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ if(data.func == "rename_node") {
|
|||
|
+ // obj, val
|
|||
|
+ nms.push(data.args[1]);
|
|||
|
+ t = this._get_node(data.args[0]);
|
|||
|
+ p = this._get_parent(t);
|
|||
|
+ if(!p || p === -1) { p = this.get_container(); }
|
|||
|
+ res = this._check_unique(nms, p.find("> ul > li").not(t), "rename_node");
|
|||
|
+ }
|
|||
|
+ if(!res) {
|
|||
|
+ e.stopPropagation();
|
|||
|
+ return false;
|
|||
|
+ }
|
|||
|
+ }, this));
|
|||
|
+ },
|
|||
|
+ defaults : {
|
|||
|
+ error_callback : $.noop
|
|||
|
+ },
|
|||
|
+ _fn : {
|
|||
|
+ _check_unique : function (nms, p, func) {
|
|||
|
+ var cnms = [];
|
|||
|
+ p.children("a").each(function () { cnms.push($(this).text().replace(/^\s+/g,"")); });
|
|||
|
+ if(!cnms.length || !nms.length) { return true; }
|
|||
|
+ cnms = cnms.sort().join(",,").replace(/(,|^)([^,]+)(,,\2)+(,|$)/g,"$1$2$4").replace(/,,+/g,",").replace(/,$/,"").split(",");
|
|||
|
+ if((cnms.length + nms.length) != cnms.concat(nms).sort().join(",,").replace(/(,|^)([^,]+)(,,\2)+(,|$)/g,"$1$2$4").replace(/,,+/g,",").replace(/,$/,"").split(",").length) {
|
|||
|
+ this._get_settings().unique.error_callback.call(null, nms, p, func);
|
|||
|
+ return false;
|
|||
|
+ }
|
|||
|
+ return true;
|
|||
|
+ },
|
|||
|
+ check_move : function () {
|
|||
|
+ if(!this.__call_old()) { return false; }
|
|||
|
+ var p = this._get_move(), nms = [];
|
|||
|
+ if(p.o && p.o.length) {
|
|||
|
+ p.o.children("a").each(function () { nms.push($(this).text().replace(/^\s+/g,"")); });
|
|||
|
+ return this._check_unique(nms, p.np.find("> ul > li").not(p.o), "check_move");
|
|||
|
+ }
|
|||
|
+ return true;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+})(jQuery);
|
|||
|
+//*/
|
|||
|
+
|
|||
|
+/*
|
|||
|
+ * jsTree wholerow plugin
|
|||
|
+ * Makes select and hover work on the entire width of the node
|
|||
|
+ * MAY BE HEAVY IN LARGE DOM
|
|||
|
+ */
|
|||
|
+(function ($) {
|
|||
|
+ $.jstree.plugin("wholerow", {
|
|||
|
+ __init : function () {
|
|||
|
+ if(!this.data.ui) { throw "jsTree wholerow: jsTree UI plugin not included."; }
|
|||
|
+ this.data.wholerow.html = false;
|
|||
|
+ this.data.wholerow.to = false;
|
|||
|
+ this.get_container()
|
|||
|
+ .bind("init.jstree", $.proxy(function (e, data) {
|
|||
|
+ this._get_settings().core.animation = 0;
|
|||
|
+ }, this))
|
|||
|
+ .bind("open_node.jstree create_node.jstree clean_node.jstree loaded.jstree", $.proxy(function (e, data) {
|
|||
|
+ this._prepare_wholerow_span( data && data.rslt && data.rslt.obj ? data.rslt.obj : -1 );
|
|||
|
+ }, this))
|
|||
|
+ .bind("search.jstree clear_search.jstree reopen.jstree after_open.jstree after_close.jstree create_node.jstree delete_node.jstree clean_node.jstree", $.proxy(function (e, data) {
|
|||
|
+ if(this.data.to) { clearTimeout(this.data.to); }
|
|||
|
+ this.data.to = setTimeout( (function (t, o) { return function() { t._prepare_wholerow_ul(o); }; })(this, data && data.rslt && data.rslt.obj ? data.rslt.obj : -1), 0);
|
|||
|
+ }, this))
|
|||
|
+ .bind("deselect_all.jstree", $.proxy(function (e, data) {
|
|||
|
+ this.get_container().find(" > .jstree-wholerow .jstree-clicked").removeClass("jstree-clicked " + (this.data.themeroller ? this._get_settings().themeroller.item_a : "" ));
|
|||
|
+ }, this))
|
|||
|
+ .bind("select_node.jstree deselect_node.jstree ", $.proxy(function (e, data) {
|
|||
|
+ data.rslt.obj.each(function () {
|
|||
|
+ var ref = data.inst.get_container().find(" > .jstree-wholerow li:visible:eq(" + ( parseInt((($(this).offset().top - data.inst.get_container().offset().top + data.inst.get_container()[0].scrollTop) / data.inst.data.core.li_height),10)) + ")");
|
|||
|
+ // ref.children("a")[e.type === "select_node" ? "addClass" : "removeClass"]("jstree-clicked");
|
|||
|
+ ref.children("a").attr("class",data.rslt.obj.children("a").attr("class"));
|
|||
|
+ });
|
|||
|
+ }, this))
|
|||
|
+ .bind("hover_node.jstree dehover_node.jstree", $.proxy(function (e, data) {
|
|||
|
+ this.get_container().find(" > .jstree-wholerow .jstree-hovered").removeClass("jstree-hovered " + (this.data.themeroller ? this._get_settings().themeroller.item_h : "" ));
|
|||
|
+ if(e.type === "hover_node") {
|
|||
|
+ var ref = this.get_container().find(" > .jstree-wholerow li:visible:eq(" + ( parseInt(((data.rslt.obj.offset().top - this.get_container().offset().top + this.get_container()[0].scrollTop) / this.data.core.li_height),10)) + ")");
|
|||
|
+ // ref.children("a").addClass("jstree-hovered");
|
|||
|
+ ref.children("a").attr("class",data.rslt.obj.children(".jstree-hovered").attr("class"));
|
|||
|
+ }
|
|||
|
+ }, this))
|
|||
|
+ .delegate(".jstree-wholerow-span, ins.jstree-icon, li", "click.jstree", function (e) {
|
|||
|
+ var n = $(e.currentTarget);
|
|||
|
+ if(e.target.tagName === "A" || (e.target.tagName === "INS" && n.closest("li").is(".jstree-open, .jstree-closed"))) { return; }
|
|||
|
+ n.closest("li").children("a:visible:eq(0)").click();
|
|||
|
+ e.stopImmediatePropagation();
|
|||
|
+ })
|
|||
|
+ .delegate("li", "mouseover.jstree", $.proxy(function (e) {
|
|||
|
+ e.stopImmediatePropagation();
|
|||
|
+ if($(e.currentTarget).children(".jstree-hovered, .jstree-clicked").length) { return false; }
|
|||
|
+ this.hover_node(e.currentTarget);
|
|||
|
+ return false;
|
|||
|
+ }, this))
|
|||
|
+ .delegate("li", "mouseleave.jstree", $.proxy(function (e) {
|
|||
|
+ if($(e.currentTarget).children("a").hasClass("jstree-hovered").length) { return; }
|
|||
|
+ this.dehover_node(e.currentTarget);
|
|||
|
+ }, this));
|
|||
|
+ if(is_ie7 || is_ie6) {
|
|||
|
+ $.vakata.css.add_sheet({ str : ".jstree-" + this.get_index() + " { position:relative; } ", title : "jstree" });
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ defaults : {
|
|||
|
+ },
|
|||
|
+ __destroy : function () {
|
|||
|
+ this.get_container().children(".jstree-wholerow").remove();
|
|||
|
+ this.get_container().find(".jstree-wholerow-span").remove();
|
|||
|
+ },
|
|||
|
+ _fn : {
|
|||
|
+ _prepare_wholerow_span : function (obj) {
|
|||
|
+ obj = !obj || obj == -1 ? this.get_container().find("> ul > li") : this._get_node(obj);
|
|||
|
+ if(obj === false) { return; } // added for removing root nodes
|
|||
|
+ obj.each(function () {
|
|||
|
+ $(this).find("li").andSelf().each(function () {
|
|||
|
+ var $t = $(this);
|
|||
|
+ if($t.children(".jstree-wholerow-span").length) { return true; }
|
|||
|
+ $t.prepend("<span class='jstree-wholerow-span' style='width:" + ($t.parentsUntil(".jstree","li").length * 18) + "px;'> </span>");
|
|||
|
+ });
|
|||
|
+ });
|
|||
|
+ },
|
|||
|
+ _prepare_wholerow_ul : function () {
|
|||
|
+ var o = this.get_container().children("ul").eq(0), h = o.html();
|
|||
|
+ o.addClass("jstree-wholerow-real");
|
|||
|
+ if(this.data.wholerow.last_html !== h) {
|
|||
|
+ this.data.wholerow.last_html = h;
|
|||
|
+ this.get_container().children(".jstree-wholerow").remove();
|
|||
|
+ this.get_container().append(
|
|||
|
+ o.clone().removeClass("jstree-wholerow-real")
|
|||
|
+ .wrapAll("<div class='jstree-wholerow' />").parent()
|
|||
|
+ .width(o.parent()[0].scrollWidth)
|
|||
|
+ .css("top", (o.height() + ( is_ie7 ? 5 : 0)) * -1 )
|
|||
|
+ .find("li[id]").each(function () { this.removeAttribute("id"); }).end()
|
|||
|
+ );
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ $(function() {
|
|||
|
+ var css_string = '' +
|
|||
|
+ '.jstree .jstree-wholerow-real { position:relative; z-index:1; } ' +
|
|||
|
+ '.jstree .jstree-wholerow-real li { cursor:pointer; } ' +
|
|||
|
+ '.jstree .jstree-wholerow-real a { border-left-color:transparent !important; border-right-color:transparent !important; } ' +
|
|||
|
+ '.jstree .jstree-wholerow { position:relative; z-index:0; height:0; } ' +
|
|||
|
+ '.jstree .jstree-wholerow ul, .jstree .jstree-wholerow li { width:100%; } ' +
|
|||
|
+ '.jstree .jstree-wholerow, .jstree .jstree-wholerow ul, .jstree .jstree-wholerow li, .jstree .jstree-wholerow a { margin:0 !important; padding:0 !important; } ' +
|
|||
|
+ '.jstree .jstree-wholerow, .jstree .jstree-wholerow ul, .jstree .jstree-wholerow li { background:transparent !important; }' +
|
|||
|
+ '.jstree .jstree-wholerow ins, .jstree .jstree-wholerow span, .jstree .jstree-wholerow input { display:none !important; }' +
|
|||
|
+ '.jstree .jstree-wholerow a, .jstree .jstree-wholerow a:hover { text-indent:-9999px; !important; width:100%; padding:0 !important; border-right-width:0px !important; border-left-width:0px !important; } ' +
|
|||
|
+ '.jstree .jstree-wholerow-span { position:absolute; left:0; margin:0px; padding:0; height:18px; border-width:0; padding:0; z-index:0; }';
|
|||
|
+ if(is_ff2) {
|
|||
|
+ css_string += '' +
|
|||
|
+ '.jstree .jstree-wholerow a { display:block; height:18px; margin:0; padding:0; border:0; } ' +
|
|||
|
+ '.jstree .jstree-wholerow-real a { border-color:transparent !important; } ';
|
|||
|
+ }
|
|||
|
+ if(is_ie7 || is_ie6) {
|
|||
|
+ css_string += '' +
|
|||
|
+ '.jstree .jstree-wholerow, .jstree .jstree-wholerow li, .jstree .jstree-wholerow ul, .jstree .jstree-wholerow a { margin:0; padding:0; line-height:18px; } ' +
|
|||
|
+ '.jstree .jstree-wholerow a { display:block; height:18px; line-height:18px; overflow:hidden; } ';
|
|||
|
+ }
|
|||
|
+ $.vakata.css.add_sheet({ str : css_string, title : "jstree" });
|
|||
|
+ });
|
|||
|
+})(jQuery);
|
|||
|
+//*/
|
|||
|
+
|
|||
|
+/*
|
|||
|
+* jsTree model plugin
|
|||
|
+* This plugin gets jstree to use a class model to retrieve data, creating great dynamism
|
|||
|
+*/
|
|||
|
+(function ($) {
|
|||
|
+ var nodeInterface = ["getChildren","getChildrenCount","getAttr","getName","getProps"],
|
|||
|
+ validateInterface = function(obj, inter) {
|
|||
|
+ var valid = true;
|
|||
|
+ obj = obj || {};
|
|||
|
+ inter = [].concat(inter);
|
|||
|
+ $.each(inter, function (i, v) {
|
|||
|
+ if(!$.isFunction(obj[v])) { valid = false; return false; }
|
|||
|
+ });
|
|||
|
+ return valid;
|
|||
|
+ };
|
|||
|
+ $.jstree.plugin("model", {
|
|||
|
+ __init : function () {
|
|||
|
+ if(!this.data.json_data) { throw "jsTree model: jsTree json_data plugin not included."; }
|
|||
|
+ this._get_settings().json_data.data = function (n, b) {
|
|||
|
+ var obj = (n == -1) ? this._get_settings().model.object : n.data("jstree_model");
|
|||
|
+ if(!validateInterface(obj, nodeInterface)) { return b.call(null, false); }
|
|||
|
+ if(this._get_settings().model.async) {
|
|||
|
+ obj.getChildren($.proxy(function (data) {
|
|||
|
+ this.model_done(data, b);
|
|||
|
+ }, this));
|
|||
|
+ }
|
|||
|
+ else {
|
|||
|
+ this.model_done(obj.getChildren(), b);
|
|||
|
+ }
|
|||
|
+ };
|
|||
|
+ },
|
|||
|
+ defaults : {
|
|||
|
+ object : false,
|
|||
|
+ id_prefix : false,
|
|||
|
+ async : false
|
|||
|
+ },
|
|||
|
+ _fn : {
|
|||
|
+ model_done : function (data, callback) {
|
|||
|
+ var ret = [],
|
|||
|
+ s = this._get_settings(),
|
|||
|
+ _this = this;
|
|||
|
+
|
|||
|
+ if(!$.isArray(data)) { data = [data]; }
|
|||
|
+ $.each(data, function (i, nd) {
|
|||
|
+ var r = nd.getProps() || {};
|
|||
|
+ r.attr = nd.getAttr() || {};
|
|||
|
+ if(nd.getChildrenCount()) { r.state = "closed"; }
|
|||
|
+ r.data = nd.getName();
|
|||
|
+ if(!$.isArray(r.data)) { r.data = [r.data]; }
|
|||
|
+ if(_this.data.types && $.isFunction(nd.getType)) {
|
|||
|
+ r.attr[s.types.type_attr] = nd.getType();
|
|||
|
+ }
|
|||
|
+ if(r.attr.id && s.model.id_prefix) { r.attr.id = s.model.id_prefix + r.attr.id; }
|
|||
|
+ if(!r.metadata) { r.metadata = { }; }
|
|||
|
+ r.metadata.jstree_model = nd;
|
|||
|
+ ret.push(r);
|
|||
|
+ });
|
|||
|
+ callback.call(null, ret);
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+})(jQuery);
|
|||
|
+//*/
|
|||
|
+
|
|||
|
+})();
|
|||
|
\ No newline at end of file
|
|||
|
diff -up cacti-0.8.8a/include/js/jquery/jquery.tablednd.js.legal cacti-0.8.8a/include/js/jquery/jquery.tablednd.js
|
|||
|
--- cacti-0.8.8a/include/js/jquery/jquery.tablednd.js.legal 2013-01-04 15:44:38.038416075 -0500
|
|||
|
+++ cacti-0.8.8a/include/js/jquery/jquery.tablednd.js 2013-01-04 15:43:12.645377988 -0500
|
|||
|
@@ -0,0 +1,382 @@
|
|||
|
+/**
|
|||
|
+ * TableDnD plug-in for JQuery, allows you to drag and drop table rows
|
|||
|
+ * You can set up various options to control how the system will work
|
|||
|
+ * Copyright (c) Denis Howlett <denish@isocra.com>
|
|||
|
+ * Licensed like jQuery, see http://docs.jquery.com/License.
|
|||
|
+ *
|
|||
|
+ * Configuration options:
|
|||
|
+ *
|
|||
|
+ * onDragStyle
|
|||
|
+ * This is the style that is assigned to the row during drag. There are limitations to the styles that can be
|
|||
|
+ * associated with a row (such as you can't assign a border--well you can, but it won't be
|
|||
|
+ * displayed). (So instead consider using onDragClass.) The CSS style to apply is specified as
|
|||
|
+ * a map (as used in the jQuery css(...) function).
|
|||
|
+ * onDropStyle
|
|||
|
+ * This is the style that is assigned to the row when it is dropped. As for onDragStyle, there are limitations
|
|||
|
+ * to what you can do. Also this replaces the original style, so again consider using onDragClass which
|
|||
|
+ * is simply added and then removed on drop.
|
|||
|
+ * onDragClass
|
|||
|
+ * This class is added for the duration of the drag and then removed when the row is dropped. It is more
|
|||
|
+ * flexible than using onDragStyle since it can be inherited by the row cells and other content. The default
|
|||
|
+ * is class is tDnD_whileDrag. So to use the default, simply customise this CSS class in your
|
|||
|
+ * stylesheet.
|
|||
|
+ * onDrop
|
|||
|
+ * Pass a function that will be called when the row is dropped. The function takes 2 parameters: the table
|
|||
|
+ * and the row that was dropped. You can work out the new order of the rows by using
|
|||
|
+ * table.rows.
|
|||
|
+ * onDragStart
|
|||
|
+ * Pass a function that will be called when the user starts dragging. The function takes 2 parameters: the
|
|||
|
+ * table and the row which the user has started to drag.
|
|||
|
+ * onAllowDrop
|
|||
|
+ * Pass a function that will be called as a row is over another row. If the function returns true, allow
|
|||
|
+ * dropping on that row, otherwise not. The function takes 2 parameters: the dragged row and the row under
|
|||
|
+ * the cursor. It returns a boolean: true allows the drop, false doesn't allow it.
|
|||
|
+ * scrollAmount
|
|||
|
+ * This is the number of pixels to scroll if the user moves the mouse cursor to the top or bottom of the
|
|||
|
+ * window. The page should automatically scroll up or down as appropriate (tested in IE6, IE7, Safari, FF2,
|
|||
|
+ * FF3 beta
|
|||
|
+ * dragHandle
|
|||
|
+ * This is the name of a class that you assign to one or more cells in each row that is draggable. If you
|
|||
|
+ * specify this class, then you are responsible for setting cursor: move in the CSS and only these cells
|
|||
|
+ * will have the drag behaviour. If you do not specify a dragHandle, then you get the old behaviour where
|
|||
|
+ * the whole row is draggable.
|
|||
|
+ *
|
|||
|
+ * Other ways to control behaviour:
|
|||
|
+ *
|
|||
|
+ * Add class="nodrop" to any rows for which you don't want to allow dropping, and class="nodrag" to any rows
|
|||
|
+ * that you don't want to be draggable.
|
|||
|
+ *
|
|||
|
+ * Inside the onDrop method you can also call $.tableDnD.serialize() this returns a string of the form
|
|||
|
+ * <tableID>[]=<rowID1>&<tableID>[]=<rowID2> so that you can send this back to the server. The table must have
|
|||
|
+ * an ID as must all the rows.
|
|||
|
+ *
|
|||
|
+ * Other methods:
|
|||
|
+ *
|
|||
|
+ * $("...").tableDnDUpdate()
|
|||
|
+ * Will update all the matching tables, that is it will reapply the mousedown method to the rows (or handle cells).
|
|||
|
+ * This is useful if you have updated the table rows using Ajax and you want to make the table draggable again.
|
|||
|
+ * The table maintains the original configuration (so you don't have to specify it again).
|
|||
|
+ *
|
|||
|
+ * $("...").tableDnDSerialize()
|
|||
|
+ * Will serialize and return the serialized string as above, but for each of the matching tables--so it can be
|
|||
|
+ * called from anywhere and isn't dependent on the currentTable being set up correctly before calling
|
|||
|
+ *
|
|||
|
+ * Known problems:
|
|||
|
+ * - Auto-scoll has some problems with IE7 (it scrolls even when it shouldn't), work-around: set scrollAmount to 0
|
|||
|
+ *
|
|||
|
+ * Version 0.2: 2008-02-20 First public version
|
|||
|
+ * Version 0.3: 2008-02-07 Added onDragStart option
|
|||
|
+ * Made the scroll amount configurable (default is 5 as before)
|
|||
|
+ * Version 0.4: 2008-03-15 Changed the noDrag/noDrop attributes to nodrag/nodrop classes
|
|||
|
+ * Added onAllowDrop to control dropping
|
|||
|
+ * Fixed a bug which meant that you couldn't set the scroll amount in both directions
|
|||
|
+ * Added serialize method
|
|||
|
+ * Version 0.5: 2008-05-16 Changed so that if you specify a dragHandle class it doesn't make the whole row
|
|||
|
+ * draggable
|
|||
|
+ * Improved the serialize method to use a default (and settable) regular expression.
|
|||
|
+ * Added tableDnDupate() and tableDnDSerialize() to be called when you are outside the table
|
|||
|
+ */
|
|||
|
+jQuery.tableDnD = {
|
|||
|
+ /** Keep hold of the current table being dragged */
|
|||
|
+ currentTable : null,
|
|||
|
+ /** Keep hold of the current drag object if any */
|
|||
|
+ dragObject: null,
|
|||
|
+ /** The current mouse offset */
|
|||
|
+ mouseOffset: null,
|
|||
|
+ /** Remember the old value of Y so that we don't do too much processing */
|
|||
|
+ oldY: 0,
|
|||
|
+
|
|||
|
+ /** Actually build the structure */
|
|||
|
+ build: function(options) {
|
|||
|
+ // Set up the defaults if any
|
|||
|
+
|
|||
|
+ this.each(function() {
|
|||
|
+ // This is bound to each matching table, set up the defaults and override with user options
|
|||
|
+ this.tableDnDConfig = jQuery.extend({
|
|||
|
+ onDragStyle: null,
|
|||
|
+ onDropStyle: null,
|
|||
|
+ // Add in the default class for whileDragging
|
|||
|
+ onDragClass: "tDnD_whileDrag",
|
|||
|
+ onDrop: null,
|
|||
|
+ onDragStart: null,
|
|||
|
+ scrollAmount: 5,
|
|||
|
+ serializeRegexp: /[^\_]*$/, // The regular expression to use to trim row IDs
|
|||
|
+ serializeParamName: null, // If you want to specify another parameter name instead of the table ID
|
|||
|
+ dragHandle: null // If you give the name of a class here, then only Cells with this class will be draggable
|
|||
|
+ }, options || {});
|
|||
|
+ // Now make the rows draggable
|
|||
|
+ jQuery.tableDnD.makeDraggable(this);
|
|||
|
+ });
|
|||
|
+
|
|||
|
+ // Now we need to capture the mouse up and mouse move event
|
|||
|
+ // We can use bind so that we don't interfere with other event handlers
|
|||
|
+ jQuery(document)
|
|||
|
+ .bind('mousemove', jQuery.tableDnD.mousemove)
|
|||
|
+ .bind('mouseup', jQuery.tableDnD.mouseup);
|
|||
|
+
|
|||
|
+ // Don't break the chain
|
|||
|
+ return this;
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ /** This function makes all the rows on the table draggable apart from those marked as "NoDrag" */
|
|||
|
+ makeDraggable: function(table) {
|
|||
|
+ var config = table.tableDnDConfig;
|
|||
|
+ if (table.tableDnDConfig.dragHandle) {
|
|||
|
+ // We only need to add the event to the specified cells
|
|||
|
+ var cells = jQuery("td."+table.tableDnDConfig.dragHandle, table);
|
|||
|
+ cells.each(function() {
|
|||
|
+ // The cell is bound to "this"
|
|||
|
+ jQuery(this).mousedown(function(ev) {
|
|||
|
+ jQuery.tableDnD.dragObject = this.parentNode;
|
|||
|
+ jQuery.tableDnD.currentTable = table;
|
|||
|
+ jQuery.tableDnD.mouseOffset = jQuery.tableDnD.getMouseOffset(this, ev);
|
|||
|
+ if (config.onDragStart) {
|
|||
|
+ // Call the onDrop method if there is one
|
|||
|
+ config.onDragStart(table, this);
|
|||
|
+ }
|
|||
|
+ return false;
|
|||
|
+ });
|
|||
|
+ })
|
|||
|
+ } else {
|
|||
|
+ // For backwards compatibility, we add the event to the whole row
|
|||
|
+ var rows = jQuery("tr", table); // get all the rows as a wrapped set
|
|||
|
+ rows.each(function() {
|
|||
|
+ // Iterate through each row, the row is bound to "this"
|
|||
|
+ var row = jQuery(this);
|
|||
|
+ if (! row.hasClass("nodrag")) {
|
|||
|
+ row.mousedown(function(ev) {
|
|||
|
+ if (ev.target.tagName == "TD") {
|
|||
|
+ jQuery.tableDnD.dragObject = this;
|
|||
|
+ jQuery.tableDnD.currentTable = table;
|
|||
|
+ jQuery.tableDnD.mouseOffset = jQuery.tableDnD.getMouseOffset(this, ev);
|
|||
|
+ if (config.onDragStart) {
|
|||
|
+ // Call the onDrop method if there is one
|
|||
|
+ config.onDragStart(table, this);
|
|||
|
+ }
|
|||
|
+ return false;
|
|||
|
+ }
|
|||
|
+ }).css("cursor", "move"); // Store the tableDnD object
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ updateTables: function() {
|
|||
|
+ this.each(function() {
|
|||
|
+ // this is now bound to each matching table
|
|||
|
+ if (this.tableDnDConfig) {
|
|||
|
+ jQuery.tableDnD.makeDraggable(this);
|
|||
|
+ }
|
|||
|
+ })
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ /** Get the mouse coordinates from the event (allowing for browser differences) */
|
|||
|
+ mouseCoords: function(ev){
|
|||
|
+ if(ev.pageX || ev.pageY){
|
|||
|
+ return {x:ev.pageX, y:ev.pageY};
|
|||
|
+ }
|
|||
|
+ return {
|
|||
|
+ x:ev.clientX + document.body.scrollLeft - document.body.clientLeft,
|
|||
|
+ y:ev.clientY + document.body.scrollTop - document.body.clientTop
|
|||
|
+ };
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ /** Given a target element and a mouse event, get the mouse offset from that element.
|
|||
|
+ To do this we need the element's position and the mouse position */
|
|||
|
+ getMouseOffset: function(target, ev) {
|
|||
|
+ ev = ev || window.event;
|
|||
|
+
|
|||
|
+ var docPos = this.getPosition(target);
|
|||
|
+ var mousePos = this.mouseCoords(ev);
|
|||
|
+ return {x:mousePos.x - docPos.x, y:mousePos.y - docPos.y};
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ /** Get the position of an element by going up the DOM tree and adding up all the offsets */
|
|||
|
+ getPosition: function(e){
|
|||
|
+ var left = 0;
|
|||
|
+ var top = 0;
|
|||
|
+ /** Safari fix -- thanks to Luis Chato for this! */
|
|||
|
+ if (e.offsetHeight == 0) {
|
|||
|
+ /** Safari 2 doesn't correctly grab the offsetTop of a table row
|
|||
|
+ this is detailed here:
|
|||
|
+ http://jacob.peargrove.com/blog/2006/technical/table-row-offsettop-bug-in-safari/
|
|||
|
+ the solution is likewise noted there, grab the offset of a table cell in the row - the firstChild.
|
|||
|
+ note that firefox will return a text node as a first child, so designing a more thorough
|
|||
|
+ solution may need to take that into account, for now this seems to work in firefox, safari, ie */
|
|||
|
+ e = e.firstChild; // a table cell
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ while (e.offsetParent){
|
|||
|
+ left += e.offsetLeft;
|
|||
|
+ top += e.offsetTop;
|
|||
|
+ e = e.offsetParent;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ left += e.offsetLeft;
|
|||
|
+ top += e.offsetTop;
|
|||
|
+
|
|||
|
+ return {x:left, y:top};
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ mousemove: function(ev) {
|
|||
|
+ if (jQuery.tableDnD.dragObject == null) {
|
|||
|
+ return;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ var dragObj = jQuery(jQuery.tableDnD.dragObject);
|
|||
|
+ var config = jQuery.tableDnD.currentTable.tableDnDConfig;
|
|||
|
+ var mousePos = jQuery.tableDnD.mouseCoords(ev);
|
|||
|
+ var y = mousePos.y - jQuery.tableDnD.mouseOffset.y;
|
|||
|
+ //auto scroll the window
|
|||
|
+ var yOffset = window.pageYOffset;
|
|||
|
+ if (document.all) {
|
|||
|
+ // Windows version
|
|||
|
+ //yOffset=document.body.scrollTop;
|
|||
|
+ if (typeof document.compatMode != 'undefined' &&
|
|||
|
+ document.compatMode != 'BackCompat') {
|
|||
|
+ yOffset = document.documentElement.scrollTop;
|
|||
|
+ }
|
|||
|
+ else if (typeof document.body != 'undefined') {
|
|||
|
+ yOffset=document.body.scrollTop;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ if (mousePos.y-yOffset < config.scrollAmount) {
|
|||
|
+ window.scrollBy(0, -config.scrollAmount);
|
|||
|
+ } else {
|
|||
|
+ var windowHeight = window.innerHeight ? window.innerHeight
|
|||
|
+ : document.documentElement.clientHeight ? document.documentElement.clientHeight : document.body.clientHeight;
|
|||
|
+ if (windowHeight-(mousePos.y-yOffset) < config.scrollAmount) {
|
|||
|
+ window.scrollBy(0, config.scrollAmount);
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+
|
|||
|
+
|
|||
|
+ if (y != jQuery.tableDnD.oldY) {
|
|||
|
+ // work out if we're going up or down...
|
|||
|
+ var movingDown = y > jQuery.tableDnD.oldY;
|
|||
|
+ // update the old value
|
|||
|
+ jQuery.tableDnD.oldY = y;
|
|||
|
+ // update the style to show we're dragging
|
|||
|
+ if (config.onDragClass) {
|
|||
|
+ dragObj.addClass(config.onDragClass);
|
|||
|
+ } else {
|
|||
|
+ dragObj.css(config.onDragStyle);
|
|||
|
+ }
|
|||
|
+ // If we're over a row then move the dragged row to there so that the user sees the
|
|||
|
+ // effect dynamically
|
|||
|
+ var currentRow = jQuery.tableDnD.findDropTargetRow(dragObj, y);
|
|||
|
+ if (currentRow) {
|
|||
|
+ // TODO worry about what happens when there are multiple TBODIES
|
|||
|
+ if (movingDown && jQuery.tableDnD.dragObject != currentRow) {
|
|||
|
+ jQuery.tableDnD.dragObject.parentNode.insertBefore(jQuery.tableDnD.dragObject, currentRow.nextSibling);
|
|||
|
+ } else if (! movingDown && jQuery.tableDnD.dragObject != currentRow) {
|
|||
|
+ jQuery.tableDnD.dragObject.parentNode.insertBefore(jQuery.tableDnD.dragObject, currentRow);
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ /** We're only worried about the y position really, because we can only move rows up and down */
|
|||
|
+ findDropTargetRow: function(draggedRow, y) {
|
|||
|
+ var rows = jQuery.tableDnD.currentTable.rows;
|
|||
|
+ for (var i=0; i<rows.length; i++) {
|
|||
|
+ var row = rows[i];
|
|||
|
+ var rowY = this.getPosition(row).y;
|
|||
|
+ var rowHeight = parseInt(row.offsetHeight)/2;
|
|||
|
+ if (row.offsetHeight == 0) {
|
|||
|
+ rowY = this.getPosition(row.firstChild).y;
|
|||
|
+ rowHeight = parseInt(row.firstChild.offsetHeight)/2;
|
|||
|
+ }
|
|||
|
+ // Because we always have to insert before, we need to offset the height a bit
|
|||
|
+ if ((y > rowY - rowHeight) && (y < (rowY + rowHeight))) {
|
|||
|
+ // that's the row we're over
|
|||
|
+ // If it's the same as the current row, ignore it
|
|||
|
+ if (row == draggedRow) {return null;}
|
|||
|
+ var config = jQuery.tableDnD.currentTable.tableDnDConfig;
|
|||
|
+ if (config.onAllowDrop) {
|
|||
|
+ if (config.onAllowDrop(draggedRow, row)) {
|
|||
|
+ return row;
|
|||
|
+ } else {
|
|||
|
+ return null;
|
|||
|
+ }
|
|||
|
+ } else {
|
|||
|
+ // If a row has nodrop class, then don't allow dropping (inspired by John Tarr and Famic)
|
|||
|
+ var nodrop = jQuery(row).hasClass("nodrop");
|
|||
|
+ if (! nodrop) {
|
|||
|
+ return row;
|
|||
|
+ } else {
|
|||
|
+ return null;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ return row;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ return null;
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ mouseup: function(e) {
|
|||
|
+ if (jQuery.tableDnD.currentTable && jQuery.tableDnD.dragObject) {
|
|||
|
+ var droppedRow = jQuery.tableDnD.dragObject;
|
|||
|
+ var config = jQuery.tableDnD.currentTable.tableDnDConfig;
|
|||
|
+ // If we have a dragObject, then we need to release it,
|
|||
|
+ // The row will already have been moved to the right place so we just reset stuff
|
|||
|
+ if (config.onDragClass) {
|
|||
|
+ jQuery(droppedRow).removeClass(config.onDragClass);
|
|||
|
+ } else {
|
|||
|
+ jQuery(droppedRow).css(config.onDropStyle);
|
|||
|
+ }
|
|||
|
+ jQuery.tableDnD.dragObject = null;
|
|||
|
+ if (config.onDrop) {
|
|||
|
+ // Call the onDrop method if there is one
|
|||
|
+ config.onDrop(jQuery.tableDnD.currentTable, droppedRow);
|
|||
|
+ }
|
|||
|
+ jQuery.tableDnD.currentTable = null; // let go of the table too
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ serialize: function() {
|
|||
|
+ if (jQuery.tableDnD.currentTable) {
|
|||
|
+ return jQuery.tableDnD.serializeTable(jQuery.tableDnD.currentTable);
|
|||
|
+ } else {
|
|||
|
+ return "Error: No Table id set, you need to set an id on your table and every row";
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ serializeTable: function(table) {
|
|||
|
+ var result = "";
|
|||
|
+ var tableId = table.id;
|
|||
|
+ var rows = table.rows;
|
|||
|
+ for (var i=0; i<rows.length; i++) {
|
|||
|
+ if (result.length > 0) result += "&";
|
|||
|
+ var rowId = rows[i].id;
|
|||
|
+ if (rowId && rowId && table.tableDnDConfig && table.tableDnDConfig.serializeRegexp) {
|
|||
|
+ rowId = rowId.match(table.tableDnDConfig.serializeRegexp)[0];
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ result += tableId + '[]=' + rowId;
|
|||
|
+ }
|
|||
|
+ return result;
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ serializeTables: function() {
|
|||
|
+ var result = "";
|
|||
|
+ this.each(function() {
|
|||
|
+ // this is now bound to each matching table
|
|||
|
+ result += jQuery.tableDnD.serializeTable(this);
|
|||
|
+ });
|
|||
|
+ return result;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+}
|
|||
|
+
|
|||
|
+jQuery.fn.extend(
|
|||
|
+ {
|
|||
|
+ tableDnD : jQuery.tableDnD.build,
|
|||
|
+ tableDnDUpdate : jQuery.tableDnD.updateTables,
|
|||
|
+ tableDnDSerialize: jQuery.tableDnD.serializeTables
|
|||
|
+ }
|
|||
|
+);
|
|||
|
\ No newline at end of file
|
|||
|
diff -up cacti-0.8.8a/include/js/jquery/jquery.timepicker.js.legal cacti-0.8.8a/include/js/jquery/jquery.timepicker.js
|
|||
|
--- cacti-0.8.8a/include/js/jquery/jquery.timepicker.js.legal 2013-01-04 15:44:38.041416077 -0500
|
|||
|
+++ cacti-0.8.8a/include/js/jquery/jquery.timepicker.js 2013-01-04 15:43:12.645377988 -0500
|
|||
|
@@ -0,0 +1,1060 @@
|
|||
|
+/*
|
|||
|
+* jQuery timepicker addon
|
|||
|
+* By: Trent Richardson [http://trentrichardson.com]
|
|||
|
+* Version 0.9.6
|
|||
|
+* Last Modified: 07/20/2011
|
|||
|
+*
|
|||
|
+* Copyright 2011 Trent Richardson
|
|||
|
+* Dual licensed under the MIT and GPL licenses.
|
|||
|
+* http://trentrichardson.com/Impromptu/GPL-LICENSE.txt
|
|||
|
+* http://trentrichardson.com/Impromptu/MIT-LICENSE.txt
|
|||
|
+*
|
|||
|
+* HERES THE CSS:
|
|||
|
+* .ui-timepicker-div .ui-widget-header{ margin-bottom: 8px; }
|
|||
|
+* .ui-timepicker-div dl{ text-align: left; }
|
|||
|
+* .ui-timepicker-div dl dt{ height: 25px; }
|
|||
|
+* .ui-timepicker-div dl dd{ margin: -25px 10px 10px 65px; }
|
|||
|
+* .ui-timepicker-div td { font-size: 90%; }
|
|||
|
+*/
|
|||
|
+
|
|||
|
+(function($) {
|
|||
|
+
|
|||
|
+$.extend($.ui, { timepicker: { version: "0.9.6" } });
|
|||
|
+
|
|||
|
+/* Time picker manager.
|
|||
|
+ Use the singleton instance of this class, $.timepicker, to interact with the time picker.
|
|||
|
+ Settings for (groups of) time pickers are maintained in an instance object,
|
|||
|
+ allowing multiple different settings on the same page. */
|
|||
|
+
|
|||
|
+function Timepicker() {
|
|||
|
+ this.regional = []; // Available regional settings, indexed by language code
|
|||
|
+ this.regional[''] = { // Default regional settings
|
|||
|
+ currentText: 'Now',
|
|||
|
+ closeText: 'Done',
|
|||
|
+ ampm: false,
|
|||
|
+ timeFormat: 'hh:mm tt',
|
|||
|
+ timeSuffix: '',
|
|||
|
+ timeOnlyTitle: 'Choose Time',
|
|||
|
+ timeText: 'Time',
|
|||
|
+ hourText: 'Hour',
|
|||
|
+ minuteText: 'Minute',
|
|||
|
+ secondText: 'Second',
|
|||
|
+ timezoneText: 'Time Zone'
|
|||
|
+ };
|
|||
|
+ this._defaults = { // Global defaults for all the datetime picker instances
|
|||
|
+ showButtonPanel: true,
|
|||
|
+ timeOnly: false,
|
|||
|
+ showHour: true,
|
|||
|
+ showMinute: true,
|
|||
|
+ showSecond: false,
|
|||
|
+ showTimezone: false,
|
|||
|
+ showTime: true,
|
|||
|
+ stepHour: 0.05,
|
|||
|
+ stepMinute: 0.05,
|
|||
|
+ stepSecond: 0.05,
|
|||
|
+ hour: 0,
|
|||
|
+ minute: 0,
|
|||
|
+ second: 0,
|
|||
|
+ timezone: '+0000',
|
|||
|
+ hourMin: 0,
|
|||
|
+ minuteMin: 0,
|
|||
|
+ secondMin: 0,
|
|||
|
+ hourMax: 23,
|
|||
|
+ minuteMax: 59,
|
|||
|
+ secondMax: 59,
|
|||
|
+ minDateTime: null,
|
|||
|
+ maxDateTime: null,
|
|||
|
+ hourGrid: 0,
|
|||
|
+ minuteGrid: 0,
|
|||
|
+ secondGrid: 0,
|
|||
|
+ alwaysSetTime: true,
|
|||
|
+ separator: ' ',
|
|||
|
+ altFieldTimeOnly: true,
|
|||
|
+ showTimepicker: true,
|
|||
|
+ timezoneList: ["-1100", "-1000", "-0900", "-0800", "-0700", "-0600",
|
|||
|
+ "-0500", "-0400", "-0300", "-0200", "-0100", "+0000",
|
|||
|
+ "+0100", "+0200", "+0300", "+0400", "+0500", "+0600",
|
|||
|
+ "+0700", "+0800", "+0900", "+1000", "+1100", "+1200"]
|
|||
|
+ };
|
|||
|
+ $.extend(this._defaults, this.regional['']);
|
|||
|
+}
|
|||
|
+
|
|||
|
+$.extend(Timepicker.prototype, {
|
|||
|
+ $input: null,
|
|||
|
+ $altInput: null,
|
|||
|
+ $timeObj: null,
|
|||
|
+ inst: null,
|
|||
|
+ hour_slider: null,
|
|||
|
+ minute_slider: null,
|
|||
|
+ second_slider: null,
|
|||
|
+ timezone_select: null,
|
|||
|
+ hour: 0,
|
|||
|
+ minute: 0,
|
|||
|
+ second: 0,
|
|||
|
+ timezone: '+0000',
|
|||
|
+ hourMinOriginal: null,
|
|||
|
+ minuteMinOriginal: null,
|
|||
|
+ secondMinOriginal: null,
|
|||
|
+ hourMaxOriginal: null,
|
|||
|
+ minuteMaxOriginal: null,
|
|||
|
+ secondMaxOriginal: null,
|
|||
|
+ ampm: '',
|
|||
|
+ formattedDate: '',
|
|||
|
+ formattedTime: '',
|
|||
|
+ formattedDateTime: '',
|
|||
|
+ timezoneList: ["-1100", "-1000", "-0900", "-0800", "-0700", "-0600",
|
|||
|
+ "-0500", "-0400", "-0300", "-0200", "-0100", "+0000",
|
|||
|
+ "+0100", "+0200", "+0300", "+0400", "+0500", "+0600",
|
|||
|
+ "+0700", "+0800", "+0900", "+1000", "+1100", "+1200"],
|
|||
|
+
|
|||
|
+ /* Override the default settings for all instances of the time picker.
|
|||
|
+ @param settings object - the new settings to use as defaults (anonymous object)
|
|||
|
+ @return the manager object */
|
|||
|
+ setDefaults: function(settings) {
|
|||
|
+ extendRemove(this._defaults, settings || {});
|
|||
|
+ return this;
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ //########################################################################
|
|||
|
+ // Create a new Timepicker instance
|
|||
|
+ //########################################################################
|
|||
|
+ _newInst: function($input, o) {
|
|||
|
+ var tp_inst = new Timepicker(),
|
|||
|
+ inlineSettings = {};
|
|||
|
+
|
|||
|
+ for (var attrName in this._defaults) {
|
|||
|
+ var attrValue = $input.attr('time:' + attrName);
|
|||
|
+ if (attrValue) {
|
|||
|
+ try {
|
|||
|
+ inlineSettings[attrName] = eval(attrValue);
|
|||
|
+ } catch (err) {
|
|||
|
+ inlineSettings[attrName] = attrValue;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ tp_inst._defaults = $.extend({}, this._defaults, inlineSettings, o, {
|
|||
|
+ beforeShow: function(input, dp_inst) {
|
|||
|
+ if ($.isFunction(o.beforeShow))
|
|||
|
+ o.beforeShow(input, dp_inst, tp_inst);
|
|||
|
+ },
|
|||
|
+ onChangeMonthYear: function(year, month, dp_inst) {
|
|||
|
+ // Update the time as well : this prevents the time from disappearing from the $input field.
|
|||
|
+ tp_inst._updateDateTime(dp_inst);
|
|||
|
+ if ($.isFunction(o.onChangeMonthYear))
|
|||
|
+ o.onChangeMonthYear.call($input[0], year, month, dp_inst, tp_inst);
|
|||
|
+ },
|
|||
|
+ onClose: function(dateText, dp_inst) {
|
|||
|
+ if (tp_inst.timeDefined === true && $input.val() != '')
|
|||
|
+ tp_inst._updateDateTime(dp_inst);
|
|||
|
+ if ($.isFunction(o.onClose))
|
|||
|
+ o.onClose.call($input[0], dateText, dp_inst, tp_inst);
|
|||
|
+ },
|
|||
|
+ timepicker: tp_inst // add timepicker as a property of datepicker: $.datepicker._get(dp_inst, 'timepicker');
|
|||
|
+ });
|
|||
|
+
|
|||
|
+ tp_inst.hour = tp_inst._defaults.hour;
|
|||
|
+ tp_inst.minute = tp_inst._defaults.minute;
|
|||
|
+ tp_inst.second = tp_inst._defaults.second;
|
|||
|
+ tp_inst.ampm = '';
|
|||
|
+ tp_inst.$input = $input;
|
|||
|
+
|
|||
|
+ if (o.altField)
|
|||
|
+ tp_inst.$altInput = $(o.altField)
|
|||
|
+ .css({ cursor: 'pointer' })
|
|||
|
+ .focus(function(){ $input.trigger("focus"); });
|
|||
|
+
|
|||
|
+ // datepicker needs minDate/maxDate, timepicker needs minDateTime/maxDateTime..
|
|||
|
+ if(tp_inst._defaults.minDate !== undefined && tp_inst._defaults.minDate instanceof Date)
|
|||
|
+ tp_inst._defaults.minDateTime = new Date(tp_inst._defaults.minDate.getTime());
|
|||
|
+ if(tp_inst._defaults.minDateTime !== undefined && tp_inst._defaults.minDateTime instanceof Date)
|
|||
|
+ tp_inst._defaults.minDate = new Date(tp_inst._defaults.minDateTime.getTime());
|
|||
|
+ if(tp_inst._defaults.maxDate !== undefined && tp_inst._defaults.maxDate instanceof Date)
|
|||
|
+ tp_inst._defaults.maxDateTime = new Date(tp_inst._defaults.maxDate.getTime());
|
|||
|
+ if(tp_inst._defaults.maxDateTime !== undefined && tp_inst._defaults.maxDateTime instanceof Date)
|
|||
|
+ tp_inst._defaults.maxDate = new Date(tp_inst._defaults.maxDateTime.getTime());
|
|||
|
+
|
|||
|
+ return tp_inst;
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ //########################################################################
|
|||
|
+ // add our sliders to the calendar
|
|||
|
+ //########################################################################
|
|||
|
+ _addTimePicker: function(dp_inst) {
|
|||
|
+ var currDT = (this.$altInput && this._defaults.altFieldTimeOnly) ?
|
|||
|
+ this.$input.val() + ' ' + this.$altInput.val() :
|
|||
|
+ this.$input.val();
|
|||
|
+
|
|||
|
+ this.timeDefined = this._parseTime(currDT);
|
|||
|
+ this._limitMinMaxDateTime(dp_inst, false);
|
|||
|
+ this._injectTimePicker();
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ //########################################################################
|
|||
|
+ // parse the time string from input value or _setTime
|
|||
|
+ //########################################################################
|
|||
|
+ _parseTime: function(timeString, withDate) {
|
|||
|
+ var regstr = this._defaults.timeFormat.toString()
|
|||
|
+ .replace(/h{1,2}/ig, '(\\d?\\d)')
|
|||
|
+ .replace(/m{1,2}/ig, '(\\d?\\d)')
|
|||
|
+ .replace(/s{1,2}/ig, '(\\d?\\d)')
|
|||
|
+ .replace(/t{1,2}/ig, '(am|pm|a|p)?')
|
|||
|
+ .replace(/z{1}/ig, '((\\+|-)\\d\\d\\d\\d)?')
|
|||
|
+ .replace(/\s/g, '\\s?') + this._defaults.timeSuffix + '$',
|
|||
|
+ order = this._getFormatPositions(),
|
|||
|
+ treg;
|
|||
|
+
|
|||
|
+ if (!this.inst) this.inst = $.datepicker._getInst(this.$input[0]);
|
|||
|
+
|
|||
|
+ if (withDate || !this._defaults.timeOnly) {
|
|||
|
+ // the time should come after x number of characters and a space.
|
|||
|
+ // x = at least the length of text specified by the date format
|
|||
|
+ var dp_dateFormat = $.datepicker._get(this.inst, 'dateFormat');
|
|||
|
+ // escape special regex characters in the seperator
|
|||
|
+ var specials = new RegExp("[.*+?|()\\[\\]{}\\\\]", "g");
|
|||
|
+ regstr = '.{' + dp_dateFormat.length + ',}' + this._defaults.separator.replace(specials, "\\$&") + regstr;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ treg = timeString.match(new RegExp(regstr, 'i'));
|
|||
|
+
|
|||
|
+ if (treg) {
|
|||
|
+ if (order.t !== -1)
|
|||
|
+ this.ampm = ((treg[order.t] === undefined || treg[order.t].length === 0) ?
|
|||
|
+ '' :
|
|||
|
+ (treg[order.t].charAt(0).toUpperCase() == 'A') ? 'AM' : 'PM').toUpperCase();
|
|||
|
+
|
|||
|
+ if (order.h !== -1) {
|
|||
|
+ if (this.ampm == 'AM' && treg[order.h] == '12')
|
|||
|
+ this.hour = 0; // 12am = 0 hour
|
|||
|
+ else if (this.ampm == 'PM' && treg[order.h] != '12')
|
|||
|
+ this.hour = (parseFloat(treg[order.h]) + 12).toFixed(0); // 12pm = 12 hour, any other pm = hour + 12
|
|||
|
+ else this.hour = Number(treg[order.h]);
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ if (order.m !== -1) this.minute = Number(treg[order.m]);
|
|||
|
+ if (order.s !== -1) this.second = Number(treg[order.s]);
|
|||
|
+ if (order.z !== -1) this.timezone = treg[order.z];
|
|||
|
+
|
|||
|
+ return true;
|
|||
|
+
|
|||
|
+ }
|
|||
|
+ return false;
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ //########################################################################
|
|||
|
+ // figure out position of time elements.. cause js cant do named captures
|
|||
|
+ //########################################################################
|
|||
|
+ _getFormatPositions: function() {
|
|||
|
+ var finds = this._defaults.timeFormat.toLowerCase().match(/(h{1,2}|m{1,2}|s{1,2}|t{1,2}|z)/g),
|
|||
|
+ orders = { h: -1, m: -1, s: -1, t: -1, z: -1 };
|
|||
|
+
|
|||
|
+ if (finds)
|
|||
|
+ for (var i = 0; i < finds.length; i++)
|
|||
|
+ if (orders[finds[i].toString().charAt(0)] == -1)
|
|||
|
+ orders[finds[i].toString().charAt(0)] = i + 1;
|
|||
|
+
|
|||
|
+ return orders;
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ //########################################################################
|
|||
|
+ // generate and inject html for timepicker into ui datepicker
|
|||
|
+ //########################################################################
|
|||
|
+ _injectTimePicker: function() {
|
|||
|
+ var $dp = this.inst.dpDiv,
|
|||
|
+ o = this._defaults,
|
|||
|
+ tp_inst = this,
|
|||
|
+ // Added by Peter Medeiros:
|
|||
|
+ // - Figure out what the hour/minute/second max should be based on the step values.
|
|||
|
+ // - Example: if stepMinute is 15, then minMax is 45.
|
|||
|
+ hourMax = (o.hourMax - (o.hourMax % o.stepHour)).toFixed(0),
|
|||
|
+ minMax = (o.minuteMax - (o.minuteMax % o.stepMinute)).toFixed(0),
|
|||
|
+ secMax = (o.secondMax - (o.secondMax % o.stepSecond)).toFixed(0),
|
|||
|
+ dp_id = this.inst.id.toString().replace(/([^A-Za-z0-9_])/g, '');
|
|||
|
+
|
|||
|
+ // Prevent displaying twice
|
|||
|
+ //if ($dp.find("div#ui-timepicker-div-"+ dp_id).length === 0) {
|
|||
|
+ if ($dp.find("div#ui-timepicker-div-"+ dp_id).length === 0 && o.showTimepicker) {
|
|||
|
+ var noDisplay = ' style="display:none;"',
|
|||
|
+ html = '<div class="ui-timepicker-div" id="ui-timepicker-div-' + dp_id + '"><dl>' +
|
|||
|
+ '<dt class="ui_tpicker_time_label" id="ui_tpicker_time_label_' + dp_id + '"' +
|
|||
|
+ ((o.showTime) ? '' : noDisplay) + '>' + o.timeText + '</dt>' +
|
|||
|
+ '<dd class="ui_tpicker_time" id="ui_tpicker_time_' + dp_id + '"' +
|
|||
|
+ ((o.showTime) ? '' : noDisplay) + '></dd>' +
|
|||
|
+ '<dt class="ui_tpicker_hour_label" id="ui_tpicker_hour_label_' + dp_id + '"' +
|
|||
|
+ ((o.showHour) ? '' : noDisplay) + '>' + o.hourText + '</dt>',
|
|||
|
+ hourGridSize = 0,
|
|||
|
+ minuteGridSize = 0,
|
|||
|
+ secondGridSize = 0,
|
|||
|
+ size;
|
|||
|
+
|
|||
|
+ if (o.showHour && o.hourGrid > 0) {
|
|||
|
+ html += '<dd class="ui_tpicker_hour">' +
|
|||
|
+ '<div id="ui_tpicker_hour_' + dp_id + '"' + ((o.showHour) ? '' : noDisplay) + '></div>' +
|
|||
|
+ '<div style="padding-left: 1px"><table class="ui-tpicker-grid-label"><tr>';
|
|||
|
+
|
|||
|
+ for (var h = o.hourMin; h <= hourMax; h += o.hourGrid) {
|
|||
|
+ hourGridSize++;
|
|||
|
+ var tmph = (o.ampm && h > 12) ? h-12 : h;
|
|||
|
+ if (tmph < 10) tmph = '0' + tmph;
|
|||
|
+ if (o.ampm) {
|
|||
|
+ if (h == 0) tmph = 12 +'a';
|
|||
|
+ else if (h < 12) tmph += 'a';
|
|||
|
+ else tmph += 'p';
|
|||
|
+ }
|
|||
|
+ html += '<td>' + tmph + '</td>';
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ html += '</tr></table></div>' +
|
|||
|
+ '</dd>';
|
|||
|
+ } else html += '<dd class="ui_tpicker_hour" id="ui_tpicker_hour_' + dp_id + '"' +
|
|||
|
+ ((o.showHour) ? '' : noDisplay) + '></dd>';
|
|||
|
+
|
|||
|
+ html += '<dt class="ui_tpicker_minute_label" id="ui_tpicker_minute_label_' + dp_id + '"' +
|
|||
|
+ ((o.showMinute) ? '' : noDisplay) + '>' + o.minuteText + '</dt>';
|
|||
|
+
|
|||
|
+ if (o.showMinute && o.minuteGrid > 0) {
|
|||
|
+ html += '<dd class="ui_tpicker_minute ui_tpicker_minute_' + o.minuteGrid + '">' +
|
|||
|
+ '<div id="ui_tpicker_minute_' + dp_id + '"' +
|
|||
|
+ ((o.showMinute) ? '' : noDisplay) + '></div>' +
|
|||
|
+ '<div style="padding-left: 1px"><table class="ui-tpicker-grid-label"><tr>';
|
|||
|
+
|
|||
|
+ for (var m = o.minuteMin; m <= minMax; m += o.minuteGrid) {
|
|||
|
+ minuteGridSize++;
|
|||
|
+ html += '<td>' + ((m < 10) ? '0' : '') + m + '</td>';
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ html += '</tr></table></div>' +
|
|||
|
+ '</dd>';
|
|||
|
+ } else html += '<dd class="ui_tpicker_minute" id="ui_tpicker_minute_' + dp_id + '"' +
|
|||
|
+ ((o.showMinute) ? '' : noDisplay) + '></dd>';
|
|||
|
+
|
|||
|
+ html += '<dt class="ui_tpicker_second_label" id="ui_tpicker_second_label_' + dp_id + '"' +
|
|||
|
+ ((o.showSecond) ? '' : noDisplay) + '>' + o.secondText + '</dt>';
|
|||
|
+
|
|||
|
+ if (o.showSecond && o.secondGrid > 0) {
|
|||
|
+ html += '<dd class="ui_tpicker_second ui_tpicker_second_' + o.secondGrid + '">' +
|
|||
|
+ '<div id="ui_tpicker_second_' + dp_id + '"' +
|
|||
|
+ ((o.showSecond) ? '' : noDisplay) + '></div>' +
|
|||
|
+ '<div style="padding-left: 1px"><table><tr>';
|
|||
|
+
|
|||
|
+ for (var s = o.secondMin; s <= secMax; s += o.secondGrid) {
|
|||
|
+ secondGridSize++;
|
|||
|
+ html += '<td>' + ((s < 10) ? '0' : '') + s + '</td>';
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ html += '</tr></table></div>' +
|
|||
|
+ '</dd>';
|
|||
|
+ } else html += '<dd class="ui_tpicker_second" id="ui_tpicker_second_' + dp_id + '"' +
|
|||
|
+ ((o.showSecond) ? '' : noDisplay) + '></dd>';
|
|||
|
+
|
|||
|
+ html += '<dt class="ui_tpicker_timezone_label" id="ui_tpicker_timezone_label_' + dp_id + '"' +
|
|||
|
+ ((o.showTimezone) ? '' : noDisplay) + '>' + o.timezoneText + '</dt>';
|
|||
|
+ html += '<dd class="ui_tpicker_timezone" id="ui_tpicker_timezone_' + dp_id + '"' +
|
|||
|
+ ((o.showTimezone) ? '' : noDisplay) + '></dd>';
|
|||
|
+
|
|||
|
+ html += '</dl></div>';
|
|||
|
+ $tp = $(html);
|
|||
|
+
|
|||
|
+ // if we only want time picker...
|
|||
|
+ if (o.timeOnly === true) {
|
|||
|
+ $tp.prepend(
|
|||
|
+ '<div class="ui-widget-header ui-helper-clearfix ui-corner-all">' +
|
|||
|
+ '<div class="ui-datepicker-title">' + o.timeOnlyTitle + '</div>' +
|
|||
|
+ '</div>');
|
|||
|
+ $dp.find('.ui-datepicker-header, .ui-datepicker-calendar').hide();
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ this.hour_slider = $tp.find('#ui_tpicker_hour_'+ dp_id).slider({
|
|||
|
+ orientation: "horizontal",
|
|||
|
+ value: this.hour,
|
|||
|
+ min: o.hourMin,
|
|||
|
+ max: hourMax,
|
|||
|
+ step: o.stepHour,
|
|||
|
+ slide: function(event, ui) {
|
|||
|
+ tp_inst.hour_slider.slider( "option", "value", ui.value);
|
|||
|
+ tp_inst._onTimeChange();
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+
|
|||
|
+ // Updated by Peter Medeiros:
|
|||
|
+ // - Pass in Event and UI instance into slide function
|
|||
|
+ this.minute_slider = $tp.find('#ui_tpicker_minute_'+ dp_id).slider({
|
|||
|
+ orientation: "horizontal",
|
|||
|
+ value: this.minute,
|
|||
|
+ min: o.minuteMin,
|
|||
|
+ max: minMax,
|
|||
|
+ step: o.stepMinute,
|
|||
|
+ slide: function(event, ui) {
|
|||
|
+ // update the global minute slider instance value with the current slider value
|
|||
|
+ tp_inst.minute_slider.slider( "option", "value", ui.value);
|
|||
|
+ tp_inst._onTimeChange();
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+
|
|||
|
+ this.second_slider = $tp.find('#ui_tpicker_second_'+ dp_id).slider({
|
|||
|
+ orientation: "horizontal",
|
|||
|
+ value: this.second,
|
|||
|
+ min: o.secondMin,
|
|||
|
+ max: secMax,
|
|||
|
+ step: o.stepSecond,
|
|||
|
+ slide: function(event, ui) {
|
|||
|
+ tp_inst.second_slider.slider( "option", "value", ui.value);
|
|||
|
+ tp_inst._onTimeChange();
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+
|
|||
|
+
|
|||
|
+ this.timezone_select = $tp.find('#ui_tpicker_timezone_'+ dp_id).append('<select></select>').find("select");
|
|||
|
+ $.fn.append.apply(this.timezone_select,
|
|||
|
+ $.map(o.timezoneList, function(val, idx) {
|
|||
|
+ return $("<option />")
|
|||
|
+ .val(typeof val == "object" ? val.value : val)
|
|||
|
+ .text(typeof val == "object" ? val.label : val);
|
|||
|
+ })
|
|||
|
+ );
|
|||
|
+ this.timezone_select.val((typeof this.timezone != "undefined" && this.timezone != null && this.timezone != "") ? this.timezone : o.timezone);
|
|||
|
+ this.timezone_select.change(function() {
|
|||
|
+ tp_inst._onTimeChange();
|
|||
|
+ });
|
|||
|
+
|
|||
|
+ // Add grid functionality
|
|||
|
+ if (o.showHour && o.hourGrid > 0) {
|
|||
|
+ size = 100 * hourGridSize * o.hourGrid / (hourMax - o.hourMin);
|
|||
|
+
|
|||
|
+ $tp.find(".ui_tpicker_hour table").css({
|
|||
|
+ width: size + "%",
|
|||
|
+ marginLeft: (size / (-2 * hourGridSize)) + "%",
|
|||
|
+ borderCollapse: 'collapse'
|
|||
|
+ }).find("td").each( function(index) {
|
|||
|
+ $(this).click(function() {
|
|||
|
+ var h = $(this).html();
|
|||
|
+ if(o.ampm) {
|
|||
|
+ var ap = h.substring(2).toLowerCase(),
|
|||
|
+ aph = parseInt(h.substring(0,2), 10);
|
|||
|
+ if (ap == 'a') {
|
|||
|
+ if (aph == 12) h = 0;
|
|||
|
+ else h = aph;
|
|||
|
+ } else if (aph == 12) h = 12;
|
|||
|
+ else h = aph + 12;
|
|||
|
+ }
|
|||
|
+ tp_inst.hour_slider.slider("option", "value", h);
|
|||
|
+ tp_inst._onTimeChange();
|
|||
|
+ tp_inst._onSelectHandler();
|
|||
|
+ }).css({
|
|||
|
+ cursor: 'pointer',
|
|||
|
+ width: (100 / hourGridSize) + '%',
|
|||
|
+ textAlign: 'center',
|
|||
|
+ overflow: 'hidden'
|
|||
|
+ });
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ if (o.showMinute && o.minuteGrid > 0) {
|
|||
|
+ size = 100 * minuteGridSize * o.minuteGrid / (minMax - o.minuteMin);
|
|||
|
+ $tp.find(".ui_tpicker_minute table").css({
|
|||
|
+ width: size + "%",
|
|||
|
+ marginLeft: (size / (-2 * minuteGridSize)) + "%",
|
|||
|
+ borderCollapse: 'collapse'
|
|||
|
+ }).find("td").each(function(index) {
|
|||
|
+ $(this).click(function() {
|
|||
|
+ tp_inst.minute_slider.slider("option", "value", $(this).html());
|
|||
|
+ tp_inst._onTimeChange();
|
|||
|
+ tp_inst._onSelectHandler();
|
|||
|
+ }).css({
|
|||
|
+ cursor: 'pointer',
|
|||
|
+ width: (100 / minuteGridSize) + '%',
|
|||
|
+ textAlign: 'center',
|
|||
|
+ overflow: 'hidden'
|
|||
|
+ });
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ if (o.showSecond && o.secondGrid > 0) {
|
|||
|
+ $tp.find(".ui_tpicker_second table").css({
|
|||
|
+ width: size + "%",
|
|||
|
+ marginLeft: (size / (-2 * secondGridSize)) + "%",
|
|||
|
+ borderCollapse: 'collapse'
|
|||
|
+ }).find("td").each(function(index) {
|
|||
|
+ $(this).click(function() {
|
|||
|
+ tp_inst.second_slider.slider("option", "value", $(this).html());
|
|||
|
+ tp_inst._onTimeChange();
|
|||
|
+ tp_inst._onSelectHandler();
|
|||
|
+ }).css({
|
|||
|
+ cursor: 'pointer',
|
|||
|
+ width: (100 / secondGridSize) + '%',
|
|||
|
+ textAlign: 'center',
|
|||
|
+ overflow: 'hidden'
|
|||
|
+ });
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ var $buttonPanel = $dp.find('.ui-datepicker-buttonpane');
|
|||
|
+ if ($buttonPanel.length) $buttonPanel.before($tp);
|
|||
|
+ else $dp.append($tp);
|
|||
|
+
|
|||
|
+ this.$timeObj = $tp.find('#ui_tpicker_time_'+ dp_id);
|
|||
|
+
|
|||
|
+ if (this.inst !== null) {
|
|||
|
+ var timeDefined = this.timeDefined;
|
|||
|
+ this._onTimeChange();
|
|||
|
+ this.timeDefined = timeDefined;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ //Emulate datepicker onSelect behavior. Call on slidestop.
|
|||
|
+ var onSelectDelegate = function() {
|
|||
|
+ tp_inst._onSelectHandler();
|
|||
|
+ };
|
|||
|
+ this.hour_slider.bind('slidestop',onSelectDelegate);
|
|||
|
+ this.minute_slider.bind('slidestop',onSelectDelegate);
|
|||
|
+ this.second_slider.bind('slidestop',onSelectDelegate);
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ //########################################################################
|
|||
|
+ // This function tries to limit the ability to go outside the
|
|||
|
+ // min/max date range
|
|||
|
+ //########################################################################
|
|||
|
+ _limitMinMaxDateTime: function(dp_inst, adjustSliders){
|
|||
|
+ var o = this._defaults,
|
|||
|
+ dp_date = new Date(dp_inst.selectedYear, dp_inst.selectedMonth, dp_inst.selectedDay);
|
|||
|
+
|
|||
|
+ if(!this._defaults.showTimepicker) return; // No time so nothing to check here
|
|||
|
+
|
|||
|
+ if($.datepicker._get(dp_inst, 'minDateTime') !== null && dp_date){
|
|||
|
+ var minDateTime = $.datepicker._get(dp_inst, 'minDateTime'),
|
|||
|
+ minDateTimeDate = new Date(minDateTime.getFullYear(), minDateTime.getMonth(), minDateTime.getDate(), 0, 0, 0, 0);
|
|||
|
+
|
|||
|
+ if(this.hourMinOriginal === null || this.minuteMinOriginal === null || this.secondMinOriginal === null){
|
|||
|
+ this.hourMinOriginal = o.hourMin;
|
|||
|
+ this.minuteMinOriginal = o.minuteMin;
|
|||
|
+ this.secondMinOriginal = o.secondMin;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ if(dp_inst.settings.timeOnly || minDateTimeDate.getTime() == dp_date.getTime()) {
|
|||
|
+ this._defaults.hourMin = minDateTime.getHours();
|
|||
|
+ if (this.hour <= this._defaults.hourMin) {
|
|||
|
+ this.hour = this._defaults.hourMin;
|
|||
|
+ this._defaults.minuteMin = minDateTime.getMinutes();
|
|||
|
+ if (this.minute <= this._defaults.minuteMin) {
|
|||
|
+ this.minute = this._defaults.minuteMin;
|
|||
|
+ this._defaults.secondMin = minDateTime.getSeconds();
|
|||
|
+ } else {
|
|||
|
+ if(this.second < this._defaults.secondMin) this.second = this._defaults.secondMin;
|
|||
|
+ this._defaults.secondMin = this.secondMinOriginal;
|
|||
|
+ }
|
|||
|
+ } else {
|
|||
|
+ this._defaults.minuteMin = this.minuteMinOriginal;
|
|||
|
+ this._defaults.secondMin = this.secondMinOriginal;
|
|||
|
+ }
|
|||
|
+ }else{
|
|||
|
+ this._defaults.hourMin = this.hourMinOriginal;
|
|||
|
+ this._defaults.minuteMin = this.minuteMinOriginal;
|
|||
|
+ this._defaults.secondMin = this.secondMinOriginal;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ if($.datepicker._get(dp_inst, 'maxDateTime') !== null && dp_date){
|
|||
|
+ var maxDateTime = $.datepicker._get(dp_inst, 'maxDateTime'),
|
|||
|
+ maxDateTimeDate = new Date(maxDateTime.getFullYear(), maxDateTime.getMonth(), maxDateTime.getDate(), 0, 0, 0, 0);
|
|||
|
+
|
|||
|
+ if(this.hourMaxOriginal === null || this.minuteMaxOriginal === null || this.secondMaxOriginal === null){
|
|||
|
+ this.hourMaxOriginal = o.hourMax;
|
|||
|
+ this.minuteMaxOriginal = o.minuteMax;
|
|||
|
+ this.secondMaxOriginal = o.secondMax;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ if(dp_inst.settings.timeOnly || maxDateTimeDate.getTime() == dp_date.getTime()){
|
|||
|
+ this._defaults.hourMax = maxDateTime.getHours();
|
|||
|
+ if (this.hour >= this._defaults.hourMax) {
|
|||
|
+ this.hour = this._defaults.hourMax;
|
|||
|
+ this._defaults.minuteMax = maxDateTime.getMinutes();
|
|||
|
+ if (this.minute >= this._defaults.minuteMax) {
|
|||
|
+ this.minute = this._defaults.minuteMax;
|
|||
|
+ this._defaults.secondMax = maxDateTime.getSeconds();
|
|||
|
+ } else {
|
|||
|
+ if(this.second > this._defaults.secondMax) this.second = this._defaults.secondMax;
|
|||
|
+ this._defaults.secondMax = this.secondMaxOriginal;
|
|||
|
+ }
|
|||
|
+ } else {
|
|||
|
+ this._defaults.minuteMax = this.minuteMaxOriginal;
|
|||
|
+ this._defaults.secondMax = this.secondMaxOriginal;
|
|||
|
+ }
|
|||
|
+ }else{
|
|||
|
+ this._defaults.hourMax = this.hourMaxOriginal;
|
|||
|
+ this._defaults.minuteMax = this.minuteMaxOriginal;
|
|||
|
+ this._defaults.secondMax = this.secondMaxOriginal;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ if(adjustSliders !== undefined && adjustSliders === true){
|
|||
|
+ var hourMax = (this._defaults.hourMax - (this._defaults.hourMax % this._defaults.stepHour)).toFixed(0),
|
|||
|
+ minMax = (this._defaults.minuteMax - (this._defaults.minuteMax % this._defaults.stepMinute)).toFixed(0),
|
|||
|
+ secMax = (this._defaults.secondMax - (this._defaults.secondMax % this._defaults.stepSecond)).toFixed(0);
|
|||
|
+
|
|||
|
+ if(this.hour_slider)
|
|||
|
+ this.hour_slider.slider("option", { min: this._defaults.hourMin, max: hourMax }).slider('value', this.hour);
|
|||
|
+ if(this.minute_slider)
|
|||
|
+ this.minute_slider.slider("option", { min: this._defaults.minuteMin, max: minMax }).slider('value', this.minute);
|
|||
|
+ if(this.second_slider)
|
|||
|
+ this.second_slider.slider("option", { min: this._defaults.secondMin, max: secMax }).slider('value', this.second);
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ },
|
|||
|
+
|
|||
|
+
|
|||
|
+ //########################################################################
|
|||
|
+ // when a slider moves, set the internal time...
|
|||
|
+ // on time change is also called when the time is updated in the text field
|
|||
|
+ //########################################################################
|
|||
|
+ _onTimeChange: function() {
|
|||
|
+ var hour = (this.hour_slider) ? this.hour_slider.slider('value') : false,
|
|||
|
+ minute = (this.minute_slider) ? this.minute_slider.slider('value') : false,
|
|||
|
+ second = (this.second_slider) ? this.second_slider.slider('value') : false,
|
|||
|
+ timezone = (this.timezone_select) ? this.timezone_select.val() : false;
|
|||
|
+
|
|||
|
+ if (typeof(hour) == 'object') hour = false;
|
|||
|
+ if (typeof(minute) == 'object') minute = false;
|
|||
|
+ if (typeof(second) == 'object') second = false;
|
|||
|
+ if (typeof(timezone) == 'object') timezone = false;
|
|||
|
+
|
|||
|
+ if (hour !== false) hour = parseInt(hour,10);
|
|||
|
+ if (minute !== false) minute = parseInt(minute,10);
|
|||
|
+ if (second !== false) second = parseInt(second,10);
|
|||
|
+
|
|||
|
+ var ampm = (hour < 12) ? 'AM' : 'PM';
|
|||
|
+
|
|||
|
+ // If the update was done in the input field, the input field should not be updated.
|
|||
|
+ // If the update was done using the sliders, update the input field.
|
|||
|
+ var hasChanged = (hour != this.hour || minute != this.minute || second != this.second || (this.ampm.length > 0 && this.ampm != ampm) || timezone != this.timezone);
|
|||
|
+
|
|||
|
+ if (hasChanged) {
|
|||
|
+
|
|||
|
+ if (hour !== false)this.hour = hour;
|
|||
|
+ if (minute !== false) this.minute = minute;
|
|||
|
+ if (second !== false) this.second = second;
|
|||
|
+ if (timezone !== false) this.timezone = timezone;
|
|||
|
+
|
|||
|
+ if (!this.inst) this.inst = $.datepicker._getInst(this.$input[0]);
|
|||
|
+
|
|||
|
+ this._limitMinMaxDateTime(this.inst, true);
|
|||
|
+ }
|
|||
|
+ if (this._defaults.ampm) this.ampm = ampm;
|
|||
|
+
|
|||
|
+ this._formatTime();
|
|||
|
+ if (this.$timeObj) this.$timeObj.text(this.formattedTime + this._defaults.timeSuffix);
|
|||
|
+ this.timeDefined = true;
|
|||
|
+ if (hasChanged) this._updateDateTime();
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ //########################################################################
|
|||
|
+ // call custom onSelect.
|
|||
|
+ // bind to sliders slidestop, and grid click.
|
|||
|
+ //########################################################################
|
|||
|
+ _onSelectHandler: function() {
|
|||
|
+ var onSelect = this._defaults['onSelect'];
|
|||
|
+ var inputEl = this.$input ? this.$input[0] : null;
|
|||
|
+ if (onSelect && inputEl) {
|
|||
|
+ onSelect.apply(inputEl, [this.formattedDateTime, this]);
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ //########################################################################
|
|||
|
+ // format the time all pretty...
|
|||
|
+ //########################################################################
|
|||
|
+ _formatTime: function(time, format, ampm) {
|
|||
|
+ if (ampm == undefined) ampm = this._defaults.ampm;
|
|||
|
+ time = time || { hour: this.hour, minute: this.minute, second: this.second, ampm: this.ampm, timezone: this.timezone };
|
|||
|
+ var tmptime = format || this._defaults.timeFormat.toString();
|
|||
|
+
|
|||
|
+ if (ampm) {
|
|||
|
+ var hour12 = ((time.ampm == 'AM') ? (time.hour) : (time.hour % 12));
|
|||
|
+ hour12 = (Number(hour12) === 0) ? 12 : hour12;
|
|||
|
+ tmptime = tmptime.toString()
|
|||
|
+ .replace(/hh/g, ((hour12 < 10) ? '0' : '') + hour12)
|
|||
|
+ .replace(/h/g, hour12)
|
|||
|
+ .replace(/mm/g, ((time.minute < 10) ? '0' : '') + time.minute)
|
|||
|
+ .replace(/m/g, time.minute)
|
|||
|
+ .replace(/ss/g, ((time.second < 10) ? '0' : '') + time.second)
|
|||
|
+ .replace(/s/g, time.second)
|
|||
|
+ .replace(/TT/g, time.ampm.toUpperCase())
|
|||
|
+ .replace(/Tt/g, time.ampm.toUpperCase())
|
|||
|
+ .replace(/tT/g, time.ampm.toLowerCase())
|
|||
|
+ .replace(/tt/g, time.ampm.toLowerCase())
|
|||
|
+ .replace(/T/g, time.ampm.charAt(0).toUpperCase())
|
|||
|
+ .replace(/t/g, time.ampm.charAt(0).toLowerCase())
|
|||
|
+ .replace(/z/g, time.timezone);
|
|||
|
+ } else {
|
|||
|
+ tmptime = tmptime.toString()
|
|||
|
+ .replace(/hh/g, ((time.hour < 10) ? '0' : '') + time.hour)
|
|||
|
+ .replace(/h/g, time.hour)
|
|||
|
+ .replace(/mm/g, ((time.minute < 10) ? '0' : '') + time.minute)
|
|||
|
+ .replace(/m/g, time.minute)
|
|||
|
+ .replace(/ss/g, ((time.second < 10) ? '0' : '') + time.second)
|
|||
|
+ .replace(/s/g, time.second)
|
|||
|
+ .replace(/z/g, time.timezone);
|
|||
|
+ tmptime = $.trim(tmptime.replace(/t/gi, ''));
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ if (arguments.length) return tmptime;
|
|||
|
+ else this.formattedTime = tmptime;
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ //########################################################################
|
|||
|
+ // update our input with the new date time..
|
|||
|
+ //########################################################################
|
|||
|
+ _updateDateTime: function(dp_inst) {
|
|||
|
+ dp_inst = this.inst || dp_inst,
|
|||
|
+ dt = new Date(dp_inst.selectedYear, dp_inst.selectedMonth, dp_inst.selectedDay),
|
|||
|
+ dateFmt = $.datepicker._get(dp_inst, 'dateFormat'),
|
|||
|
+ formatCfg = $.datepicker._getFormatConfig(dp_inst),
|
|||
|
+ timeAvailable = dt !== null && this.timeDefined;
|
|||
|
+ this.formattedDate = $.datepicker.formatDate(dateFmt, (dt === null ? new Date() : dt), formatCfg);
|
|||
|
+ var formattedDateTime = this.formattedDate;
|
|||
|
+ if (dp_inst.lastVal !== undefined && (dp_inst.lastVal.length > 0 && this.$input.val().length === 0))
|
|||
|
+ return;
|
|||
|
+
|
|||
|
+ if (this._defaults.timeOnly === true) {
|
|||
|
+ formattedDateTime = this.formattedTime;
|
|||
|
+ } else if (this._defaults.timeOnly !== true && (this._defaults.alwaysSetTime || timeAvailable)) {
|
|||
|
+ formattedDateTime += this._defaults.separator + this.formattedTime + this._defaults.timeSuffix;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ this.formattedDateTime = formattedDateTime;
|
|||
|
+
|
|||
|
+ if(!this._defaults.showTimepicker) {
|
|||
|
+ this.$input.val(this.formattedDate);
|
|||
|
+ } else if (this.$altInput && this._defaults.altFieldTimeOnly === true) {
|
|||
|
+ this.$altInput.val(this.formattedTime);
|
|||
|
+ this.$input.val(this.formattedDate);
|
|||
|
+ } else if(this.$altInput) {
|
|||
|
+ this.$altInput.val(formattedDateTime);
|
|||
|
+ this.$input.val(formattedDateTime);
|
|||
|
+ } else {
|
|||
|
+ this.$input.val(formattedDateTime);
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ this.$input.trigger("change");
|
|||
|
+ }
|
|||
|
+
|
|||
|
+});
|
|||
|
+
|
|||
|
+$.fn.extend({
|
|||
|
+ //########################################################################
|
|||
|
+ // shorthand just to use timepicker..
|
|||
|
+ //########################################################################
|
|||
|
+ timepicker: function(o) {
|
|||
|
+ o = o || {};
|
|||
|
+ var tmp_args = arguments;
|
|||
|
+
|
|||
|
+ if (typeof o == 'object') tmp_args[0] = $.extend(o, { timeOnly: true });
|
|||
|
+
|
|||
|
+ return $(this).each(function() {
|
|||
|
+ $.fn.datetimepicker.apply($(this), tmp_args);
|
|||
|
+ });
|
|||
|
+ },
|
|||
|
+
|
|||
|
+ //########################################################################
|
|||
|
+ // extend timepicker to datepicker
|
|||
|
+ //########################################################################
|
|||
|
+ datetimepicker: function(o) {
|
|||
|
+ o = o || {};
|
|||
|
+ var $input = this,
|
|||
|
+ tmp_args = arguments;
|
|||
|
+
|
|||
|
+ if (typeof(o) == 'string'){
|
|||
|
+ if(o == 'getDate')
|
|||
|
+ return $.fn.datepicker.apply($(this[0]), tmp_args);
|
|||
|
+ else
|
|||
|
+ return this.each(function() {
|
|||
|
+ var $t = $(this);
|
|||
|
+ $t.datepicker.apply($t, tmp_args);
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+ else
|
|||
|
+ return this.each(function() {
|
|||
|
+ var $t = $(this);
|
|||
|
+ $t.datepicker($.timepicker._newInst($t, o)._defaults);
|
|||
|
+ });
|
|||
|
+ }
|
|||
|
+});
|
|||
|
+
|
|||
|
+//########################################################################
|
|||
|
+// the bad hack :/ override datepicker so it doesnt close on select
|
|||
|
+// inspired: http://stackoverflow.com/questions/1252512/jquery-datepicker-prevent-closing-picker-when-clicking-a-date/1762378#1762378
|
|||
|
+//########################################################################
|
|||
|
+$.datepicker._base_selectDate = $.datepicker._selectDate;
|
|||
|
+$.datepicker._selectDate = function (id, dateStr) {
|
|||
|
+ var inst = this._getInst($(id)[0]),
|
|||
|
+ tp_inst = this._get(inst, 'timepicker');
|
|||
|
+
|
|||
|
+ if (tp_inst) {
|
|||
|
+ tp_inst._limitMinMaxDateTime(inst, true);
|
|||
|
+ inst.inline = inst.stay_open = true;
|
|||
|
+ //This way the onSelect handler called from calendarpicker get the full dateTime
|
|||
|
+ this._base_selectDate(id, dateStr + tp_inst._defaults.separator + tp_inst.formattedTime + tp_inst._defaults.timeSuffix);
|
|||
|
+ inst.inline = inst.stay_open = false;
|
|||
|
+ this._notifyChange(inst);
|
|||
|
+ this._updateDatepicker(inst);
|
|||
|
+ }
|
|||
|
+ else this._base_selectDate(id, dateStr);
|
|||
|
+};
|
|||
|
+
|
|||
|
+//#############################################################################################
|
|||
|
+// second bad hack :/ override datepicker so it triggers an event when changing the input field
|
|||
|
+// and does not redraw the datepicker on every selectDate event
|
|||
|
+//#############################################################################################
|
|||
|
+$.datepicker._base_updateDatepicker = $.datepicker._updateDatepicker;
|
|||
|
+$.datepicker._updateDatepicker = function(inst) {
|
|||
|
+
|
|||
|
+ // don't popup the datepicker if there is another instance already opened
|
|||
|
+ var input = inst.input[0];
|
|||
|
+ if($.datepicker._curInst &&
|
|||
|
+ $.datepicker._curInst != inst &&
|
|||
|
+ $.datepicker._datepickerShowing &&
|
|||
|
+ $.datepicker._lastInput != input) {
|
|||
|
+ return;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ if (typeof(inst.stay_open) !== 'boolean' || inst.stay_open === false) {
|
|||
|
+
|
|||
|
+ this._base_updateDatepicker(inst);
|
|||
|
+
|
|||
|
+ // Reload the time control when changing something in the input text field.
|
|||
|
+ var tp_inst = this._get(inst, 'timepicker');
|
|||
|
+ if(tp_inst) tp_inst._addTimePicker(inst);
|
|||
|
+ }
|
|||
|
+};
|
|||
|
+
|
|||
|
+//#######################################################################################
|
|||
|
+// third bad hack :/ override datepicker so it allows spaces and colon in the input field
|
|||
|
+//#######################################################################################
|
|||
|
+$.datepicker._base_doKeyPress = $.datepicker._doKeyPress;
|
|||
|
+$.datepicker._doKeyPress = function(event) {
|
|||
|
+ var inst = $.datepicker._getInst(event.target),
|
|||
|
+ tp_inst = $.datepicker._get(inst, 'timepicker');
|
|||
|
+
|
|||
|
+ if (tp_inst) {
|
|||
|
+ if ($.datepicker._get(inst, 'constrainInput')) {
|
|||
|
+ var ampm = tp_inst._defaults.ampm,
|
|||
|
+ dateChars = $.datepicker._possibleChars($.datepicker._get(inst, 'dateFormat')),
|
|||
|
+ datetimeChars = tp_inst._defaults.timeFormat.toString()
|
|||
|
+ .replace(/[hms]/g, '')
|
|||
|
+ .replace(/TT/g, ampm ? 'APM' : '')
|
|||
|
+ .replace(/Tt/g, ampm ? 'AaPpMm' : '')
|
|||
|
+ .replace(/tT/g, ampm ? 'AaPpMm' : '')
|
|||
|
+ .replace(/T/g, ampm ? 'AP' : '')
|
|||
|
+ .replace(/tt/g, ampm ? 'apm' : '')
|
|||
|
+ .replace(/t/g, ampm ? 'ap' : '') +
|
|||
|
+ " " +
|
|||
|
+ tp_inst._defaults.separator +
|
|||
|
+ tp_inst._defaults.timeSuffix +
|
|||
|
+ (tp_inst._defaults.showTimezone ? tp_inst._defaults.timezoneList.join('') : '') +
|
|||
|
+ dateChars,
|
|||
|
+ chr = String.fromCharCode(event.charCode === undefined ? event.keyCode : event.charCode);
|
|||
|
+ return event.ctrlKey || (chr < ' ' || !dateChars || datetimeChars.indexOf(chr) > -1);
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ return $.datepicker._base_doKeyPress(event);
|
|||
|
+};
|
|||
|
+
|
|||
|
+//#######################################################################################
|
|||
|
+// Override key up event to sync manual input changes.
|
|||
|
+//#######################################################################################
|
|||
|
+$.datepicker._base_doKeyUp = $.datepicker._doKeyUp;
|
|||
|
+$.datepicker._doKeyUp = function (event) {
|
|||
|
+ var inst = $.datepicker._getInst(event.target),
|
|||
|
+ tp_inst = $.datepicker._get(inst, 'timepicker');
|
|||
|
+
|
|||
|
+ if (tp_inst) {
|
|||
|
+ if (tp_inst._defaults.timeOnly && (inst.input.val() != inst.lastVal)) {
|
|||
|
+ try {
|
|||
|
+ $.datepicker._updateDatepicker(inst);
|
|||
|
+ }
|
|||
|
+ catch (err) {
|
|||
|
+ $.datepicker.log(err);
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ return $.datepicker._base_doKeyUp(event);
|
|||
|
+};
|
|||
|
+
|
|||
|
+//#######################################################################################
|
|||
|
+// override "Today" button to also grab the time.
|
|||
|
+//#######################################################################################
|
|||
|
+$.datepicker._base_gotoToday = $.datepicker._gotoToday;
|
|||
|
+$.datepicker._gotoToday = function(id) {
|
|||
|
+ this._base_gotoToday(id);
|
|||
|
+ this._setTime(this._getInst($(id)[0]), new Date());
|
|||
|
+};
|
|||
|
+
|
|||
|
+//#######################################################################################
|
|||
|
+// Disable & enable the Time in the datetimepicker
|
|||
|
+//#######################################################################################
|
|||
|
+$.datepicker._disableTimepickerDatepicker = function(target, date, withDate) {
|
|||
|
+ var inst = this._getInst(target),
|
|||
|
+ tp_inst = this._get(inst, 'timepicker');
|
|||
|
+ $(target).datepicker('getDate'); // Init selected[Year|Month|Day]
|
|||
|
+ if (tp_inst) {
|
|||
|
+ tp_inst._defaults.showTimepicker = false;
|
|||
|
+ tp_inst._updateDateTime(inst);
|
|||
|
+ }
|
|||
|
+};
|
|||
|
+
|
|||
|
+$.datepicker._enableTimepickerDatepicker = function(target, date, withDate) {
|
|||
|
+ var inst = this._getInst(target),
|
|||
|
+ tp_inst = this._get(inst, 'timepicker');
|
|||
|
+ $(target).datepicker('getDate'); // Init selected[Year|Month|Day]
|
|||
|
+ if (tp_inst) {
|
|||
|
+ tp_inst._defaults.showTimepicker = true;
|
|||
|
+ tp_inst._addTimePicker(inst); // Could be disabled on page load
|
|||
|
+ tp_inst._updateDateTime(inst);
|
|||
|
+ }
|
|||
|
+};
|
|||
|
+
|
|||
|
+//#######################################################################################
|
|||
|
+// Create our own set time function
|
|||
|
+//#######################################################################################
|
|||
|
+$.datepicker._setTime = function(inst, date) {
|
|||
|
+ var tp_inst = this._get(inst, 'timepicker');
|
|||
|
+ if (tp_inst) {
|
|||
|
+ var defaults = tp_inst._defaults,
|
|||
|
+ // calling _setTime with no date sets time to defaults
|
|||
|
+ hour = date ? date.getHours() : defaults.hour,
|
|||
|
+ minute = date ? date.getMinutes() : defaults.minute,
|
|||
|
+ second = date ? date.getSeconds() : defaults.second;
|
|||
|
+
|
|||
|
+ //check if within min/max times..
|
|||
|
+ if ((hour < defaults.hourMin || hour > defaults.hourMax) || (minute < defaults.minuteMin || minute > defaults.minuteMax) || (second < defaults.secondMin || second > defaults.secondMax)) {
|
|||
|
+ hour = defaults.hourMin;
|
|||
|
+ minute = defaults.minuteMin;
|
|||
|
+ second = defaults.secondMin;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ tp_inst.hour = hour;
|
|||
|
+ tp_inst.minute = minute;
|
|||
|
+ tp_inst.second = second;
|
|||
|
+
|
|||
|
+ if (tp_inst.hour_slider) tp_inst.hour_slider.slider('value', hour);
|
|||
|
+ if (tp_inst.minute_slider) tp_inst.minute_slider.slider('value', minute);
|
|||
|
+ if (tp_inst.second_slider) tp_inst.second_slider.slider('value', second);
|
|||
|
+
|
|||
|
+ tp_inst._onTimeChange();
|
|||
|
+ tp_inst._updateDateTime(inst);
|
|||
|
+ }
|
|||
|
+};
|
|||
|
+
|
|||
|
+//#######################################################################################
|
|||
|
+// Create new public method to set only time, callable as $().datepicker('setTime', date)
|
|||
|
+//#######################################################################################
|
|||
|
+$.datepicker._setTimeDatepicker = function(target, date, withDate) {
|
|||
|
+ var inst = this._getInst(target),
|
|||
|
+ tp_inst = this._get(inst, 'timepicker');
|
|||
|
+
|
|||
|
+ if (tp_inst) {
|
|||
|
+ this._setDateFromField(inst);
|
|||
|
+ var tp_date;
|
|||
|
+ if (date) {
|
|||
|
+ if (typeof date == "string") {
|
|||
|
+ tp_inst._parseTime(date, withDate);
|
|||
|
+ tp_date = new Date();
|
|||
|
+ tp_date.setHours(tp_inst.hour, tp_inst.minute, tp_inst.second);
|
|||
|
+ }
|
|||
|
+ else tp_date = new Date(date.getTime());
|
|||
|
+ if (tp_date.toString() == 'Invalid Date') tp_date = undefined;
|
|||
|
+ this._setTime(inst, tp_date);
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+
|
|||
|
+};
|
|||
|
+
|
|||
|
+//#######################################################################################
|
|||
|
+// override setDate() to allow setting time too within Date object
|
|||
|
+//#######################################################################################
|
|||
|
+$.datepicker._base_setDateDatepicker = $.datepicker._setDateDatepicker;
|
|||
|
+$.datepicker._setDateDatepicker = function(target, date) {
|
|||
|
+ var inst = this._getInst(target),
|
|||
|
+ tp_date = (date instanceof Date) ? new Date(date.getTime()) : date;
|
|||
|
+
|
|||
|
+ this._updateDatepicker(inst);
|
|||
|
+ this._base_setDateDatepicker.apply(this, arguments);
|
|||
|
+ this._setTimeDatepicker(target, tp_date, true);
|
|||
|
+};
|
|||
|
+
|
|||
|
+//#######################################################################################
|
|||
|
+// override getDate() to allow getting time too within Date object
|
|||
|
+//#######################################################################################
|
|||
|
+$.datepicker._base_getDateDatepicker = $.datepicker._getDateDatepicker;
|
|||
|
+$.datepicker._getDateDatepicker = function(target, noDefault) {
|
|||
|
+ var inst = this._getInst(target),
|
|||
|
+ tp_inst = this._get(inst, 'timepicker');
|
|||
|
+
|
|||
|
+ if (tp_inst) {
|
|||
|
+ this._setDateFromField(inst, noDefault);
|
|||
|
+ var date = this._getDate(inst);
|
|||
|
+ if (date && tp_inst._parseTime($(target).val(), tp_inst.timeOnly)) date.setHours(tp_inst.hour, tp_inst.minute, tp_inst.second);
|
|||
|
+ return date;
|
|||
|
+ }
|
|||
|
+ return this._base_getDateDatepicker(target, noDefault);
|
|||
|
+};
|
|||
|
+
|
|||
|
+//#######################################################################################
|
|||
|
+// override parseDate() because UI 1.8.14 throws an error about "Extra characters"
|
|||
|
+// An option in datapicker to ignore extra format characters would be nicer.
|
|||
|
+//#######################################################################################
|
|||
|
+$.datepicker._base_parseDate = $.datepicker.parseDate;
|
|||
|
+$.datepicker.parseDate = function(format, value, settings) {
|
|||
|
+ var date;
|
|||
|
+ try {
|
|||
|
+ date = this._base_parseDate(format, value, settings);
|
|||
|
+ } catch (err) {
|
|||
|
+ // Hack! The error message ends with a colon, a space, and
|
|||
|
+ // the "extra" characters. We rely on that instead of
|
|||
|
+ // attempting to perfectly reproduce the parsing algorithm.
|
|||
|
+ date = this._base_parseDate(format, value.substring(0,value.length-(err.length-err.indexOf(':')-2)), settings);
|
|||
|
+ }
|
|||
|
+ return date;
|
|||
|
+};
|
|||
|
+
|
|||
|
+//#######################################################################################
|
|||
|
+// override options setter to add time to maxDate(Time) and minDate(Time)
|
|||
|
+//#######################################################################################
|
|||
|
+$.datepicker._base_optionDatepicker = $.datepicker._optionDatepicker;
|
|||
|
+$.datepicker._optionDatepicker = function(target, name, value) {
|
|||
|
+ this._base_optionDatepicker(target, name, value);
|
|||
|
+ var inst = this._getInst(target),
|
|||
|
+ tp_inst = this._get(inst, 'timepicker');
|
|||
|
+ if (tp_inst) {
|
|||
|
+ //Set minimum and maximum date values if we have timepicker
|
|||
|
+ if(name==='minDate') {
|
|||
|
+ if(tp_inst._defaults.minDate !== undefined && tp_inst._defaults.minDate instanceof Date)
|
|||
|
+ tp_inst._defaults.minDateTime = new Date(value);
|
|||
|
+ if(tp_inst._defaults.minDateTime !== undefined && tp_inst._defaults.minDateTime instanceof Date)
|
|||
|
+ tp_inst._defaults.minDate = new Date(tp_inst._defaults.minDateTime.getTime());
|
|||
|
+ tp_inst._limitMinMaxDateTime(inst,true);
|
|||
|
+ }
|
|||
|
+ if(name==='maxDate') {
|
|||
|
+ if(tp_inst._defaults.maxDate !== undefined && tp_inst._defaults.maxDate instanceof Date)
|
|||
|
+ tp_inst._defaults.maxDateTime = new Date(value);
|
|||
|
+ if(tp_inst._defaults.maxDateTime !== undefined && tp_inst._defaults.maxDateTime instanceof Date)
|
|||
|
+ tp_inst._defaults.maxDate = new Date(tp_inst._defaults.maxDateTime.getTime());
|
|||
|
+ tp_inst._limitMinMaxDateTime(inst,true);
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+};
|
|||
|
+
|
|||
|
+//#######################################################################################
|
|||
|
+// jQuery extend now ignores nulls!
|
|||
|
+//#######################################################################################
|
|||
|
+function extendRemove(target, props) {
|
|||
|
+ $.extend(target, props);
|
|||
|
+ for (var name in props)
|
|||
|
+ if (props[name] === null || props[name] === undefined)
|
|||
|
+ target[name] = props[name];
|
|||
|
+ return target;
|
|||
|
+}
|
|||
|
+
|
|||
|
+$.timepicker = new Timepicker(); // singleton instance
|
|||
|
+$.timepicker.version = "0.9.6";
|
|||
|
+
|
|||
|
+})(jQuery);
|
|||
|
\ No newline at end of file
|
|||
|
diff -up cacti-0.8.8a/include/js/jquery/jquery-ui.js.legal cacti-0.8.8a/include/js/jquery/jquery-ui.js
|
|||
|
--- cacti-0.8.8a/include/js/jquery/jquery-ui.js.legal 2013-01-04 15:44:38.043416079 -0500
|
|||
|
+++ cacti-0.8.8a/include/js/jquery/jquery-ui.js 2013-01-04 15:43:12.646377987 -0500
|
|||
|
@@ -0,0 +1,356 @@
|
|||
|
+/*!
|
|||
|
+ * jQuery UI 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI
|
|||
|
+ */(function(a,b){function d(b){return!a(b).parents().andSelf().filter(function(){return a.curCSS(this,"visibility")==="hidden"||a.expr.filters.hidden(this)}).length}function c(b,c){var e=b.nodeName.toLowerCase();if("area"===e){var f=b.parentNode,g=f.name,h;if(!b.href||!g||f.nodeName.toLowerCase()!=="map")return!1;h=a("img[usemap=#"+g+"]")[0];return!!h&&d(h)}return(/input|select|textarea|button|object/.test(e)?!b.disabled:"a"==e?b.href||c:c)&&d(b)}a.ui=a.ui||{};a.ui.version||(a.extend(a.ui,{version:"1.8.18",keyCode:{ALT:18,BACKSPACE:8,CAPS_LOCK:20,COMMA:188,COMMAND:91,COMMAND_LEFT:91,COMMAND_RIGHT:93,CONTROL:17,DELETE:46,DOWN:40,END:35,ENTER:13,ESCAPE:27,HOME:36,INSERT:45,LEFT:37,MENU:93,NUMPAD_ADD:107,NUMPAD_DECIMAL:110,NUMPAD_DIVIDE:111,NUMPAD_ENTER:108,NUMPAD_MULTIPLY:106,NUMPAD_SUBTRACT:109,PAGE_DOWN:34,PAGE_UP:33,PERIOD:190,RIGHT:39,SHIFT:16,SPACE:32,TAB:9,UP:38,WINDOWS:91}}),a.fn.extend({propAttr:a.fn.prop||a.fn.attr,_focus:a.fn.focus,focus:function(b,c){return typeof b=="number"?this.each(function(){var d=this;setTimeout(function(){a(d).focus(),c&&c.call(d)},b)}):this._focus.apply(this,arguments)},scrollParent:function(){var b;a.browser.msie&&/(static|relative)/.test(this.css("position"))||/absolute/.test(this.css("position"))?b=this.parents().filter(function(){return/(relative|absolute|fixed)/.test(a.curCSS(this,"position",1))&&/(auto|scroll)/.test(a.curCSS(this,"overflow",1)+a.curCSS(this,"overflow-y",1)+a.curCSS(this,"overflow-x",1))}).eq(0):b=this.parents().filter(function(){return/(auto|scroll)/.test(a.curCSS(this,"overflow",1)+a.curCSS(this,"overflow-y",1)+a.curCSS(this,"overflow-x",1))}).eq(0);return/fixed/.test(this.css("position"))||!b.length?a(document):b},zIndex:function(c){if(c!==b)return this.css("zIndex",c);if(this.length){var d=a(this[0]),e,f;while(d.length&&d[0]!==document){e=d.css("position");if(e==="absolute"||e==="relative"||e==="fixed"){f=parseInt(d.css("zIndex"),10);if(!isNaN(f)&&f!==0)return f}d=d.parent()}}return 0},disableSelection:function(){return this.bind((a.support.selectstart?"selectstart":"mousedown")+".ui-disableSelection",function(a){a.preventDefault()})},enableSelection:function(){return this.unbind(".ui-disableSelection")}}),a.each(["Width","Height"],function(c,d){function h(b,c,d,f){a.each(e,function(){c-=parseFloat(a.curCSS(b,"padding"+this,!0))||0,d&&(c-=parseFloat(a.curCSS(b,"border"+this+"Width",!0))||0),f&&(c-=parseFloat(a.curCSS(b,"margin"+this,!0))||0)});return c}var e=d==="Width"?["Left","Right"]:["Top","Bottom"],f=d.toLowerCase(),g={innerWidth:a.fn.innerWidth,innerHeight:a.fn.innerHeight,outerWidth:a.fn.outerWidth,outerHeight:a.fn.outerHeight};a.fn["inner"+d]=function(c){if(c===b)return g["inner"+d].call(this);return this.each(function(){a(this).css(f,h(this,c)+"px")})},a.fn["outer"+d]=function(b,c){if(typeof b!="number")return g["outer"+d].call(this,b);return this.each(function(){a(this).css(f,h(this,b,!0,c)+"px")})}}),a.extend(a.expr[":"],{data:function(b,c,d){return!!a.data(b,d[3])},focusable:function(b){return c(b,!isNaN(a.attr(b,"tabindex")))},tabbable:function(b){var d=a.attr(b,"tabindex"),e=isNaN(d);return(e||d>=0)&&c(b,!e)}}),a(function(){var b=document.body,c=b.appendChild(c=document.createElement("div"));c.offsetHeight,a.extend(c.style,{minHeight:"100px",height:"auto",padding:0,borderWidth:0}),a.support.minHeight=c.offsetHeight===100,a.support.selectstart="onselectstart"in c,b.removeChild(c).style.display="none"}),a.extend(a.ui,{plugin:{add:function(b,c,d){var e=a.ui[b].prototype;for(var f in d)e.plugins[f]=e.plugins[f]||[],e.plugins[f].push([c,d[f]])},call:function(a,b,c){var d=a.plugins[b];if(!!d&&!!a.element[0].parentNode)for(var e=0;e<d.length;e++)a.options[d[e][0]]&&d[e][1].apply(a.element,c)}},contains:function(a,b){return document.compareDocumentPosition?a.compareDocumentPosition(b)&16:a!==b&&a.contains(b)},hasScroll:function(b,c){if(a(b).css("overflow")==="hidden")return!1;var d=c&&c==="left"?"scrollLeft":"scrollTop",e=!1;if(b[d]>0)return!0;b[d]=1,e=b[d]>0,b[d]=0;return e},isOverAxis:function(a,b,c){return a>b&&a<b+c},isOver:function(b,c,d,e,f,g){ret
|
|||
|
+ * jQuery UI Widget 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Widget
|
|||
|
+ */(function(a,b){if(a.cleanData){var c=a.cleanData;a.cleanData=function(b){for(var d=0,e;(e=b[d])!=null;d++)try{a(e).triggerHandler("remove")}catch(f){}c(b)}}else{var d=a.fn.remove;a.fn.remove=function(b,c){return this.each(function(){c||(!b||a.filter(b,[this]).length)&&a("*",this).add([this]).each(function(){try{a(this).triggerHandler("remove")}catch(b){}});return d.call(a(this),b,c)})}}a.widget=function(b,c,d){var e=b.split(".")[0],f;b=b.split(".")[1],f=e+"-"+b,d||(d=c,c=a.Widget),a.expr[":"][f]=function(c){return!!a.data(c,b)},a[e]=a[e]||{},a[e][b]=function(a,b){arguments.length&&this._createWidget(a,b)};var g=new c;g.options=a.extend(!0,{},g.options),a[e][b].prototype=a.extend(!0,g,{namespace:e,widgetName:b,widgetEventPrefix:a[e][b].prototype.widgetEventPrefix||b,widgetBaseClass:f},d),a.widget.bridge(b,a[e][b])},a.widget.bridge=function(c,d){a.fn[c]=function(e){var f=typeof e=="string",g=Array.prototype.slice.call(arguments,1),h=this;e=!f&&g.length?a.extend.apply(null,[!0,e].concat(g)):e;if(f&&e.charAt(0)==="_")return h;f?this.each(function(){var d=a.data(this,c),f=d&&a.isFunction(d[e])?d[e].apply(d,g):d;if(f!==d&&f!==b){h=f;return!1}}):this.each(function(){var b=a.data(this,c);b?b.option(e||{})._init():a.data(this,c,new d(e,this))});return h}},a.Widget=function(a,b){arguments.length&&this._createWidget(a,b)},a.Widget.prototype={widgetName:"widget",widgetEventPrefix:"",options:{disabled:!1},_createWidget:function(b,c){a.data(c,this.widgetName,this),this.element=a(c),this.options=a.extend(!0,{},this.options,this._getCreateOptions(),b);var d=this;this.element.bind("remove."+this.widgetName,function(){d.destroy()}),this._create(),this._trigger("create"),this._init()},_getCreateOptions:function(){return a.metadata&&a.metadata.get(this.element[0])[this.widgetName]},_create:function(){},_init:function(){},destroy:function(){this.element.unbind("."+this.widgetName).removeData(this.widgetName),this.widget().unbind("."+this.widgetName).removeAttr("aria-disabled").removeClass(this.widgetBaseClass+"-disabled "+"ui-state-disabled")},widget:function(){return this.element},option:function(c,d){var e=c;if(arguments.length===0)return a.extend({},this.options);if(typeof c=="string"){if(d===b)return this.options[c];e={},e[c]=d}this._setOptions(e);return this},_setOptions:function(b){var c=this;a.each(b,function(a,b){c._setOption(a,b)});return this},_setOption:function(a,b){this.options[a]=b,a==="disabled"&&this.widget()[b?"addClass":"removeClass"](this.widgetBaseClass+"-disabled"+" "+"ui-state-disabled").attr("aria-disabled",b);return this},enable:function(){return this._setOption("disabled",!1)},disable:function(){return this._setOption("disabled",!0)},_trigger:function(b,c,d){var e,f,g=this.options[b];d=d||{},c=a.Event(c),c.type=(b===this.widgetEventPrefix?b:this.widgetEventPrefix+b).toLowerCase(),c.target=this.element[0],f=c.originalEvent;if(f)for(e in f)e in c||(c[e]=f[e]);this.element.trigger(c,d);return!(a.isFunction(g)&&g.call(this.element[0],c,d)===!1||c.isDefaultPrevented())}}})(jQuery);/*!
|
|||
|
+ * jQuery UI Mouse 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Mouse
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.ui.widget.js
|
|||
|
+ */(function(a,b){var c=!1;a(document).mouseup(function(a){c=!1}),a.widget("ui.mouse",{options:{cancel:":input,option",distance:1,delay:0},_mouseInit:function(){var b=this;this.element.bind("mousedown."+this.widgetName,function(a){return b._mouseDown(a)}).bind("click."+this.widgetName,function(c){if(!0===a.data(c.target,b.widgetName+".preventClickEvent")){a.removeData(c.target,b.widgetName+".preventClickEvent"),c.stopImmediatePropagation();return!1}}),this.started=!1},_mouseDestroy:function(){this.element.unbind("."+this.widgetName)},_mouseDown:function(b){if(!c){this._mouseStarted&&this._mouseUp(b),this._mouseDownEvent=b;var d=this,e=b.which==1,f=typeof this.options.cancel=="string"&&b.target.nodeName?a(b.target).closest(this.options.cancel).length:!1;if(!e||f||!this._mouseCapture(b))return!0;this.mouseDelayMet=!this.options.delay,this.mouseDelayMet||(this._mouseDelayTimer=setTimeout(function(){d.mouseDelayMet=!0},this.options.delay));if(this._mouseDistanceMet(b)&&this._mouseDelayMet(b)){this._mouseStarted=this._mouseStart(b)!==!1;if(!this._mouseStarted){b.preventDefault();return!0}}!0===a.data(b.target,this.widgetName+".preventClickEvent")&&a.removeData(b.target,this.widgetName+".preventClickEvent"),this._mouseMoveDelegate=function(a){return d._mouseMove(a)},this._mouseUpDelegate=function(a){return d._mouseUp(a)},a(document).bind("mousemove."+this.widgetName,this._mouseMoveDelegate).bind("mouseup."+this.widgetName,this._mouseUpDelegate),b.preventDefault(),c=!0;return!0}},_mouseMove:function(b){if(a.browser.msie&&!(document.documentMode>=9)&&!b.button)return this._mouseUp(b);if(this._mouseStarted){this._mouseDrag(b);return b.preventDefault()}this._mouseDistanceMet(b)&&this._mouseDelayMet(b)&&(this._mouseStarted=this._mouseStart(this._mouseDownEvent,b)!==!1,this._mouseStarted?this._mouseDrag(b):this._mouseUp(b));return!this._mouseStarted},_mouseUp:function(b){a(document).unbind("mousemove."+this.widgetName,this._mouseMoveDelegate).unbind("mouseup."+this.widgetName,this._mouseUpDelegate),this._mouseStarted&&(this._mouseStarted=!1,b.target==this._mouseDownEvent.target&&a.data(b.target,this.widgetName+".preventClickEvent",!0),this._mouseStop(b));return!1},_mouseDistanceMet:function(a){return Math.max(Math.abs(this._mouseDownEvent.pageX-a.pageX),Math.abs(this._mouseDownEvent.pageY-a.pageY))>=this.options.distance},_mouseDelayMet:function(a){return this.mouseDelayMet},_mouseStart:function(a){},_mouseDrag:function(a){},_mouseStop:function(a){},_mouseCapture:function(a){return!0}})})(jQuery);/*
|
|||
|
+ * jQuery UI Position 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Position
|
|||
|
+ */(function(a,b){a.ui=a.ui||{};var c=/left|center|right/,d=/top|center|bottom/,e="center",f={},g=a.fn.position,h=a.fn.offset;a.fn.position=function(b){if(!b||!b.of)return g.apply(this,arguments);b=a.extend({},b);var h=a(b.of),i=h[0],j=(b.collision||"flip").split(" "),k=b.offset?b.offset.split(" "):[0,0],l,m,n;i.nodeType===9?(l=h.width(),m=h.height(),n={top:0,left:0}):i.setTimeout?(l=h.width(),m=h.height(),n={top:h.scrollTop(),left:h.scrollLeft()}):i.preventDefault?(b.at="left top",l=m=0,n={top:b.of.pageY,left:b.of.pageX}):(l=h.outerWidth(),m=h.outerHeight(),n=h.offset()),a.each(["my","at"],function(){var a=(b[this]||"").split(" ");a.length===1&&(a=c.test(a[0])?a.concat([e]):d.test(a[0])?[e].concat(a):[e,e]),a[0]=c.test(a[0])?a[0]:e,a[1]=d.test(a[1])?a[1]:e,b[this]=a}),j.length===1&&(j[1]=j[0]),k[0]=parseInt(k[0],10)||0,k.length===1&&(k[1]=k[0]),k[1]=parseInt(k[1],10)||0,b.at[0]==="right"?n.left+=l:b.at[0]===e&&(n.left+=l/2),b.at[1]==="bottom"?n.top+=m:b.at[1]===e&&(n.top+=m/2),n.left+=k[0],n.top+=k[1];return this.each(function(){var c=a(this),d=c.outerWidth(),g=c.outerHeight(),h=parseInt(a.curCSS(this,"marginLeft",!0))||0,i=parseInt(a.curCSS(this,"marginTop",!0))||0,o=d+h+(parseInt(a.curCSS(this,"marginRight",!0))||0),p=g+i+(parseInt(a.curCSS(this,"marginBottom",!0))||0),q=a.extend({},n),r;b.my[0]==="right"?q.left-=d:b.my[0]===e&&(q.left-=d/2),b.my[1]==="bottom"?q.top-=g:b.my[1]===e&&(q.top-=g/2),f.fractions||(q.left=Math.round(q.left),q.top=Math.round(q.top)),r={left:q.left-h,top:q.top-i},a.each(["left","top"],function(c,e){a.ui.position[j[c]]&&a.ui.position[j[c]][e](q,{targetWidth:l,targetHeight:m,elemWidth:d,elemHeight:g,collisionPosition:r,collisionWidth:o,collisionHeight:p,offset:k,my:b.my,at:b.at})}),a.fn.bgiframe&&c.bgiframe(),c.offset(a.extend(q,{using:b.using}))})},a.ui.position={fit:{left:function(b,c){var d=a(window),e=c.collisionPosition.left+c.collisionWidth-d.width()-d.scrollLeft();b.left=e>0?b.left-e:Math.max(b.left-c.collisionPosition.left,b.left)},top:function(b,c){var d=a(window),e=c.collisionPosition.top+c.collisionHeight-d.height()-d.scrollTop();b.top=e>0?b.top-e:Math.max(b.top-c.collisionPosition.top,b.top)}},flip:{left:function(b,c){if(c.at[0]!==e){var d=a(window),f=c.collisionPosition.left+c.collisionWidth-d.width()-d.scrollLeft(),g=c.my[0]==="left"?-c.elemWidth:c.my[0]==="right"?c.elemWidth:0,h=c.at[0]==="left"?c.targetWidth:-c.targetWidth,i=-2*c.offset[0];b.left+=c.collisionPosition.left<0?g+h+i:f>0?g+h+i:0}},top:function(b,c){if(c.at[1]!==e){var d=a(window),f=c.collisionPosition.top+c.collisionHeight-d.height()-d.scrollTop(),g=c.my[1]==="top"?-c.elemHeight:c.my[1]==="bottom"?c.elemHeight:0,h=c.at[1]==="top"?c.targetHeight:-c.targetHeight,i=-2*c.offset[1];b.top+=c.collisionPosition.top<0?g+h+i:f>0?g+h+i:0}}}},a.offset.setOffset||(a.offset.setOffset=function(b,c){/static/.test(a.curCSS(b,"position"))&&(b.style.position="relative");var d=a(b),e=d.offset(),f=parseInt(a.curCSS(b,"top",!0),10)||0,g=parseInt(a.curCSS(b,"left",!0),10)||0,h={top:c.top-e.top+f,left:c.left-e.left+g};"using"in c?c.using.call(b,h):d.css(h)},a.fn.offset=function(b){var c=this[0];if(!c||!c.ownerDocument)return null;if(b)return this.each(function(){a.offset.setOffset(this,b)});return h.call(this)}),function(){var b=document.getElementsByTagName("body")[0],c=document.createElement("div"),d,e,g,h,i;d=document.createElement(b?"div":"body"),g={visibility:"hidden",width:0,height:0,border:0,margin:0,background:"none"},b&&a.extend(g,{position:"absolute",left:"-1000px",top:"-1000px"});for(var j in g)d.style[j]=g[j];d.appendChild(c),e=b||document.documentElement,e.insertBefore(d,e.firstChild),c.style.cssText="position: absolute; left: 10.7432222px; top: 10.432325px; height: 30px; width: 201px;",h=a(c).offset(function(a,b){return b}).offset(),d.innerHTML="",e.removeChild(d),i=h.top+h.left+(b?2e3:0),f.fractions=i>21&&i<22}()})(jQuery);/*
|
|||
|
+ * jQuery UI Draggable 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Draggables
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.ui.core.js
|
|||
|
+ * jquery.ui.mouse.js
|
|||
|
+ * jquery.ui.widget.js
|
|||
|
+ */(function(a,b){a.widget("ui.draggable",a.ui.mouse,{widgetEventPrefix:"drag",options:{addClasses:!0,appendTo:"parent",axis:!1,connectToSortable:!1,containment:!1,cursor:"auto",cursorAt:!1,grid:!1,handle:!1,helper:"original",iframeFix:!1,opacity:!1,refreshPositions:!1,revert:!1,revertDuration:500,scope:"default",scroll:!0,scrollSensitivity:20,scrollSpeed:20,snap:!1,snapMode:"both",snapTolerance:20,stack:!1,zIndex:!1},_create:function(){this.options.helper=="original"&&!/^(?:r|a|f)/.test(this.element.css("position"))&&(this.element[0].style.position="relative"),this.options.addClasses&&this.element.addClass("ui-draggable"),this.options.disabled&&this.element.addClass("ui-draggable-disabled"),this._mouseInit()},destroy:function(){if(!!this.element.data("draggable")){this.element.removeData("draggable").unbind(".draggable").removeClass("ui-draggable ui-draggable-dragging ui-draggable-disabled"),this._mouseDestroy();return this}},_mouseCapture:function(b){var c=this.options;if(this.helper||c.disabled||a(b.target).is(".ui-resizable-handle"))return!1;this.handle=this._getHandle(b);if(!this.handle)return!1;c.iframeFix&&a(c.iframeFix===!0?"iframe":c.iframeFix).each(function(){a('<div class="ui-draggable-iframeFix" style="background: #fff;"></div>').css({width:this.offsetWidth+"px",height:this.offsetHeight+"px",position:"absolute",opacity:"0.001",zIndex:1e3}).css(a(this).offset()).appendTo("body")});return!0},_mouseStart:function(b){var c=this.options;this.helper=this._createHelper(b),this._cacheHelperProportions(),a.ui.ddmanager&&(a.ui.ddmanager.current=this),this._cacheMargins(),this.cssPosition=this.helper.css("position"),this.scrollParent=this.helper.scrollParent(),this.offset=this.positionAbs=this.element.offset(),this.offset={top:this.offset.top-this.margins.top,left:this.offset.left-this.margins.left},a.extend(this.offset,{click:{left:b.pageX-this.offset.left,top:b.pageY-this.offset.top},parent:this._getParentOffset(),relative:this._getRelativeOffset()}),this.originalPosition=this.position=this._generatePosition(b),this.originalPageX=b.pageX,this.originalPageY=b.pageY,c.cursorAt&&this._adjustOffsetFromHelper(c.cursorAt),c.containment&&this._setContainment();if(this._trigger("start",b)===!1){this._clear();return!1}this._cacheHelperProportions(),a.ui.ddmanager&&!c.dropBehaviour&&a.ui.ddmanager.prepareOffsets(this,b),this.helper.addClass("ui-draggable-dragging"),this._mouseDrag(b,!0),a.ui.ddmanager&&a.ui.ddmanager.dragStart(this,b);return!0},_mouseDrag:function(b,c){this.position=this._generatePosition(b),this.positionAbs=this._convertPositionTo("absolute");if(!c){var d=this._uiHash();if(this._trigger("drag",b,d)===!1){this._mouseUp({});return!1}this.position=d.position}if(!this.options.axis||this.options.axis!="y")this.helper[0].style.left=this.position.left+"px";if(!this.options.axis||this.options.axis!="x")this.helper[0].style.top=this.position.top+"px";a.ui.ddmanager&&a.ui.ddmanager.drag(this,b);return!1},_mouseStop:function(b){var c=!1;a.ui.ddmanager&&!this.options.dropBehaviour&&(c=a.ui.ddmanager.drop(this,b)),this.dropped&&(c=this.dropped,this.dropped=!1);if((!this.element[0]||!this.element[0].parentNode)&&this.options.helper=="original")return!1;if(this.options.revert=="invalid"&&!c||this.options.revert=="valid"&&c||this.options.revert===!0||a.isFunction(this.options.revert)&&this.options.revert.call(this.element,c)){var d=this;a(this.helper).animate(this.originalPosition,parseInt(this.options.revertDuration,10),function(){d._trigger("stop",b)!==!1&&d._clear()})}else this._trigger("stop",b)!==!1&&this._clear();return!1},_mouseUp:function(b){this.options.iframeFix===!0&&a("div.ui-draggable-iframeFix").each(function(){this.parentNode.removeChild(this)}),a.ui.ddmanager&&a.ui.ddmanager.dragStop(this,b);return a.ui.mouse.prototype._mouseUp.call(this,b)},cancel:function(){this.helper.is(".ui-draggable-dragging")?this._mouseUp({}):this._clear();return this},_getHandle:function(b){var c=!this.options.handle||!a(this.options.handle,this.element).length?!0:!1;a(this.options.handle,this.element).find("*").andSelf().each(funct
|
|||
|
+ * jQuery UI Droppable 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Droppables
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.ui.core.js
|
|||
|
+ * jquery.ui.widget.js
|
|||
|
+ * jquery.ui.mouse.js
|
|||
|
+ * jquery.ui.draggable.js
|
|||
|
+ */(function(a,b){a.widget("ui.droppable",{widgetEventPrefix:"drop",options:{accept:"*",activeClass:!1,addClasses:!0,greedy:!1,hoverClass:!1,scope:"default",tolerance:"intersect"},_create:function(){var b=this.options,c=b.accept;this.isover=0,this.isout=1,this.accept=a.isFunction(c)?c:function(a){return a.is(c)},this.proportions={width:this.element[0].offsetWidth,height:this.element[0].offsetHeight},a.ui.ddmanager.droppables[b.scope]=a.ui.ddmanager.droppables[b.scope]||[],a.ui.ddmanager.droppables[b.scope].push(this),b.addClasses&&this.element.addClass("ui-droppable")},destroy:function(){var b=a.ui.ddmanager.droppables[this.options.scope];for(var c=0;c<b.length;c++)b[c]==this&&b.splice(c,1);this.element.removeClass("ui-droppable ui-droppable-disabled").removeData("droppable").unbind(".droppable");return this},_setOption:function(b,c){b=="accept"&&(this.accept=a.isFunction(c)?c:function(a){return a.is(c)}),a.Widget.prototype._setOption.apply(this,arguments)},_activate:function(b){var c=a.ui.ddmanager.current;this.options.activeClass&&this.element.addClass(this.options.activeClass),c&&this._trigger("activate",b,this.ui(c))},_deactivate:function(b){var c=a.ui.ddmanager.current;this.options.activeClass&&this.element.removeClass(this.options.activeClass),c&&this._trigger("deactivate",b,this.ui(c))},_over:function(b){var c=a.ui.ddmanager.current;!!c&&(c.currentItem||c.element)[0]!=this.element[0]&&this.accept.call(this.element[0],c.currentItem||c.element)&&(this.options.hoverClass&&this.element.addClass(this.options.hoverClass),this._trigger("over",b,this.ui(c)))},_out:function(b){var c=a.ui.ddmanager.current;!!c&&(c.currentItem||c.element)[0]!=this.element[0]&&this.accept.call(this.element[0],c.currentItem||c.element)&&(this.options.hoverClass&&this.element.removeClass(this.options.hoverClass),this._trigger("out",b,this.ui(c)))},_drop:function(b,c){var d=c||a.ui.ddmanager.current;if(!d||(d.currentItem||d.element)[0]==this.element[0])return!1;var e=!1;this.element.find(":data(droppable)").not(".ui-draggable-dragging").each(function(){var b=a.data(this,"droppable");if(b.options.greedy&&!b.options.disabled&&b.options.scope==d.options.scope&&b.accept.call(b.element[0],d.currentItem||d.element)&&a.ui.intersect(d,a.extend(b,{offset:b.element.offset()}),b.options.tolerance)){e=!0;return!1}});if(e)return!1;if(this.accept.call(this.element[0],d.currentItem||d.element)){this.options.activeClass&&this.element.removeClass(this.options.activeClass),this.options.hoverClass&&this.element.removeClass(this.options.hoverClass),this._trigger("drop",b,this.ui(d));return this.element}return!1},ui:function(a){return{draggable:a.currentItem||a.element,helper:a.helper,position:a.position,offset:a.positionAbs}}}),a.extend(a.ui.droppable,{version:"1.8.18"}),a.ui.intersect=function(b,c,d){if(!c.offset)return!1;var e=(b.positionAbs||b.position.absolute).left,f=e+b.helperProportions.width,g=(b.positionAbs||b.position.absolute).top,h=g+b.helperProportions.height,i=c.offset.left,j=i+c.proportions.width,k=c.offset.top,l=k+c.proportions.height;switch(d){case"fit":return i<=e&&f<=j&&k<=g&&h<=l;case"intersect":return i<e+b.helperProportions.width/2&&f-b.helperProportions.width/2<j&&k<g+b.helperProportions.height/2&&h-b.helperProportions.height/2<l;case"pointer":var m=(b.positionAbs||b.position.absolute).left+(b.clickOffset||b.offset.click).left,n=(b.positionAbs||b.position.absolute).top+(b.clickOffset||b.offset.click).top,o=a.ui.isOver(n,m,k,i,c.proportions.height,c.proportions.width);return o;case"touch":return(g>=k&&g<=l||h>=k&&h<=l||g<k&&h>l)&&(e>=i&&e<=j||f>=i&&f<=j||e<i&&f>j);default:return!1}},a.ui.ddmanager={current:null,droppables:{"default":[]},prepareOffsets:function(b,c){var d=a.ui.ddmanager.droppables[b.options.scope]||[],e=c?c.type:null,f=(b.currentItem||b.element).find(":data(droppable)").andSelf();droppablesLoop:for(var g=0;g<d.length;g++){if(d[g].options.disabled||b&&!d[g].accept.call(d[g].element[0],b.currentItem||b.element))continue;for(var h=0;h<f.length;h++)if(f[h]==d[g].element[0]){d[g].proportions.height=0;continue droppablesLoop}d[g].v
|
|||
|
+ * jQuery UI Resizable 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Resizables
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.ui.core.js
|
|||
|
+ * jquery.ui.mouse.js
|
|||
|
+ * jquery.ui.widget.js
|
|||
|
+ */(function(a,b){a.widget("ui.resizable",a.ui.mouse,{widgetEventPrefix:"resize",options:{alsoResize:!1,animate:!1,animateDuration:"slow",animateEasing:"swing",aspectRatio:!1,autoHide:!1,containment:!1,ghost:!1,grid:!1,handles:"e,s,se",helper:!1,maxHeight:null,maxWidth:null,minHeight:10,minWidth:10,zIndex:1e3},_create:function(){var b=this,c=this.options;this.element.addClass("ui-resizable"),a.extend(this,{_aspectRatio:!!c.aspectRatio,aspectRatio:c.aspectRatio,originalElement:this.element,_proportionallyResizeElements:[],_helper:c.helper||c.ghost||c.animate?c.helper||"ui-resizable-helper":null}),this.element[0].nodeName.match(/canvas|textarea|input|select|button|img/i)&&(this.element.wrap(a('<div class="ui-wrapper" style="overflow: hidden;"></div>').css({position:this.element.css("position"),width:this.element.outerWidth(),height:this.element.outerHeight(),top:this.element.css("top"),left:this.element.css("left")})),this.element=this.element.parent().data("resizable",this.element.data("resizable")),this.elementIsWrapper=!0,this.element.css({marginLeft:this.originalElement.css("marginLeft"),marginTop:this.originalElement.css("marginTop"),marginRight:this.originalElement.css("marginRight"),marginBottom:this.originalElement.css("marginBottom")}),this.originalElement.css({marginLeft:0,marginTop:0,marginRight:0,marginBottom:0}),this.originalResizeStyle=this.originalElement.css("resize"),this.originalElement.css("resize","none"),this._proportionallyResizeElements.push(this.originalElement.css({position:"static",zoom:1,display:"block"})),this.originalElement.css({margin:this.originalElement.css("margin")}),this._proportionallyResize()),this.handles=c.handles||(a(".ui-resizable-handle",this.element).length?{n:".ui-resizable-n",e:".ui-resizable-e",s:".ui-resizable-s",w:".ui-resizable-w",se:".ui-resizable-se",sw:".ui-resizable-sw",ne:".ui-resizable-ne",nw:".ui-resizable-nw"}:"e,s,se");if(this.handles.constructor==String){this.handles=="all"&&(this.handles="n,e,s,w,se,sw,ne,nw");var d=this.handles.split(",");this.handles={};for(var e=0;e<d.length;e++){var f=a.trim(d[e]),g="ui-resizable-"+f,h=a('<div class="ui-resizable-handle '+g+'"></div>');/sw|se|ne|nw/.test(f)&&h.css({zIndex:++c.zIndex}),"se"==f&&h.addClass("ui-icon ui-icon-gripsmall-diagonal-se"),this.handles[f]=".ui-resizable-"+f,this.element.append(h)}}this._renderAxis=function(b){b=b||this.element;for(var c in this.handles){this.handles[c].constructor==String&&(this.handles[c]=a(this.handles[c],this.element).show());if(this.elementIsWrapper&&this.originalElement[0].nodeName.match(/textarea|input|select|button/i)){var d=a(this.handles[c],this.element),e=0;e=/sw|ne|nw|se|n|s/.test(c)?d.outerHeight():d.outerWidth();var f=["padding",/ne|nw|n/.test(c)?"Top":/se|sw|s/.test(c)?"Bottom":/^e$/.test(c)?"Right":"Left"].join("");b.css(f,e),this._proportionallyResize()}if(!a(this.handles[c]).length)continue}},this._renderAxis(this.element),this._handles=a(".ui-resizable-handle",this.element).disableSelection(),this._handles.mouseover(function(){if(!b.resizing){if(this.className)var a=this.className.match(/ui-resizable-(se|sw|ne|nw|n|e|s|w)/i);b.axis=a&&a[1]?a[1]:"se"}}),c.autoHide&&(this._handles.hide(),a(this.element).addClass("ui-resizable-autohide").hover(function(){c.disabled||(a(this).removeClass("ui-resizable-autohide"),b._handles.show())},function(){c.disabled||b.resizing||(a(this).addClass("ui-resizable-autohide"),b._handles.hide())})),this._mouseInit()},destroy:function(){this._mouseDestroy();var b=function(b){a(b).removeClass("ui-resizable ui-resizable-disabled ui-resizable-resizing").removeData("resizable").unbind(".resizable").find(".ui-resizable-handle").remove()};if(this.elementIsWrapper){b(this.element);var c=this.element;c.after(this.originalElement.css({position:c.css("position"),width:c.outerWidth(),height:c.outerHeight(),top:c.css("top"),left:c.css("left")})).remove()}this.originalElement.css("resize",this.originalResizeStyle),b(this.originalElement);return this},_mouseCapture:function(b){var c=!1;for(var d in this.handles)a(this.handles[d])[0]==b.target&&(c=!0);retu
|
|||
|
+ * jQuery UI Selectable 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Selectables
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.ui.core.js
|
|||
|
+ * jquery.ui.mouse.js
|
|||
|
+ * jquery.ui.widget.js
|
|||
|
+ */(function(a,b){a.widget("ui.selectable",a.ui.mouse,{options:{appendTo:"body",autoRefresh:!0,distance:0,filter:"*",tolerance:"touch"},_create:function(){var b=this;this.element.addClass("ui-selectable"),this.dragged=!1;var c;this.refresh=function(){c=a(b.options.filter,b.element[0]),c.addClass("ui-selectee"),c.each(function(){var b=a(this),c=b.offset();a.data(this,"selectable-item",{element:this,$element:b,left:c.left,top:c.top,right:c.left+b.outerWidth(),bottom:c.top+b.outerHeight(),startselected:!1,selected:b.hasClass("ui-selected"),selecting:b.hasClass("ui-selecting"),unselecting:b.hasClass("ui-unselecting")})})},this.refresh(),this.selectees=c.addClass("ui-selectee"),this._mouseInit(),this.helper=a("<div class='ui-selectable-helper'></div>")},destroy:function(){this.selectees.removeClass("ui-selectee").removeData("selectable-item"),this.element.removeClass("ui-selectable ui-selectable-disabled").removeData("selectable").unbind(".selectable"),this._mouseDestroy();return this},_mouseStart:function(b){var c=this;this.opos=[b.pageX,b.pageY];if(!this.options.disabled){var d=this.options;this.selectees=a(d.filter,this.element[0]),this._trigger("start",b),a(d.appendTo).append(this.helper),this.helper.css({left:b.clientX,top:b.clientY,width:0,height:0}),d.autoRefresh&&this.refresh(),this.selectees.filter(".ui-selected").each(function(){var d=a.data(this,"selectable-item");d.startselected=!0,!b.metaKey&&!b.ctrlKey&&(d.$element.removeClass("ui-selected"),d.selected=!1,d.$element.addClass("ui-unselecting"),d.unselecting=!0,c._trigger("unselecting",b,{unselecting:d.element}))}),a(b.target).parents().andSelf().each(function(){var d=a.data(this,"selectable-item");if(d){var e=!b.metaKey&&!b.ctrlKey||!d.$element.hasClass("ui-selected");d.$element.removeClass(e?"ui-unselecting":"ui-selected").addClass(e?"ui-selecting":"ui-unselecting"),d.unselecting=!e,d.selecting=e,d.selected=e,e?c._trigger("selecting",b,{selecting:d.element}):c._trigger("unselecting",b,{unselecting:d.element});return!1}})}},_mouseDrag:function(b){var c=this;this.dragged=!0;if(!this.options.disabled){var d=this.options,e=this.opos[0],f=this.opos[1],g=b.pageX,h=b.pageY;if(e>g){var i=g;g=e,e=i}if(f>h){var i=h;h=f,f=i}this.helper.css({left:e,top:f,width:g-e,height:h-f}),this.selectees.each(function(){var i=a.data(this,"selectable-item");if(!!i&&i.element!=c.element[0]){var j=!1;d.tolerance=="touch"?j=!(i.left>g||i.right<e||i.top>h||i.bottom<f):d.tolerance=="fit"&&(j=i.left>e&&i.right<g&&i.top>f&&i.bottom<h),j?(i.selected&&(i.$element.removeClass("ui-selected"),i.selected=!1),i.unselecting&&(i.$element.removeClass("ui-unselecting"),i.unselecting=!1),i.selecting||(i.$element.addClass("ui-selecting"),i.selecting=!0,c._trigger("selecting",b,{selecting:i.element}))):(i.selecting&&((b.metaKey||b.ctrlKey)&&i.startselected?(i.$element.removeClass("ui-selecting"),i.selecting=!1,i.$element.addClass("ui-selected"),i.selected=!0):(i.$element.removeClass("ui-selecting"),i.selecting=!1,i.startselected&&(i.$element.addClass("ui-unselecting"),i.unselecting=!0),c._trigger("unselecting",b,{unselecting:i.element}))),i.selected&&!b.metaKey&&!b.ctrlKey&&!i.startselected&&(i.$element.removeClass("ui-selected"),i.selected=!1,i.$element.addClass("ui-unselecting"),i.unselecting=!0,c._trigger("unselecting",b,{unselecting:i.element})))}});return!1}},_mouseStop:function(b){var c=this;this.dragged=!1;var d=this.options;a(".ui-unselecting",this.element[0]).each(function(){var d=a.data(this,"selectable-item");d.$element.removeClass("ui-unselecting"),d.unselecting=!1,d.startselected=!1,c._trigger("unselected",b,{unselected:d.element})}),a(".ui-selecting",this.element[0]).each(function(){var d=a.data(this,"selectable-item");d.$element.removeClass("ui-selecting").addClass("ui-selected"),d.selecting=!1,d.selected=!0,d.startselected=!0,c._trigger("selected",b,{selected:d.element})}),this._trigger("stop",b),this.helper.remove();return!1}}),a.extend(a.ui.selectable,{version:"1.8.18"})})(jQuery);/*
|
|||
|
+ * jQuery UI Sortable 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Sortables
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.ui.core.js
|
|||
|
+ * jquery.ui.mouse.js
|
|||
|
+ * jquery.ui.widget.js
|
|||
|
+ */(function(a,b){a.widget("ui.sortable",a.ui.mouse,{widgetEventPrefix:"sort",ready:!1,options:{appendTo:"parent",axis:!1,connectWith:!1,containment:!1,cursor:"auto",cursorAt:!1,dropOnEmpty:!0,forcePlaceholderSize:!1,forceHelperSize:!1,grid:!1,handle:!1,helper:"original",items:"> *",opacity:!1,placeholder:!1,revert:!1,scroll:!0,scrollSensitivity:20,scrollSpeed:20,scope:"default",tolerance:"intersect",zIndex:1e3},_create:function(){var a=this.options;this.containerCache={},this.element.addClass("ui-sortable"),this.refresh(),this.floating=this.items.length?a.axis==="x"||/left|right/.test(this.items[0].item.css("float"))||/inline|table-cell/.test(this.items[0].item.css("display")):!1,this.offset=this.element.offset(),this._mouseInit(),this.ready=!0},destroy:function(){a.Widget.prototype.destroy.call(this),this.element.removeClass("ui-sortable ui-sortable-disabled"),this._mouseDestroy();for(var b=this.items.length-1;b>=0;b--)this.items[b].item.removeData(this.widgetName+"-item");return this},_setOption:function(b,c){b==="disabled"?(this.options[b]=c,this.widget()[c?"addClass":"removeClass"]("ui-sortable-disabled")):a.Widget.prototype._setOption.apply(this,arguments)},_mouseCapture:function(b,c){var d=this;if(this.reverting)return!1;if(this.options.disabled||this.options.type=="static")return!1;this._refreshItems(b);var e=null,f=this,g=a(b.target).parents().each(function(){if(a.data(this,d.widgetName+"-item")==f){e=a(this);return!1}});a.data(b.target,d.widgetName+"-item")==f&&(e=a(b.target));if(!e)return!1;if(this.options.handle&&!c){var h=!1;a(this.options.handle,e).find("*").andSelf().each(function(){this==b.target&&(h=!0)});if(!h)return!1}this.currentItem=e,this._removeCurrentsFromItems();return!0},_mouseStart:function(b,c,d){var e=this.options,f=this;this.currentContainer=this,this.refreshPositions(),this.helper=this._createHelper(b),this._cacheHelperProportions(),this._cacheMargins(),this.scrollParent=this.helper.scrollParent(),this.offset=this.currentItem.offset(),this.offset={top:this.offset.top-this.margins.top,left:this.offset.left-this.margins.left},this.helper.css("position","absolute"),this.cssPosition=this.helper.css("position"),a.extend(this.offset,{click:{left:b.pageX-this.offset.left,top:b.pageY-this.offset.top},parent:this._getParentOffset(),relative:this._getRelativeOffset()}),this.originalPosition=this._generatePosition(b),this.originalPageX=b.pageX,this.originalPageY=b.pageY,e.cursorAt&&this._adjustOffsetFromHelper(e.cursorAt),this.domPosition={prev:this.currentItem.prev()[0],parent:this.currentItem.parent()[0]},this.helper[0]!=this.currentItem[0]&&this.currentItem.hide(),this._createPlaceholder(),e.containment&&this._setContainment(),e.cursor&&(a("body").css("cursor")&&(this._storedCursor=a("body").css("cursor")),a("body").css("cursor",e.cursor)),e.opacity&&(this.helper.css("opacity")&&(this._storedOpacity=this.helper.css("opacity")),this.helper.css("opacity",e.opacity)),e.zIndex&&(this.helper.css("zIndex")&&(this._storedZIndex=this.helper.css("zIndex")),this.helper.css("zIndex",e.zIndex)),this.scrollParent[0]!=document&&this.scrollParent[0].tagName!="HTML"&&(this.overflowOffset=this.scrollParent.offset()),this._trigger("start",b,this._uiHash()),this._preserveHelperProportions||this._cacheHelperProportions();if(!d)for(var g=this.containers.length-1;g>=0;g--)this.containers[g]._trigger("activate",b,f._uiHash(this));a.ui.ddmanager&&(a.ui.ddmanager.current=this),a.ui.ddmanager&&!e.dropBehaviour&&a.ui.ddmanager.prepareOffsets(this,b),this.dragging=!0,this.helper.addClass("ui-sortable-helper"),this._mouseDrag(b);return!0},_mouseDrag:function(b){this.position=this._generatePosition(b),this.positionAbs=this._convertPositionTo("absolute"),this.lastPositionAbs||(this.lastPositionAbs=this.positionAbs);if(this.options.scroll){var c=this.options,d=!1;this.scrollParent[0]!=document&&this.scrollParent[0].tagName!="HTML"?(this.overflowOffset.top+this.scrollParent[0].offsetHeight-b.pageY<c.scrollSensitivity?this.scrollParent[0].scrollTop=d=this.scrollParent[0].scrollTop+c.scrollSpeed:b.pageY-this.overflowOffset.top<c.s
|
|||
|
+ * jQuery UI Accordion 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Accordion
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.ui.core.js
|
|||
|
+ * jquery.ui.widget.js
|
|||
|
+ */(function(a,b){a.widget("ui.accordion",{options:{active:0,animated:"slide",autoHeight:!0,clearStyle:!1,collapsible:!1,event:"click",fillSpace:!1,header:"> li > :first-child,> :not(li):even",icons:{header:"ui-icon-triangle-1-e",headerSelected:"ui-icon-triangle-1-s"},navigation:!1,navigationFilter:function(){return this.href.toLowerCase()===location.href.toLowerCase()}},_create:function(){var b=this,c=b.options;b.running=0,b.element.addClass("ui-accordion ui-widget ui-helper-reset").children("li").addClass("ui-accordion-li-fix"),b.headers=b.element.find(c.header).addClass("ui-accordion-header ui-helper-reset ui-state-default ui-corner-all").bind("mouseenter.accordion",function(){c.disabled||a(this).addClass("ui-state-hover")}).bind("mouseleave.accordion",function(){c.disabled||a(this).removeClass("ui-state-hover")}).bind("focus.accordion",function(){c.disabled||a(this).addClass("ui-state-focus")}).bind("blur.accordion",function(){c.disabled||a(this).removeClass("ui-state-focus")}),b.headers.next().addClass("ui-accordion-content ui-helper-reset ui-widget-content ui-corner-bottom");if(c.navigation){var d=b.element.find("a").filter(c.navigationFilter).eq(0);if(d.length){var e=d.closest(".ui-accordion-header");e.length?b.active=e:b.active=d.closest(".ui-accordion-content").prev()}}b.active=b._findActive(b.active||c.active).addClass("ui-state-default ui-state-active").toggleClass("ui-corner-all").toggleClass("ui-corner-top"),b.active.next().addClass("ui-accordion-content-active"),b._createIcons(),b.resize(),b.element.attr("role","tablist"),b.headers.attr("role","tab").bind("keydown.accordion",function(a){return b._keydown(a)}).next().attr("role","tabpanel"),b.headers.not(b.active||"").attr({"aria-expanded":"false","aria-selected":"false",tabIndex:-1}).next().hide(),b.active.length?b.active.attr({"aria-expanded":"true","aria-selected":"true",tabIndex:0}):b.headers.eq(0).attr("tabIndex",0),a.browser.safari||b.headers.find("a").attr("tabIndex",-1),c.event&&b.headers.bind(c.event.split(" ").join(".accordion ")+".accordion",function(a){b._clickHandler.call(b,a,this),a.preventDefault()})},_createIcons:function(){var b=this.options;b.icons&&(a("<span></span>").addClass("ui-icon "+b.icons.header).prependTo(this.headers),this.active.children(".ui-icon").toggleClass(b.icons.header).toggleClass(b.icons.headerSelected),this.element.addClass("ui-accordion-icons"))},_destroyIcons:function(){this.headers.children(".ui-icon").remove(),this.element.removeClass("ui-accordion-icons")},destroy:function(){var b=this.options;this.element.removeClass("ui-accordion ui-widget ui-helper-reset").removeAttr("role"),this.headers.unbind(".accordion").removeClass("ui-accordion-header ui-accordion-disabled ui-helper-reset ui-state-default ui-corner-all ui-state-active ui-state-disabled ui-corner-top").removeAttr("role").removeAttr("aria-expanded").removeAttr("aria-selected").removeAttr("tabIndex"),this.headers.find("a").removeAttr("tabIndex"),this._destroyIcons();var c=this.headers.next().css("display","").removeAttr("role").removeClass("ui-helper-reset ui-widget-content ui-corner-bottom ui-accordion-content ui-accordion-content-active ui-accordion-disabled ui-state-disabled");(b.autoHeight||b.fillHeight)&&c.css("height","");return a.Widget.prototype.destroy.call(this)},_setOption:function(b,c){a.Widget.prototype._setOption.apply(this,arguments),b=="active"&&this.activate(c),b=="icons"&&(this._destroyIcons(),c&&this._createIcons()),b=="disabled"&&this.headers.add(this.headers.next())[c?"addClass":"removeClass"]("ui-accordion-disabled ui-state-disabled")},_keydown:function(b){if(!(this.options.disabled||b.altKey||b.ctrlKey)){var c=a.ui.keyCode,d=this.headers.length,e=this.headers.index(b.target),f=!1;switch(b.keyCode){case c.RIGHT:case c.DOWN:f=this.headers[(e+1)%d];break;case c.LEFT:case c.UP:f=this.headers[(e-1+d)%d];break;case c.SPACE:case c.ENTER:this._clickHandler({target:b.target},b.target),b.preventDefault()}if(f){a(b.target).attr("tabIndex",-1),a(f).attr("tabIndex",0),f.focus();return!1}return!0}},resize:function(){var b=this.options,c;if(b.fillSp
|
|||
|
+ * jQuery UI Autocomplete 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Autocomplete
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.ui.core.js
|
|||
|
+ * jquery.ui.widget.js
|
|||
|
+ * jquery.ui.position.js
|
|||
|
+ */(function(a,b){var c=0;a.widget("ui.autocomplete",{options:{appendTo:"body",autoFocus:!1,delay:300,minLength:1,position:{my:"left top",at:"left bottom",collision:"none"},source:null},pending:0,_create:function(){var b=this,c=this.element[0].ownerDocument,d;this.element.addClass("ui-autocomplete-input").attr("autocomplete","off").attr({role:"textbox","aria-autocomplete":"list","aria-haspopup":"true"}).bind("keydown.autocomplete",function(c){if(!b.options.disabled&&!b.element.propAttr("readOnly")){d=!1;var e=a.ui.keyCode;switch(c.keyCode){case e.PAGE_UP:b._move("previousPage",c);break;case e.PAGE_DOWN:b._move("nextPage",c);break;case e.UP:b._move("previous",c),c.preventDefault();break;case e.DOWN:b._move("next",c),c.preventDefault();break;case e.ENTER:case e.NUMPAD_ENTER:b.menu.active&&(d=!0,c.preventDefault());case e.TAB:if(!b.menu.active)return;b.menu.select(c);break;case e.ESCAPE:b.element.val(b.term),b.close(c);break;default:clearTimeout(b.searching),b.searching=setTimeout(function(){b.term!=b.element.val()&&(b.selectedItem=null,b.search(null,c))},b.options.delay)}}}).bind("keypress.autocomplete",function(a){d&&(d=!1,a.preventDefault())}).bind("focus.autocomplete",function(){b.options.disabled||(b.selectedItem=null,b.previous=b.element.val())}).bind("blur.autocomplete",function(a){b.options.disabled||(clearTimeout(b.searching),b.closing=setTimeout(function(){b.close(a),b._change(a)},150))}),this._initSource(),this.response=function(){return b._response.apply(b,arguments)},this.menu=a("<ul></ul>").addClass("ui-autocomplete").appendTo(a(this.options.appendTo||"body",c)[0]).mousedown(function(c){var d=b.menu.element[0];a(c.target).closest(".ui-menu-item").length||setTimeout(function(){a(document).one("mousedown",function(c){c.target!==b.element[0]&&c.target!==d&&!a.ui.contains(d,c.target)&&b.close()})},1),setTimeout(function(){clearTimeout(b.closing)},13)}).menu({focus:function(a,c){var d=c.item.data("item.autocomplete");!1!==b._trigger("focus",a,{item:d})&&/^key/.test(a.originalEvent.type)&&b.element.val(d.value)},selected:function(a,d){var e=d.item.data("item.autocomplete"),f=b.previous;b.element[0]!==c.activeElement&&(b.element.focus(),b.previous=f,setTimeout(function(){b.previous=f,b.selectedItem=e},1)),!1!==b._trigger("select",a,{item:e})&&b.element.val(e.value),b.term=b.element.val(),b.close(a),b.selectedItem=e},blur:function(a,c){b.menu.element.is(":visible")&&b.element.val()!==b.term&&b.element.val(b.term)}}).zIndex(this.element.zIndex()+1).css({top:0,left:0}).hide().data("menu"),a.fn.bgiframe&&this.menu.element.bgiframe(),b.beforeunloadHandler=function(){b.element.removeAttr("autocomplete")},a(window).bind("beforeunload",b.beforeunloadHandler)},destroy:function(){this.element.removeClass("ui-autocomplete-input").removeAttr("autocomplete").removeAttr("role").removeAttr("aria-autocomplete").removeAttr("aria-haspopup"),this.menu.element.remove(),a(window).unbind("beforeunload",this.beforeunloadHandler),a.Widget.prototype.destroy.call(this)},_setOption:function(b,c){a.Widget.prototype._setOption.apply(this,arguments),b==="source"&&this._initSource(),b==="appendTo"&&this.menu.element.appendTo(a(c||"body",this.element[0].ownerDocument)[0]),b==="disabled"&&c&&this.xhr&&this.xhr.abort()},_initSource:function(){var b=this,d,e;a.isArray(this.options.source)?(d=this.options.source,this.source=function(b,c){c(a.ui.autocomplete.filter(d,b.term))}):typeof this.options.source=="string"?(e=this.options.source,this.source=function(d,f){b.xhr&&b.xhr.abort(),b.xhr=a.ajax({url:e,data:d,dataType:"json",context:{autocompleteRequest:++c},success:function(a,b){this.autocompleteRequest===c&&f(a)},error:function(){this.autocompleteRequest===c&&f([])}})}):this.source=this.options.source},search:function(a,b){a=a!=null?a:this.element.val(),this.term=this.element.val();if(a.length<this.options.minLength)return this.close(b);clearTimeout(this.closing);if(this._trigger("search",b)!==!1)return this._search(a)},_search:function(a){this.pending++,this.element.addClass("ui-autocomplete-loading"),this.source({term:a},this.response)},_response:
|
|||
|
+ * jQuery UI Button 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Button
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.ui.core.js
|
|||
|
+ * jquery.ui.widget.js
|
|||
|
+ */(function(a,b){var c,d,e,f,g="ui-button ui-widget ui-state-default ui-corner-all",h="ui-state-hover ui-state-active ",i="ui-button-icons-only ui-button-icon-only ui-button-text-icons ui-button-text-icon-primary ui-button-text-icon-secondary ui-button-text-only",j=function(){var b=a(this).find(":ui-button");setTimeout(function(){b.button("refresh")},1)},k=function(b){var c=b.name,d=b.form,e=a([]);c&&(d?e=a(d).find("[name='"+c+"']"):e=a("[name='"+c+"']",b.ownerDocument).filter(function(){return!this.form}));return e};a.widget("ui.button",{options:{disabled:null,text:!0,label:null,icons:{primary:null,secondary:null}},_create:function(){this.element.closest("form").unbind("reset.button").bind("reset.button",j),typeof this.options.disabled!="boolean"?this.options.disabled=!!this.element.propAttr("disabled"):this.element.propAttr("disabled",this.options.disabled),this._determineButtonType(),this.hasTitle=!!this.buttonElement.attr("title");var b=this,h=this.options,i=this.type==="checkbox"||this.type==="radio",l="ui-state-hover"+(i?"":" ui-state-active"),m="ui-state-focus";h.label===null&&(h.label=this.buttonElement.html()),this.buttonElement.addClass(g).attr("role","button").bind("mouseenter.button",function(){h.disabled||(a(this).addClass("ui-state-hover"),this===c&&a(this).addClass("ui-state-active"))}).bind("mouseleave.button",function(){h.disabled||a(this).removeClass(l)}).bind("click.button",function(a){h.disabled&&(a.preventDefault(),a.stopImmediatePropagation())}),this.element.bind("focus.button",function(){b.buttonElement.addClass(m)}).bind("blur.button",function(){b.buttonElement.removeClass(m)}),i&&(this.element.bind("change.button",function(){f||b.refresh()}),this.buttonElement.bind("mousedown.button",function(a){h.disabled||(f=!1,d=a.pageX,e=a.pageY)}).bind("mouseup.button",function(a){!h.disabled&&(d!==a.pageX||e!==a.pageY)&&(f=!0)})),this.type==="checkbox"?this.buttonElement.bind("click.button",function(){if(h.disabled||f)return!1;a(this).toggleClass("ui-state-active"),b.buttonElement.attr("aria-pressed",b.element[0].checked)}):this.type==="radio"?this.buttonElement.bind("click.button",function(){if(h.disabled||f)return!1;a(this).addClass("ui-state-active"),b.buttonElement.attr("aria-pressed","true");var c=b.element[0];k(c).not(c).map(function(){return a(this).button("widget")[0]}).removeClass("ui-state-active").attr("aria-pressed","false")}):(this.buttonElement.bind("mousedown.button",function(){if(h.disabled)return!1;a(this).addClass("ui-state-active"),c=this,a(document).one("mouseup",function(){c=null})}).bind("mouseup.button",function(){if(h.disabled)return!1;a(this).removeClass("ui-state-active")}).bind("keydown.button",function(b){if(h.disabled)return!1;(b.keyCode==a.ui.keyCode.SPACE||b.keyCode==a.ui.keyCode.ENTER)&&a(this).addClass("ui-state-active")}).bind("keyup.button",function(){a(this).removeClass("ui-state-active")}),this.buttonElement.is("a")&&this.buttonElement.keyup(function(b){b.keyCode===a.ui.keyCode.SPACE&&a(this).click()})),this._setOption("disabled",h.disabled),this._resetButton()},_determineButtonType:function(){this.element.is(":checkbox")?this.type="checkbox":this.element.is(":radio")?this.type="radio":this.element.is("input")?this.type="input":this.type="button";if(this.type==="checkbox"||this.type==="radio"){var a=this.element.parents().filter(":last"),b="label[for='"+this.element.attr("id")+"']";this.buttonElement=a.find(b),this.buttonElement.length||(a=a.length?a.siblings():this.element.siblings(),this.buttonElement=a.filter(b),this.buttonElement.length||(this.buttonElement=a.find(b))),this.element.addClass("ui-helper-hidden-accessible");var c=this.element.is(":checked");c&&this.buttonElement.addClass("ui-state-active"),this.buttonElement.attr("aria-pressed",c)}else this.buttonElement=this.element},widget:function(){return this.buttonElement},destroy:function(){this.element.removeClass("ui-helper-hidden-accessible"),this.buttonElement.removeClass(g+" "+h+" "+i).removeAttr("role").removeAttr("aria-pressed").html(this.buttonElement.find(".ui-button-text").html()),this.hasTitle||this
|
|||
|
+ * jQuery UI Dialog 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Dialog
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.ui.core.js
|
|||
|
+ * jquery.ui.widget.js
|
|||
|
+ * jquery.ui.button.js
|
|||
|
+ * jquery.ui.draggable.js
|
|||
|
+ * jquery.ui.mouse.js
|
|||
|
+ * jquery.ui.position.js
|
|||
|
+ * jquery.ui.resizable.js
|
|||
|
+ */(function(a,b){var c="ui-dialog ui-widget ui-widget-content ui-corner-all ",d={buttons:!0,height:!0,maxHeight:!0,maxWidth:!0,minHeight:!0,minWidth:!0,width:!0},e={maxHeight:!0,maxWidth:!0,minHeight:!0,minWidth:!0},f=a.attrFn||{val:!0,css:!0,html:!0,text:!0,data:!0,width:!0,height:!0,offset:!0,click:!0};a.widget("ui.dialog",{options:{autoOpen:!0,buttons:{},closeOnEscape:!0,closeText:"close",dialogClass:"",draggable:!0,hide:null,height:"auto",maxHeight:!1,maxWidth:!1,minHeight:150,minWidth:150,modal:!1,position:{my:"center",at:"center",collision:"fit",using:function(b){var c=a(this).css(b).offset().top;c<0&&a(this).css("top",b.top-c)}},resizable:!0,show:null,stack:!0,title:"",width:300,zIndex:1e3},_create:function(){this.originalTitle=this.element.attr("title"),typeof this.originalTitle!="string"&&(this.originalTitle=""),this.options.title=this.options.title||this.originalTitle;var b=this,d=b.options,e=d.title||" ",f=a.ui.dialog.getTitleId(b.element),g=(b.uiDialog=a("<div></div>")).appendTo(document.body).hide().addClass(c+d.dialogClass).css({zIndex:d.zIndex}).attr("tabIndex",-1).css("outline",0).keydown(function(c){d.closeOnEscape&&!c.isDefaultPrevented()&&c.keyCode&&c.keyCode===a.ui.keyCode.ESCAPE&&(b.close(c),c.preventDefault())}).attr({role:"dialog","aria-labelledby":f}).mousedown(function(a){b.moveToTop(!1,a)}),h=b.element.show().removeAttr("title").addClass("ui-dialog-content ui-widget-content").appendTo(g),i=(b.uiDialogTitlebar=a("<div></div>")).addClass("ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix").prependTo(g),j=a('<a href="#"></a>').addClass("ui-dialog-titlebar-close ui-corner-all").attr("role","button").hover(function(){j.addClass("ui-state-hover")},function(){j.removeClass("ui-state-hover")}).focus(function(){j.addClass("ui-state-focus")}).blur(function(){j.removeClass("ui-state-focus")}).click(function(a){b.close(a);return!1}).appendTo(i),k=(b.uiDialogTitlebarCloseText=a("<span></span>")).addClass("ui-icon ui-icon-closethick").text(d.closeText).appendTo(j),l=a("<span></span>").addClass("ui-dialog-title").attr("id",f).html(e).prependTo(i);a.isFunction(d.beforeclose)&&!a.isFunction(d.beforeClose)&&(d.beforeClose=d.beforeclose),i.find("*").add(i).disableSelection(),d.draggable&&a.fn.draggable&&b._makeDraggable(),d.resizable&&a.fn.resizable&&b._makeResizable(),b._createButtons(d.buttons),b._isOpen=!1,a.fn.bgiframe&&g.bgiframe()},_init:function(){this.options.autoOpen&&this.open()},destroy:function(){var a=this;a.overlay&&a.overlay.destroy(),a.uiDialog.hide(),a.element.unbind(".dialog").removeData("dialog").removeClass("ui-dialog-content ui-widget-content").hide().appendTo("body"),a.uiDialog.remove(),a.originalTitle&&a.element.attr("title",a.originalTitle);return a},widget:function(){return this.uiDialog},close:function(b){var c=this,d,e;if(!1!==c._trigger("beforeClose",b)){c.overlay&&c.overlay.destroy(),c.uiDialog.unbind("keypress.ui-dialog"),c._isOpen=!1,c.options.hide?c.uiDialog.hide(c.options.hide,function(){c._trigger("close",b)}):(c.uiDialog.hide(),c._trigger("close",b)),a.ui.dialog.overlay.resize(),c.options.modal&&(d=0,a(".ui-dialog").each(function(){this!==c.uiDialog[0]&&(e=a(this).css("z-index"),isNaN(e)||(d=Math.max(d,e)))}),a.ui.dialog.maxZ=d);return c}},isOpen:function(){return this._isOpen},moveToTop:function(b,c){var d=this,e=d.options,f;if(e.modal&&!b||!e.stack&&!e.modal)return d._trigger("focus",c);e.zIndex>a.ui.dialog.maxZ&&(a.ui.dialog.maxZ=e.zIndex),d.overlay&&(a.ui.dialog.maxZ+=1,d.overlay.$el.css("z-index",a.ui.dialog.overlay.maxZ=a.ui.dialog.maxZ)),f={scrollTop:d.element.scrollTop(),scrollLeft:d.element.scrollLeft()},a.ui.dialog.maxZ+=1,d.uiDialog.css("z-index",a.ui.dialog.maxZ),d.element.attr(f),d._trigger("focus",c);return d},open:function(){if(!this._isOpen){var b=this,c=b.options,d=b.uiDialog;b.overlay=c.modal?new a.ui.dialog.overlay(b):null,b._size(),b._position(c.position),d.show(c.show),b.moveToTop(!0),c.modal&&d.bind("keydown.ui-dialog",function(b){if(b.keyCode===a.ui.keyCode.TAB){var c=a(":tabbable",this),d=c.filter(":first"),e=c.filter(":last");if
|
|||
|
+ * jQuery UI Slider 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Slider
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.ui.core.js
|
|||
|
+ * jquery.ui.mouse.js
|
|||
|
+ * jquery.ui.widget.js
|
|||
|
+ */(function(a,b){var c=5;a.widget("ui.slider",a.ui.mouse,{widgetEventPrefix:"slide",options:{animate:!1,distance:0,max:100,min:0,orientation:"horizontal",range:!1,step:1,value:0,values:null},_create:function(){var b=this,d=this.options,e=this.element.find(".ui-slider-handle").addClass("ui-state-default ui-corner-all"),f="<a class='ui-slider-handle ui-state-default ui-corner-all' href='#'></a>",g=d.values&&d.values.length||1,h=[];this._keySliding=!1,this._mouseSliding=!1,this._animateOff=!0,this._handleIndex=null,this._detectOrientation(),this._mouseInit(),this.element.addClass("ui-slider ui-slider-"+this.orientation+" ui-widget"+" ui-widget-content"+" ui-corner-all"+(d.disabled?" ui-slider-disabled ui-disabled":"")),this.range=a([]),d.range&&(d.range===!0&&(d.values||(d.values=[this._valueMin(),this._valueMin()]),d.values.length&&d.values.length!==2&&(d.values=[d.values[0],d.values[0]])),this.range=a("<div></div>").appendTo(this.element).addClass("ui-slider-range ui-widget-header"+(d.range==="min"||d.range==="max"?" ui-slider-range-"+d.range:"")));for(var i=e.length;i<g;i+=1)h.push(f);this.handles=e.add(a(h.join("")).appendTo(b.element)),this.handle=this.handles.eq(0),this.handles.add(this.range).filter("a").click(function(a){a.preventDefault()}).hover(function(){d.disabled||a(this).addClass("ui-state-hover")},function(){a(this).removeClass("ui-state-hover")}).focus(function(){d.disabled?a(this).blur():(a(".ui-slider .ui-state-focus").removeClass("ui-state-focus"),a(this).addClass("ui-state-focus"))}).blur(function(){a(this).removeClass("ui-state-focus")}),this.handles.each(function(b){a(this).data("index.ui-slider-handle",b)}),this.handles.keydown(function(d){var e=a(this).data("index.ui-slider-handle"),f,g,h,i;if(!b.options.disabled){switch(d.keyCode){case a.ui.keyCode.HOME:case a.ui.keyCode.END:case a.ui.keyCode.PAGE_UP:case a.ui.keyCode.PAGE_DOWN:case a.ui.keyCode.UP:case a.ui.keyCode.RIGHT:case a.ui.keyCode.DOWN:case a.ui.keyCode.LEFT:d.preventDefault();if(!b._keySliding){b._keySliding=!0,a(this).addClass("ui-state-active"),f=b._start(d,e);if(f===!1)return}}i=b.options.step,b.options.values&&b.options.values.length?g=h=b.values(e):g=h=b.value();switch(d.keyCode){case a.ui.keyCode.HOME:h=b._valueMin();break;case a.ui.keyCode.END:h=b._valueMax();break;case a.ui.keyCode.PAGE_UP:h=b._trimAlignValue(g+(b._valueMax()-b._valueMin())/c);break;case a.ui.keyCode.PAGE_DOWN:h=b._trimAlignValue(g-(b._valueMax()-b._valueMin())/c);break;case a.ui.keyCode.UP:case a.ui.keyCode.RIGHT:if(g===b._valueMax())return;h=b._trimAlignValue(g+i);break;case a.ui.keyCode.DOWN:case a.ui.keyCode.LEFT:if(g===b._valueMin())return;h=b._trimAlignValue(g-i)}b._slide(d,e,h)}}).keyup(function(c){var d=a(this).data("index.ui-slider-handle");b._keySliding&&(b._keySliding=!1,b._stop(c,d),b._change(c,d),a(this).removeClass("ui-state-active"))}),this._refreshValue(),this._animateOff=!1},destroy:function(){this.handles.remove(),this.range.remove(),this.element.removeClass("ui-slider ui-slider-horizontal ui-slider-vertical ui-slider-disabled ui-widget ui-widget-content ui-corner-all").removeData("slider").unbind(".slider"),this._mouseDestroy();return this},_mouseCapture:function(b){var c=this.options,d,e,f,g,h,i,j,k,l;if(c.disabled)return!1;this.elementSize={width:this.element.outerWidth(),height:this.element.outerHeight()},this.elementOffset=this.element.offset(),d={x:b.pageX,y:b.pageY},e=this._normValueFromMouse(d),f=this._valueMax()-this._valueMin()+1,h=this,this.handles.each(function(b){var c=Math.abs(e-h.values(b));f>c&&(f=c,g=a(this),i=b)}),c.range===!0&&this.values(1)===c.min&&(i+=1,g=a(this.handles[i])),j=this._start(b,i);if(j===!1)return!1;this._mouseSliding=!0,h._handleIndex=i,g.addClass("ui-state-active").focus(),k=g.offset(),l=!a(b.target).parents().andSelf().is(".ui-slider-handle"),this._clickOffset=l?{left:0,top:0}:{left:b.pageX-k.left-g.width()/2,top:b.pageY-k.top-g.height()/2-(parseInt(g.css("borderTopWidth"),10)||0)-(parseInt(g.css("borderBottomWidth"),10)||0)+(parseInt(g.css("marginTop"),10)||0)},this.handles.hasClass("ui-state-hover")||thi
|
|||
|
+ * jQuery UI Tabs 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Tabs
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.ui.core.js
|
|||
|
+ * jquery.ui.widget.js
|
|||
|
+ */(function(a,b){function f(){return++d}function e(){return++c}var c=0,d=0;a.widget("ui.tabs",{options:{add:null,ajaxOptions:null,cache:!1,cookie:null,collapsible:!1,disable:null,disabled:[],enable:null,event:"click",fx:null,idPrefix:"ui-tabs-",load:null,panelTemplate:"<div></div>",remove:null,select:null,show:null,spinner:"<em>Loading…</em>",tabTemplate:"<li><a href='#{href}'><span>#{label}</span></a></li>"},_create:function(){this._tabify(!0)},_setOption:function(a,b){if(a=="selected"){if(this.options.collapsible&&b==this.options.selected)return;this.select(b)}else this.options[a]=b,this._tabify()},_tabId:function(a){return a.title&&a.title.replace(/\s/g,"_").replace(/[^\w\u00c0-\uFFFF-]/g,"")||this.options.idPrefix+e()},_sanitizeSelector:function(a){return a.replace(/:/g,"\\:")},_cookie:function(){var b=this.cookie||(this.cookie=this.options.cookie.name||"ui-tabs-"+f());return a.cookie.apply(null,[b].concat(a.makeArray(arguments)))},_ui:function(a,b){return{tab:a,panel:b,index:this.anchors.index(a)}},_cleanup:function(){this.lis.filter(".ui-state-processing").removeClass("ui-state-processing").find("span:data(label.tabs)").each(function(){var b=a(this);b.html(b.data("label.tabs")).removeData("label.tabs")})},_tabify:function(c){function m(b,c){b.css("display",""),!a.support.opacity&&c.opacity&&b[0].style.removeAttribute("filter")}var d=this,e=this.options,f=/^#.+/;this.list=this.element.find("ol,ul").eq(0),this.lis=a(" > li:has(a[href])",this.list),this.anchors=this.lis.map(function(){return a("a",this)[0]}),this.panels=a([]),this.anchors.each(function(b,c){var g=a(c).attr("href"),h=g.split("#")[0],i;h&&(h===location.toString().split("#")[0]||(i=a("base")[0])&&h===i.href)&&(g=c.hash,c.href=g);if(f.test(g))d.panels=d.panels.add(d.element.find(d._sanitizeSelector(g)));else if(g&&g!=="#"){a.data(c,"href.tabs",g),a.data(c,"load.tabs",g.replace(/#.*$/,""));var j=d._tabId(c);c.href="#"+j;var k=d.element.find("#"+j);k.length||(k=a(e.panelTemplate).attr("id",j).addClass("ui-tabs-panel ui-widget-content ui-corner-bottom").insertAfter(d.panels[b-1]||d.list),k.data("destroy.tabs",!0)),d.panels=d.panels.add(k)}else e.disabled.push(b)}),c?(this.element.addClass("ui-tabs ui-widget ui-widget-content ui-corner-all"),this.list.addClass("ui-tabs-nav ui-helper-reset ui-helper-clearfix ui-widget-header ui-corner-all"),this.lis.addClass("ui-state-default ui-corner-top"),this.panels.addClass("ui-tabs-panel ui-widget-content ui-corner-bottom"),e.selected===b?(location.hash&&this.anchors.each(function(a,b){if(b.hash==location.hash){e.selected=a;return!1}}),typeof e.selected!="number"&&e.cookie&&(e.selected=parseInt(d._cookie(),10)),typeof e.selected!="number"&&this.lis.filter(".ui-tabs-selected").length&&(e.selected=this.lis.index(this.lis.filter(".ui-tabs-selected"))),e.selected=e.selected||(this.lis.length?0:-1)):e.selected===null&&(e.selected=-1),e.selected=e.selected>=0&&this.anchors[e.selected]||e.selected<0?e.selected:0,e.disabled=a.unique(e.disabled.concat(a.map(this.lis.filter(".ui-state-disabled"),function(a,b){return d.lis.index(a)}))).sort(),a.inArray(e.selected,e.disabled)!=-1&&e.disabled.splice(a.inArray(e.selected,e.disabled),1),this.panels.addClass("ui-tabs-hide"),this.lis.removeClass("ui-tabs-selected ui-state-active"),e.selected>=0&&this.anchors.length&&(d.element.find(d._sanitizeSelector(d.anchors[e.selected].hash)).removeClass("ui-tabs-hide"),this.lis.eq(e.selected).addClass("ui-tabs-selected ui-state-active"),d.element.queue("tabs",function(){d._trigger("show",null,d._ui(d.anchors[e.selected],d.element.find(d._sanitizeSelector(d.anchors[e.selected].hash))[0]))}),this.load(e.selected)),a(window).bind("unload",function(){d.lis.add(d.anchors).unbind(".tabs"),d.lis=d.anchors=d.panels=null})):e.selected=this.lis.index(this.lis.filter(".ui-tabs-selected")),this.element[e.collapsible?"addClass":"removeClass"]("ui-tabs-collapsible"),e.cookie&&this._cookie(e.selected,e.cookie);for(var g=0,h;h=this.lis[g];g++)a(h)[a.inArray(g,e.disabled)!=-1&&!a(h).hasClass("ui-tabs-selected")?"addClass":"removeClass"]("ui-state-disabled")
|
|||
|
+ * jQuery UI Datepicker 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Datepicker
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.ui.core.js
|
|||
|
+ */(function($,undefined){function isArray(a){return a&&($.browser.safari&&typeof a=="object"&&a.length||a.constructor&&a.constructor.toString().match(/\Array\(\)/))}function extendRemove(a,b){$.extend(a,b);for(var c in b)if(b[c]==null||b[c]==undefined)a[c]=b[c];return a}function bindHover(a){var b="button, .ui-datepicker-prev, .ui-datepicker-next, .ui-datepicker-calendar td a";return a.bind("mouseout",function(a){var c=$(a.target).closest(b);!c.length||c.removeClass("ui-state-hover ui-datepicker-prev-hover ui-datepicker-next-hover")}).bind("mouseover",function(c){var d=$(c.target).closest(b);!$.datepicker._isDisabledDatepicker(instActive.inline?a.parent()[0]:instActive.input[0])&&!!d.length&&(d.parents(".ui-datepicker-calendar").find("a").removeClass("ui-state-hover"),d.addClass("ui-state-hover"),d.hasClass("ui-datepicker-prev")&&d.addClass("ui-datepicker-prev-hover"),d.hasClass("ui-datepicker-next")&&d.addClass("ui-datepicker-next-hover"))})}function Datepicker(){this.debug=!1,this._curInst=null,this._keyEvent=!1,this._disabledInputs=[],this._datepickerShowing=!1,this._inDialog=!1,this._mainDivId="ui-datepicker-div",this._inlineClass="ui-datepicker-inline",this._appendClass="ui-datepicker-append",this._triggerClass="ui-datepicker-trigger",this._dialogClass="ui-datepicker-dialog",this._disableClass="ui-datepicker-disabled",this._unselectableClass="ui-datepicker-unselectable",this._currentClass="ui-datepicker-current-day",this._dayOverClass="ui-datepicker-days-cell-over",this.regional=[],this.regional[""]={closeText:"Done",prevText:"Prev",nextText:"Next",currentText:"Today",monthNames:["January","February","March","April","May","June","July","August","September","October","November","December"],monthNamesShort:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],dayNames:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],dayNamesShort:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],dayNamesMin:["Su","Mo","Tu","We","Th","Fr","Sa"],weekHeader:"Wk",dateFormat:"mm/dd/yy",firstDay:0,isRTL:!1,showMonthAfterYear:!1,yearSuffix:""},this._defaults={showOn:"focus",showAnim:"fadeIn",showOptions:{},defaultDate:null,appendText:"",buttonText:"...",buttonImage:"",buttonImageOnly:!1,hideIfNoPrevNext:!1,navigationAsDateFormat:!1,gotoCurrent:!1,changeMonth:!1,changeYear:!1,yearRange:"c-10:c+10",showOtherMonths:!1,selectOtherMonths:!1,showWeek:!1,calculateWeek:this.iso8601Week,shortYearCutoff:"+10",minDate:null,maxDate:null,duration:"fast",beforeShowDay:null,beforeShow:null,onSelect:null,onChangeMonthYear:null,onClose:null,numberOfMonths:1,showCurrentAtPos:0,stepMonths:1,stepBigMonths:12,altField:"",altFormat:"",constrainInput:!0,showButtonPanel:!1,autoSize:!1,disabled:!1},$.extend(this._defaults,this.regional[""]),this.dpDiv=bindHover($('<div id="'+this._mainDivId+'" class="ui-datepicker ui-widget ui-widget-content ui-helper-clearfix ui-corner-all"></div>'))}$.extend($.ui,{datepicker:{version:"1.8.18"}});var PROP_NAME="datepicker",dpuuid=(new Date).getTime(),instActive;$.extend(Datepicker.prototype,{markerClassName:"hasDatepicker",maxRows:4,log:function(){this.debug&&console.log.apply("",arguments)},_widgetDatepicker:function(){return this.dpDiv},setDefaults:function(a){extendRemove(this._defaults,a||{});return this},_attachDatepicker:function(target,settings){var inlineSettings=null;for(var attrName in this._defaults){var attrValue=target.getAttribute("date:"+attrName);if(attrValue){inlineSettings=inlineSettings||{};try{inlineSettings[attrName]=eval(attrValue)}catch(err){inlineSettings[attrName]=attrValue}}}var nodeName=target.nodeName.toLowerCase(),inline=nodeName=="div"||nodeName=="span";target.id||(this.uuid+=1,target.id="dp"+this.uuid);var inst=this._newInst($(target),inline);inst.settings=$.extend({},settings||{},inlineSettings||{}),nodeName=="input"?this._connectDatepicker(target,inst):inline&&this._inlineDatepicker(target,inst)},_newInst:function(a,b){var c=a[0].id.replace(/([^A-Za-z0-9_-])/g,"\\\\$1");return{id:c,input:a,selectedDay:0,selectedMonth:0,selectedYear:0,drawMonth:0,drawYear:0,in
|
|||
|
+a._keyEvent=!1;return K},_generateMonthYearHeader:function(a,b,c,d,e,f,g,h){var i=this._get(a,"changeMonth"),j=this._get(a,"changeYear"),k=this._get(a,"showMonthAfterYear"),l='<div class="ui-datepicker-title">',m="";if(f||!i)m+='<span class="ui-datepicker-month">'+g[b]+"</span>";else{var n=d&&d.getFullYear()==c,o=e&&e.getFullYear()==c;m+='<select class="ui-datepicker-month" onchange="DP_jQuery_'+dpuuid+".datepicker._selectMonthYear('#"+a.id+"', this, 'M');\" "+">";for(var p=0;p<12;p++)(!n||p>=d.getMonth())&&(!o||p<=e.getMonth())&&(m+='<option value="'+p+'"'+(p==b?' selected="selected"':"")+">"+h[p]+"</option>");m+="</select>"}k||(l+=m+(f||!i||!j?" ":""));if(!a.yearshtml){a.yearshtml="";if(f||!j)l+='<span class="ui-datepicker-year">'+c+"</span>";else{var q=this._get(a,"yearRange").split(":"),r=(new Date).getFullYear(),s=function(a){var b=a.match(/c[+-].*/)?c+parseInt(a.substring(1),10):a.match(/[+-].*/)?r+parseInt(a,10):parseInt(a,10);return isNaN(b)?r:b},t=s(q[0]),u=Math.max(t,s(q[1]||""));t=d?Math.max(t,d.getFullYear()):t,u=e?Math.min(u,e.getFullYear()):u,a.yearshtml+='<select class="ui-datepicker-year" onchange="DP_jQuery_'+dpuuid+".datepicker._selectMonthYear('#"+a.id+"', this, 'Y');\" "+">";for(;t<=u;t++)a.yearshtml+='<option value="'+t+'"'+(t==c?' selected="selected"':"")+">"+t+"</option>";a.yearshtml+="</select>",l+=a.yearshtml,a.yearshtml=null}}l+=this._get(a,"yearSuffix"),k&&(l+=(f||!i||!j?" ":"")+m),l+="</div>";return l},_adjustInstDate:function(a,b,c){var d=a.drawYear+(c=="Y"?b:0),e=a.drawMonth+(c=="M"?b:0),f=Math.min(a.selectedDay,this._getDaysInMonth(d,e))+(c=="D"?b:0),g=this._restrictMinMax(a,this._daylightSavingAdjust(new Date(d,e,f)));a.selectedDay=g.getDate(),a.drawMonth=a.selectedMonth=g.getMonth(),a.drawYear=a.selectedYear=g.getFullYear(),(c=="M"||c=="Y")&&this._notifyChange(a)},_restrictMinMax:function(a,b){var c=this._getMinMaxDate(a,"min"),d=this._getMinMaxDate(a,"max"),e=c&&b<c?c:b;e=d&&e>d?d:e;return e},_notifyChange:function(a){var b=this._get(a,"onChangeMonthYear");b&&b.apply(a.input?a.input[0]:null,[a.selectedYear,a.selectedMonth+1,a])},_getNumberOfMonths:function(a){var b=this._get(a,"numberOfMonths");return b==null?[1,1]:typeof b=="number"?[1,b]:b},_getMinMaxDate:function(a,b){return this._determineDate(a,this._get(a,b+"Date"),null)},_getDaysInMonth:function(a,b){return 32-this._daylightSavingAdjust(new Date(a,b,32)).getDate()},_getFirstDayOfMonth:function(a,b){return(new Date(a,b,1)).getDay()},_canAdjustMonth:function(a,b,c,d){var e=this._getNumberOfMonths(a),f=this._daylightSavingAdjust(new Date(c,d+(b<0?b:e[0]*e[1]),1));b<0&&f.setDate(this._getDaysInMonth(f.getFullYear(),f.getMonth()));return this._isInRange(a,f)},_isInRange:function(a,b){var c=this._getMinMaxDate(a,"min"),d=this._getMinMaxDate(a,"max");return(!c||b.getTime()>=c.getTime())&&(!d||b.getTime()<=d.getTime())},_getFormatConfig:function(a){var b=this._get(a,"shortYearCutoff");b=typeof b!="string"?b:(new Date).getFullYear()%100+parseInt(b,10);return{shortYearCutoff:b,dayNamesShort:this._get(a,"dayNamesShort"),dayNames:this._get(a,"dayNames"),monthNamesShort:this._get(a,"monthNamesShort"),monthNames:this._get(a,"monthNames")}},_formatDate:function(a,b,c,d){b||(a.currentDay=a.selectedDay,a.currentMonth=a.selectedMonth,a.currentYear=a.selectedYear);var e=b?typeof b=="object"?b:this._daylightSavingAdjust(new Date(d,c,b)):this._daylightSavingAdjust(new Date(a.currentYear,a.currentMonth,a.currentDay));return this.formatDate(this._get(a,"dateFormat"),e,this._getFormatConfig(a))}}),$.fn.datepicker=function(a){if(!this.length)return this;$.datepicker.initialized||($(document).mousedown($.datepicker._checkExternalClick).find("body").append($.datepicker.dpDiv),$.datepicker.initialized=!0);var b=Array.prototype.slice.call(arguments,1);if(typeof a=="string"&&(a=="isDisabled"||a=="getDate"||a=="widget"))return $.datepicker["_"+a+"Datepicker"].apply($.datepicker,[this[0]].concat(b));if(a=="option"&&arguments.length==2&&typeof arguments[1]=="string")return $.datepicker["_"+a+"Datepicker"].apply($.datepicker,[this[0]].concat(b));return
|
|||
|
+ * jQuery UI Progressbar 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Progressbar
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.ui.core.js
|
|||
|
+ * jquery.ui.widget.js
|
|||
|
+ */(function(a,b){a.widget("ui.progressbar",{options:{value:0,max:100},min:0,_create:function(){this.element.addClass("ui-progressbar ui-widget ui-widget-content ui-corner-all").attr({role:"progressbar","aria-valuemin":this.min,"aria-valuemax":this.options.max,"aria-valuenow":this._value()}),this.valueDiv=a("<div class='ui-progressbar-value ui-widget-header ui-corner-left'></div>").appendTo(this.element),this.oldValue=this._value(),this._refreshValue()},destroy:function(){this.element.removeClass("ui-progressbar ui-widget ui-widget-content ui-corner-all").removeAttr("role").removeAttr("aria-valuemin").removeAttr("aria-valuemax").removeAttr("aria-valuenow"),this.valueDiv.remove(),a.Widget.prototype.destroy.apply(this,arguments)},value:function(a){if(a===b)return this._value();this._setOption("value",a);return this},_setOption:function(b,c){b==="value"&&(this.options.value=c,this._refreshValue(),this._value()===this.options.max&&this._trigger("complete")),a.Widget.prototype._setOption.apply(this,arguments)},_value:function(){var a=this.options.value;typeof a!="number"&&(a=0);return Math.min(this.options.max,Math.max(this.min,a))},_percentage:function(){return 100*this._value()/this.options.max},_refreshValue:function(){var a=this.value(),b=this._percentage();this.oldValue!==a&&(this.oldValue=a,this._trigger("change")),this.valueDiv.toggle(a>this.min).toggleClass("ui-corner-right",a===this.options.max).width(b.toFixed(0)+"%"),this.element.attr("aria-valuenow",a)}}),a.extend(a.ui.progressbar,{version:"1.8.18"})})(jQuery);/*
|
|||
|
+ * jQuery UI Effects 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Effects/
|
|||
|
+ */jQuery.effects||function(a,b){function l(b){if(!b||typeof b=="number"||a.fx.speeds[b])return!0;if(typeof b=="string"&&!a.effects[b])return!0;return!1}function k(b,c,d,e){typeof b=="object"&&(e=c,d=null,c=b,b=c.effect),a.isFunction(c)&&(e=c,d=null,c={});if(typeof c=="number"||a.fx.speeds[c])e=d,d=c,c={};a.isFunction(d)&&(e=d,d=null),c=c||{},d=d||c.duration,d=a.fx.off?0:typeof d=="number"?d:d in a.fx.speeds?a.fx.speeds[d]:a.fx.speeds._default,e=e||c.complete;return[b,c,d,e]}function j(a,b){var c={_:0},d;for(d in b)a[d]!=b[d]&&(c[d]=b[d]);return c}function i(b){var c,d;for(c in b)d=b[c],(d==null||a.isFunction(d)||c in g||/scrollbar/.test(c)||!/color/i.test(c)&&isNaN(parseFloat(d)))&&delete b[c];return b}function h(){var a=document.defaultView?document.defaultView.getComputedStyle(this,null):this.currentStyle,b={},c,d;if(a&&a.length&&a[0]&&a[a[0]]){var e=a.length;while(e--)c=a[e],typeof a[c]=="string"&&(d=c.replace(/\-(\w)/g,function(a,b){return b.toUpperCase()}),b[d]=a[c])}else for(c in a)typeof a[c]=="string"&&(b[c]=a[c]);return b}function d(b,d){var e;do{e=a.curCSS(b,d);if(e!=""&&e!="transparent"||a.nodeName(b,"body"))break;d="backgroundColor"}while(b=b.parentNode);return c(e)}function c(b){var c;if(b&&b.constructor==Array&&b.length==3)return b;if(c=/rgb\(\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*\)/.exec(b))return[parseInt(c[1],10),parseInt(c[2],10),parseInt(c[3],10)];if(c=/rgb\(\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\%\s*\)/.exec(b))return[parseFloat(c[1])*2.55,parseFloat(c[2])*2.55,parseFloat(c[3])*2.55];if(c=/#([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})/.exec(b))return[parseInt(c[1],16),parseInt(c[2],16),parseInt(c[3],16)];if(c=/#([a-fA-F0-9])([a-fA-F0-9])([a-fA-F0-9])/.exec(b))return[parseInt(c[1]+c[1],16),parseInt(c[2]+c[2],16),parseInt(c[3]+c[3],16)];if(c=/rgba\(0, 0, 0, 0\)/.exec(b))return e.transparent;return e[a.trim(b).toLowerCase()]}a.effects={},a.each(["backgroundColor","borderBottomColor","borderLeftColor","borderRightColor","borderTopColor","borderColor","color","outlineColor"],function(b,e){a.fx.step[e]=function(a){a.colorInit||(a.start=d(a.elem,e),a.end=c(a.end),a.colorInit=!0),a.elem.style[e]="rgb("+Math.max(Math.min(parseInt(a.pos*(a.end[0]-a.start[0])+a.start[0],10),255),0)+","+Math.max(Math.min(parseInt(a.pos*(a.end[1]-a.start[1])+a.start[1],10),255),0)+","+Math.max(Math.min(parseInt(a.pos*(a.end[2]-a.start[2])+a.start[2],10),255),0)+")"}});var e={aqua:[0,255,255],azure:[240,255,255],beige:[245,245,220],black:[0,0,0],blue:[0,0,255],brown:[165,42,42],cyan:[0,255,255],darkblue:[0,0,139],darkcyan:[0,139,139],darkgrey:[169,169,169],darkgreen:[0,100,0],darkkhaki:[189,183,107],darkmagenta:[139,0,139],darkolivegreen:[85,107,47],darkorange:[255,140,0],darkorchid:[153,50,204],darkred:[139,0,0],darksalmon:[233,150,122],darkviolet:[148,0,211],fuchsia:[255,0,255],gold:[255,215,0],green:[0,128,0],indigo:[75,0,130],khaki:[240,230,140],lightblue:[173,216,230],lightcyan:[224,255,255],lightgreen:[144,238,144],lightgrey:[211,211,211],lightpink:[255,182,193],lightyellow:[255,255,224],lime:[0,255,0],magenta:[255,0,255],maroon:[128,0,0],navy:[0,0,128],olive:[128,128,0],orange:[255,165,0],pink:[255,192,203],purple:[128,0,128],violet:[128,0,128],red:[255,0,0],silver:[192,192,192],white:[255,255,255],yellow:[255,255,0],transparent:[255,255,255]},f=["add","remove","toggle"],g={border:1,borderBottom:1,borderColor:1,borderLeft:1,borderRight:1,borderTop:1,borderWidth:1,margin:1,padding:1};a.effects.animateClass=function(b,c,d,e){a.isFunction(d)&&(e=d,d=null);return this.queue(function(){var g=a(this),k=g.attr("style")||" ",l=i(h.call(this)),m,n=g.attr("class");a.each(f,function(a,c){b[c]&&g[c+"Class"](b[c])}),m=i(h.call(this)),g.attr("class",n),g.animate(j(l,m),{queue:!1,duration:c,easing:d,complete:function(){a.each(f,function(a,c){b[c]&&g[c+"Class"](b[c])}),typeof g.attr("style")=="object"?(g.attr("style").cssText="",g.attr("style").cssText=k):g.attr("style",k),e&&e.apply(this,arguments),a.dequeue(this)}})})},a.fn.extend({_addClass:a.fn.addClass,addClass:func
|
|||
|
+ * jQuery UI Effects Blind 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Effects/Blind
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.effects.core.js
|
|||
|
+ */(function(a,b){a.effects.blind=function(b){return this.queue(function(){var c=a(this),d=["position","top","bottom","left","right"],e=a.effects.setMode(c,b.options.mode||"hide"),f=b.options.direction||"vertical";a.effects.save(c,d),c.show();var g=a.effects.createWrapper(c).css({overflow:"hidden"}),h=f=="vertical"?"height":"width",i=f=="vertical"?g.height():g.width();e=="show"&&g.css(h,0);var j={};j[h]=e=="show"?i:0,g.animate(j,b.duration,b.options.easing,function(){e=="hide"&&c.hide(),a.effects.restore(c,d),a.effects.removeWrapper(c),b.callback&&b.callback.apply(c[0],arguments),c.dequeue()})})}})(jQuery);/*
|
|||
|
+ * jQuery UI Effects Bounce 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Effects/Bounce
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.effects.core.js
|
|||
|
+ */(function(a,b){a.effects.bounce=function(b){return this.queue(function(){var c=a(this),d=["position","top","bottom","left","right"],e=a.effects.setMode(c,b.options.mode||"effect"),f=b.options.direction||"up",g=b.options.distance||20,h=b.options.times||5,i=b.duration||250;/show|hide/.test(e)&&d.push("opacity"),a.effects.save(c,d),c.show(),a.effects.createWrapper(c);var j=f=="up"||f=="down"?"top":"left",k=f=="up"||f=="left"?"pos":"neg",g=b.options.distance||(j=="top"?c.outerHeight({margin:!0})/3:c.outerWidth({margin:!0})/3);e=="show"&&c.css("opacity",0).css(j,k=="pos"?-g:g),e=="hide"&&(g=g/(h*2)),e!="hide"&&h--;if(e=="show"){var l={opacity:1};l[j]=(k=="pos"?"+=":"-=")+g,c.animate(l,i/2,b.options.easing),g=g/2,h--}for(var m=0;m<h;m++){var n={},p={};n[j]=(k=="pos"?"-=":"+=")+g,p[j]=(k=="pos"?"+=":"-=")+g,c.animate(n,i/2,b.options.easing).animate(p,i/2,b.options.easing),g=e=="hide"?g*2:g/2}if(e=="hide"){var l={opacity:0};l[j]=(k=="pos"?"-=":"+=")+g,c.animate(l,i/2,b.options.easing,function(){c.hide(),a.effects.restore(c,d),a.effects.removeWrapper(c),b.callback&&b.callback.apply(this,arguments)})}else{var n={},p={};n[j]=(k=="pos"?"-=":"+=")+g,p[j]=(k=="pos"?"+=":"-=")+g,c.animate(n,i/2,b.options.easing).animate(p,i/2,b.options.easing,function(){a.effects.restore(c,d),a.effects.removeWrapper(c),b.callback&&b.callback.apply(this,arguments)})}c.queue("fx",function(){c.dequeue()}),c.dequeue()})}})(jQuery);/*
|
|||
|
+ * jQuery UI Effects Clip 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Effects/Clip
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.effects.core.js
|
|||
|
+ */(function(a,b){a.effects.clip=function(b){return this.queue(function(){var c=a(this),d=["position","top","bottom","left","right","height","width"],e=a.effects.setMode(c,b.options.mode||"hide"),f=b.options.direction||"vertical";a.effects.save(c,d),c.show();var g=a.effects.createWrapper(c).css({overflow:"hidden"}),h=c[0].tagName=="IMG"?g:c,i={size:f=="vertical"?"height":"width",position:f=="vertical"?"top":"left"},j=f=="vertical"?h.height():h.width();e=="show"&&(h.css(i.size,0),h.css(i.position,j/2));var k={};k[i.size]=e=="show"?j:0,k[i.position]=e=="show"?0:j/2,h.animate(k,{queue:!1,duration:b.duration,easing:b.options.easing,complete:function(){e=="hide"&&c.hide(),a.effects.restore(c,d),a.effects.removeWrapper(c),b.callback&&b.callback.apply(c[0],arguments),c.dequeue()}})})}})(jQuery);/*
|
|||
|
+ * jQuery UI Effects Drop 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Effects/Drop
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.effects.core.js
|
|||
|
+ */(function(a,b){a.effects.drop=function(b){return this.queue(function(){var c=a(this),d=["position","top","bottom","left","right","opacity"],e=a.effects.setMode(c,b.options.mode||"hide"),f=b.options.direction||"left";a.effects.save(c,d),c.show(),a.effects.createWrapper(c);var g=f=="up"||f=="down"?"top":"left",h=f=="up"||f=="left"?"pos":"neg",i=b.options.distance||(g=="top"?c.outerHeight({margin:!0})/2:c.outerWidth({margin:!0})/2);e=="show"&&c.css("opacity",0).css(g,h=="pos"?-i:i);var j={opacity:e=="show"?1:0};j[g]=(e=="show"?h=="pos"?"+=":"-=":h=="pos"?"-=":"+=")+i,c.animate(j,{queue:!1,duration:b.duration,easing:b.options.easing,complete:function(){e=="hide"&&c.hide(),a.effects.restore(c,d),a.effects.removeWrapper(c),b.callback&&b.callback.apply(this,arguments),c.dequeue()}})})}})(jQuery);/*
|
|||
|
+ * jQuery UI Effects Explode 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Effects/Explode
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.effects.core.js
|
|||
|
+ */(function(a,b){a.effects.explode=function(b){return this.queue(function(){var c=b.options.pieces?Math.round(Math.sqrt(b.options.pieces)):3,d=b.options.pieces?Math.round(Math.sqrt(b.options.pieces)):3;b.options.mode=b.options.mode=="toggle"?a(this).is(":visible")?"hide":"show":b.options.mode;var e=a(this).show().css("visibility","hidden"),f=e.offset();f.top-=parseInt(e.css("marginTop"),10)||0,f.left-=parseInt(e.css("marginLeft"),10)||0;var g=e.outerWidth(!0),h=e.outerHeight(!0);for(var i=0;i<c;i++)for(var j=0;j<d;j++)e.clone().appendTo("body").wrap("<div></div>").css({position:"absolute",visibility:"visible",left:-j*(g/d),top:-i*(h/c)}).parent().addClass("ui-effects-explode").css({position:"absolute",overflow:"hidden",width:g/d,height:h/c,left:f.left+j*(g/d)+(b.options.mode=="show"?(j-Math.floor(d/2))*(g/d):0),top:f.top+i*(h/c)+(b.options.mode=="show"?(i-Math.floor(c/2))*(h/c):0),opacity:b.options.mode=="show"?0:1}).animate({left:f.left+j*(g/d)+(b.options.mode=="show"?0:(j-Math.floor(d/2))*(g/d)),top:f.top+i*(h/c)+(b.options.mode=="show"?0:(i-Math.floor(c/2))*(h/c)),opacity:b.options.mode=="show"?1:0},b.duration||500);setTimeout(function(){b.options.mode=="show"?e.css({visibility:"visible"}):e.css({visibility:"visible"}).hide(),b.callback&&b.callback.apply(e[0]),e.dequeue(),a("div.ui-effects-explode").remove()},b.duration||500)})}})(jQuery);/*
|
|||
|
+ * jQuery UI Effects Fade 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Effects/Fade
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.effects.core.js
|
|||
|
+ */(function(a,b){a.effects.fade=function(b){return this.queue(function(){var c=a(this),d=a.effects.setMode(c,b.options.mode||"hide");c.animate({opacity:d},{queue:!1,duration:b.duration,easing:b.options.easing,complete:function(){b.callback&&b.callback.apply(this,arguments),c.dequeue()}})})}})(jQuery);/*
|
|||
|
+ * jQuery UI Effects Fold 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Effects/Fold
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.effects.core.js
|
|||
|
+ */(function(a,b){a.effects.fold=function(b){return this.queue(function(){var c=a(this),d=["position","top","bottom","left","right"],e=a.effects.setMode(c,b.options.mode||"hide"),f=b.options.size||15,g=!!b.options.horizFirst,h=b.duration?b.duration/2:a.fx.speeds._default/2;a.effects.save(c,d),c.show();var i=a.effects.createWrapper(c).css({overflow:"hidden"}),j=e=="show"!=g,k=j?["width","height"]:["height","width"],l=j?[i.width(),i.height()]:[i.height(),i.width()],m=/([0-9]+)%/.exec(f);m&&(f=parseInt(m[1],10)/100*l[e=="hide"?0:1]),e=="show"&&i.css(g?{height:0,width:f}:{height:f,width:0});var n={},p={};n[k[0]]=e=="show"?l[0]:f,p[k[1]]=e=="show"?l[1]:0,i.animate(n,h,b.options.easing).animate(p,h,b.options.easing,function(){e=="hide"&&c.hide(),a.effects.restore(c,d),a.effects.removeWrapper(c),b.callback&&b.callback.apply(c[0],arguments),c.dequeue()})})}})(jQuery);/*
|
|||
|
+ * jQuery UI Effects Highlight 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Effects/Highlight
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.effects.core.js
|
|||
|
+ */(function(a,b){a.effects.highlight=function(b){return this.queue(function(){var c=a(this),d=["backgroundImage","backgroundColor","opacity"],e=a.effects.setMode(c,b.options.mode||"show"),f={backgroundColor:c.css("backgroundColor")};e=="hide"&&(f.opacity=0),a.effects.save(c,d),c.show().css({backgroundImage:"none",backgroundColor:b.options.color||"#ffff99"}).animate(f,{queue:!1,duration:b.duration,easing:b.options.easing,complete:function(){e=="hide"&&c.hide(),a.effects.restore(c,d),e=="show"&&!a.support.opacity&&this.style.removeAttribute("filter"),b.callback&&b.callback.apply(this,arguments),c.dequeue()}})})}})(jQuery);/*
|
|||
|
+ * jQuery UI Effects Pulsate 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Effects/Pulsate
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.effects.core.js
|
|||
|
+ */(function(a,b){a.effects.pulsate=function(b){return this.queue(function(){var c=a(this),d=a.effects.setMode(c,b.options.mode||"show");times=(b.options.times||5)*2-1,duration=b.duration?b.duration/2:a.fx.speeds._default/2,isVisible=c.is(":visible"),animateTo=0,isVisible||(c.css("opacity",0).show(),animateTo=1),(d=="hide"&&isVisible||d=="show"&&!isVisible)&×--;for(var e=0;e<times;e++)c.animate({opacity:animateTo},duration,b.options.easing),animateTo=(animateTo+1)%2;c.animate({opacity:animateTo},duration,b.options.easing,function(){animateTo==0&&c.hide(),b.callback&&b.callback.apply(this,arguments)}),c.queue("fx",function(){c.dequeue()}).dequeue()})}})(jQuery);/*
|
|||
|
+ * jQuery UI Effects Scale 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Effects/Scale
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.effects.core.js
|
|||
|
+ */(function(a,b){a.effects.puff=function(b){return this.queue(function(){var c=a(this),d=a.effects.setMode(c,b.options.mode||"hide"),e=parseInt(b.options.percent,10)||150,f=e/100,g={height:c.height(),width:c.width()};a.extend(b.options,{fade:!0,mode:d,percent:d=="hide"?e:100,from:d=="hide"?g:{height:g.height*f,width:g.width*f}}),c.effect("scale",b.options,b.duration,b.callback),c.dequeue()})},a.effects.scale=function(b){return this.queue(function(){var c=a(this),d=a.extend(!0,{},b.options),e=a.effects.setMode(c,b.options.mode||"effect"),f=parseInt(b.options.percent,10)||(parseInt(b.options.percent,10)==0?0:e=="hide"?0:100),g=b.options.direction||"both",h=b.options.origin;e!="effect"&&(d.origin=h||["middle","center"],d.restore=!0);var i={height:c.height(),width:c.width()};c.from=b.options.from||(e=="show"?{height:0,width:0}:i);var j={y:g!="horizontal"?f/100:1,x:g!="vertical"?f/100:1};c.to={height:i.height*j.y,width:i.width*j.x},b.options.fade&&(e=="show"&&(c.from.opacity=0,c.to.opacity=1),e=="hide"&&(c.from.opacity=1,c.to.opacity=0)),d.from=c.from,d.to=c.to,d.mode=e,c.effect("size",d,b.duration,b.callback),c.dequeue()})},a.effects.size=function(b){return this.queue(function(){var c=a(this),d=["position","top","bottom","left","right","width","height","overflow","opacity"],e=["position","top","bottom","left","right","overflow","opacity"],f=["width","height","overflow"],g=["fontSize"],h=["borderTopWidth","borderBottomWidth","paddingTop","paddingBottom"],i=["borderLeftWidth","borderRightWidth","paddingLeft","paddingRight"],j=a.effects.setMode(c,b.options.mode||"effect"),k=b.options.restore||!1,l=b.options.scale||"both",m=b.options.origin,n={height:c.height(),width:c.width()};c.from=b.options.from||n,c.to=b.options.to||n;if(m){var p=a.effects.getBaseline(m,n);c.from.top=(n.height-c.from.height)*p.y,c.from.left=(n.width-c.from.width)*p.x,c.to.top=(n.height-c.to.height)*p.y,c.to.left=(n.width-c.to.width)*p.x}var q={from:{y:c.from.height/n.height,x:c.from.width/n.width},to:{y:c.to.height/n.height,x:c.to.width/n.width}};if(l=="box"||l=="both")q.from.y!=q.to.y&&(d=d.concat(h),c.from=a.effects.setTransition(c,h,q.from.y,c.from),c.to=a.effects.setTransition(c,h,q.to.y,c.to)),q.from.x!=q.to.x&&(d=d.concat(i),c.from=a.effects.setTransition(c,i,q.from.x,c.from),c.to=a.effects.setTransition(c,i,q.to.x,c.to));(l=="content"||l=="both")&&q.from.y!=q.to.y&&(d=d.concat(g),c.from=a.effects.setTransition(c,g,q.from.y,c.from),c.to=a.effects.setTransition(c,g,q.to.y,c.to)),a.effects.save(c,k?d:e),c.show(),a.effects.createWrapper(c),c.css("overflow","hidden").css(c.from);if(l=="content"||l=="both")h=h.concat(["marginTop","marginBottom"]).concat(g),i=i.concat(["marginLeft","marginRight"]),f=d.concat(h).concat(i),c.find("*[width]").each(function(){child=a(this),k&&a.effects.save(child,f);var c={height:child.height(),width:child.width()};child.from={height:c.height*q.from.y,width:c.width*q.from.x},child.to={height:c.height*q.to.y,width:c.width*q.to.x},q.from.y!=q.to.y&&(child.from=a.effects.setTransition(child,h,q.from.y,child.from),child.to=a.effects.setTransition(child,h,q.to.y,child.to)),q.from.x!=q.to.x&&(child.from=a.effects.setTransition(child,i,q.from.x,child.from),child.to=a.effects.setTransition(child,i,q.to.x,child.to)),child.css(child.from),child.animate(child.to,b.duration,b.options.easing,function(){k&&a.effects.restore(child,f)})});c.animate(c.to,{queue:!1,duration:b.duration,easing:b.options.easing,complete:function(){c.to.opacity===0&&c.css("opacity",c.from.opacity),j=="hide"&&c.hide(),a.effects.restore(c,k?d:e),a.effects.removeWrapper(c),b.callback&&b.callback.apply(this,arguments),c.dequeue()}})})}})(jQuery);/*
|
|||
|
+ * jQuery UI Effects Shake 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Effects/Shake
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.effects.core.js
|
|||
|
+ */(function(a,b){a.effects.shake=function(b){return this.queue(function(){var c=a(this),d=["position","top","bottom","left","right"],e=a.effects.setMode(c,b.options.mode||"effect"),f=b.options.direction||"left",g=b.options.distance||20,h=b.options.times||3,i=b.duration||b.options.duration||140;a.effects.save(c,d),c.show(),a.effects.createWrapper(c);var j=f=="up"||f=="down"?"top":"left",k=f=="up"||f=="left"?"pos":"neg",l={},m={},n={};l[j]=(k=="pos"?"-=":"+=")+g,m[j]=(k=="pos"?"+=":"-=")+g*2,n[j]=(k=="pos"?"-=":"+=")+g*2,c.animate(l,i,b.options.easing);for(var p=1;p<h;p++)c.animate(m,i,b.options.easing).animate(n,i,b.options.easing);c.animate(m,i,b.options.easing).animate(l,i/2,b.options.easing,function(){a.effects.restore(c,d),a.effects.removeWrapper(c),b.callback&&b.callback.apply(this,arguments)}),c.queue("fx",function(){c.dequeue()}),c.dequeue()})}})(jQuery);/*
|
|||
|
+ * jQuery UI Effects Slide 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Effects/Slide
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.effects.core.js
|
|||
|
+ */(function(a,b){a.effects.slide=function(b){return this.queue(function(){var c=a(this),d=["position","top","bottom","left","right"],e=a.effects.setMode(c,b.options.mode||"show"),f=b.options.direction||"left";a.effects.save(c,d),c.show(),a.effects.createWrapper(c).css({overflow:"hidden"});var g=f=="up"||f=="down"?"top":"left",h=f=="up"||f=="left"?"pos":"neg",i=b.options.distance||(g=="top"?c.outerHeight({margin:!0}):c.outerWidth({margin:!0}));e=="show"&&c.css(g,h=="pos"?isNaN(i)?"-"+i:-i:i);var j={};j[g]=(e=="show"?h=="pos"?"+=":"-=":h=="pos"?"-=":"+=")+i,c.animate(j,{queue:!1,duration:b.duration,easing:b.options.easing,complete:function(){e=="hide"&&c.hide(),a.effects.restore(c,d),a.effects.removeWrapper(c),b.callback&&b.callback.apply(this,arguments),c.dequeue()}})})}})(jQuery);/*
|
|||
|
+ * jQuery UI Effects Transfer 1.8.18
|
|||
|
+ *
|
|||
|
+ * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
|||
|
+ * Dual licensed under the MIT or GPL Version 2 licenses.
|
|||
|
+ * http://jquery.org/license
|
|||
|
+ *
|
|||
|
+ * http://docs.jquery.com/UI/Effects/Transfer
|
|||
|
+ *
|
|||
|
+ * Depends:
|
|||
|
+ * jquery.effects.core.js
|
|||
|
+ */(function(a,b){a.effects.transfer=function(b){return this.queue(function(){var c=a(this),d=a(b.options.to),e=d.offset(),f={top:e.top,left:e.left,height:d.innerHeight(),width:d.innerWidth()},g=c.offset(),h=a('<div class="ui-effects-transfer"></div>').appendTo(document.body).addClass(b.options.className).css({top:g.top,left:g.left,height:c.innerHeight(),width:c.innerWidth(),position:"absolute"}).animate(f,b.duration,b.options.easing,function(){h.remove(),b.callback&&b.callback.apply(c[0],arguments),c.dequeue()})})}})(jQuery);
|
|||
|
\ No newline at end of file
|
|||
|
diff -up cacti-0.8.8a/include/js/jquery/jquery.zoom.js.legal cacti-0.8.8a/include/js/jquery/jquery.zoom.js
|
|||
|
--- cacti-0.8.8a/include/js/jquery/jquery.zoom.js.legal 2013-01-04 15:44:38.045416081 -0500
|
|||
|
+++ cacti-0.8.8a/include/js/jquery/jquery.zoom.js 2013-01-04 15:43:12.646377987 -0500
|
|||
|
@@ -0,0 +1,866 @@
|
|||
|
+/*
|
|||
|
+ +-------------------------------------------------------------------------+
|
|||
|
+ | Copyright (C) 2004-2013 The Cacti Group |
|
|||
|
+ | |
|
|||
|
+ | This program is free software; you can redistribute it and/or |
|
|||
|
+ | modify it under the terms of the GNU General Public License |
|
|||
|
+ | as published by the Free Software Foundation; either version 2 |
|
|||
|
+ | of the License, or (at your option) any later version. |
|
|||
|
+ | |
|
|||
|
+ | This program is distributed in the hope that it will be useful, |
|
|||
|
+ | but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
|||
|
+ | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
|||
|
+ | GNU General Public License for more details. |
|
|||
|
+ +-------------------------------------------------------------------------+
|
|||
|
+ | Cacti: The Complete RRDTool-based Graphing Solution |
|
|||
|
+ +-------------------------------------------------------------------------+
|
|||
|
+ | This code is designed, written, and maintained by the Cacti Group. See |
|
|||
|
+ | about.php and/or the AUTHORS file for specific developer information. |
|
|||
|
+ +-------------------------------------------------------------------------+
|
|||
|
+ | http://www.cacti.net/ |
|
|||
|
+ +-------------------------------------------------------------------------+
|
|||
|
+*/
|
|||
|
+
|
|||
|
+/* requirements:
|
|||
|
+ jQuery 1.7.x or above
|
|||
|
+ jQuery UI 1.8.x or above
|
|||
|
+ jQuery cookie plugin
|
|||
|
+*/
|
|||
|
+
|
|||
|
+(function($){
|
|||
|
+ $.fn.zoom = function(options) {
|
|||
|
+
|
|||
|
+ /* +++++++++++++++++++++++ Global Variables +++++++++++++++++++++++++ */
|
|||
|
+
|
|||
|
+ // default values of the different options being offered
|
|||
|
+ var defaults = {
|
|||
|
+ inputfieldStartTime : '', // ID of the input field that contains the start date
|
|||
|
+ inputfieldEndTime : '', // ID of the input field that contains the end date
|
|||
|
+ submitButton : 'button_refresh_x', // ID of the submit button
|
|||
|
+ cookieName : 'cacti_zoom' // default name required for session cookie
|
|||
|
+ };
|
|||
|
+
|
|||
|
+ // define global variables / objects here
|
|||
|
+ var zoom = {
|
|||
|
+ // "initiator" is the element that initiates Zoom
|
|||
|
+ initiator: $(this),
|
|||
|
+ // "image" means the image tag and its properties
|
|||
|
+ image: { top:0, left:0, width:0, height:0 },
|
|||
|
+ // "graph" stands for the rrdgraph itself excluding legend, graph title etc.
|
|||
|
+ graph: { timespan:0, secondsPerPixel:0 },
|
|||
|
+ // "box" describes the area in front of the graph whithin jQueryZoom will allow interaction
|
|||
|
+ box: { top:0, left:0, right:0, width:0, height:0 },
|
|||
|
+ // "markers" are selectors useable within the advanced mode
|
|||
|
+ marker: { 1 : { placed:false }, 2 : { placed:false} },
|
|||
|
+ // "custom" holds the local configuration done by the user
|
|||
|
+ custom: {},
|
|||
|
+ // "options" contains the start input parameters
|
|||
|
+ options: $.extend(defaults, options),
|
|||
|
+ // "attributes" holds all values that will describe the selected area
|
|||
|
+ attr: { activeElement:'', start:'none', end:'none', action:'left2right', location: window.location.href.split("?") }
|
|||
|
+ };
|
|||
|
+
|
|||
|
+
|
|||
|
+ /* ++++++++++++++++++++++++ Initialization ++++++++++++++++++++++++++ */
|
|||
|
+
|
|||
|
+ // use a cookie to support local settings
|
|||
|
+ zoom.custom = $.cookie(zoom.options.cookieName) ? unserialize( $.cookie(zoom.options.cookieName) ) : {};
|
|||
|
+ if(zoom.custom.zoomMode == undefined) zoom.custom.zoomMode = 'quick';
|
|||
|
+ if(zoom.custom.zoomOutPositioning == undefined) zoom.custom.zoomOutPositioning = 'center';
|
|||
|
+ if(zoom.custom.zoomOutFactor == undefined) zoom.custom.zoomOutFactor = '2';
|
|||
|
+ if(zoom.custom.zoomMarkers == undefined) zoom.custom.zoomMarkers = true;
|
|||
|
+ if(zoom.custom.zoomTimestamps == undefined) zoom.custom.zoomTimestamps = 'auto';
|
|||
|
+ if(zoom.custom.zoom3rdMouseButton == undefined) zoom.custom.zoom3rdMouseButton = false;
|
|||
|
+
|
|||
|
+ // create or update a session cookie
|
|||
|
+ $.cookie( zoom.options.cookieName, serialize(zoom.custom), {expires: null} );
|
|||
|
+
|
|||
|
+ // support jQuery's concatination
|
|||
|
+ return this.each(function() { zoom_init( $(this) ); });
|
|||
|
+
|
|||
|
+
|
|||
|
+ /* ++++++++++++++++++++ Universal Functions +++++++++++++++++++++++++ */
|
|||
|
+
|
|||
|
+ /**
|
|||
|
+ * checks if an image has been already loaded or if the link is broken
|
|||
|
+ **/
|
|||
|
+ function isReady(image){
|
|||
|
+ if(typeof image[0].naturalWidth !== undefined && image[0].naturalWidth == 0) {
|
|||
|
+ return false;
|
|||
|
+ }
|
|||
|
+ // support older versions of IE(6-8)
|
|||
|
+ if(!image[0].complete) {
|
|||
|
+ return false;
|
|||
|
+ }
|
|||
|
+ return true;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ /**
|
|||
|
+ * splits off the parameters of a given url
|
|||
|
+ **/
|
|||
|
+ function getUrlVars(url) {
|
|||
|
+ var parameters = [], name, value;
|
|||
|
+
|
|||
|
+ urlBaseAndParameters = url.split("?");
|
|||
|
+ urlBase = urlBaseAndParameters[0];
|
|||
|
+ urlParameters = urlBaseAndParameters[1].split("&");
|
|||
|
+ parameters["urlBase"] = urlBase;
|
|||
|
+
|
|||
|
+ for(var i=0; i<urlParameters.length; i++) {
|
|||
|
+ parameter = urlParameters[i].split("=");
|
|||
|
+ parameters[parameter[0].replace(/^graph_/, "")] = $.isNumeric(parameter[1]) ? +parameter[1] : parameter[1];
|
|||
|
+ }
|
|||
|
+ return parameters;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ /**
|
|||
|
+ * transforms an object into a comma separated string of key-value pairs
|
|||
|
+ **/
|
|||
|
+ function serialize(object){
|
|||
|
+ var str = "";
|
|||
|
+ for(var key in object) { str += (key + '=' + object[key] + ','); }
|
|||
|
+ return str.slice(0, -1);
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ /**
|
|||
|
+ * transforms a comma separated string of key-values pairs into an object
|
|||
|
+ * including a change of the value type from string to boolean or numeric if reasonable.
|
|||
|
+ **/
|
|||
|
+ function unserialize(string){
|
|||
|
+ var obj = new Array();
|
|||
|
+ pairs = string.split(',');
|
|||
|
+ for(var i=0; i<pairs.length; i++) {
|
|||
|
+ pair = pairs[i].split("=");
|
|||
|
+ if(pair[1] == "true") {
|
|||
|
+ pair[1] = true;
|
|||
|
+ }else if(pair[1] == "false") {
|
|||
|
+ pair[1] = false;
|
|||
|
+ }else if($.isNumeric(pair[1])) {
|
|||
|
+ pair[1] = +pair[1];
|
|||
|
+ }
|
|||
|
+ obj[pair[0]] = pair[1];
|
|||
|
+ }
|
|||
|
+ return obj;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ /**
|
|||
|
+ * converts a Unix time stamp to a formatted date string
|
|||
|
+ **/
|
|||
|
+ function unixTime2Date(unixTime){
|
|||
|
+ var date = new Date(unixTime*1000);
|
|||
|
+ var year = date.getFullYear();
|
|||
|
+ var month = ((date.getMonth()+1) < 9 ) ? '0' + (date.getMonth()+1) : date.getMonth()+1;
|
|||
|
+ var day = (date.getDate() > 9) ? date.getDate() : '0' + date.getDate();
|
|||
|
+ var hours = (date.getHours() > 9) ? date.getHours() : '0' + date.getHours();
|
|||
|
+ var minutes = (date.getMinutes() > 9) ? date.getMinutes() : '0' + date.getMinutes();
|
|||
|
+ var seconds = (date.getSeconds() > 9) ? date.getSeconds() : '0' + date.getSeconds();
|
|||
|
+
|
|||
|
+ var formattedTime = year + '-' + month + '-' + day + ' ' + hours + ':' + minutes + ':' + seconds;
|
|||
|
+ return formattedTime;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+
|
|||
|
+ /* +++++++++++++++++++++++ Core Functions +++++++++++++++++++++++++++ */
|
|||
|
+
|
|||
|
+ /* init zoom */
|
|||
|
+ function zoom_init(image) {
|
|||
|
+ var $this = image;
|
|||
|
+ $this.mouseenter(
|
|||
|
+ function(){
|
|||
|
+ if(zoom.attr.activeElement == '') {
|
|||
|
+ zoom.attr.activeElement = $(this).attr('id');
|
|||
|
+ zoomFunction_init($this);
|
|||
|
+ // focusing another image will trigger a reset of Zoom
|
|||
|
+ }else if(zoom.attr.activeElement != $(this).attr('id')) {
|
|||
|
+ zoom.attr.activeElement = $(this).attr('id');
|
|||
|
+ zoomFunction_init($this);
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ );
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ function zoomFunction_init(image) {
|
|||
|
+ var $this = image;
|
|||
|
+ // exit if image has not been already loaded or if image is not available
|
|||
|
+ if(isReady($this)) {
|
|||
|
+ // update zoom.image object with the attributes of this image
|
|||
|
+ zoom.image.width = parseInt($this.width());
|
|||
|
+ zoom.image.height = parseInt($this.height());
|
|||
|
+ zoom.image.top = parseInt($this.offset().top);
|
|||
|
+ zoom.image.left = parseInt($this.offset().left);
|
|||
|
+ }else {
|
|||
|
+ return;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ // get all graph parameters and merge results with zoom.graph object
|
|||
|
+ $.extend(zoom.graph, getUrlVars( $this.attr("src") ));
|
|||
|
+ zoom.graph.timespan = zoom.graph.end - zoom.graph.start;
|
|||
|
+ zoom.graph.secondsPerPixel = zoom.graph.timespan/zoom.graph.width;
|
|||
|
+
|
|||
|
+ if((zoom.graph.title_font_size <= 0) || (zoom.graph.title_font_size == "")) {
|
|||
|
+ zoom.graph.title_font_size = 10;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ if(zoom.graph.nolegend != undefined) {
|
|||
|
+ zoom.graph.title_font_size *= .70;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ // update all zoom box attributes. Unfortunately we have to use that best fit way
|
|||
|
+ // to support RRDtool 1.2 and below. With RRDtool 1.3 or higher there would be a
|
|||
|
+ // much more elegant solution available. (see RRDdtool graph option "graphv")
|
|||
|
+ zoom.box.width = zoom.graph.width;
|
|||
|
+ zoom.box.height = zoom.graph.height;
|
|||
|
+
|
|||
|
+ if(zoom.graph.title_font_size == null) {
|
|||
|
+ zoom.box.top = 32 - 1;
|
|||
|
+ }else {
|
|||
|
+ //default multiplier
|
|||
|
+ var multiplier = 2.4;
|
|||
|
+ // array of "best fit" multipliers
|
|||
|
+ multipliers = new Array("-5", "-2", "0", "1.7", "1.6", "1.7", "1.8", "1.9", "2", "2", "2.1", "2.1", "2.2", "2.2", "2.3", "2.3", "2.3", "2.3", "2.3");
|
|||
|
+ if(multipliers[Math.round(zoom.graph.title_font_size)] != null) {
|
|||
|
+ multiplier = multipliers[Math.round(zoom.graph.title_font_size)];
|
|||
|
+ }
|
|||
|
+ zoom.box.top = zoom.image.top + parseInt(Math.abs(zoom.graph.title_font_size) * multiplier) + 15;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ zoom.box.bottom = zoom.box.top + zoom.box.height;
|
|||
|
+ zoom.box.right = zoom.image.left + zoom.image.width - 30;
|
|||
|
+ zoom.box.left = zoom.box.right - zoom.graph.width;
|
|||
|
+
|
|||
|
+ // add all additional HTML elements to the DOM if necessary and register
|
|||
|
+ // the individual events needed. Once added we will only reset
|
|||
|
+ // and reposition these elements.
|
|||
|
+
|
|||
|
+ // add the "zoomBox"
|
|||
|
+ if($("#zoom-box").length == 0) {
|
|||
|
+ // Please note: IE does not fire hover or click behaviors on completely transparent elements.
|
|||
|
+ // Use a background color and set opacity to 1% as a workaround.(see CSS file)
|
|||
|
+ $("<div id='zoom-box'></div>").appendTo("body");
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ // add the "zoomSelectedArea"
|
|||
|
+ if($("#zoom-area").length == 0) {
|
|||
|
+ $("<div id='zoom-area'></div>").appendTo("body");
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ // add two markers for the advanced mode
|
|||
|
+ if($("#zoom-marker-1").length == 0) {
|
|||
|
+ $('<div id="zoom-excluded-area-1" class="zoom-area-excluded"></div>').appendTo("body");
|
|||
|
+ $('<div class="zoom-marker" id="zoom-marker-1"><div class="zoom-marker-arrow-down"></div><div class="zoom-marker-arrow-up"></div></div>').appendTo("body");
|
|||
|
+ $('<div id="zoom-marker-tooltip-1" class="zoom-marker-tooltip"><div id="zoom-marker-tooltip-1-arrow-left" class="zoom-marker-tooltip-arrow-left"><div id="zoom-marker-tooltip-1-arrow-left-inner" class="zoom-marker-tooltip-arrow-left-inner"></div></div><span id="zoom-marker-tooltip-value-1" class="zoom-marker-tooltip-value">-</span><div id="zoom-marker-tooltip-1-arrow-right" class="zoom-marker-tooltip-arrow-right"><div id="zoom-marker-tooltip-1-arrow-right-inner" class="zoom-marker-tooltip-arrow-right-inner"></div></div></div>').appendTo('body');
|
|||
|
+ }
|
|||
|
+ if($("#zoom-marker-2").length == 0) {
|
|||
|
+ $('<div id="zoom-excluded-area-2" class="zoom-area-excluded"></div>').appendTo("body");
|
|||
|
+ $('<div class="zoom-marker" id="zoom-marker-2"><div class="zoom-marker-arrow-down"></div><div class="zoom-marker-arrow-up"></div></div>').appendTo("body");
|
|||
|
+ $('<div id="zoom-marker-tooltip-2" class="zoom-marker-tooltip"><div id="zoom-marker-tooltip-2-arrow-left" class="zoom-marker-tooltip-arrow-left"><div id="zoom-marker-tooltip-1-arrow-left-inner" class="zoom-marker-tooltip-arrow-left-inner"></div></div><span id="zoom-marker-tooltip-value-2" class="zoom-marker-tooltip-value">-</span><div id="zoom-marker-tooltip-2-arrow-right" class="zoom-marker-tooltip-arrow-right"><div id="zoom-marker-tooltip-2-arrow-right-inner" class="zoom-marker-tooltip-arrow-right-inner"></div></div></div>').appendTo('body');
|
|||
|
+ }
|
|||
|
+ zoom.marker[1].placed = false;
|
|||
|
+ zoom.marker[2].placed = false;
|
|||
|
+
|
|||
|
+ // add the context (right click) menu
|
|||
|
+ if($("#zoom-menu").length == 0) {
|
|||
|
+ $('<div id="zoom-menu" class="zoom-menu">'
|
|||
|
+ + '<div class="first_li">'
|
|||
|
+ + '<div class="ui-icon ui-icon-zoomin"></div>'
|
|||
|
+ + '<span class="zoomContextMenuAction__zoom_in">Zoom In</span>'
|
|||
|
+ + '</div>'
|
|||
|
+ + '<div class="first_li">'
|
|||
|
+ + '<div class="ui-icon ui-icon-zoomout"></div>'
|
|||
|
+ + '<span class="zoomContextMenuAction__zoom_out">Zoom Out (2x)</span>'
|
|||
|
+ + '<div class="inner_li advanced_mode">'
|
|||
|
+ + '<span class="zoomContextMenuAction__zoom_out__2">2x</span>'
|
|||
|
+ + '<span class="zoomContextMenuAction__zoom_out__4">4x</span>'
|
|||
|
+ + '<span class="zoomContextMenuAction__zoom_out__8">8x</span>'
|
|||
|
+ + '<span class="zoomContextMenuAction__zoom_out__16">16x</span>'
|
|||
|
+ + '<span class="zoomContextMenuAction__zoom_out__32">32x</span>'
|
|||
|
+ + '</div>'
|
|||
|
+ + '</div>'
|
|||
|
+ + '<div class="sep_li"></div>'
|
|||
|
+ + '<div class="first_li">'
|
|||
|
+ + '<div class="ui-icon ui-icon-empty"></div><span>Zoom Mode</span>'
|
|||
|
+ + '<div class="inner_li">'
|
|||
|
+ + '<span class="zoomContextMenuAction__set_zoomMode__quick">Quick</span>'
|
|||
|
+ + '<span class="zoomContextMenuAction__set_zoomMode__advanced">Advanced</span>'
|
|||
|
+ + '</div>'
|
|||
|
+ + '</div>'
|
|||
|
+ + '<div class="first_li advanced_mode">'
|
|||
|
+ + '<div class="ui-icon ui-icon-wrench"></div><span>Settings</span>'
|
|||
|
+ + '<div class="inner_li">'
|
|||
|
+ + '<div class="sec_li"><span>Markers</span>'
|
|||
|
+ + '<div class="inner_li advanced_mode">'
|
|||
|
+ + '<span class="zoomContextMenuAction__set_zoomMarkers__on">Enabled</span>'
|
|||
|
+ + '<span class="zoomContextMenuAction__set_zoomMarkers__off">Disabled</span>'
|
|||
|
+ + '</div>'
|
|||
|
+ + '</div>'
|
|||
|
+ + '<div class="sec_li"><span>Timestamps</span></span>'
|
|||
|
+ + '<div class="inner_li advanced_mode">'
|
|||
|
+ + '<span class="zoomContextMenuAction__set_zoomTimestamps__on">Always On</span>'
|
|||
|
+ + '<span class="zoomContextMenuAction__set_zoomTimestamps__auto">Auto</span>'
|
|||
|
+ + '<span class="zoomContextMenuAction__set_zoomTimestamps__off">Always Off</span>'
|
|||
|
+ + '</div>'
|
|||
|
+ + '</div>'
|
|||
|
+ + '<div class="sep_li"></div>'
|
|||
|
+ + '<div class="sec_li"><span>Zoom Out Factor</span>'
|
|||
|
+ + '<div class="inner_li advanced_mode">'
|
|||
|
+ + '<span class="zoomContextMenuAction__set_zoomOutFactor__2">2x</span>'
|
|||
|
+ + '<span class="zoomContextMenuAction__set_zoomOutFactor__4">4x</span>'
|
|||
|
+ + '<span class="zoomContextMenuAction__set_zoomOutFactor__8">8x</span>'
|
|||
|
+ + '<span class="zoomContextMenuAction__set_zoomOutFactor__16">16x</span>'
|
|||
|
+ + '<span class="zoomContextMenuAction__set_zoomOutFactor__32">32x</span>'
|
|||
|
+ + '</div>'
|
|||
|
+ + '</div>'
|
|||
|
+ + '<div class="sec_li"><span>Zoom Out Positioning</span>'
|
|||
|
+ + '<div class="inner_li advanced_mode">'
|
|||
|
+ + '<span class="zoomContextMenuAction__set_zoomOutPositioning__begin">Begin with</span>'
|
|||
|
+ + '<span class="zoomContextMenuAction__set_zoomOutPositioning__center">Center</span>'
|
|||
|
+ + '<span class="zoomContextMenuAction__set_zoomOutPositioning__end">End with</span>'
|
|||
|
+ + '</div>'
|
|||
|
+ + '</div>'
|
|||
|
+ + '<div class="sec_li"><span>3rd Mouse Button</span>'
|
|||
|
+ + '<div class="inner_li advanced_mode">'
|
|||
|
+ + '<span class="zoomContextMenuAction__set_zoom3rdMouseButton__zoom_in">Zoom in</span>'
|
|||
|
+ + '<span class="zoomContextMenuAction__set_zoom3rdMouseButton__zoom_out">Zoom out</span>'
|
|||
|
+ + '<span class="zoomContextMenuAction__set_zoom3rdMouseButton__off">Disabled</span>'
|
|||
|
+ + '</div>'
|
|||
|
+ + '</div>'
|
|||
|
+ + '</div>'
|
|||
|
+ + '</div>'
|
|||
|
+ + '<div class="sep_li"></div>'
|
|||
|
+ + '<div class="first_li">'
|
|||
|
+ + '<div class="ui-icon ui-icon-close"></div><span class="zoomContextMenuAction__close">Close</span>'
|
|||
|
+ + '</div>').appendTo('body');
|
|||
|
+ }
|
|||
|
+ zoomElemtents_reset()
|
|||
|
+ zoomContextMenu_init();
|
|||
|
+ zoomAction_init(image);
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ /**
|
|||
|
+ * resets all elements of Zoom
|
|||
|
+ **/
|
|||
|
+ function zoomElemtents_reset() {
|
|||
|
+ zoom.marker = { 1 : { placed:false }, 2 : { placed:false} };
|
|||
|
+ $('div[id^="zoom-"]').not('#zoom-menu').each( function () {
|
|||
|
+ $(this).removeAttr('style');
|
|||
|
+ });
|
|||
|
+ $("#zoom-box").off();
|
|||
|
+ $("#zoom-box").css({ cursor:'crosshair', width:zoom.box.width + 'px', height:zoom.box.height + 'px', top:zoom.box.top+'px', left:zoom.box.left+'px' });
|
|||
|
+ $("#zoom-box").bind('contextmenu', function(e) { zoomContextMenu_show(e); return false;} );
|
|||
|
+ $("#zoom-area").off().css({ top:zoom.box.top+'px', height:zoom.box.height+'px' });
|
|||
|
+ $(".zoom-area-excluded").off();
|
|||
|
+ $(".zoom-area-excluded").bind('contextmenu', function(e) { zoomContextMenu_show(e); return false;} );
|
|||
|
+ $(".zoom-area-excluded").bind('click', function(e) { zoomContextMenu_hide(); return false;} );
|
|||
|
+ $(".zoom-marker-arrow-up").css({ top:(zoom.box.height-6) + 'px' });
|
|||
|
+ $(".zoom-marker-tooltip-value").disableSelection();
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ /*
|
|||
|
+ * registers all the different mouse click event handler
|
|||
|
+ */
|
|||
|
+ function zoomAction_init(image) {
|
|||
|
+
|
|||
|
+ if(zoom.custom.zoomMode == 'quick') {
|
|||
|
+ $("#zoom-box").off("mousedown").on("mousedown", function(e) {
|
|||
|
+ switch(e.which) {
|
|||
|
+ /* clicking the left mouse button will initiates a zoom-in */
|
|||
|
+ case 1:
|
|||
|
+ zoomContextMenu_hide();
|
|||
|
+ // reset the zoom area
|
|||
|
+ zoom.attr.start = e.pageX;
|
|||
|
+ if(zoom.custom.zoomMode != 'quick') {
|
|||
|
+ $("#zoom-marker-1").css({ height:zoom.box.height+'px', top:zoom.box.top+'px', left:zoom.attr.start+'px', display:'block' });
|
|||
|
+ $("#zoom-marker-tooltip-1").css({ top:zoom.box.top+'px', left:zoom.attr.start+'px'});
|
|||
|
+ }
|
|||
|
+ $("#zoom-box").css({ cursor:'e-resize' });
|
|||
|
+ $("#zoom-area").css({ width:'0px', left:zoom.attr.start+'px' });
|
|||
|
+ break;
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+
|
|||
|
+ /* register the mouse up event */
|
|||
|
+ $("#zoom-area").off("mouseup").on("mouseup", function(e) {
|
|||
|
+ switch(e.which) {
|
|||
|
+ /* leaving the left mouse button will execute a zoom in */
|
|||
|
+ case 1:
|
|||
|
+ if(zoom.custom.zoomMode == 'quick' && zoom.attr.start != 'none') {
|
|||
|
+ zoomAction_zoom_in();
|
|||
|
+ }
|
|||
|
+ break;
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+
|
|||
|
+ /* stretch the zoom area in that direction the user moved the mouse pointer */
|
|||
|
+ $("#zoom-box").mousemove( function(e) { zoomAction_draw(e) } );
|
|||
|
+
|
|||
|
+ /* stretch the zoom area in that direction the user moved the mouse pointer.
|
|||
|
+ That is required to get it working faultlessly with Opera, IE and Chrome */
|
|||
|
+ $("#zoom-area").mousemove( function(e) { zoomAction_draw(e); } );
|
|||
|
+
|
|||
|
+ /* moving the mouse pointer quickly will avoid that the mousemove event has enough time to actualize the zoom area */
|
|||
|
+ $("#zoom-box").mouseout( function(e) { zoomAction_draw(e) } );
|
|||
|
+
|
|||
|
+ }else{
|
|||
|
+ /* welcome to the advanced mode ;) */
|
|||
|
+ $("#zoom-box").off("mousedown").on("mousedown", function(e) {
|
|||
|
+ switch(e.which) {
|
|||
|
+ case 1:
|
|||
|
+ /* hide context menu if open */
|
|||
|
+ zoomContextMenu_hide();
|
|||
|
+
|
|||
|
+ /* find out which marker has to be added */
|
|||
|
+ if(zoom.marker[1].placed && zoom.marker[2].placed) {
|
|||
|
+ zoomAction_zoom_in();
|
|||
|
+ return;
|
|||
|
+ }else {
|
|||
|
+ var marker = zoom.marker[1].placed ? 2 : 1;
|
|||
|
+ var secondmarker = (marker == 1) ? 2 : 1;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ /* select marker */
|
|||
|
+ var $this = $("#zoom-marker-" + marker);
|
|||
|
+
|
|||
|
+ /* place the marker and make it visible */
|
|||
|
+ $this.css({ height:zoom.box.height+'px', top:zoom.box.top+'px', left:e.pageX+'px', display:'block' });
|
|||
|
+ zoom.marker[marker].placed = true;
|
|||
|
+ zoom.marker[marker].left = e.pageX;
|
|||
|
+
|
|||
|
+ /* place the marker's tooltip, update its value and make it visible if necessary (Setting: "Always On") */
|
|||
|
+ zoom.marker[marker].unixtime = parseInt(parseInt(zoom.graph.start) + (e.pageX + 1 - zoom.box.left)*zoom.graph.secondsPerPixel);
|
|||
|
+ $("#zoom-marker-tooltip-value-" + marker).html(
|
|||
|
+ unixTime2Date(zoom.marker[marker].unixtime).replace(" ", "<br>")
|
|||
|
+ );
|
|||
|
+ zoom.marker[marker].width = $("#zoom-marker-tooltip-" + marker).width();
|
|||
|
+
|
|||
|
+ $("#zoom-marker-tooltip-" + marker).css({
|
|||
|
+ top: ( (marker == 1) ? zoom.box.top+3 : zoom.box.bottom-30 )+'px',
|
|||
|
+ left:( (marker == 1) ? e.pageX - zoom.marker[marker].width : e.pageX )+'px'}
|
|||
|
+ );
|
|||
|
+
|
|||
|
+ if(zoom.custom.zoomTimestamps === true) {
|
|||
|
+ $("#zoom-marker-tooltip-" + marker).fadeIn(500);
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ if(e.pageX == $("#zoom-marker-tooltip-" + marker).position().left) {
|
|||
|
+ $("#zoom-marker-tooltip-" + marker + "-arrow-right").css({ visibility:'hidden'});
|
|||
|
+ }else {
|
|||
|
+ $("#zoom-marker-tooltip-" + marker + "-arrow-left").css({ visibility:'hidden'});
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ /* make the excluded areas visible directly in that moment both markers are set */
|
|||
|
+ if(zoom.marker[1].placed && zoom.marker[2].placed) {
|
|||
|
+ zoom.marker.distance = zoom.marker[1].left - zoom.marker[2].left;
|
|||
|
+
|
|||
|
+ $("#zoom-excluded-area-1").css({
|
|||
|
+ height:zoom.box.height+'px',
|
|||
|
+ top:zoom.box.top+'px',
|
|||
|
+ left: (zoom.marker.distance > 0) ? zoom.marker[1].left : zoom.box.left,
|
|||
|
+ width: (zoom.marker.distance > 0) ? zoom.box.right - zoom.marker[1].left : zoom.marker[1].left - zoom.box.left,
|
|||
|
+ display:'block'
|
|||
|
+ });
|
|||
|
+
|
|||
|
+ $("#zoom-excluded-area-2").css({
|
|||
|
+ height:zoom.box.height+'px',
|
|||
|
+ top:zoom.box.top+'px',
|
|||
|
+ left: (zoom.marker.distance < 0) ? zoom.marker[2].left : zoom.box.left,
|
|||
|
+ width: (zoom.marker.distance < 0) ? zoom.box.right - zoom.marker[2].left : zoom.marker[2].left - zoom.box.left,
|
|||
|
+ display:'block'
|
|||
|
+ });
|
|||
|
+
|
|||
|
+ /* reposition both tooltips */
|
|||
|
+ $("#zoom-marker-tooltip-1").css({ left: $("#zoom-marker-1").position().left - ( (zoom.marker.distance > 0) ? 0 : $("#zoom-marker-tooltip-1").width() ) + 'px' });
|
|||
|
+ $("#zoom-marker-tooltip-1-arrow-left").css({ visibility: (($("#zoom-marker-tooltip-1").position().left < $("#zoom-marker-1").position().left ) ? 'hidden' : 'visible') });
|
|||
|
+ $("#zoom-marker-tooltip-1-arrow-right").css({ visibility: (($("#zoom-marker-tooltip-1").position().left < $("#zoom-marker-1").position().left ) ? 'visible' : 'hidden') });
|
|||
|
+
|
|||
|
+ $("#zoom-marker-tooltip-2").css({ left: $("#zoom-marker-2").position().left - ( (zoom.marker.distance < 0) ? 0 : $("#zoom-marker-tooltip-2").width() ) + 'px' });
|
|||
|
+ $("#zoom-marker-tooltip-2-arrow-left").css({ visibility: (($("#zoom-marker-tooltip-2").position().left < $("#zoom-marker-2").position().left ) ? 'hidden' : 'visible') });
|
|||
|
+ $("#zoom-marker-tooltip-2-arrow-right").css({ visibility: (($("#zoom-marker-tooltip-2").position().left < $("#zoom-marker-2").position().left ) ? 'visible' : 'hidden') });
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ /* make the marker draggable */
|
|||
|
+ $this.draggable({
|
|||
|
+ containment:[ zoom.box.left-1, 0 , zoom.box.left+parseInt(zoom.box.width), 0 ],
|
|||
|
+ axis: "x",
|
|||
|
+ start:
|
|||
|
+ function(event, ui) {
|
|||
|
+ if(zoom.custom.zoomTimestamps == "auto") {
|
|||
|
+ $(".zoom-marker-tooltip").fadeIn(500);
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ drag:
|
|||
|
+ function(event, ui) {
|
|||
|
+
|
|||
|
+ zoom.marker[marker].left = ui.position["left"];
|
|||
|
+
|
|||
|
+ /* update the timestamp shown in tooltip */
|
|||
|
+ zoom.marker[marker].unixtime = parseInt(parseInt(zoom.graph.start) + (zoom.marker[marker].left + 1 - zoom.box.left)*zoom.graph.secondsPerPixel);
|
|||
|
+ $("#zoom-marker-tooltip-value-" + marker).html(
|
|||
|
+ unixTime2Date(zoom.marker[marker].unixtime).replace(" ", "<br>")
|
|||
|
+ );
|
|||
|
+
|
|||
|
+ zoom.marker[marker].width = $("#zoom-marker-tooltip-" + marker).width();
|
|||
|
+
|
|||
|
+ /* update the execludedArea if both markers have been placed */
|
|||
|
+ if(zoom.marker[1].placed && zoom.marker[2].placed) {
|
|||
|
+ zoom.marker.distance = zoom.marker[marker].left - zoom.marker[secondmarker].left;
|
|||
|
+
|
|||
|
+ if( zoom.marker.distance > 0 ) {
|
|||
|
+ zoom.marker[marker].excludeArea = 'right';
|
|||
|
+ zoom.marker[secondmarker].excludeArea = 'left';
|
|||
|
+ }else {
|
|||
|
+ zoom.marker[marker].excludeArea = 'left';
|
|||
|
+ zoom.marker[secondmarker].excludeArea = 'right';
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ /* in that case we have to update the tooltip of both marker */
|
|||
|
+ $("#zoom-excluded-area-" + marker).css({ left: (zoom.marker.distance > 0) ? zoom.marker[marker].left : zoom.box.left, width: (zoom.marker.distance > 0) ? zoom.box.right - zoom.marker[marker].left : zoom.marker[marker].left - zoom.box.left});
|
|||
|
+ $("#zoom-marker-tooltip-" + marker).css({ left: zoom.marker[marker].left + ( (zoom.marker[marker].excludeArea == 'right') ? (0) : (-zoom.marker[marker].width) ) });
|
|||
|
+ $("#zoom-marker-tooltip-" + marker + "-arrow-left").css({ visibility: ( zoom.marker[marker].excludeArea == 'left' ? 'hidden' : 'visible') });
|
|||
|
+ $("#zoom-marker-tooltip-" + marker + "-arrow-right").css({ visibility: ( zoom.marker[marker].excludeArea == 'left' ? 'visible' : 'hidden') });
|
|||
|
+
|
|||
|
+ $("#zoom-excluded-area-" + secondmarker).css({ left: (zoom.marker.distance > 0) ? zoom.box.left : zoom.marker[secondmarker].left, width: (zoom.marker.distance > 0) ? zoom.marker[secondmarker].left - zoom.box.left : zoom.box.right - zoom.marker[secondmarker].left});
|
|||
|
+ $("#zoom-marker-tooltip-" + secondmarker ).css({ left: zoom.marker[secondmarker].left + ( (zoom.marker[secondmarker].excludeArea == 'right') ? (0) : (-zoom.marker[secondmarker].width) ) });
|
|||
|
+ $("#zoom-marker-tooltip-" + secondmarker + "-arrow-left").css({ visibility: ( zoom.marker[secondmarker].excludeArea == 'left' ? 'hidden' : 'visible') });
|
|||
|
+ $("#zoom-marker-tooltip-" + secondmarker + "-arrow-right").css({ visibility: ( zoom.marker[secondmarker].excludeArea == 'left' ? 'visible' : 'hidden') });
|
|||
|
+
|
|||
|
+ }else {
|
|||
|
+ /* let the tooltip follow its marker */
|
|||
|
+ $("#zoom-marker-tooltip-" + marker).css({ left: zoom.marker[marker].left -zoom.marker[marker].width });
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ },
|
|||
|
+ stop:
|
|||
|
+ function(event,ui) {
|
|||
|
+ /* hide all tooltip if we are in auto mode */
|
|||
|
+ if(zoom.custom.zoomTimestamps == "auto") {
|
|||
|
+ $(".zoom-marker-tooltip").fadeOut(1000);
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ });
|
|||
|
+
|
|||
|
+ break;
|
|||
|
+ case 2:
|
|||
|
+ if(zoom.custom.zoom3rdMouseButton != false) {
|
|||
|
+ /* hide context menu if open */
|
|||
|
+ zoomContextMenu_hide();
|
|||
|
+ if(zoom.custom.zoom3rdMouseButton == "zoom_in") {
|
|||
|
+ zoomAction_zoom_in();
|
|||
|
+ }else {
|
|||
|
+ zoomAction_zoom_out( zoom.custom.zoomOutFactor );
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ break;
|
|||
|
+ }
|
|||
|
+ return false;
|
|||
|
+
|
|||
|
+ });
|
|||
|
+
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+
|
|||
|
+
|
|||
|
+ /*
|
|||
|
+ * executes a dynamic zoom in
|
|||
|
+ */
|
|||
|
+ function zoomAction_zoom_in(){
|
|||
|
+
|
|||
|
+ /* hide context menu if open */
|
|||
|
+ zoomContextMenu_hide();
|
|||
|
+
|
|||
|
+ if(zoom.custom.zoomMode == 'quick') {
|
|||
|
+
|
|||
|
+ var newGraphStartTime = (zoom.attr.action == 'left2right') ? parseInt(parseInt(zoom.graph.start) + (zoom.attr.start - zoom.box.left)*zoom.graph.secondsPerPixel)
|
|||
|
+ : parseInt(parseInt(zoom.graph.start) + (zoom.attr.end - zoom.box.left)*zoom.graph.secondsPerPixel);
|
|||
|
+ var newGraphEndTime = (zoom.attr.action == 'left2right') ? parseInt(newGraphStartTime + (zoom.attr.end-zoom.attr.start)*zoom.graph.secondsPerPixel)
|
|||
|
+ : parseInt(newGraphStartTime + (zoom.attr.start-zoom.attr.end)*zoom.graph.secondsPerPixel);
|
|||
|
+
|
|||
|
+ /* If the user only clicked on a graph then equal end and start date to ensure that we do not propergate NaNs */
|
|||
|
+ if(isNaN(newGraphStartTime) & isNaN(newGraphEndTime)) {
|
|||
|
+ return;
|
|||
|
+ }else if(isNaN(newGraphStartTime) & !isNaN(newGraphEndTime)) {
|
|||
|
+ newGraphStartTime = newGraphEndTime;
|
|||
|
+ }else if(!isNaN(newGraphStartTime) & isNaN(newGraphEndTime)){
|
|||
|
+ newGraphEndTime = newGraphStartTime;
|
|||
|
+ }
|
|||
|
+ }else {
|
|||
|
+ /* advanced mode has other requirements */
|
|||
|
+ /* first of, do nothing if not both marker have been positioned */
|
|||
|
+ if(!zoom.marker[1].placed | !zoom.marker[2].placed) {
|
|||
|
+ alert("NOTE: In advanced mode both markers have to be positioned first to define the period of time you want to zoom in.");
|
|||
|
+ return;
|
|||
|
+ }else {
|
|||
|
+ var newGraphStartTime = zoom.marker[((zoom.marker[1].unixtime > zoom.marker[2].unixtime)? 2 : 1 )].unixtime;
|
|||
|
+ var newGraphEndTime = zoom.marker[((zoom.marker[1].unixtime > zoom.marker[2].unixtime)? 1 : 2 )].unixtime;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ if(zoom.options.inputfieldStartTime != '' & zoom.options.inputfieldEndTime != ''){
|
|||
|
+ /* execute zoom within "tree view" or the "preview view" */
|
|||
|
+ $('#' + zoom.options.inputfieldStartTime).val(unixTime2Date(newGraphStartTime));
|
|||
|
+ $('#' + zoom.options.inputfieldEndTime).val(unixTime2Date(newGraphEndTime));
|
|||
|
+
|
|||
|
+ $("input[name='" + zoom.options.submitButton + "']").trigger('click');
|
|||
|
+ return false;
|
|||
|
+ }else {
|
|||
|
+ /* graph view is alread in zoom status */
|
|||
|
+ open(zoom.attr.location[0] + "?action=" + zoom.graph.action + "&local_graph_id=" + zoom.graph.local_graph_id + "&rra_id=" + zoom.graph.rra_id + "&view_type=" + zoom.graph.view_type + "&graph_start=" + newGraphStartTime + "&graph_end=" + newGraphEndTime + "&graph_height=" + zoom.graph.height + "&graph_width=" + zoom.graph.width + "&title_font_size=" + zoom.graph.title_font_size, "_self");
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ }
|
|||
|
+
|
|||
|
+
|
|||
|
+
|
|||
|
+
|
|||
|
+ /*
|
|||
|
+ * executes a static zoom out (as right click event)
|
|||
|
+ */
|
|||
|
+ function zoomAction_zoom_out(multiplier){
|
|||
|
+
|
|||
|
+ multiplier--;
|
|||
|
+ /* avoid that we can not zoom out anymore if start and end date will be equal */
|
|||
|
+ if(zoom.graph.timespan == 0) {
|
|||
|
+ zoom.graph.timespan = 1;
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ if(zoom.custom.zoomMode == 'quick' || !zoom.marker[1].placed || !zoom.marker[2].placed ) {
|
|||
|
+ if(zoom.custom.zoomOutPositioning == 'begin') {
|
|||
|
+ var newGraphStartTime = parseInt(zoom.graph.start);
|
|||
|
+ var newGraphEndTime = parseInt(parseInt(zoom.graph.end) + (multiplier * zoom.graph.timespan));
|
|||
|
+ }else if(zoom.custom.zoomOutPositioning == 'end') {
|
|||
|
+ var newGraphStartTime = parseInt(parseInt(zoom.graph.start) - (multiplier * zoom.graph.timespan));
|
|||
|
+ var newGraphEndTime = parseInt(zoom.graph.end);
|
|||
|
+ }else {
|
|||
|
+ // define the new start and end time, so that the selected area will be centered per default
|
|||
|
+ var newGraphStartTime = parseInt(parseInt(zoom.graph.start) - (0.5 * multiplier * zoom.graph.timespan));
|
|||
|
+ var newGraphEndTime = parseInt(parseInt(zoom.graph.end) + (0.5 * multiplier * zoom.graph.timespan));
|
|||
|
+ }
|
|||
|
+ }else {
|
|||
|
+ var newGraphStartTime = zoom.marker[((zoom.marker[1].unixtime > zoom.marker[2].unixtime)? 2 : 1 )].unixtime;
|
|||
|
+ var newGraphEndTime = zoom.marker[((zoom.marker[1].unixtime > zoom.marker[2].unixtime)? 1 : 2 )].unixtime;
|
|||
|
+ var selectedTimeSpan = newGraphEndTime - newGraphStartTime;
|
|||
|
+
|
|||
|
+ if(zoom.custom.zoomOutPositioning == 'begin') {
|
|||
|
+ newGraphEndTime = newGraphEndTime + multiplier * selectedTimeSpan;
|
|||
|
+ }else if(zoom.custom.zoomOutPositioning == 'end') {
|
|||
|
+ newGraphStartTime = newGraphStartTime - multiplier * selectedTimeSpan;
|
|||
|
+ }else {
|
|||
|
+ newGraphStartTime = newGraphStartTime - 0.5 * multiplier * selectedTimeSpan;
|
|||
|
+ newGraphEndTime = newGraphEndTime + 0.5 * multiplier * selectedTimeSpan;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ if(zoom.options.inputfieldStartTime != '' & zoom.options.inputfieldEndTime != ''){
|
|||
|
+ $('#' + zoom.options.inputfieldStartTime).val(unixTime2Date(newGraphStartTime));
|
|||
|
+ $('#' + zoom.options.inputfieldEndTime).val(unixTime2Date(newGraphEndTime));
|
|||
|
+ $('#' + zoom.options.inputfieldStartTime).closest("form").submit();
|
|||
|
+ }else {
|
|||
|
+ open(zoom.attr.location[0] + "?action=" + zoom.graph.action + "&local_graph_id=" + zoom.graph.local_graph_id + "&rra_id=" + zoom.graph.rra_id + "&view_type=" + zoom.graph.view_type + "&graph_start=" + newGraphStartTime + "&graph_end=" + newGraphEndTime + "&graph_height=" + zoom.graph.height + "&graph_width=" + zoom.graph.width + "&title_font_size=" + zoom.graph.title_font_size, "_self");
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+
|
|||
|
+
|
|||
|
+ /*
|
|||
|
+ * updates the css parameters of the zoom area to reflect user's interaction
|
|||
|
+ */
|
|||
|
+ function zoomAction_draw(event) {
|
|||
|
+
|
|||
|
+ if(zoom.attr.start == 'none') { return; }
|
|||
|
+
|
|||
|
+ /* mouse has been moved from right to left */
|
|||
|
+ if((event.pageX-zoom.attr.start)<0) {
|
|||
|
+ zoom.attr.action = 'right2left';
|
|||
|
+ zoom.attr.end = (event.pageX < zoom.box.left) ? zoom.box.left : event.pageX;
|
|||
|
+ $("#zoom-area").css({ background:'red', left:(zoom.attr.end+1)+'px', width:Math.abs(zoom.attr.start-zoom.attr.end-1)+'px' });
|
|||
|
+ /* mouse has been moved from left to right*/
|
|||
|
+ }else {
|
|||
|
+ zoom.attr.action = 'left2right';
|
|||
|
+ zoom.attr.end = (event.pageX > zoom.box.right) ? zoom.box.right : event.pageX;
|
|||
|
+ $("#zoom-area").css({ background:'red', left:zoom.attr.start+'px', width:Math.abs(zoom.attr.end-zoom.attr.start-1)+'px' });
|
|||
|
+ }
|
|||
|
+ /* move second marker if necessary */
|
|||
|
+ if(zoom.custom.zoomMode != 'quick') {
|
|||
|
+ $("#zoom-marker-2").css({ left:(zoom.attr.end+1)+'px' });
|
|||
|
+ $("#zoom-marker-tooltip-2").css({ top:zoom.box.top+'px', left:(zoom.attr.end-5)+'px' });
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ /**
|
|||
|
+ *
|
|||
|
+ * @access public
|
|||
|
+ * @return void
|
|||
|
+ **/
|
|||
|
+ function zoomContextMenu_init(){
|
|||
|
+
|
|||
|
+ /* sync menu with cookie parameters */
|
|||
|
+ $(".zoomContextMenuAction__set_zoomMode__" + zoom.custom.zoomMode).addClass("ui-state-highlight");
|
|||
|
+ $(".zoomContextMenuAction__set_zoomMarkers__" + ((zoom.custom.zoomMarkers === true) ? "on" : "off") ).addClass("ui-state-highlight");
|
|||
|
+ $(".zoomContextMenuAction__set_zoomTimestamps__" + ((zoom.custom.zoomTimestamps == 'auto') ? "auto" : ((zoom.custom.zoomTimestamps) ? "on" : "off" ))).addClass("ui-state-highlight");
|
|||
|
+ $(".zoomContextMenuAction__set_zoomOutFactor__" + zoom.custom.zoomOutFactor).addClass("ui-state-highlight");
|
|||
|
+ $(".zoomContextMenuAction__set_zoomOutPositioning__" + zoom.custom.zoomOutPositioning).addClass("ui-state-highlight");
|
|||
|
+ $(".zoomContextMenuAction__set_zoom3rdMouseButton__" + ((zoom.custom.zoom3rdMouseButton === false) ? "off" : zoom.custom.zoom3rdMouseButton) ).addClass("ui-state-highlight");
|
|||
|
+
|
|||
|
+ if(zoom.custom.zoomMode == "quick") {
|
|||
|
+ $("#zoom-menu > .advanced_mode").hide();
|
|||
|
+ }else {
|
|||
|
+ $(".zoomContextMenuAction__zoom_out").text("Zoom Out (" + zoom.custom.zoomOutFactor + "x)");
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ /* init click on events */
|
|||
|
+ $('[class*=zoomContextMenuAction__]').off().on('click', function() {
|
|||
|
+ var zoomContextMenuAction = false;
|
|||
|
+ var zoomContextMenuActionValue = false;
|
|||
|
+ var classList = $(this).attr('class').trim().split(/\s+/);
|
|||
|
+
|
|||
|
+ $.each( classList, function(index, item){
|
|||
|
+ if( item.search("zoomContextMenuAction__") != -1) {
|
|||
|
+ zoomContextMenuActionList = item.replace("zoomContextMenuAction__", "").split("__");
|
|||
|
+ zoomContextMenuAction = zoomContextMenuActionList[0];
|
|||
|
+ if(zoomContextMenuActionList[1] == 'undefined' || zoomContextMenuActionList[1] == 'off') {
|
|||
|
+ zoomContextMenuActionValue = false;
|
|||
|
+ }else if(zoomContextMenuActionList[1] == 'on') {
|
|||
|
+ zoomContextMenuActionValue = true;
|
|||
|
+ }else {
|
|||
|
+ zoomContextMenuActionValue = zoomContextMenuActionList[1];
|
|||
|
+ }
|
|||
|
+ return( false );
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+
|
|||
|
+ if( zoomContextMenuAction ) {
|
|||
|
+ if( zoomContextMenuAction.substring(0,8) == "set_zoom") {
|
|||
|
+ zoomContextMenuAction_set( zoomContextMenuAction.replace("set_zoom", "").toLowerCase(), zoomContextMenuActionValue);
|
|||
|
+ }else {
|
|||
|
+ zoomContextMenuAction_do( zoomContextMenuAction, zoomContextMenuActionValue);
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ });
|
|||
|
+
|
|||
|
+ /* init hover events */
|
|||
|
+ $(".first_li , .sec_li, .inner_li span").hover(
|
|||
|
+ function () {
|
|||
|
+ $(this).css({backgroundColor : '#E0EDFE' , cursor : 'pointer'});
|
|||
|
+ if ( $(this).children().size() >0 )
|
|||
|
+ if(zoom.custom.zoomMode == "quick") {
|
|||
|
+ $(this).children('.inner_li:not(.advanced_mode)').show();
|
|||
|
+ }else {
|
|||
|
+ $(this).children('.inner_li').show();
|
|||
|
+ }
|
|||
|
+ },
|
|||
|
+ function () {
|
|||
|
+ $(this).css('background-color' , '#fff' );
|
|||
|
+ $(this).children('.inner_li').hide();
|
|||
|
+ }
|
|||
|
+ );
|
|||
|
+ };
|
|||
|
+
|
|||
|
+ /**
|
|||
|
+ *
|
|||
|
+ * @access public
|
|||
|
+ * @return void
|
|||
|
+ **/
|
|||
|
+ function zoomContextMenuAction_set(object, value){
|
|||
|
+ switch(object) {
|
|||
|
+ case "mode":
|
|||
|
+ if( zoom.custom.zoomMode != value) {
|
|||
|
+ zoom.custom.zoomMode = value;
|
|||
|
+ $('[class*=zoomContextMenuAction__set_zoomMode__]').toggleClass("ui-state-highlight");
|
|||
|
+
|
|||
|
+ if(value == "quick") {
|
|||
|
+ // reset menu
|
|||
|
+ $("#zoom-menu > .advanced_mode").hide();
|
|||
|
+ $(".zoomContextMenuAction__zoom_out").text("Zoom Out (2x)");
|
|||
|
+
|
|||
|
+ zoom.custom.zoomMode = 'quick';
|
|||
|
+ $.cookie( zoom.options.cookieName, serialize(zoom.custom));
|
|||
|
+ }else {
|
|||
|
+ // switch to advanced mode
|
|||
|
+ $("#zoom-menu > .advanced_mode").show();
|
|||
|
+ $(".zoomContextMenuAction__zoom_out").text("Zoom Out (" + + zoom.custom.zoomOutFactor + "x)");
|
|||
|
+
|
|||
|
+ zoom.custom.zoomMode = 'advanced';
|
|||
|
+ $.cookie( zoom.options.cookieName, serialize(zoom.custom));
|
|||
|
+ }
|
|||
|
+ zoomElemtents_reset();
|
|||
|
+ zoomAction_init(zoom.initiator);
|
|||
|
+
|
|||
|
+ }
|
|||
|
+ break;
|
|||
|
+ case "markers":
|
|||
|
+ if( zoom.custom.zoomMarkers != value) {
|
|||
|
+ zoom.custom.zoomMarkers = value;
|
|||
|
+ $.cookie( zoom.options.cookieName, serialize(zoom.custom));
|
|||
|
+ $('[class*=zoomContextMenuAction__set_zoomMarkers__]').toggleClass('ui-state-highlight');
|
|||
|
+ }
|
|||
|
+ break;
|
|||
|
+ case "timestamps":
|
|||
|
+ if( zoom.custom.zoomTimestamps != value) {
|
|||
|
+ zoom.custom.zoomTimestamps = value;
|
|||
|
+ $.cookie( zoom.options.cookieName, serialize(zoom.custom));
|
|||
|
+ $('[class*=zoomContextMenuAction__set_zoomTimestamps__]').removeClass('ui-state-highlight');
|
|||
|
+ $('.zoomContextMenuAction__set_zoomTimestamps__' + ((zoom.custom.zoomTimestamps == 'auto') ? "auto" : ((zoom.custom.zoomTimestamps) ? "on" : "off" ))).addClass('ui-state-highlight');
|
|||
|
+
|
|||
|
+ /* make them visible only for mode "Always On" */
|
|||
|
+ if(zoom.custom.zoomTimestamps === true) {
|
|||
|
+ $('.zoom-marker-tooltip').fadeIn(500);
|
|||
|
+ }else {
|
|||
|
+ $('.zoom-marker-tooltip').fadeOut(500);
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+ break;
|
|||
|
+ case "outfactor":
|
|||
|
+ if( zoom.custom.zoomOutFactor != value) {
|
|||
|
+ zoom.custom.zoomOutFactor = value;
|
|||
|
+ $.cookie( zoom.options.cookieName, serialize(zoom.custom));
|
|||
|
+ $('[class*=zoomContextMenuAction__set_zoomOutFactor__]').removeClass('ui-state-highlight');
|
|||
|
+ $('.zoomContextMenuAction__set_zoomOutFactor__' + value).addClass('ui-state-highlight');
|
|||
|
+ $('.zoomContextMenuAction__zoom_out').text('Zoom Out (' + value + 'x)');
|
|||
|
+ }
|
|||
|
+ break;
|
|||
|
+ case "outpositioning":
|
|||
|
+ if( zoom.custom.zoomOutPositioning != value) {
|
|||
|
+ zoom.custom.zoomOutPositioning = value;
|
|||
|
+ $.cookie( zoom.options.cookieName, serialize(zoom.custom));
|
|||
|
+ $('[class*=zoomContextMenuAction__set_zoomOutPositioning__]').removeClass('ui-state-highlight');
|
|||
|
+ $('.zoomContextMenuAction__set_zoomOutPositioning__' + value).addClass('ui-state-highlight');
|
|||
|
+ }
|
|||
|
+ break;
|
|||
|
+ case "3rdmousebutton":
|
|||
|
+ if( zoom.custom.zoom3rdMouseButton != value) {
|
|||
|
+ zoom.custom.zoom3rdMouseButton = value;
|
|||
|
+ $.cookie( zoom.options.cookieName, serialize(zoom.custom));
|
|||
|
+ $('[class*=zoomContextMenuAction__set_zoom3rdMouseButton__]').removeClass('ui-state-highlight');
|
|||
|
+ $('.zoomContextMenuAction__set_zoom3rdMouseButton__' + ((value === false) ? "off" : value)).addClass('ui-state-highlight');
|
|||
|
+ }
|
|||
|
+ break;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ function zoomContextMenuAction_do(action, value){
|
|||
|
+ switch(action) {
|
|||
|
+ case "close":
|
|||
|
+ zoomContextMenu_hide();
|
|||
|
+ break;
|
|||
|
+ case "zoom_out":
|
|||
|
+ if(value == undefined) {
|
|||
|
+ value = (zoom.custom.zoomMode != "quick") ? zoom.custom.zoomOutFactor : 2;
|
|||
|
+ }
|
|||
|
+ zoomAction_zoom_out(value);
|
|||
|
+ break;
|
|||
|
+ case "zoom_in":
|
|||
|
+ zoomAction_zoom_in();
|
|||
|
+ break;
|
|||
|
+ }
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ function zoomContextMenu_show(e){
|
|||
|
+ $("#zoom-menu").css({ left: e.pageX, top: e.pageY, zIndex: '101' }).show();
|
|||
|
+ };
|
|||
|
+
|
|||
|
+ function zoomContextMenu_hide(){
|
|||
|
+ $('#zoom-menu').hide();
|
|||
|
+ }
|
|||
|
+
|
|||
|
+ };
|
|||
|
+
|
|||
|
+})(jQuery);
|
|||
|
\ No newline at end of file
|
|||
|
diff -up cacti-0.8.8a/include/js/jquery/themes/default/d.gif.legal cacti-0.8.8a/include/js/jquery/themes/default/d.gif
|
|||
|
Binary files cacti-0.8.8a/include/js/jquery/themes/default/d.gif.legal and cacti-0.8.8a/include/js/jquery/themes/default/d.gif differ
|
|||
|
diff -up cacti-0.8.8a/include/js/jquery/themes/default/d.png.legal cacti-0.8.8a/include/js/jquery/themes/default/d.png
|
|||
|
Binary files cacti-0.8.8a/include/js/jquery/themes/default/d.png.legal and cacti-0.8.8a/include/js/jquery/themes/default/d.png differ
|
|||
|
diff -up cacti-0.8.8a/include/js/jquery/themes/default/style.css.legal cacti-0.8.8a/include/js/jquery/themes/default/style.css
|
|||
|
--- cacti-0.8.8a/include/js/jquery/themes/default/style.css.legal 2013-01-04 15:44:49.350420872 -0500
|
|||
|
+++ cacti-0.8.8a/include/js/jquery/themes/default/style.css 2013-01-04 15:44:08.391403304 -0500
|
|||
|
@@ -0,0 +1,74 @@
|
|||
|
+/*
|
|||
|
+ * jsTree default theme 1.0
|
|||
|
+ * Supported features: dots/no-dots, icons/no-icons, focused, loading
|
|||
|
+ * Supported plugins: ui (hovered, clicked), checkbox, contextmenu, search
|
|||
|
+ */
|
|||
|
+
|
|||
|
+.jstree-default li,
|
|||
|
+.jstree-default ins { background-image:url("d.png"); background-repeat:no-repeat; background-color:transparent; }
|
|||
|
+.jstree-default li { background-position:-90px 0; background-repeat:repeat-y; }
|
|||
|
+.jstree-default li.jstree-last { background:transparent; }
|
|||
|
+.jstree-default .jstree-open > ins { background-position:-72px 0; }
|
|||
|
+.jstree-default .jstree-closed > ins { background-position:-54px 0; }
|
|||
|
+.jstree-default .jstree-leaf > ins { background-position:-36px 0; }
|
|||
|
+
|
|||
|
+.jstree-default .jstree-hovered { background:#e7f4f9; border:1px solid #d8f0fa; padding:0 2px 0 1px; }
|
|||
|
+.jstree-default .jstree-clicked { background:#beebff; border:1px solid #99defd; padding:0 2px 0 1px; }
|
|||
|
+.jstree-default a .jstree-icon { background-position:-56px -19px; }
|
|||
|
+.jstree-default a.jstree-loading .jstree-icon { background:url("throbber.gif") center center no-repeat !important; }
|
|||
|
+
|
|||
|
+.jstree-default.jstree-focused { background:#ffffee; }
|
|||
|
+
|
|||
|
+.jstree-default .jstree-no-dots li,
|
|||
|
+.jstree-default .jstree-no-dots .jstree-leaf > ins { background:transparent; }
|
|||
|
+.jstree-default .jstree-no-dots .jstree-open > ins { background-position:-18px 0; }
|
|||
|
+.jstree-default .jstree-no-dots .jstree-closed > ins { background-position:0 0; }
|
|||
|
+
|
|||
|
+.jstree-default .jstree-no-icons a .jstree-icon { display:none; }
|
|||
|
+
|
|||
|
+.jstree-default .jstree-search { font-style:italic; }
|
|||
|
+
|
|||
|
+.jstree-default .jstree-no-icons .jstree-checkbox { display:inline-block; }
|
|||
|
+.jstree-default .jstree-no-checkboxes .jstree-checkbox { display:none !important; }
|
|||
|
+.jstree-default .jstree-checked > a > .jstree-checkbox { background-position:-38px -19px; }
|
|||
|
+.jstree-default .jstree-unchecked > a > .jstree-checkbox { background-position:-2px -19px; }
|
|||
|
+.jstree-default .jstree-undetermined > a > .jstree-checkbox { background-position:-20px -19px; }
|
|||
|
+.jstree-default .jstree-checked > a > .jstree-checkbox:hover { background-position:-38px -37px; }
|
|||
|
+.jstree-default .jstree-unchecked > a > .jstree-checkbox:hover { background-position:-2px -37px; }
|
|||
|
+.jstree-default .jstree-undetermined > a > .jstree-checkbox:hover { background-position:-20px -37px; }
|
|||
|
+
|
|||
|
+#vakata-dragged.jstree-default ins { background:transparent !important; }
|
|||
|
+#vakata-dragged.jstree-default .jstree-ok { background:url("d.png") -2px -53px no-repeat !important; }
|
|||
|
+#vakata-dragged.jstree-default .jstree-invalid { background:url("d.png") -18px -53px no-repeat !important; }
|
|||
|
+#jstree-marker.jstree-default { background:url("d.png") -41px -57px no-repeat !important; text-indent:-100px; }
|
|||
|
+
|
|||
|
+.jstree-default a.jstree-search { color:aqua; }
|
|||
|
+.jstree-default .jstree-locked a { color:silver; cursor:default; }
|
|||
|
+
|
|||
|
+#vakata-contextmenu.jstree-default-context,
|
|||
|
+#vakata-contextmenu.jstree-default-context li ul { background:#f0f0f0; border:1px solid #979797; -moz-box-shadow: 1px 1px 2px #999; -webkit-box-shadow: 1px 1px 2px #999; box-shadow: 1px 1px 2px #999; }
|
|||
|
+#vakata-contextmenu.jstree-default-context li { }
|
|||
|
+#vakata-contextmenu.jstree-default-context a { color:black; }
|
|||
|
+#vakata-contextmenu.jstree-default-context a:hover,
|
|||
|
+#vakata-contextmenu.jstree-default-context .vakata-hover > a { padding:0 5px; background:#e8eff7; border:1px solid #aecff7; color:black; -moz-border-radius:2px; -webkit-border-radius:2px; border-radius:2px; }
|
|||
|
+#vakata-contextmenu.jstree-default-context li.jstree-contextmenu-disabled a,
|
|||
|
+#vakata-contextmenu.jstree-default-context li.jstree-contextmenu-disabled a:hover { color:silver; background:transparent; border:0; padding:1px 4px; }
|
|||
|
+#vakata-contextmenu.jstree-default-context li.vakata-separator { background:white; border-top:1px solid #e0e0e0; margin:0; }
|
|||
|
+#vakata-contextmenu.jstree-default-context li ul { margin-left:-4px; }
|
|||
|
+
|
|||
|
+/* IE6 BEGIN */
|
|||
|
+.jstree-default li,
|
|||
|
+.jstree-default ins,
|
|||
|
+#vakata-dragged.jstree-default .jstree-invalid,
|
|||
|
+#vakata-dragged.jstree-default .jstree-ok,
|
|||
|
+#jstree-marker.jstree-default { _background-image:url("d.gif"); }
|
|||
|
+.jstree-default .jstree-open ins { _background-position:-72px 0; }
|
|||
|
+.jstree-default .jstree-closed ins { _background-position:-54px 0; }
|
|||
|
+.jstree-default .jstree-leaf ins { _background-position:-36px 0; }
|
|||
|
+.jstree-default a ins.jstree-icon { _background-position:-56px -19px; }
|
|||
|
+#vakata-contextmenu.jstree-default-context ins { _display:none; }
|
|||
|
+#vakata-contextmenu.jstree-default-context li { _zoom:1; }
|
|||
|
+.jstree-default .jstree-undetermined a .jstree-checkbox { _background-position:-20px -19px; }
|
|||
|
+.jstree-default .jstree-checked a .jstree-checkbox { _background-position:-38px -19px; }
|
|||
|
+.jstree-default .jstree-unchecked a .jstree-checkbox { _background-position:-2px -19px; }
|
|||
|
+/* IE6 END */
|
|||
|
\ No newline at end of file
|
|||
|
diff -up cacti-0.8.8a/include/js/jquery/themes/default/throbber.gif.legal cacti-0.8.8a/include/js/jquery/themes/default/throbber.gif
|
|||
|
Binary files cacti-0.8.8a/include/js/jquery/themes/default/throbber.gif.legal and cacti-0.8.8a/include/js/jquery/themes/default/throbber.gif differ
|