@ -0,0 +1 @@ |
|||
define(["exports","./util"],function(a,b){"use strict";function c(a){return a&&a.__esModule?a:{"default":a}}function d(a,b){if(!(a instanceof b))throw new TypeError("Cannot call a class as a function")}Object.defineProperty(a,"__esModule",{value:!0});var e=c(b),f=function(){function a(a,b){for(var c=0;c<b.length;c++){var d=b[c];d.enumerable=d.enumerable||!1,d.configurable=!0,"value"in d&&(d.writable=!0),Object.defineProperty(a,d.key,d)}}return function(b,c,d){return c&&a(b.prototype,c),d&&a(b,d),b}}(),g=function(a){var b="alert",c="4.0.0-alpha.4",g="bs.alert",h="."+g,i=".data-api",j=a.fn[b],k=150,l={DISMISS:'[data-dismiss="alert"]'},m={CLOSE:"close"+h,CLOSED:"closed"+h,CLICK_DATA_API:"click"+h+i},n={ALERT:"alert",FADE:"fade",IN:"in"},o=function(){function b(a){d(this,b),this._element=a}return f(b,[{key:"close",value:function(a){a=a||this._element;var b=this._getRootElement(a),c=this._triggerCloseEvent(b);c.isDefaultPrevented()||this._removeElement(b)}},{key:"dispose",value:function(){a.removeData(this._element,g),this._element=null}},{key:"_getRootElement",value:function(b){var c=e["default"].getSelectorFromElement(b),d=!1;return c&&(d=a(c)[0]),d||(d=a(b).closest("."+n.ALERT)[0]),d}},{key:"_triggerCloseEvent",value:function(b){var c=a.Event(m.CLOSE);return a(b).trigger(c),c}},{key:"_removeElement",value:function(b){return a(b).removeClass(n.IN),e["default"].supportsTransitionEnd()&&a(b).hasClass(n.FADE)?void a(b).one(e["default"].TRANSITION_END,a.proxy(this._destroyElement,this,b)).emulateTransitionEnd(k):void this._destroyElement(b)}},{key:"_destroyElement",value:function(b){a(b).detach().trigger(m.CLOSED).remove()}}],[{key:"_jQueryInterface",value:function(c){return this.each(function(){var d=a(this),e=d.data(g);e||(e=new b(this),d.data(g,e)),"close"===c&&e[c](this)})}},{key:"_handleDismiss",value:function(a){return function(b){b&&b.preventDefault(),a.close(this)}}},{key:"VERSION",get:function(){return c}}]),b}();return a(document).on(m.CLICK_DATA_API,l.DISMISS,o._handleDismiss(new o)),a.fn[b]=o._jQueryInterface,a.fn[b].Constructor=o,a.fn[b].noConflict=function(){return a.fn[b]=j,o._jQueryInterface},o}(jQuery);a["default"]=g}); |
@ -0,0 +1 @@ |
|||
define(["exports"],function(a){"use strict";function b(a,b){if(!(a instanceof b))throw new TypeError("Cannot call a class as a function")}Object.defineProperty(a,"__esModule",{value:!0});var c=function(){function a(a,b){for(var c=0;c<b.length;c++){var d=b[c];d.enumerable=d.enumerable||!1,d.configurable=!0,"value"in d&&(d.writable=!0),Object.defineProperty(a,d.key,d)}}return function(b,c,d){return c&&a(b.prototype,c),d&&a(b,d),b}}(),d=function(a){var d="button",e="4.0.0-alpha.4",f="bs.button",g="."+f,h=".data-api",i=a.fn[d],j={ACTIVE:"active",BUTTON:"btn",FOCUS:"focus"},k={DATA_TOGGLE_CARROT:'[data-toggle^="button"]',DATA_TOGGLE:'[data-toggle="buttons"]',INPUT:"input",ACTIVE:".active",BUTTON:".btn"},l={CLICK_DATA_API:"click"+g+h,FOCUS_BLUR_DATA_API:"focus"+g+h+" "+("blur"+g+h)},m=function(){function d(a){b(this,d),this._element=a}return c(d,[{key:"toggle",value:function(){var b=!0,c=a(this._element).closest(k.DATA_TOGGLE)[0];if(c){var d=a(this._element).find(k.INPUT)[0];if(d){if("radio"===d.type)if(d.checked&&a(this._element).hasClass(j.ACTIVE))b=!1;else{var e=a(c).find(k.ACTIVE)[0];e&&a(e).removeClass(j.ACTIVE)}b&&(d.checked=!a(this._element).hasClass(j.ACTIVE),a(this._element).trigger("change")),d.focus()}}else this._element.setAttribute("aria-pressed",!a(this._element).hasClass(j.ACTIVE));b&&a(this._element).toggleClass(j.ACTIVE)}},{key:"dispose",value:function(){a.removeData(this._element,f),this._element=null}}],[{key:"_jQueryInterface",value:function(b){return this.each(function(){var c=a(this).data(f);c||(c=new d(this),a(this).data(f,c)),"toggle"===b&&c[b]()})}},{key:"VERSION",get:function(){return e}}]),d}();return a(document).on(l.CLICK_DATA_API,k.DATA_TOGGLE_CARROT,function(b){b.preventDefault();var c=b.target;a(c).hasClass(j.BUTTON)||(c=a(c).closest(k.BUTTON)),m._jQueryInterface.call(a(c),"toggle")}).on(l.FOCUS_BLUR_DATA_API,k.DATA_TOGGLE_CARROT,function(b){var c=a(b.target).closest(k.BUTTON)[0];a(c).toggleClass(j.FOCUS,/^focus(in)?$/.test(b.type))}),a.fn[d]=m._jQueryInterface,a.fn[d].Constructor=m,a.fn[d].noConflict=function(){return a.fn[d]=i,m._jQueryInterface},m}(jQuery);a["default"]=d}); |
@ -0,0 +1 @@ |
|||
define(["jquery","core/custom_interaction_events","core/log"],function(a,b,c){var d={TOGGLE_REGION:'[data-region="drawer-toggle"]',TOGGLE_ACTION:'[data-action="toggle-drawer"]',TOGGLE_TARGET:"aria-controls",TOGGLE_SIDE:"left",BODY:"body"},e=function(){a(d.TOGGLE_REGION).length||c.debug("Page is missing a drawer region"),a(d.TOGGLE_ACTION).length||c.debug("Page is missing a drawer toggle link"),a(d.TOGGLE_REGION).each(function(b,c){var e=a(c).find(d.TOGGLE_ACTION),f=e.attr("aria-controls"),g=a(document.getElementById(f)),h="false"==e.attr("aria-expanded"),i=e.attr("data-side"),j=a(d.BODY);g.on("mousewheel DOMMouseScroll",this.preventPageScroll),h?e.attr("aria-expanded","false"):(j.addClass("drawer-open-"+i),e.attr("aria-expanded","true"))}.bind(this)),this.registerEventListeners();var b=a(document).width()<768;b&&this.closeAll()};return e.prototype.closeAll=function(){a(d.TOGGLE_REGION).each(function(b,c){var e=a(c).find(d.TOGGLE_ACTION),f=e.attr("data-side"),g=a(d.BODY),h=e.attr("aria-controls"),i=a(document.getElementById(h)),j=e.attr("data-preference");e.attr("aria-expanded","false"),g.removeClass("drawer-open-"+f),i.attr("aria-hidden","true"),i.addClass("closed"),M.util.set_user_preference(j,"false")})},e.prototype.toggleDrawer=function(b){var c=a(b.target).closest("[data-action=toggle-drawer]"),e=c.attr("aria-controls"),f=a(document.getElementById(e)),g=a(d.BODY),h=c.attr("data-side"),i=c.attr("data-preference");g.addClass("drawer-ease");var j="true"==c.attr("aria-expanded");if(j)g.removeClass("drawer-open-"+h),c.attr("aria-expanded","false"),f.attr("aria-hidden","true"),f.addClass("closed"),M.util.set_user_preference(i,"false");else{var k=a(document).width()<768;k&&this.closeAll(),c.attr("aria-expanded","true"),f.attr("aria-hidden","false"),f.focus(),g.addClass("drawer-open-"+h),f.removeClass("closed"),M.util.set_user_preference(i,"true")}},e.prototype.preventPageScroll=function(b){var c=b.wheelDelta||b.originalEvent&&b.originalEvent.wheelDelta||-b.originalEvent.detail,d=this.scrollTop+a(this).outerHeight()-this.scrollHeight>=0,e=this.scrollTop<=0;(c<0&&d||c>0&&e)&&b.preventDefault()},e.prototype.registerEventListeners=function(){a(d.TOGGLE_ACTION).each(function(c,d){b.define(a(d),[b.events.activate]),a(d).on(b.events.activate,function(a,b){this.toggleDrawer(b.originalEvent),b.originalEvent.preventDefault()}.bind(this))}.bind(this))},{init:function(){return new e}}}); |
@ -0,0 +1 @@ |
|||
define(["exports","./util"],function(a,b){"use strict";function c(a){return a&&a.__esModule?a:{"default":a}}function d(a,b){if(!(a instanceof b))throw new TypeError("Cannot call a class as a function")}Object.defineProperty(a,"__esModule",{value:!0});var e=c(b),f=function(){function a(a,b){for(var c=0;c<b.length;c++){var d=b[c];d.enumerable=d.enumerable||!1,d.configurable=!0,"value"in d&&(d.writable=!0),Object.defineProperty(a,d.key,d)}}return function(b,c,d){return c&&a(b.prototype,c),d&&a(b,d),b}}(),g=function(a){var b="dropdown",c="4.0.0-alpha.4",g="bs.dropdown",h="."+g,i=".data-api",j=a.fn[b],k=27,l=38,m=40,n=3,o={HIDE:"hide"+h,HIDDEN:"hidden"+h,SHOW:"show"+h,SHOWN:"shown"+h,CLICK:"click"+h,CLICK_DATA_API:"click"+h+i,KEYDOWN_DATA_API:"keydown"+h+i},p={BACKDROP:"dropdown-backdrop",DISABLED:"disabled",OPEN:"open"},q={BACKDROP:".dropdown-backdrop",DATA_TOGGLE:'[data-toggle="dropdown"]',FORM_CHILD:".dropdown form",ROLE_MENU:'[role="menu"]',ROLE_LISTBOX:'[role="listbox"]',NAVBAR_NAV:".navbar-nav",VISIBLE_ITEMS:'[role="menu"] li:not(.disabled) a, [role="listbox"] li:not(.disabled) a'},r=function(){function b(a){d(this,b),this._element=a,this._addEventListeners()}return f(b,[{key:"toggle",value:function(){if(this.disabled||a(this).hasClass(p.DISABLED))return!1;var c=b._getParentFromElement(this),d=a(c).hasClass(p.OPEN);if(b._clearMenus(),d)return!1;if("ontouchstart"in document.documentElement&&!a(c).closest(q.NAVBAR_NAV).length){var e=document.createElement("div");e.className=p.BACKDROP,a(e).insertBefore(this),a(e).on("click",b._clearMenus)}var f={relatedTarget:this},g=a.Event(o.SHOW,f);return a(c).trigger(g),!g.isDefaultPrevented()&&(this.focus(),this.setAttribute("aria-expanded","true"),a(c).toggleClass(p.OPEN),a(c).trigger(a.Event(o.SHOWN,f)),!1)}},{key:"dispose",value:function(){a.removeData(this._element,g),a(this._element).off(h),this._element=null}},{key:"_addEventListeners",value:function(){a(this._element).on(o.CLICK,this.toggle)}}],[{key:"_jQueryInterface",value:function(c){return this.each(function(){var d=a(this).data(g);if(d||a(this).data(g,d=new b(this)),"string"==typeof c){if(void 0===d[c])throw new Error('No method named "'+c+'"');d[c].call(this)}})}},{key:"_clearMenus",value:function(c){if(!c||c.which!==n){var d=a(q.BACKDROP)[0];d&&d.parentNode.removeChild(d);for(var e=a.makeArray(a(q.DATA_TOGGLE)),f=0;f<e.length;f++){var g=b._getParentFromElement(e[f]),h={relatedTarget:e[f]};if(a(g).hasClass(p.OPEN)&&!(c&&"click"===c.type&&/input|textarea/i.test(c.target.tagName)&&a.contains(g,c.target))){var i=a.Event(o.HIDE,h);a(g).trigger(i),i.isDefaultPrevented()||(e[f].setAttribute("aria-expanded","false"),a(g).removeClass(p.OPEN).trigger(a.Event(o.HIDDEN,h)))}}}}},{key:"_getParentFromElement",value:function(b){var c=void 0,d=e["default"].getSelectorFromElement(b);return d&&(c=a(d)[0]),c||b.parentNode}},{key:"_dataApiKeydownHandler",value:function(c){if(/(38|40|27|32)/.test(c.which)&&!/input|textarea/i.test(c.target.tagName)&&(c.preventDefault(),c.stopPropagation(),!this.disabled&&!a(this).hasClass(p.DISABLED))){var d=b._getParentFromElement(this),e=a(d).hasClass(p.OPEN);if(!e&&c.which!==k||e&&c.which===k){if(c.which===k){var f=a(d).find(q.DATA_TOGGLE)[0];a(f).trigger("focus")}return void a(this).trigger("click")}var g=a.makeArray(a(q.VISIBLE_ITEMS));if(g=g.filter(function(a){return a.offsetWidth||a.offsetHeight}),g.length){var h=g.indexOf(c.target);c.which===l&&h>0&&h--,c.which===m&&h<g.length-1&&h++,h<0&&(h=0),g[h].focus()}}}},{key:"VERSION",get:function(){return c}}]),b}();return a(document).on(o.KEYDOWN_DATA_API,q.DATA_TOGGLE,r._dataApiKeydownHandler).on(o.KEYDOWN_DATA_API,q.ROLE_MENU,r._dataApiKeydownHandler).on(o.KEYDOWN_DATA_API,q.ROLE_LISTBOX,r._dataApiKeydownHandler).on(o.CLICK_DATA_API,r._clearMenus).on(o.CLICK_DATA_API,q.DATA_TOGGLE,r.prototype.toggle).on(o.CLICK_DATA_API,q.FORM_CHILD,function(a){a.stopPropagation()}),a.fn[b]=r._jQueryInterface,a.fn[b].Constructor=r,a.fn[b].noConflict=function(){return a.fn[b]=j,r._jQueryInterface},r}(jQuery);a["default"]=g}); |
@ -0,0 +1 @@ |
|||
define(["jquery","core/event"],function(a,b){return{enhance:function(c){var d=document.getElementById(c);a(d).on(b.Events.FORM_FIELD_VALIDATION,function(b,c){b.preventDefault();var e=a(d).closest(".form-group"),f=e.find(".form-control-feedback");"TEXTAREA"==a(d).prop("tagName")&&e.find("[contenteditable]")&&(d=e.find("[contenteditable]")),""!==c?(e.addClass("has-danger"),e.data("client-validation-error",!0),a(d).addClass("form-control-danger"),a(d).attr("aria-describedby",f.attr("id")),a(d).attr("aria-invalid",!0),f.attr("tabindex",0),f.html(c),f.is(":visible")||(f.show(),f.focus())):e.data("client-validation-error")===!0&&(e.removeClass("has-danger"),e.data("client-validation-error",!1),a(d).removeClass("form-control-danger"),a(d).removeAttr("aria-describedby"),a(d).attr("aria-invalid",!1),f.hide())})}}}); |
@ -0,0 +1 @@ |
|||
define(["jquery","./tether","core/event"],function(a,b,c){return window.jQuery=a,window.Tether=b,require(["theme_ilb/util","theme_ilb/alert","theme_ilb/button","theme_ilb/carousel","theme_ilb/collapse","theme_ilb/dropdown","theme_ilb/modal","theme_ilb/scrollspy","theme_ilb/tab","theme_ilb/tooltip","theme_ilb/popover"],function(){a("body").popover({selector:'[data-toggle="popover"]',trigger:"focus"}),c.getLegacyEvents().done(function(b){a(document).on(b.FILTER_CONTENT_UPDATED,function(){a("body").popover({selector:'[data-toggle="popover"]',trigger:"focus"})})})}),{}}); |
@ -0,0 +1 @@ |
|||
define(["exports","./tooltip"],function(a,b){"use strict";function c(a){return a&&a.__esModule?a:{"default":a}}function d(a,b){if(!(a instanceof b))throw new TypeError("Cannot call a class as a function")}function e(a,b){if(!a)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!b||"object"!=typeof b&&"function"!=typeof b?a:b}function f(a,b){if("function"!=typeof b&&null!==b)throw new TypeError("Super expression must either be null or a function, not "+typeof b);a.prototype=Object.create(b&&b.prototype,{constructor:{value:a,enumerable:!1,writable:!0,configurable:!0}}),b&&(Object.setPrototypeOf?Object.setPrototypeOf(a,b):a.__proto__=b)}Object.defineProperty(a,"__esModule",{value:!0});var g=c(b),h="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(a){return typeof a}:function(a){return a&&"function"==typeof Symbol&&a.constructor===Symbol?"symbol":typeof a},i=function(){function a(a,b){for(var c=0;c<b.length;c++){var d=b[c];d.enumerable=d.enumerable||!1,d.configurable=!0,"value"in d&&(d.writable=!0),Object.defineProperty(a,d.key,d)}}return function(b,c,d){return c&&a(b.prototype,c),d&&a(b,d),b}}(),j=function(a){var b="popover",c="4.0.0-alpha.4",j="bs.popover",k="."+j,l=a.fn[b],m=a.extend({},g["default"].Default,{placement:"right",trigger:"click",content:"",template:'<div class="popover" role="tooltip"><div class="popover-arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>'}),n=a.extend({},g["default"].DefaultType,{content:"(string|element|function)"}),o={FADE:"fade",IN:"in"},p={TITLE:".popover-title",CONTENT:".popover-content",ARROW:".popover-arrow"},q={HIDE:"hide"+k,HIDDEN:"hidden"+k,SHOW:"show"+k,SHOWN:"shown"+k,INSERTED:"inserted"+k,CLICK:"click"+k,FOCUSIN:"focusin"+k,FOCUSOUT:"focusout"+k,MOUSEENTER:"mouseenter"+k,MOUSELEAVE:"mouseleave"+k},r=function(g){function l(){return d(this,l),e(this,(l.__proto__||Object.getPrototypeOf(l)).apply(this,arguments))}return f(l,g),i(l,[{key:"isWithContent",value:function(){return this.getTitle()||this._getContent()}},{key:"getTipElement",value:function(){return this.tip=this.tip||a(this.config.template)[0]}},{key:"setContent",value:function(){var b=a(this.getTipElement());this.setElementContent(b.find(p.TITLE),this.getTitle()),this.setElementContent(b.find(p.CONTENT),this._getContent()),b.removeClass(o.FADE).removeClass(o.IN),this.cleanupTether()}},{key:"_getContent",value:function(){return this.element.getAttribute("data-content")||("function"==typeof this.config.content?this.config.content.call(this.element):this.config.content)}}],[{key:"_jQueryInterface",value:function(b){return this.each(function(){var c=a(this).data(j),d="object"===("undefined"==typeof b?"undefined":h(b))?b:null;if((c||!/destroy|hide/.test(b))&&(c||(c=new l(this,d),a(this).data(j,c)),"string"==typeof b)){if(void 0===c[b])throw new Error('No method named "'+b+'"');c[b]()}})}},{key:"VERSION",get:function(){return c}},{key:"Default",get:function(){return m}},{key:"NAME",get:function(){return b}},{key:"DATA_KEY",get:function(){return j}},{key:"Event",get:function(){return q}},{key:"EVENT_KEY",get:function(){return k}},{key:"DefaultType",get:function(){return n}}]),l}(g["default"]);return a.fn[b]=r._jQueryInterface,a.fn[b].Constructor=r,a.fn[b].noConflict=function(){return a.fn[b]=l,r._jQueryInterface},r}(jQuery);a["default"]=j}); |
@ -0,0 +1 @@ |
|||
define(["exports","./util"],function(a,b){"use strict";function c(a){return a&&a.__esModule?a:{"default":a}}function d(a,b){if(!(a instanceof b))throw new TypeError("Cannot call a class as a function")}Object.defineProperty(a,"__esModule",{value:!0});var e=c(b),f="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(a){return typeof a}:function(a){return a&&"function"==typeof Symbol&&a.constructor===Symbol?"symbol":typeof a},g=function(){function a(a,b){for(var c=0;c<b.length;c++){var d=b[c];d.enumerable=d.enumerable||!1,d.configurable=!0,"value"in d&&(d.writable=!0),Object.defineProperty(a,d.key,d)}}return function(b,c,d){return c&&a(b.prototype,c),d&&a(b,d),b}}(),h=function(a){var b="scrollspy",c="4.0.0-alpha.4",h="bs.scrollspy",i="."+h,j=".data-api",k=a.fn[b],l={offset:10,method:"auto",target:""},m={offset:"number",method:"string",target:"(string|element)"},n={ACTIVATE:"activate"+i,SCROLL:"scroll"+i,LOAD_DATA_API:"load"+i+j},o={DROPDOWN_ITEM:"dropdown-item",DROPDOWN_MENU:"dropdown-menu",NAV_LINK:"nav-link",NAV:"nav",ACTIVE:"active"},p={DATA_SPY:'[data-spy="scroll"]',ACTIVE:".active",LIST_ITEM:".list-item",LI:"li",LI_DROPDOWN:"li.dropdown",NAV_LINKS:".nav-link",DROPDOWN:".dropdown",DROPDOWN_ITEMS:".dropdown-item",DROPDOWN_TOGGLE:".dropdown-toggle"},q={OFFSET:"offset",POSITION:"position"},r=function(){function j(b,c){d(this,j),this._element=b,this._scrollElement="BODY"===b.tagName?window:b,this._config=this._getConfig(c),this._selector=this._config.target+" "+p.NAV_LINKS+","+(this._config.target+" "+p.DROPDOWN_ITEMS),this._offsets=[],this._targets=[],this._activeTarget=null,this._scrollHeight=0,a(this._scrollElement).on(n.SCROLL,a.proxy(this._process,this)),this.refresh(),this._process()}return g(j,[{key:"refresh",value:function(){var b=this,c=this._scrollElement!==this._scrollElement.window?q.POSITION:q.OFFSET,d="auto"===this._config.method?c:this._config.method,f=d===q.POSITION?this._getScrollTop():0;this._offsets=[],this._targets=[],this._scrollHeight=this._getScrollHeight();var g=a.makeArray(a(this._selector));g.map(function(b){var c=void 0,g=e["default"].getSelectorFromElement(b);return g&&(c=a(g)[0]),c&&(c.offsetWidth||c.offsetHeight)?[a(c)[d]().top+f,g]:null}).filter(function(a){return a}).sort(function(a,b){return a[0]-b[0]}).forEach(function(a){b._offsets.push(a[0]),b._targets.push(a[1])})}},{key:"dispose",value:function(){a.removeData(this._element,h),a(this._scrollElement).off(i),this._element=null,this._scrollElement=null,this._config=null,this._selector=null,this._offsets=null,this._targets=null,this._activeTarget=null,this._scrollHeight=null}},{key:"_getConfig",value:function(c){if(c=a.extend({},l,c),"string"!=typeof c.target){var d=a(c.target).attr("id");d||(d=e["default"].getUID(b),a(c.target).attr("id",d)),c.target="#"+d}return e["default"].typeCheckConfig(b,c,m),c}},{key:"_getScrollTop",value:function(){return this._scrollElement===window?this._scrollElement.scrollY:this._scrollElement.scrollTop}},{key:"_getScrollHeight",value:function(){return this._scrollElement.scrollHeight||Math.max(document.body.scrollHeight,document.documentElement.scrollHeight)}},{key:"_process",value:function(){var a=this._getScrollTop()+this._config.offset,b=this._getScrollHeight(),c=this._config.offset+b-this._scrollElement.offsetHeight;if(this._scrollHeight!==b&&this.refresh(),a>=c){var d=this._targets[this._targets.length-1];this._activeTarget!==d&&this._activate(d)}if(this._activeTarget&&a<this._offsets[0])return this._activeTarget=null,void this._clear();for(var e=this._offsets.length;e--;){var f=this._activeTarget!==this._targets[e]&&a>=this._offsets[e]&&(void 0===this._offsets[e+1]||a<this._offsets[e+1]);f&&this._activate(this._targets[e])}}},{key:"_activate",value:function(b){this._activeTarget=b,this._clear();var c=this._selector.split(",");c=c.map(function(a){return a+'[data-target="'+b+'"],'+(a+'[href="'+b+'"]')});var d=a(c.join(","));d.hasClass(o.DROPDOWN_ITEM)?(d.closest(p.DROPDOWN).find(p.DROPDOWN_TOGGLE).addClass(o.ACTIVE),d.addClass(o.ACTIVE)):d.parents(p.LI).find(p.NAV_LINKS).addClass(o.ACTIVE),a(this._scrollElement).trigger(n.ACTIVATE,{relatedTarget:b})}},{key:"_clear",value:function(){a(this._selector).filter(p.ACTIVE).removeClass(o.ACTIVE)}}],[{key:"_jQueryInterface",value:function(b){return this.each(function(){var c=a(this).data(h),d="object"===("undefined"==typeof b?"undefined":f(b))&&b||null;if(c||(c=new j(this,d),a(this).data(h,c)),"string"==typeof b){if(void 0===c[b])throw new Error('No method named "'+b+'"');c[b]()}})}},{key:"VERSION",get:function(){return c}},{key:"Default",get:function(){return l}}]),j}();return a(window).on(n.LOAD_DATA_API,function(){for(var b=a.makeArray(a(p.DATA_SPY)),c=b.length;c--;){var d=a(b[c]);r._jQueryInterface.call(d,d.data())}}),a.fn[b]=r._jQueryInterface,a.fn[b].Constructor=r,a.fn[b].noConflict=function(){return a.fn[b]=k,r._jQueryInterface},r}(jQuery);a["default"]=h}); |
@ -0,0 +1 @@ |
|||
define(["exports","./util"],function(a,b){"use strict";function c(a){return a&&a.__esModule?a:{"default":a}}function d(a,b){if(!(a instanceof b))throw new TypeError("Cannot call a class as a function")}Object.defineProperty(a,"__esModule",{value:!0});var e=c(b),f=function(){function a(a,b){for(var c=0;c<b.length;c++){var d=b[c];d.enumerable=d.enumerable||!1,d.configurable=!0,"value"in d&&(d.writable=!0),Object.defineProperty(a,d.key,d)}}return function(b,c,d){return c&&a(b.prototype,c),d&&a(b,d),b}}(),g=function(a){var b="tab",c="4.0.0-alpha.4",g="bs.tab",h="."+g,i=".data-api",j=a.fn[b],k=150,l={HIDE:"hide"+h,HIDDEN:"hidden"+h,SHOW:"show"+h,SHOWN:"shown"+h,CLICK_DATA_API:"click"+h+i},m={DROPDOWN_MENU:"dropdown-menu",ACTIVE:"active",FADE:"fade",IN:"in"},n={A:"a",LI:"li",DROPDOWN:".dropdown",UL:"ul:not(.dropdown-menu)",FADE_CHILD:"> .nav-item .fade, > .fade",ACTIVE:".active",ACTIVE_CHILD:"> .nav-item > .active, > .active",DATA_TOGGLE:'[data-toggle="tab"], [data-toggle="pill"]',DROPDOWN_TOGGLE:".dropdown-toggle",DROPDOWN_ACTIVE_CHILD:"> .dropdown-menu .active"},o=function(){function b(a){d(this,b),this._element=a}return f(b,[{key:"show",value:function(){var b=this;if(!this._element.parentNode||this._element.parentNode.nodeType!==Node.ELEMENT_NODE||!a(this._element).hasClass(m.ACTIVE)){var c=void 0,d=void 0,f=a(this._element).closest(n.UL)[0],g=e["default"].getSelectorFromElement(this._element);f&&(d=a.makeArray(a(f).find(n.ACTIVE)),d=d[d.length-1]);var h=a.Event(l.HIDE,{relatedTarget:this._element}),i=a.Event(l.SHOW,{relatedTarget:d});if(d&&a(d).trigger(h),a(this._element).trigger(i),!i.isDefaultPrevented()&&!h.isDefaultPrevented()){g&&(c=a(g)[0]),this._activate(this._element,f);var j=function(){var c=a.Event(l.HIDDEN,{relatedTarget:b._element}),e=a.Event(l.SHOWN,{relatedTarget:d});a(d).trigger(c),a(b._element).trigger(e)};c?this._activate(c,c.parentNode,j):j()}}}},{key:"dispose",value:function(){a.removeClass(this._element,g),this._element=null}},{key:"_activate",value:function(b,c,d){var f=a(c).find(n.ACTIVE_CHILD)[0],g=d&&e["default"].supportsTransitionEnd()&&(f&&a(f).hasClass(m.FADE)||Boolean(a(c).find(n.FADE_CHILD)[0])),h=a.proxy(this._transitionComplete,this,b,f,g,d);f&&g?a(f).one(e["default"].TRANSITION_END,h).emulateTransitionEnd(k):h(),f&&a(f).removeClass(m.IN)}},{key:"_transitionComplete",value:function(b,c,d,f){if(c){a(c).removeClass(m.ACTIVE);var g=a(c).find(n.DROPDOWN_ACTIVE_CHILD)[0];g&&a(g).removeClass(m.ACTIVE),c.setAttribute("aria-expanded",!1)}if(a(b).addClass(m.ACTIVE),b.setAttribute("aria-expanded",!0),d?(e["default"].reflow(b),a(b).addClass(m.IN)):a(b).removeClass(m.FADE),b.parentNode&&a(b.parentNode).hasClass(m.DROPDOWN_MENU)){var h=a(b).closest(n.DROPDOWN)[0];h&&a(h).find(n.DROPDOWN_TOGGLE).addClass(m.ACTIVE),b.setAttribute("aria-expanded",!0)}f&&f()}}],[{key:"_jQueryInterface",value:function(c){return this.each(function(){var d=a(this),e=d.data(g);if(e||(e=e=new b(this),d.data(g,e)),"string"==typeof c){if(void 0===e[c])throw new Error('No method named "'+c+'"');e[c]()}})}},{key:"VERSION",get:function(){return c}}]),b}();return a(document).on(l.CLICK_DATA_API,n.DATA_TOGGLE,function(b){b.preventDefault(),o._jQueryInterface.call(a(this),"show")}),a.fn[b]=o._jQueryInterface,a.fn[b].Constructor=o,a.fn[b].noConflict=function(){return a.fn[b]=j,o._jQueryInterface},o}(jQuery);a["default"]=g}); |
@ -0,0 +1 @@ |
|||
define(["exports"],function(a){"use strict";Object.defineProperty(a,"__esModule",{value:!0});var b=function(a){function b(a){return{}.toString.call(a).match(/\s([a-zA-Z]+)/)[1].toLowerCase()}function c(a){return(a[0]||a).nodeType}function d(){return{bindType:h.end,delegateType:h.end,handle:function(b){if(a(b.target).is(this))return b.handleObj.handler.apply(this,arguments)}}}function e(){if(window.QUnit)return!1;var a=document.createElement("bootstrap");for(var b in j)if(void 0!==a.style[b])return{end:j[b]};return!1}function f(b){var c=this,d=!1;return a(this).one(k.TRANSITION_END,function(){d=!0}),setTimeout(function(){d||k.triggerTransitionEnd(c)},b),this}function g(){h=e(),a.fn.emulateTransitionEnd=f,k.supportsTransitionEnd()&&(a.event.special[k.TRANSITION_END]=d())}var h=!1,i=1e6,j={WebkitTransition:"webkitTransitionEnd",MozTransition:"transitionend",OTransition:"oTransitionEnd otransitionend",transition:"transitionend"},k={TRANSITION_END:"bsTransitionEnd",getUID:function(a){do a+=~~(Math.random()*i);while(document.getElementById(a));return a},getSelectorFromElement:function(a){var b=a.getAttribute("data-target");return b||(b=a.getAttribute("href")||"",b=/^#[a-z]/i.test(b)?b:null),b},reflow:function(a){new Function("bs","return bs")(a.offsetHeight)},triggerTransitionEnd:function(b){a(b).trigger(h.end)},supportsTransitionEnd:function(){return Boolean(h)},typeCheckConfig:function(a,d,e){for(var f in e)if(e.hasOwnProperty(f)){var g=e[f],h=d[f],i=void 0;if(i=h&&c(h)?"element":b(h),!new RegExp(g).test(i))throw new Error(a.toUpperCase()+": "+('Option "'+f+'" provided type "'+i+'" ')+('but expected type "'+g+'".'))}}};return g(),k}(jQuery);a["default"]=b}); |
@ -0,0 +1,218 @@ |
|||
define(['exports', './util'], function (exports, _util) { |
|||
'use strict'; |
|||
|
|||
Object.defineProperty(exports, "__esModule", { |
|||
value: true |
|||
}); |
|||
|
|||
var _util2 = _interopRequireDefault(_util); |
|||
|
|||
function _interopRequireDefault(obj) { |
|||
return obj && obj.__esModule ? obj : { |
|||
default: obj |
|||
}; |
|||
} |
|||
|
|||
function _classCallCheck(instance, Constructor) { |
|||
if (!(instance instanceof Constructor)) { |
|||
throw new TypeError("Cannot call a class as a function"); |
|||
} |
|||
} |
|||
|
|||
var _createClass = function () { |
|||
function defineProperties(target, props) { |
|||
for (var i = 0; i < props.length; i++) { |
|||
var descriptor = props[i]; |
|||
descriptor.enumerable = descriptor.enumerable || false; |
|||
descriptor.configurable = true; |
|||
if ("value" in descriptor) descriptor.writable = true; |
|||
Object.defineProperty(target, descriptor.key, descriptor); |
|||
} |
|||
} |
|||
|
|||
return function (Constructor, protoProps, staticProps) { |
|||
if (protoProps) defineProperties(Constructor.prototype, protoProps); |
|||
if (staticProps) defineProperties(Constructor, staticProps); |
|||
return Constructor; |
|||
}; |
|||
}(); |
|||
|
|||
/** |
|||
* -------------------------------------------------------------------------- |
|||
* Bootstrap (v4.0.0-alpha.4): alert.js |
|||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|||
* -------------------------------------------------------------------------- |
|||
*/ |
|||
|
|||
var Alert = function ($) { |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Constants |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
var NAME = 'alert'; |
|||
var VERSION = '4.0.0-alpha.4'; |
|||
var DATA_KEY = 'bs.alert'; |
|||
var EVENT_KEY = '.' + DATA_KEY; |
|||
var DATA_API_KEY = '.data-api'; |
|||
var JQUERY_NO_CONFLICT = $.fn[NAME]; |
|||
var TRANSITION_DURATION = 150; |
|||
|
|||
var Selector = { |
|||
DISMISS: '[data-dismiss="alert"]' |
|||
}; |
|||
|
|||
var Event = { |
|||
CLOSE: 'close' + EVENT_KEY, |
|||
CLOSED: 'closed' + EVENT_KEY, |
|||
CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY |
|||
}; |
|||
|
|||
var ClassName = { |
|||
ALERT: 'alert', |
|||
FADE: 'fade', |
|||
IN: 'in' |
|||
}; |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Class Definition |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
var Alert = function () { |
|||
function Alert(element) { |
|||
_classCallCheck(this, Alert); |
|||
|
|||
this._element = element; |
|||
} |
|||
|
|||
// getters
|
|||
|
|||
_createClass(Alert, [{ |
|||
key: 'close', |
|||
value: function close(element) { |
|||
element = element || this._element; |
|||
|
|||
var rootElement = this._getRootElement(element); |
|||
var customEvent = this._triggerCloseEvent(rootElement); |
|||
|
|||
if (customEvent.isDefaultPrevented()) { |
|||
return; |
|||
} |
|||
|
|||
this._removeElement(rootElement); |
|||
} |
|||
}, { |
|||
key: 'dispose', |
|||
value: function dispose() { |
|||
$.removeData(this._element, DATA_KEY); |
|||
this._element = null; |
|||
} |
|||
}, { |
|||
key: '_getRootElement', |
|||
value: function _getRootElement(element) { |
|||
var selector = _util2.default.getSelectorFromElement(element); |
|||
var parent = false; |
|||
|
|||
if (selector) { |
|||
parent = $(selector)[0]; |
|||
} |
|||
|
|||
if (!parent) { |
|||
parent = $(element).closest('.' + ClassName.ALERT)[0]; |
|||
} |
|||
|
|||
return parent; |
|||
} |
|||
}, { |
|||
key: '_triggerCloseEvent', |
|||
value: function _triggerCloseEvent(element) { |
|||
var closeEvent = $.Event(Event.CLOSE); |
|||
|
|||
$(element).trigger(closeEvent); |
|||
return closeEvent; |
|||
} |
|||
}, { |
|||
key: '_removeElement', |
|||
value: function _removeElement(element) { |
|||
$(element).removeClass(ClassName.IN); |
|||
|
|||
if (!_util2.default.supportsTransitionEnd() || !$(element).hasClass(ClassName.FADE)) { |
|||
this._destroyElement(element); |
|||
return; |
|||
} |
|||
|
|||
$(element).one(_util2.default.TRANSITION_END, $.proxy(this._destroyElement, this, element)).emulateTransitionEnd(TRANSITION_DURATION); |
|||
} |
|||
}, { |
|||
key: '_destroyElement', |
|||
value: function _destroyElement(element) { |
|||
$(element).detach().trigger(Event.CLOSED).remove(); |
|||
} |
|||
}], [{ |
|||
key: '_jQueryInterface', |
|||
value: function _jQueryInterface(config) { |
|||
return this.each(function () { |
|||
var $element = $(this); |
|||
var data = $element.data(DATA_KEY); |
|||
|
|||
if (!data) { |
|||
data = new Alert(this); |
|||
$element.data(DATA_KEY, data); |
|||
} |
|||
|
|||
if (config === 'close') { |
|||
data[config](this); |
|||
} |
|||
}); |
|||
} |
|||
}, { |
|||
key: '_handleDismiss', |
|||
value: function _handleDismiss(alertInstance) { |
|||
return function (event) { |
|||
if (event) { |
|||
event.preventDefault(); |
|||
} |
|||
|
|||
alertInstance.close(this); |
|||
}; |
|||
} |
|||
}, { |
|||
key: 'VERSION', |
|||
get: function get() { |
|||
return VERSION; |
|||
} |
|||
}]); |
|||
|
|||
return Alert; |
|||
}(); |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Data Api implementation |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
$(document).on(Event.CLICK_DATA_API, Selector.DISMISS, Alert._handleDismiss(new Alert())); |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* jQuery |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
$.fn[NAME] = Alert._jQueryInterface; |
|||
$.fn[NAME].Constructor = Alert; |
|||
$.fn[NAME].noConflict = function () { |
|||
$.fn[NAME] = JQUERY_NO_CONFLICT; |
|||
return Alert._jQueryInterface; |
|||
}; |
|||
|
|||
return Alert; |
|||
}(jQuery); |
|||
|
|||
exports.default = Alert; |
|||
}); |
@ -0,0 +1,195 @@ |
|||
define(['exports'], function (exports) { |
|||
'use strict'; |
|||
|
|||
Object.defineProperty(exports, "__esModule", { |
|||
value: true |
|||
}); |
|||
|
|||
function _classCallCheck(instance, Constructor) { |
|||
if (!(instance instanceof Constructor)) { |
|||
throw new TypeError("Cannot call a class as a function"); |
|||
} |
|||
} |
|||
|
|||
var _createClass = function () { |
|||
function defineProperties(target, props) { |
|||
for (var i = 0; i < props.length; i++) { |
|||
var descriptor = props[i]; |
|||
descriptor.enumerable = descriptor.enumerable || false; |
|||
descriptor.configurable = true; |
|||
if ("value" in descriptor) descriptor.writable = true; |
|||
Object.defineProperty(target, descriptor.key, descriptor); |
|||
} |
|||
} |
|||
|
|||
return function (Constructor, protoProps, staticProps) { |
|||
if (protoProps) defineProperties(Constructor.prototype, protoProps); |
|||
if (staticProps) defineProperties(Constructor, staticProps); |
|||
return Constructor; |
|||
}; |
|||
}(); |
|||
|
|||
/** |
|||
* -------------------------------------------------------------------------- |
|||
* Bootstrap (v4.0.0-alpha.4): button.js |
|||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|||
* -------------------------------------------------------------------------- |
|||
*/ |
|||
|
|||
var Button = function ($) { |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Constants |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
var NAME = 'button'; |
|||
var VERSION = '4.0.0-alpha.4'; |
|||
var DATA_KEY = 'bs.button'; |
|||
var EVENT_KEY = '.' + DATA_KEY; |
|||
var DATA_API_KEY = '.data-api'; |
|||
var JQUERY_NO_CONFLICT = $.fn[NAME]; |
|||
|
|||
var ClassName = { |
|||
ACTIVE: 'active', |
|||
BUTTON: 'btn', |
|||
FOCUS: 'focus' |
|||
}; |
|||
|
|||
var Selector = { |
|||
DATA_TOGGLE_CARROT: '[data-toggle^="button"]', |
|||
DATA_TOGGLE: '[data-toggle="buttons"]', |
|||
INPUT: 'input', |
|||
ACTIVE: '.active', |
|||
BUTTON: '.btn' |
|||
}; |
|||
|
|||
var Event = { |
|||
CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY, |
|||
FOCUS_BLUR_DATA_API: 'focus' + EVENT_KEY + DATA_API_KEY + ' ' + ('blur' + EVENT_KEY + DATA_API_KEY) |
|||
}; |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Class Definition |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
var Button = function () { |
|||
function Button(element) { |
|||
_classCallCheck(this, Button); |
|||
|
|||
this._element = element; |
|||
} |
|||
|
|||
// getters
|
|||
|
|||
_createClass(Button, [{ |
|||
key: 'toggle', |
|||
value: function toggle() { |
|||
var triggerChangeEvent = true; |
|||
var rootElement = $(this._element).closest(Selector.DATA_TOGGLE)[0]; |
|||
|
|||
if (rootElement) { |
|||
var input = $(this._element).find(Selector.INPUT)[0]; |
|||
|
|||
if (input) { |
|||
if (input.type === 'radio') { |
|||
if (input.checked && $(this._element).hasClass(ClassName.ACTIVE)) { |
|||
triggerChangeEvent = false; |
|||
} else { |
|||
var activeElement = $(rootElement).find(Selector.ACTIVE)[0]; |
|||
|
|||
if (activeElement) { |
|||
$(activeElement).removeClass(ClassName.ACTIVE); |
|||
} |
|||
} |
|||
} |
|||
|
|||
if (triggerChangeEvent) { |
|||
input.checked = !$(this._element).hasClass(ClassName.ACTIVE); |
|||
$(this._element).trigger('change'); |
|||
} |
|||
|
|||
input.focus(); |
|||
} |
|||
} else { |
|||
this._element.setAttribute('aria-pressed', !$(this._element).hasClass(ClassName.ACTIVE)); |
|||
} |
|||
|
|||
if (triggerChangeEvent) { |
|||
$(this._element).toggleClass(ClassName.ACTIVE); |
|||
} |
|||
} |
|||
}, { |
|||
key: 'dispose', |
|||
value: function dispose() { |
|||
$.removeData(this._element, DATA_KEY); |
|||
this._element = null; |
|||
} |
|||
}], [{ |
|||
key: '_jQueryInterface', |
|||
value: function _jQueryInterface(config) { |
|||
return this.each(function () { |
|||
var data = $(this).data(DATA_KEY); |
|||
|
|||
if (!data) { |
|||
data = new Button(this); |
|||
$(this).data(DATA_KEY, data); |
|||
} |
|||
|
|||
if (config === 'toggle') { |
|||
data[config](); |
|||
} |
|||
}); |
|||
} |
|||
}, { |
|||
key: 'VERSION', |
|||
get: function get() { |
|||
return VERSION; |
|||
} |
|||
}]); |
|||
|
|||
return Button; |
|||
}(); |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Data Api implementation |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
$(document).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE_CARROT, function (event) { |
|||
event.preventDefault(); |
|||
|
|||
var button = event.target; |
|||
|
|||
if (!$(button).hasClass(ClassName.BUTTON)) { |
|||
button = $(button).closest(Selector.BUTTON); |
|||
} |
|||
|
|||
Button._jQueryInterface.call($(button), 'toggle'); |
|||
}).on(Event.FOCUS_BLUR_DATA_API, Selector.DATA_TOGGLE_CARROT, function (event) { |
|||
var button = $(event.target).closest(Selector.BUTTON)[0]; |
|||
$(button).toggleClass(ClassName.FOCUS, /^focus(in)?$/.test(event.type)); |
|||
}); |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* jQuery |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
$.fn[NAME] = Button._jQueryInterface; |
|||
$.fn[NAME].Constructor = Button; |
|||
$.fn[NAME].noConflict = function () { |
|||
$.fn[NAME] = JQUERY_NO_CONFLICT; |
|||
return Button._jQueryInterface; |
|||
}; |
|||
|
|||
return Button; |
|||
}(jQuery); |
|||
|
|||
exports.default = Button; |
|||
}); |
@ -0,0 +1,514 @@ |
|||
define(['exports', './util'], function (exports, _util) { |
|||
'use strict'; |
|||
|
|||
Object.defineProperty(exports, "__esModule", { |
|||
value: true |
|||
}); |
|||
|
|||
var _util2 = _interopRequireDefault(_util); |
|||
|
|||
function _interopRequireDefault(obj) { |
|||
return obj && obj.__esModule ? obj : { |
|||
default: obj |
|||
}; |
|||
} |
|||
|
|||
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { |
|||
return typeof obj; |
|||
} : function (obj) { |
|||
return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; |
|||
}; |
|||
|
|||
function _classCallCheck(instance, Constructor) { |
|||
if (!(instance instanceof Constructor)) { |
|||
throw new TypeError("Cannot call a class as a function"); |
|||
} |
|||
} |
|||
|
|||
var _createClass = function () { |
|||
function defineProperties(target, props) { |
|||
for (var i = 0; i < props.length; i++) { |
|||
var descriptor = props[i]; |
|||
descriptor.enumerable = descriptor.enumerable || false; |
|||
descriptor.configurable = true; |
|||
if ("value" in descriptor) descriptor.writable = true; |
|||
Object.defineProperty(target, descriptor.key, descriptor); |
|||
} |
|||
} |
|||
|
|||
return function (Constructor, protoProps, staticProps) { |
|||
if (protoProps) defineProperties(Constructor.prototype, protoProps); |
|||
if (staticProps) defineProperties(Constructor, staticProps); |
|||
return Constructor; |
|||
}; |
|||
}(); |
|||
|
|||
/** |
|||
* -------------------------------------------------------------------------- |
|||
* Bootstrap (v4.0.0-alpha.4): carousel.js |
|||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|||
* -------------------------------------------------------------------------- |
|||
*/ |
|||
|
|||
var Carousel = function ($) { |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Constants |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
var NAME = 'carousel'; |
|||
var VERSION = '4.0.0-alpha.4'; |
|||
var DATA_KEY = 'bs.carousel'; |
|||
var EVENT_KEY = '.' + DATA_KEY; |
|||
var DATA_API_KEY = '.data-api'; |
|||
var JQUERY_NO_CONFLICT = $.fn[NAME]; |
|||
var TRANSITION_DURATION = 600; |
|||
var ARROW_LEFT_KEYCODE = 37; // KeyboardEvent.which value for left arrow key
|
|||
var ARROW_RIGHT_KEYCODE = 39; // KeyboardEvent.which value for right arrow key
|
|||
|
|||
var Default = { |
|||
interval: 5000, |
|||
keyboard: true, |
|||
slide: false, |
|||
pause: 'hover', |
|||
wrap: true |
|||
}; |
|||
|
|||
var DefaultType = { |
|||
interval: '(number|boolean)', |
|||
keyboard: 'boolean', |
|||
slide: '(boolean|string)', |
|||
pause: '(string|boolean)', |
|||
wrap: 'boolean' |
|||
}; |
|||
|
|||
var Direction = { |
|||
NEXT: 'next', |
|||
PREVIOUS: 'prev' |
|||
}; |
|||
|
|||
var Event = { |
|||
SLIDE: 'slide' + EVENT_KEY, |
|||
SLID: 'slid' + EVENT_KEY, |
|||
KEYDOWN: 'keydown' + EVENT_KEY, |
|||
MOUSEENTER: 'mouseenter' + EVENT_KEY, |
|||
MOUSELEAVE: 'mouseleave' + EVENT_KEY, |
|||
LOAD_DATA_API: 'load' + EVENT_KEY + DATA_API_KEY, |
|||
CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY |
|||
}; |
|||
|
|||
var ClassName = { |
|||
CAROUSEL: 'carousel', |
|||
ACTIVE: 'active', |
|||
SLIDE: 'slide', |
|||
RIGHT: 'right', |
|||
LEFT: 'left', |
|||
ITEM: 'carousel-item' |
|||
}; |
|||
|
|||
var Selector = { |
|||
ACTIVE: '.active', |
|||
ACTIVE_ITEM: '.active.carousel-item', |
|||
ITEM: '.carousel-item', |
|||
NEXT_PREV: '.next, .prev', |
|||
INDICATORS: '.carousel-indicators', |
|||
DATA_SLIDE: '[data-slide], [data-slide-to]', |
|||
DATA_RIDE: '[data-ride="carousel"]' |
|||
}; |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Class Definition |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
var Carousel = function () { |
|||
function Carousel(element, config) { |
|||
_classCallCheck(this, Carousel); |
|||
|
|||
this._items = null; |
|||
this._interval = null; |
|||
this._activeElement = null; |
|||
|
|||
this._isPaused = false; |
|||
this._isSliding = false; |
|||
|
|||
this._config = this._getConfig(config); |
|||
this._element = $(element)[0]; |
|||
this._indicatorsElement = $(this._element).find(Selector.INDICATORS)[0]; |
|||
|
|||
this._addEventListeners(); |
|||
} |
|||
|
|||
// getters
|
|||
|
|||
_createClass(Carousel, [{ |
|||
key: 'next', |
|||
value: function next() { |
|||
if (!this._isSliding) { |
|||
this._slide(Direction.NEXT); |
|||
} |
|||
} |
|||
}, { |
|||
key: 'nextWhenVisible', |
|||
value: function nextWhenVisible() { |
|||
// Don't call next when the page isn't visible
|
|||
if (!document.hidden) { |
|||
this.next(); |
|||
} |
|||
} |
|||
}, { |
|||
key: 'prev', |
|||
value: function prev() { |
|||
if (!this._isSliding) { |
|||
this._slide(Direction.PREVIOUS); |
|||
} |
|||
} |
|||
}, { |
|||
key: 'pause', |
|||
value: function pause(event) { |
|||
if (!event) { |
|||
this._isPaused = true; |
|||
} |
|||
|
|||
if ($(this._element).find(Selector.NEXT_PREV)[0] && _util2.default.supportsTransitionEnd()) { |
|||
_util2.default.triggerTransitionEnd(this._element); |
|||
this.cycle(true); |
|||
} |
|||
|
|||
clearInterval(this._interval); |
|||
this._interval = null; |
|||
} |
|||
}, { |
|||
key: 'cycle', |
|||
value: function cycle(event) { |
|||
if (!event) { |
|||
this._isPaused = false; |
|||
} |
|||
|
|||
if (this._interval) { |
|||
clearInterval(this._interval); |
|||
this._interval = null; |
|||
} |
|||
|
|||
if (this._config.interval && !this._isPaused) { |
|||
this._interval = setInterval($.proxy(document.visibilityState ? this.nextWhenVisible : this.next, this), this._config.interval); |
|||
} |
|||
} |
|||
}, { |
|||
key: 'to', |
|||
value: function to(index) { |
|||
var _this = this; |
|||
|
|||
this._activeElement = $(this._element).find(Selector.ACTIVE_ITEM)[0]; |
|||
|
|||
var activeIndex = this._getItemIndex(this._activeElement); |
|||
|
|||
if (index > this._items.length - 1 || index < 0) { |
|||
return; |
|||
} |
|||
|
|||
if (this._isSliding) { |
|||
$(this._element).one(Event.SLID, function () { |
|||
return _this.to(index); |
|||
}); |
|||
return; |
|||
} |
|||
|
|||
if (activeIndex === index) { |
|||
this.pause(); |
|||
this.cycle(); |
|||
return; |
|||
} |
|||
|
|||
var direction = index > activeIndex ? Direction.NEXT : Direction.PREVIOUS; |
|||
|
|||
this._slide(direction, this._items[index]); |
|||
} |
|||
}, { |
|||
key: 'dispose', |
|||
value: function dispose() { |
|||
$(this._element).off(EVENT_KEY); |
|||
$.removeData(this._element, DATA_KEY); |
|||
|
|||
this._items = null; |
|||
this._config = null; |
|||
this._element = null; |
|||
this._interval = null; |
|||
this._isPaused = null; |
|||
this._isSliding = null; |
|||
this._activeElement = null; |
|||
this._indicatorsElement = null; |
|||
} |
|||
}, { |
|||
key: '_getConfig', |
|||
value: function _getConfig(config) { |
|||
config = $.extend({}, Default, config); |
|||
_util2.default.typeCheckConfig(NAME, config, DefaultType); |
|||
return config; |
|||
} |
|||
}, { |
|||
key: '_addEventListeners', |
|||
value: function _addEventListeners() { |
|||
if (this._config.keyboard) { |
|||
$(this._element).on(Event.KEYDOWN, $.proxy(this._keydown, this)); |
|||
} |
|||
|
|||
if (this._config.pause === 'hover' && !('ontouchstart' in document.documentElement)) { |
|||
$(this._element).on(Event.MOUSEENTER, $.proxy(this.pause, this)).on(Event.MOUSELEAVE, $.proxy(this.cycle, this)); |
|||
} |
|||
} |
|||
}, { |
|||
key: '_keydown', |
|||
value: function _keydown(event) { |
|||
event.preventDefault(); |
|||
|
|||
if (/input|textarea/i.test(event.target.tagName)) { |
|||
return; |
|||
} |
|||
|
|||
switch (event.which) { |
|||
case ARROW_LEFT_KEYCODE: |
|||
this.prev(); |
|||
break; |
|||
case ARROW_RIGHT_KEYCODE: |
|||
this.next(); |
|||
break; |
|||
default: |
|||
return; |
|||
} |
|||
} |
|||
}, { |
|||
key: '_getItemIndex', |
|||
value: function _getItemIndex(element) { |
|||
this._items = $.makeArray($(element).parent().find(Selector.ITEM)); |
|||
return this._items.indexOf(element); |
|||
} |
|||
}, { |
|||
key: '_getItemByDirection', |
|||
value: function _getItemByDirection(direction, activeElement) { |
|||
var isNextDirection = direction === Direction.NEXT; |
|||
var isPrevDirection = direction === Direction.PREVIOUS; |
|||
var activeIndex = this._getItemIndex(activeElement); |
|||
var lastItemIndex = this._items.length - 1; |
|||
var isGoingToWrap = isPrevDirection && activeIndex === 0 || isNextDirection && activeIndex === lastItemIndex; |
|||
|
|||
if (isGoingToWrap && !this._config.wrap) { |
|||
return activeElement; |
|||
} |
|||
|
|||
var delta = direction === Direction.PREVIOUS ? -1 : 1; |
|||
var itemIndex = (activeIndex + delta) % this._items.length; |
|||
|
|||
return itemIndex === -1 ? this._items[this._items.length - 1] : this._items[itemIndex]; |
|||
} |
|||
}, { |
|||
key: '_triggerSlideEvent', |
|||
value: function _triggerSlideEvent(relatedTarget, directionalClassname) { |
|||
var slideEvent = $.Event(Event.SLIDE, { |
|||
relatedTarget: relatedTarget, |
|||
direction: directionalClassname |
|||
}); |
|||
|
|||
$(this._element).trigger(slideEvent); |
|||
|
|||
return slideEvent; |
|||
} |
|||
}, { |
|||
key: '_setActiveIndicatorElement', |
|||
value: function _setActiveIndicatorElement(element) { |
|||
if (this._indicatorsElement) { |
|||
$(this._indicatorsElement).find(Selector.ACTIVE).removeClass(ClassName.ACTIVE); |
|||
|
|||
var nextIndicator = this._indicatorsElement.children[this._getItemIndex(element)]; |
|||
|
|||
if (nextIndicator) { |
|||
$(nextIndicator).addClass(ClassName.ACTIVE); |
|||
} |
|||
} |
|||
} |
|||
}, { |
|||
key: '_slide', |
|||
value: function _slide(direction, element) { |
|||
var _this2 = this; |
|||
|
|||
var activeElement = $(this._element).find(Selector.ACTIVE_ITEM)[0]; |
|||
var nextElement = element || activeElement && this._getItemByDirection(direction, activeElement); |
|||
|
|||
var isCycling = Boolean(this._interval); |
|||
|
|||
var directionalClassName = direction === Direction.NEXT ? ClassName.LEFT : ClassName.RIGHT; |
|||
|
|||
if (nextElement && $(nextElement).hasClass(ClassName.ACTIVE)) { |
|||
this._isSliding = false; |
|||
return; |
|||
} |
|||
|
|||
var slideEvent = this._triggerSlideEvent(nextElement, directionalClassName); |
|||
if (slideEvent.isDefaultPrevented()) { |
|||
return; |
|||
} |
|||
|
|||
if (!activeElement || !nextElement) { |
|||
// some weirdness is happening, so we bail
|
|||
return; |
|||
} |
|||
|
|||
this._isSliding = true; |
|||
|
|||
if (isCycling) { |
|||
this.pause(); |
|||
} |
|||
|
|||
this._setActiveIndicatorElement(nextElement); |
|||
|
|||
var slidEvent = $.Event(Event.SLID, { |
|||
relatedTarget: nextElement, |
|||
direction: directionalClassName |
|||
}); |
|||
|
|||
if (_util2.default.supportsTransitionEnd() && $(this._element).hasClass(ClassName.SLIDE)) { |
|||
|
|||
$(nextElement).addClass(direction); |
|||
|
|||
_util2.default.reflow(nextElement); |
|||
|
|||
$(activeElement).addClass(directionalClassName); |
|||
$(nextElement).addClass(directionalClassName); |
|||
|
|||
$(activeElement).one(_util2.default.TRANSITION_END, function () { |
|||
$(nextElement).removeClass(directionalClassName).removeClass(direction); |
|||
|
|||
$(nextElement).addClass(ClassName.ACTIVE); |
|||
|
|||
$(activeElement).removeClass(ClassName.ACTIVE).removeClass(direction).removeClass(directionalClassName); |
|||
|
|||
_this2._isSliding = false; |
|||
|
|||
setTimeout(function () { |
|||
return $(_this2._element).trigger(slidEvent); |
|||
}, 0); |
|||
}).emulateTransitionEnd(TRANSITION_DURATION); |
|||
} else { |
|||
$(activeElement).removeClass(ClassName.ACTIVE); |
|||
$(nextElement).addClass(ClassName.ACTIVE); |
|||
|
|||
this._isSliding = false; |
|||
$(this._element).trigger(slidEvent); |
|||
} |
|||
|
|||
if (isCycling) { |
|||
this.cycle(); |
|||
} |
|||
} |
|||
}], [{ |
|||
key: '_jQueryInterface', |
|||
value: function _jQueryInterface(config) { |
|||
return this.each(function () { |
|||
var data = $(this).data(DATA_KEY); |
|||
var _config = $.extend({}, Default, $(this).data()); |
|||
|
|||
if ((typeof config === 'undefined' ? 'undefined' : _typeof(config)) === 'object') { |
|||
$.extend(_config, config); |
|||
} |
|||
|
|||
var action = typeof config === 'string' ? config : _config.slide; |
|||
|
|||
if (!data) { |
|||
data = new Carousel(this, _config); |
|||
$(this).data(DATA_KEY, data); |
|||
} |
|||
|
|||
if (typeof config === 'number') { |
|||
data.to(config); |
|||
} else if (typeof action === 'string') { |
|||
if (data[action] === undefined) { |
|||
throw new Error('No method named "' + action + '"'); |
|||
} |
|||
data[action](); |
|||
} else if (_config.interval) { |
|||
data.pause(); |
|||
data.cycle(); |
|||
} |
|||
}); |
|||
} |
|||
}, { |
|||
key: '_dataApiClickHandler', |
|||
value: function _dataApiClickHandler(event) { |
|||
var selector = _util2.default.getSelectorFromElement(this); |
|||
|
|||
if (!selector) { |
|||
return; |
|||
} |
|||
|
|||
var target = $(selector)[0]; |
|||
|
|||
if (!target || !$(target).hasClass(ClassName.CAROUSEL)) { |
|||
return; |
|||
} |
|||
|
|||
var config = $.extend({}, $(target).data(), $(this).data()); |
|||
var slideIndex = this.getAttribute('data-slide-to'); |
|||
|
|||
if (slideIndex) { |
|||
config.interval = false; |
|||
} |
|||
|
|||
Carousel._jQueryInterface.call($(target), config); |
|||
|
|||
if (slideIndex) { |
|||
$(target).data(DATA_KEY).to(slideIndex); |
|||
} |
|||
|
|||
event.preventDefault(); |
|||
} |
|||
}, { |
|||
key: 'VERSION', |
|||
get: function get() { |
|||
return VERSION; |
|||
} |
|||
}, { |
|||
key: 'Default', |
|||
get: function get() { |
|||
return Default; |
|||
} |
|||
}]); |
|||
|
|||
return Carousel; |
|||
}(); |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Data Api implementation |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
$(document).on(Event.CLICK_DATA_API, Selector.DATA_SLIDE, Carousel._dataApiClickHandler); |
|||
|
|||
$(window).on(Event.LOAD_DATA_API, function () { |
|||
$(Selector.DATA_RIDE).each(function () { |
|||
var $carousel = $(this); |
|||
Carousel._jQueryInterface.call($carousel, $carousel.data()); |
|||
}); |
|||
}); |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* jQuery |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
$.fn[NAME] = Carousel._jQueryInterface; |
|||
$.fn[NAME].Constructor = Carousel; |
|||
$.fn[NAME].noConflict = function () { |
|||
$.fn[NAME] = JQUERY_NO_CONFLICT; |
|||
return Carousel._jQueryInterface; |
|||
}; |
|||
|
|||
return Carousel; |
|||
}(jQuery); |
|||
|
|||
exports.default = Carousel; |
|||
}); |
@ -0,0 +1,396 @@ |
|||
define(['exports', './util'], function (exports, _util) { |
|||
'use strict'; |
|||
|
|||
Object.defineProperty(exports, "__esModule", { |
|||
value: true |
|||
}); |
|||
|
|||
var _util2 = _interopRequireDefault(_util); |
|||
|
|||
function _interopRequireDefault(obj) { |
|||
return obj && obj.__esModule ? obj : { |
|||
default: obj |
|||
}; |
|||
} |
|||
|
|||
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { |
|||
return typeof obj; |
|||
} : function (obj) { |
|||
return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; |
|||
}; |
|||
|
|||
function _classCallCheck(instance, Constructor) { |
|||
if (!(instance instanceof Constructor)) { |
|||
throw new TypeError("Cannot call a class as a function"); |
|||
} |
|||
} |
|||
|
|||
var _createClass = function () { |
|||
function defineProperties(target, props) { |
|||
for (var i = 0; i < props.length; i++) { |
|||
var descriptor = props[i]; |
|||
descriptor.enumerable = descriptor.enumerable || false; |
|||
descriptor.configurable = true; |
|||
if ("value" in descriptor) descriptor.writable = true; |
|||
Object.defineProperty(target, descriptor.key, descriptor); |
|||
} |
|||
} |
|||
|
|||
return function (Constructor, protoProps, staticProps) { |
|||
if (protoProps) defineProperties(Constructor.prototype, protoProps); |
|||
if (staticProps) defineProperties(Constructor, staticProps); |
|||
return Constructor; |
|||
}; |
|||
}(); |
|||
|
|||
/** |
|||
* -------------------------------------------------------------------------- |
|||
* Bootstrap (v4.0.0-alpha.4): collapse.js |
|||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|||
* -------------------------------------------------------------------------- |
|||
*/ |
|||
|
|||
var Collapse = function ($) { |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Constants |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
var NAME = 'collapse'; |
|||
var VERSION = '4.0.0-alpha.4'; |
|||
var DATA_KEY = 'bs.collapse'; |
|||
var EVENT_KEY = '.' + DATA_KEY; |
|||
var DATA_API_KEY = '.data-api'; |
|||
var JQUERY_NO_CONFLICT = $.fn[NAME]; |
|||
var TRANSITION_DURATION = 600; |
|||
|
|||
var Default = { |
|||
toggle: true, |
|||
parent: '' |
|||
}; |
|||
|
|||
var DefaultType = { |
|||
toggle: 'boolean', |
|||
parent: 'string' |
|||
}; |
|||
|
|||
var Event = { |
|||
SHOW: 'show' + EVENT_KEY, |
|||
SHOWN: 'shown' + EVENT_KEY, |
|||
HIDE: 'hide' + EVENT_KEY, |
|||
HIDDEN: 'hidden' + EVENT_KEY, |
|||
CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY |
|||
}; |
|||
|
|||
var ClassName = { |
|||
IN: 'in', |
|||
COLLAPSE: 'collapse', |
|||
COLLAPSING: 'collapsing', |
|||
COLLAPSED: 'collapsed' |
|||
}; |
|||
|
|||
var Dimension = { |
|||
WIDTH: 'width', |
|||
HEIGHT: 'height' |
|||
}; |
|||
|
|||
var Selector = { |
|||
ACTIVES: '.panel > .in, .panel > .collapsing', |
|||
DATA_TOGGLE: '[data-toggle="collapse"]' |
|||
}; |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Class Definition |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
var Collapse = function () { |
|||
function Collapse(element, config) { |
|||
_classCallCheck(this, Collapse); |
|||
|
|||
this._isTransitioning = false; |
|||
this._element = element; |
|||
this._config = this._getConfig(config); |
|||
this._triggerArray = $.makeArray($('[data-toggle="collapse"][href="#' + element.id + '"],' + ('[data-toggle="collapse"][data-target="#' + element.id + '"]'))); |
|||
|
|||
this._parent = this._config.parent ? this._getParent() : null; |
|||
|
|||
if (!this._config.parent) { |
|||
this._addAriaAndCollapsedClass(this._element, this._triggerArray); |
|||
} |
|||
|
|||
if (this._config.toggle) { |
|||
this.toggle(); |
|||
} |
|||
} |
|||
|
|||
// getters
|
|||
|
|||
_createClass(Collapse, [{ |
|||
key: 'toggle', |
|||
value: function toggle() { |
|||
if ($(this._element).hasClass(ClassName.IN)) { |
|||
this.hide(); |
|||
} else { |
|||
this.show(); |
|||
} |
|||
} |
|||
}, { |
|||
key: 'show', |
|||
value: function show() { |
|||
var _this = this; |
|||
|
|||
if (this._isTransitioning || $(this._element).hasClass(ClassName.IN)) { |
|||
return; |
|||
} |
|||
|
|||
var actives = void 0; |
|||
var activesData = void 0; |
|||
|
|||
if (this._parent) { |
|||
actives = $.makeArray($(Selector.ACTIVES)); |
|||
if (!actives.length) { |
|||
actives = null; |
|||
} |
|||
} |
|||
|
|||
if (actives) { |
|||
activesData = $(actives).data(DATA_KEY); |
|||
if (activesData && activesData._isTransitioning) { |
|||
return; |
|||
} |
|||
} |
|||
|
|||
var startEvent = $.Event(Event.SHOW); |
|||
$(this._element).trigger(startEvent); |
|||
if (startEvent.isDefaultPrevented()) { |
|||
return; |
|||
} |
|||
|
|||
if (actives) { |
|||
Collapse._jQueryInterface.call($(actives), 'hide'); |
|||
if (!activesData) { |
|||
$(actives).data(DATA_KEY, null); |
|||
} |
|||
} |
|||
|
|||
var dimension = this._getDimension(); |
|||
|
|||
$(this._element).removeClass(ClassName.COLLAPSE).addClass(ClassName.COLLAPSING); |
|||
|
|||
this._element.style[dimension] = 0; |
|||
this._element.setAttribute('aria-expanded', true); |
|||
|
|||
if (this._triggerArray.length) { |
|||
$(this._triggerArray).removeClass(ClassName.COLLAPSED).attr('aria-expanded', true); |
|||
} |
|||
|
|||
this.setTransitioning(true); |
|||
|
|||
var complete = function complete() { |
|||
$(_this._element).removeClass(ClassName.COLLAPSING).addClass(ClassName.COLLAPSE).addClass(ClassName.IN); |
|||
|
|||
_this._element.style[dimension] = ''; |
|||
|
|||
_this.setTransitioning(false); |
|||
|
|||
$(_this._element).trigger(Event.SHOWN); |
|||
}; |
|||
|
|||
if (!_util2.default.supportsTransitionEnd()) { |
|||
complete(); |
|||
return; |
|||
} |
|||
|
|||
var capitalizedDimension = dimension[0].toUpperCase() + dimension.slice(1); |
|||
var scrollSize = 'scroll' + capitalizedDimension; |
|||
|
|||
$(this._element).one(_util2.default.TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION); |
|||
|
|||
this._element.style[dimension] = this._element[scrollSize] + 'px'; |
|||
} |
|||
}, { |
|||
key: 'hide', |
|||
value: function hide() { |
|||
var _this2 = this; |
|||
|
|||
if (this._isTransitioning || !$(this._element).hasClass(ClassName.IN)) { |
|||
return; |
|||
} |
|||
|
|||
var startEvent = $.Event(Event.HIDE); |
|||
$(this._element).trigger(startEvent); |
|||
if (startEvent.isDefaultPrevented()) { |
|||
return; |
|||
} |
|||
|
|||
var dimension = this._getDimension(); |
|||
var offsetDimension = dimension === Dimension.WIDTH ? 'offsetWidth' : 'offsetHeight'; |
|||
|
|||
this._element.style[dimension] = this._element[offsetDimension] + 'px'; |
|||
|
|||
_util2.default.reflow(this._element); |
|||
|
|||
$(this._element).addClass(ClassName.COLLAPSING).removeClass(ClassName.COLLAPSE).removeClass(ClassName.IN); |
|||
|
|||
this._element.setAttribute('aria-expanded', false); |
|||
|
|||
if (this._triggerArray.length) { |
|||
$(this._triggerArray).addClass(ClassName.COLLAPSED).attr('aria-expanded', false); |
|||
} |
|||
|
|||
this.setTransitioning(true); |
|||
|
|||
var complete = function complete() { |
|||
_this2.setTransitioning(false); |
|||
$(_this2._element).removeClass(ClassName.COLLAPSING).addClass(ClassName.COLLAPSE).trigger(Event.HIDDEN); |
|||
}; |
|||
|
|||
this._element.style[dimension] = 0; |
|||
|
|||
if (!_util2.default.supportsTransitionEnd()) { |
|||
complete(); |
|||
return; |
|||
} |
|||
|
|||
$(this._element).one(_util2.default.TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION); |
|||
} |
|||
}, { |
|||
key: 'setTransitioning', |
|||
value: function setTransitioning(isTransitioning) { |
|||
this._isTransitioning = isTransitioning; |
|||
} |
|||
}, { |
|||
key: 'dispose', |
|||
value: function dispose() { |
|||
$.removeData(this._element, DATA_KEY); |
|||
|
|||
this._config = null; |
|||
this._parent = null; |
|||
this._element = null; |
|||
this._triggerArray = null; |
|||
this._isTransitioning = null; |
|||
} |
|||
}, { |
|||
key: '_getConfig', |
|||
value: function _getConfig(config) { |
|||
config = $.extend({}, Default, config); |
|||
config.toggle = Boolean(config.toggle); // coerce string values
|
|||
_util2.default.typeCheckConfig(NAME, config, DefaultType); |
|||
return config; |
|||
} |
|||
}, { |
|||
key: '_getDimension', |
|||
value: function _getDimension() { |
|||
var hasWidth = $(this._element).hasClass(Dimension.WIDTH); |
|||
return hasWidth ? Dimension.WIDTH : Dimension.HEIGHT; |
|||
} |
|||
}, { |
|||
key: '_getParent', |
|||
value: function _getParent() { |
|||
var _this3 = this; |
|||
|
|||
var parent = $(this._config.parent)[0]; |
|||
var selector = '[data-toggle="collapse"][data-parent="' + this._config.parent + '"]'; |
|||
|
|||
$(parent).find(selector).each(function (i, element) { |
|||
_this3._addAriaAndCollapsedClass(Collapse._getTargetFromElement(element), [element]); |
|||
}); |
|||
|
|||
return parent; |
|||
} |
|||
}, { |
|||
key: '_addAriaAndCollapsedClass', |
|||
value: function _addAriaAndCollapsedClass(element, triggerArray) { |
|||
if (element) { |
|||
var isOpen = $(element).hasClass(ClassName.IN); |
|||
element.setAttribute('aria-expanded', isOpen); |
|||
|
|||
if (triggerArray.length) { |
|||
$(triggerArray).toggleClass(ClassName.COLLAPSED, !isOpen).attr('aria-expanded', isOpen); |
|||
} |
|||
} |
|||
} |
|||
}], [{ |
|||
key: '_getTargetFromElement', |
|||
value: function _getTargetFromElement(element) { |
|||
var selector = _util2.default.getSelectorFromElement(element); |
|||
return selector ? $(selector)[0] : null; |
|||
} |
|||
}, { |
|||
key: '_jQueryInterface', |
|||
value: function _jQueryInterface(config) { |
|||
return this.each(function () { |
|||
var $this = $(this); |
|||
var data = $this.data(DATA_KEY); |
|||
var _config = $.extend({}, Default, $this.data(), (typeof config === 'undefined' ? 'undefined' : _typeof(config)) === 'object' && config); |
|||
|
|||
if (!data && _config.toggle && /show|hide/.test(config)) { |
|||
_config.toggle = false; |
|||
} |
|||
|
|||
if (!data) { |
|||
data = new Collapse(this, _config); |
|||
$this.data(DATA_KEY, data); |
|||
} |
|||
|
|||
if (typeof config === 'string') { |
|||
if (data[config] === undefined) { |
|||
throw new Error('No method named "' + config + '"'); |
|||
} |
|||
data[config](); |
|||
} |
|||
}); |
|||
} |
|||
}, { |
|||
key: 'VERSION', |
|||
get: function get() { |
|||
return VERSION; |
|||
} |
|||
}, { |
|||
key: 'Default', |
|||
get: function get() { |
|||
return Default; |
|||
} |
|||
}]); |
|||
|
|||
return Collapse; |
|||
}(); |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Data Api implementation |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
$(document).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE, function (event) { |
|||
event.preventDefault(); |
|||
|
|||
var target = Collapse._getTargetFromElement(this); |
|||
var data = $(target).data(DATA_KEY); |
|||
var config = data ? 'toggle' : $(this).data(); |
|||
|
|||
Collapse._jQueryInterface.call($(target), config); |
|||
}); |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* jQuery |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
$.fn[NAME] = Collapse._jQueryInterface; |
|||
$.fn[NAME].Constructor = Collapse; |
|||
$.fn[NAME].noConflict = function () { |
|||
$.fn[NAME] = JQUERY_NO_CONFLICT; |
|||
return Collapse._jQueryInterface; |
|||
}; |
|||
|
|||
return Collapse; |
|||
}(jQuery); |
|||
|
|||
exports.default = Collapse; |
|||
}); |
@ -0,0 +1,165 @@ |
|||
// This file is part of Moodle - http://moodle.org/
|
|||
//
|
|||
// Moodle 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 3 of the License, or
|
|||
// (at your option) any later version.
|
|||
//
|
|||
// Moodle 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.
|
|||
//
|
|||
// You should have received a copy of the GNU General Public License
|
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
|
|||
|
|||
/** |
|||
* Contain the logic for a drawer. |
|||
* |
|||
* @package theme_ilb |
|||
* @copyright 2016 Damyon Wiese |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|||
*/ |
|||
define(['jquery', 'core/custom_interaction_events', 'core/log'], |
|||
function($, CustomEvents, Log) { |
|||
|
|||
var SELECTORS = { |
|||
TOGGLE_REGION: '[data-region="drawer-toggle"]', |
|||
TOGGLE_ACTION: '[data-action="toggle-drawer"]', |
|||
TOGGLE_TARGET: 'aria-controls', |
|||
TOGGLE_SIDE: 'left', |
|||
BODY: 'body' |
|||
}; |
|||
|
|||
/** |
|||
* Constructor for the Drawer. |
|||
* |
|||
* @param {object} root The root jQuery element for the modal |
|||
*/ |
|||
var Drawer = function() { |
|||
|
|||
if (!$(SELECTORS.TOGGLE_REGION).length) { |
|||
Log.debug('Page is missing a drawer region'); |
|||
} |
|||
if (!$(SELECTORS.TOGGLE_ACTION).length) { |
|||
Log.debug('Page is missing a drawer toggle link'); |
|||
} |
|||
$(SELECTORS.TOGGLE_REGION).each(function(index, ele) { |
|||
var trigger = $(ele).find(SELECTORS.TOGGLE_ACTION); |
|||
var drawerid = trigger.attr('aria-controls'); |
|||
var drawer = $(document.getElementById(drawerid)); |
|||
var hidden = trigger.attr('aria-expanded') == 'false'; |
|||
var side = trigger.attr('data-side'); |
|||
var body = $(SELECTORS.BODY); |
|||
|
|||
drawer.on('mousewheel DOMMouseScroll', this.preventPageScroll); |
|||
|
|||
if (!hidden) { |
|||
body.addClass('drawer-open-' + side); |
|||
trigger.attr('aria-expanded', 'true'); |
|||
} else { |
|||
trigger.attr('aria-expanded', 'false'); |
|||
} |
|||
}.bind(this)); |
|||
|
|||
this.registerEventListeners(); |
|||
var small = $(document).width() < 768; |
|||
if (small) { |
|||
this.closeAll(); |
|||
} |
|||
}; |
|||
|
|||
Drawer.prototype.closeAll = function() { |
|||
$(SELECTORS.TOGGLE_REGION).each(function(index, ele) { |
|||
var trigger = $(ele).find(SELECTORS.TOGGLE_ACTION); |
|||
var side = trigger.attr('data-side'); |
|||
var body = $(SELECTORS.BODY); |
|||
var drawerid = trigger.attr('aria-controls'); |
|||
var drawer = $(document.getElementById(drawerid)); |
|||
var preference = trigger.attr('data-preference'); |
|||
|
|||
trigger.attr('aria-expanded', 'false'); |
|||
body.removeClass('drawer-open-' + side); |
|||
drawer.attr('aria-hidden', 'true'); |
|||
drawer.addClass('closed'); |
|||
M.util.set_user_preference(preference, 'false'); |
|||
}); |
|||
}; |
|||
|
|||
/** |
|||
* Open / close the blocks drawer. |
|||
* |
|||
* @method toggleDrawer |
|||
* @param {Event} e |
|||
*/ |
|||
Drawer.prototype.toggleDrawer = function(e) { |
|||
var trigger = $(e.target).closest('[data-action=toggle-drawer]'); |
|||
var drawerid = trigger.attr('aria-controls'); |
|||
var drawer = $(document.getElementById(drawerid)); |
|||
var body = $(SELECTORS.BODY); |
|||
var side = trigger.attr('data-side'); |
|||
var preference = trigger.attr('data-preference'); |
|||
|
|||
body.addClass('drawer-ease'); |
|||
var open = trigger.attr('aria-expanded') == 'true'; |
|||
if (!open) { |
|||
var small = $(document).width() < 768; |
|||
if (small) { |
|||
this.closeAll(); |
|||
} |
|||
// Open.
|
|||
trigger.attr('aria-expanded', 'true'); |
|||
drawer.attr('aria-hidden', 'false'); |
|||
drawer.focus(); |
|||
body.addClass('drawer-open-' + side); |
|||
drawer.removeClass('closed'); |
|||
M.util.set_user_preference(preference, 'true'); |
|||
} else { |
|||
// Close.
|
|||
body.removeClass('drawer-open-' + side); |
|||
trigger.attr('aria-expanded', 'false'); |
|||
drawer.attr('aria-hidden', 'true'); |
|||
drawer.addClass('closed'); |
|||
M.util.set_user_preference(preference, 'false'); |
|||
} |
|||
}; |
|||
|
|||
/** |
|||
* Prevent the page from scrolling when the drawer is at max scroll. |
|||
* |
|||
* @method preventPageScroll |
|||
* @param {Event} e |
|||
*/ |
|||
Drawer.prototype.preventPageScroll = function(e) { |
|||
var delta = e.wheelDelta || (e.originalEvent && e.originalEvent.wheelDelta) || -e.originalEvent.detail, |
|||
bottomOverflow = (this.scrollTop + $(this).outerHeight() - this.scrollHeight) >= 0, |
|||
topOverflow = this.scrollTop <= 0; |
|||
|
|||
if ((delta < 0 && bottomOverflow) || (delta > 0 && topOverflow)) { |
|||
e.preventDefault(); |
|||
} |
|||
}; |
|||
|
|||
/** |
|||
* Set up all of the event handling for the modal. |
|||
* |
|||
* @method registerEventListeners |
|||
*/ |
|||
Drawer.prototype.registerEventListeners = function() { |
|||
|
|||
$(SELECTORS.TOGGLE_ACTION).each(function(index, element) { |
|||
CustomEvents.define($(element), [CustomEvents.events.activate]); |
|||
$(element).on(CustomEvents.events.activate, function(e, data) { |
|||
this.toggleDrawer(data.originalEvent); |
|||
data.originalEvent.preventDefault(); |
|||
}.bind(this)); |
|||
}.bind(this)); |
|||
|
|||
}; |
|||
|
|||
return { |
|||
'init': function() { |
|||
return new Drawer(); |
|||
} |
|||
}; |
|||
}); |
@ -0,0 +1,323 @@ |
|||
define(['exports', './util'], function (exports, _util) { |
|||
'use strict'; |
|||
|
|||
Object.defineProperty(exports, "__esModule", { |
|||
value: true |
|||
}); |
|||
|
|||
var _util2 = _interopRequireDefault(_util); |
|||
|
|||
function _interopRequireDefault(obj) { |
|||
return obj && obj.__esModule ? obj : { |
|||
default: obj |
|||
}; |
|||
} |
|||
|
|||
function _classCallCheck(instance, Constructor) { |
|||
if (!(instance instanceof Constructor)) { |
|||
throw new TypeError("Cannot call a class as a function"); |
|||
} |
|||
} |
|||
|
|||
var _createClass = function () { |
|||
function defineProperties(target, props) { |
|||
for (var i = 0; i < props.length; i++) { |
|||
var descriptor = props[i]; |
|||
descriptor.enumerable = descriptor.enumerable || false; |
|||
descriptor.configurable = true; |
|||
if ("value" in descriptor) descriptor.writable = true; |
|||
Object.defineProperty(target, descriptor.key, descriptor); |
|||
} |
|||
} |
|||
|
|||
return function (Constructor, protoProps, staticProps) { |
|||
if (protoProps) defineProperties(Constructor.prototype, protoProps); |
|||
if (staticProps) defineProperties(Constructor, staticProps); |
|||
return Constructor; |
|||
}; |
|||
}(); |
|||
|
|||
/** |
|||
* -------------------------------------------------------------------------- |
|||
* Bootstrap (v4.0.0-alpha.4): dropdown.js |
|||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|||
* -------------------------------------------------------------------------- |
|||
*/ |
|||
|
|||
var Dropdown = function ($) { |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Constants |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
var NAME = 'dropdown'; |
|||
var VERSION = '4.0.0-alpha.4'; |
|||
var DATA_KEY = 'bs.dropdown'; |
|||
var EVENT_KEY = '.' + DATA_KEY; |
|||
var DATA_API_KEY = '.data-api'; |
|||
var JQUERY_NO_CONFLICT = $.fn[NAME]; |
|||
var ESCAPE_KEYCODE = 27; // KeyboardEvent.which value for Escape (Esc) key
|
|||
var ARROW_UP_KEYCODE = 38; // KeyboardEvent.which value for up arrow key
|
|||
var ARROW_DOWN_KEYCODE = 40; // KeyboardEvent.which value for down arrow key
|
|||
var RIGHT_MOUSE_BUTTON_WHICH = 3; // MouseEvent.which value for the right button (assuming a right-handed mouse)
|
|||
|
|||
var Event = { |
|||
HIDE: 'hide' + EVENT_KEY, |
|||
HIDDEN: 'hidden' + EVENT_KEY, |
|||
SHOW: 'show' + EVENT_KEY, |
|||
SHOWN: 'shown' + EVENT_KEY, |
|||
CLICK: 'click' + EVENT_KEY, |
|||
CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY, |
|||
KEYDOWN_DATA_API: 'keydown' + EVENT_KEY + DATA_API_KEY |
|||
}; |
|||
|
|||
var ClassName = { |
|||
BACKDROP: 'dropdown-backdrop', |
|||
DISABLED: 'disabled', |
|||
OPEN: 'open' |
|||
}; |
|||
|
|||
var Selector = { |
|||
BACKDROP: '.dropdown-backdrop', |
|||
DATA_TOGGLE: '[data-toggle="dropdown"]', |
|||
FORM_CHILD: '.dropdown form', |
|||
ROLE_MENU: '[role="menu"]', |
|||
ROLE_LISTBOX: '[role="listbox"]', |
|||
NAVBAR_NAV: '.navbar-nav', |
|||
VISIBLE_ITEMS: '[role="menu"] li:not(.disabled) a, ' + '[role="listbox"] li:not(.disabled) a' |
|||
}; |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Class Definition |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
var Dropdown = function () { |
|||
function Dropdown(element) { |
|||
_classCallCheck(this, Dropdown); |
|||
|
|||
this._element = element; |
|||
|
|||
this._addEventListeners(); |
|||
} |
|||
|
|||
// getters
|
|||
|
|||
_createClass(Dropdown, [{ |
|||
key: 'toggle', |
|||
value: function toggle() { |
|||
if (this.disabled || $(this).hasClass(ClassName.DISABLED)) { |
|||
return false; |
|||
} |
|||
|
|||
var parent = Dropdown._getParentFromElement(this); |
|||
var isActive = $(parent).hasClass(ClassName.OPEN); |
|||
|
|||
Dropdown._clearMenus(); |
|||
|
|||
if (isActive) { |
|||
return false; |
|||
} |
|||
|
|||
if ('ontouchstart' in document.documentElement && !$(parent).closest(Selector.NAVBAR_NAV).length) { |
|||
|
|||
// if mobile we use a backdrop because click events don't delegate
|
|||
var dropdown = document.createElement('div'); |
|||
dropdown.className = ClassName.BACKDROP; |
|||
$(dropdown).insertBefore(this); |
|||
$(dropdown).on('click', Dropdown._clearMenus); |
|||
} |
|||
|
|||
var relatedTarget = { relatedTarget: this }; |
|||
var showEvent = $.Event(Event.SHOW, relatedTarget); |
|||
|
|||
$(parent).trigger(showEvent); |
|||
|
|||
if (showEvent.isDefaultPrevented()) { |
|||
return false; |
|||
} |
|||
|
|||
this.focus(); |
|||
this.setAttribute('aria-expanded', 'true'); |
|||
|
|||
$(parent).toggleClass(ClassName.OPEN); |
|||
$(parent).trigger($.Event(Event.SHOWN, relatedTarget)); |
|||
|
|||
return false; |
|||
} |
|||
}, { |
|||
key: 'dispose', |
|||
value: function dispose() { |
|||
$.removeData(this._element, DATA_KEY); |
|||
$(this._element).off(EVENT_KEY); |
|||
this._element = null; |
|||
} |
|||
}, { |
|||
key: '_addEventListeners', |
|||
value: function _addEventListeners() { |
|||
$(this._element).on(Event.CLICK, this.toggle); |
|||
} |
|||
}], [{ |
|||
key: '_jQueryInterface', |
|||
value: function _jQueryInterface(config) { |
|||
return this.each(function () { |
|||
var data = $(this).data(DATA_KEY); |
|||
|
|||
if (!data) { |
|||
$(this).data(DATA_KEY, data = new Dropdown(this)); |
|||
} |
|||
|
|||
if (typeof config === 'string') { |
|||
if (data[config] === undefined) { |
|||
throw new Error('No method named "' + config + '"'); |
|||
} |
|||
data[config].call(this); |
|||
} |
|||
}); |
|||
} |
|||
}, { |
|||
key: '_clearMenus', |
|||
value: function _clearMenus(event) { |
|||
if (event && event.which === RIGHT_MOUSE_BUTTON_WHICH) { |
|||
return; |
|||
} |
|||
|
|||
var backdrop = $(Selector.BACKDROP)[0]; |
|||
if (backdrop) { |
|||
backdrop.parentNode.removeChild(backdrop); |
|||
} |
|||
|
|||
var toggles = $.makeArray($(Selector.DATA_TOGGLE)); |
|||
|
|||
for (var i = 0; i < toggles.length; i++) { |
|||
var parent = Dropdown._getParentFromElement(toggles[i]); |
|||
var relatedTarget = { relatedTarget: toggles[i] }; |
|||
|
|||
if (!$(parent).hasClass(ClassName.OPEN)) { |
|||
continue; |
|||
} |
|||
|
|||
if (event && event.type === 'click' && /input|textarea/i.test(event.target.tagName) && $.contains(parent, event.target)) { |
|||
continue; |
|||
} |
|||
|
|||
var hideEvent = $.Event(Event.HIDE, relatedTarget); |
|||
$(parent).trigger(hideEvent); |
|||
if (hideEvent.isDefaultPrevented()) { |
|||
continue; |
|||
} |
|||
|
|||
toggles[i].setAttribute('aria-expanded', 'false'); |
|||
|
|||
$(parent).removeClass(ClassName.OPEN).trigger($.Event(Event.HIDDEN, relatedTarget)); |
|||
} |
|||
} |
|||
}, { |
|||
key: '_getParentFromElement', |
|||
value: function _getParentFromElement(element) { |
|||
var parent = void 0; |
|||
var selector = _util2.default.getSelectorFromElement(element); |
|||
|
|||
if (selector) { |
|||
parent = $(selector)[0]; |
|||
} |
|||
|
|||
return parent || element.parentNode; |
|||
} |
|||
}, { |
|||
key: '_dataApiKeydownHandler', |
|||
value: function _dataApiKeydownHandler(event) { |
|||
if (!/(38|40|27|32)/.test(event.which) || /input|textarea/i.test(event.target.tagName)) { |
|||
return; |
|||
} |
|||
|
|||
event.preventDefault(); |
|||
event.stopPropagation(); |
|||
|
|||
if (this.disabled || $(this).hasClass(ClassName.DISABLED)) { |
|||
return; |
|||
} |
|||
|
|||
var parent = Dropdown._getParentFromElement(this); |
|||
var isActive = $(parent).hasClass(ClassName.OPEN); |
|||
|
|||
if (!isActive && event.which !== ESCAPE_KEYCODE || isActive && event.which === ESCAPE_KEYCODE) { |
|||
|
|||
if (event.which === ESCAPE_KEYCODE) { |
|||
var toggle = $(parent).find(Selector.DATA_TOGGLE)[0]; |
|||
$(toggle).trigger('focus'); |
|||
} |
|||
|
|||
$(this).trigger('click'); |
|||
return; |
|||
} |
|||
|
|||
var items = $.makeArray($(Selector.VISIBLE_ITEMS)); |
|||
|
|||
items = items.filter(function (item) { |
|||
return item.offsetWidth || item.offsetHeight; |
|||
}); |
|||
|
|||
if (!items.length) { |
|||
return; |
|||
} |
|||
|
|||
var index = items.indexOf(event.target); |
|||
|
|||
if (event.which === ARROW_UP_KEYCODE && index > 0) { |
|||
// up
|
|||
index--; |
|||
} |
|||
|
|||
if (event.which === ARROW_DOWN_KEYCODE && index < items.length - 1) { |
|||
// down
|
|||
index++; |
|||
} |
|||
|
|||
if (index < 0) { |
|||
index = 0; |
|||
} |
|||
|
|||
items[index].focus(); |
|||
} |
|||
}, { |
|||
key: 'VERSION', |
|||
get: function get() { |
|||
return VERSION; |
|||
} |
|||
}]); |
|||
|
|||
return Dropdown; |
|||
}(); |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Data Api implementation |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
$(document).on(Event.KEYDOWN_DATA_API, Selector.DATA_TOGGLE, Dropdown._dataApiKeydownHandler).on(Event.KEYDOWN_DATA_API, Selector.ROLE_MENU, Dropdown._dataApiKeydownHandler).on(Event.KEYDOWN_DATA_API, Selector.ROLE_LISTBOX, Dropdown._dataApiKeydownHandler).on(Event.CLICK_DATA_API, Dropdown._clearMenus).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE, Dropdown.prototype.toggle).on(Event.CLICK_DATA_API, Selector.FORM_CHILD, function (e) { |
|||
e.stopPropagation(); |
|||
}); |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* jQuery |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
$.fn[NAME] = Dropdown._jQueryInterface; |
|||
$.fn[NAME].Constructor = Dropdown; |
|||
$.fn[NAME].noConflict = function () { |
|||
$.fn[NAME] = JQUERY_NO_CONFLICT; |
|||
return Dropdown._jQueryInterface; |
|||
}; |
|||
|
|||
return Dropdown; |
|||
}(jQuery); |
|||
|
|||
exports.default = Dropdown; |
|||
}); |
@ -0,0 +1,65 @@ |
|||
// This file is part of Moodle - http://moodle.org/
|
|||
//
|
|||
// Moodle 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 3 of the License, or
|
|||
// (at your option) any later version.
|
|||
//
|
|||
// Moodle 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.
|
|||
//
|
|||
// You should have received a copy of the GNU General Public License
|
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
|
|||
|
|||
/** |
|||
* Custom form error event handler to manipulate the bootstrap markup and show |
|||
* nicely styled errors in an mform. |
|||
* |
|||
* @module theme_ilb/form-display-errors |
|||
* @copyright 2016 Damyon Wiese <damyon@moodle.com> |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|||
*/ |
|||
define(['jquery', 'core/event'], function($, Event) { |
|||
return { |
|||
enhance: function(elementid) { |
|||
var element = document.getElementById(elementid); |
|||
$(element).on(Event.Events.FORM_FIELD_VALIDATION, function(event, msg) { |
|||
event.preventDefault(); |
|||
var parent = $(element).closest('.form-group'); |
|||
var feedback = parent.find('.form-control-feedback'); |
|||
|
|||
// Sometimes (atto) we have a hidden textarea backed by a real contenteditable div.
|
|||
if (($(element).prop("tagName") == 'TEXTAREA') && parent.find('[contenteditable]')) { |
|||
element = parent.find('[contenteditable]'); |
|||
} |
|||
if (msg !== '') { |
|||
parent.addClass('has-danger'); |
|||
parent.data('client-validation-error', true); |
|||
$(element).addClass('form-control-danger'); |
|||
$(element).attr('aria-describedby', feedback.attr('id')); |
|||
$(element).attr('aria-invalid', true); |
|||
feedback.attr('tabindex', 0); |
|||
feedback.html(msg); |
|||
|
|||
// Only display and focus when the error was not already visible.
|
|||
if (!feedback.is(':visible')) { |
|||
feedback.show(); |
|||
feedback.focus(); |
|||
} |
|||
|
|||
} else { |
|||
if (parent.data('client-validation-error') === true) { |
|||
parent.removeClass('has-danger'); |
|||
parent.data('client-validation-error', false); |
|||
$(element).removeClass('form-control-danger'); |
|||
$(element).removeAttr('aria-describedby'); |
|||
$(element).attr('aria-invalid', false); |
|||
feedback.hide(); |
|||
} |
|||
} |
|||
}); |
|||
} |
|||
}; |
|||
}); |
@ -0,0 +1,62 @@ |
|||
// This file is part of Moodle - http://moodle.org/
|
|||
//
|
|||
// Moodle 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 3 of the License, or
|
|||
// (at your option) any later version.
|
|||
//
|
|||
// Moodle 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.
|
|||
//
|
|||
// You should have received a copy of the GNU General Public License
|
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
|
|||
|
|||
/** |
|||
* Template renderer for Moodle. Load and render Moodle templates with Mustache. |
|||
* |
|||
* @module core/templates |
|||
* @package core |
|||
* @class templates |
|||
* @copyright 2015 Damyon Wiese <damyon@moodle.com> |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|||
* @since 2.9 |
|||
*/ |
|||
define(['jquery', './tether', 'core/event'], function(jQuery, Tether, Event) { |
|||
|
|||
window.jQuery = jQuery; |
|||
window.Tether = Tether; |
|||
|
|||
require(['theme_ilb/util', |
|||
'theme_ilb/alert', |
|||
'theme_ilb/button', |
|||
'theme_ilb/carousel', |
|||
'theme_ilb/collapse', |
|||
'theme_ilb/dropdown', |
|||
'theme_ilb/modal', |
|||
'theme_ilb/scrollspy', |
|||
'theme_ilb/tab', |
|||
'theme_ilb/tooltip', |
|||
'theme_ilb/popover'], |
|||
function() { |
|||
|
|||
jQuery('body').popover({ |
|||
selector: '[data-toggle="popover"]', |
|||
trigger: 'focus' |
|||
}); |
|||
|
|||
// We need to call popover automatically if nodes are added to the page later.
|
|||
Event.getLegacyEvents().done(function(events) { |
|||
jQuery(document).on(events.FILTER_CONTENT_UPDATED, function() { |
|||
jQuery('body').popover({ |
|||
selector: '[data-toggle="popover"]', |
|||
trigger: 'focus' |
|||
}); |
|||
}); |
|||
}); |
|||
}); |
|||
|
|||
|
|||
return {}; |
|||
}); |
@ -0,0 +1,559 @@ |
|||
define(['exports', './util'], function (exports, _util) { |
|||
'use strict'; |
|||
|
|||
Object.defineProperty(exports, "__esModule", { |
|||
value: true |
|||
}); |
|||
|
|||
var _util2 = _interopRequireDefault(_util); |
|||
|
|||
function _interopRequireDefault(obj) { |
|||
return obj && obj.__esModule ? obj : { |
|||
default: obj |
|||
}; |
|||
} |
|||
|
|||
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { |
|||
return typeof obj; |
|||
} : function (obj) { |
|||
return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; |
|||
}; |
|||
|
|||
function _classCallCheck(instance, Constructor) { |
|||
if (!(instance instanceof Constructor)) { |
|||
throw new TypeError("Cannot call a class as a function"); |
|||
} |
|||
} |
|||
|
|||
var _createClass = function () { |
|||
function defineProperties(target, props) { |
|||
for (var i = 0; i < props.length; i++) { |
|||
var descriptor = props[i]; |
|||
descriptor.enumerable = descriptor.enumerable || false; |
|||
descriptor.configurable = true; |
|||
if ("value" in descriptor) descriptor.writable = true; |
|||
Object.defineProperty(target, descriptor.key, descriptor); |
|||
} |
|||
} |
|||
|
|||
return function (Constructor, protoProps, staticProps) { |
|||
if (protoProps) defineProperties(Constructor.prototype, protoProps); |
|||
if (staticProps) defineProperties(Constructor, staticProps); |
|||
return Constructor; |
|||
}; |
|||
}(); |
|||
|
|||
/** |
|||
* -------------------------------------------------------------------------- |
|||
* Bootstrap (v4.0.0-alpha.4): modal.js |
|||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|||
* -------------------------------------------------------------------------- |
|||
*/ |
|||
|
|||
var Modal = function ($) { |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Constants |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
var NAME = 'modal'; |
|||
var VERSION = '4.0.0-alpha.4'; |
|||
var DATA_KEY = 'bs.modal'; |
|||
var EVENT_KEY = '.' + DATA_KEY; |
|||
var DATA_API_KEY = '.data-api'; |
|||
var JQUERY_NO_CONFLICT = $.fn[NAME]; |
|||
var TRANSITION_DURATION = 300; |
|||
var BACKDROP_TRANSITION_DURATION = 150; |
|||
var ESCAPE_KEYCODE = 27; // KeyboardEvent.which value for Escape (Esc) key
|
|||
|
|||
var Default = { |
|||
backdrop: true, |
|||
keyboard: true, |
|||
focus: true, |
|||
show: true |
|||
}; |
|||
|
|||
var DefaultType = { |
|||
backdrop: '(boolean|string)', |
|||
keyboard: 'boolean', |
|||
focus: 'boolean', |
|||
show: 'boolean' |
|||
}; |
|||
|
|||
var Event = { |
|||
HIDE: 'hide' + EVENT_KEY, |
|||
HIDDEN: 'hidden' + EVENT_KEY, |
|||
SHOW: 'show' + EVENT_KEY, |
|||
SHOWN: 'shown' + EVENT_KEY, |
|||
FOCUSIN: 'focusin' + EVENT_KEY, |
|||
RESIZE: 'resize' + EVENT_KEY, |
|||
CLICK_DISMISS: 'click.dismiss' + EVENT_KEY, |
|||
KEYDOWN_DISMISS: 'keydown.dismiss' + EVENT_KEY, |
|||
MOUSEUP_DISMISS: 'mouseup.dismiss' + EVENT_KEY, |
|||
MOUSEDOWN_DISMISS: 'mousedown.dismiss' + EVENT_KEY, |
|||
CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY |
|||
}; |
|||
|
|||
var ClassName = { |
|||
SCROLLBAR_MEASURER: 'modal-scrollbar-measure', |
|||
BACKDROP: 'modal-backdrop', |
|||
OPEN: 'modal-open', |
|||
FADE: 'fade', |
|||
IN: 'in' |
|||
}; |
|||
|
|||
var Selector = { |
|||
DIALOG: '.modal-dialog', |
|||
DATA_TOGGLE: '[data-toggle="modal"]', |
|||
DATA_DISMISS: '[data-dismiss="modal"]', |
|||
FIXED_CONTENT: '.navbar-fixed-top, .navbar-fixed-bottom, .is-fixed' |
|||
}; |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Class Definition |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
var Modal = function () { |
|||
function Modal(element, config) { |
|||
_classCallCheck(this, Modal); |
|||
|
|||
this._config = this._getConfig(config); |
|||
this._element = element; |
|||
this._dialog = $(element).find(Selector.DIALOG)[0]; |
|||
this._backdrop = null; |
|||
this._isShown = false; |
|||
this._isBodyOverflowing = false; |
|||
this._ignoreBackdropClick = false; |
|||
this._originalBodyPadding = 0; |
|||
this._scrollbarWidth = 0; |
|||
} |
|||
|
|||
// getters
|
|||
|
|||
_createClass(Modal, [{ |
|||
key: 'toggle', |
|||
value: function toggle(relatedTarget) { |
|||
return this._isShown ? this.hide() : this.show(relatedTarget); |
|||
} |
|||
}, { |
|||
key: 'show', |
|||
value: function show(relatedTarget) { |
|||
var _this = this; |
|||
|
|||
var showEvent = $.Event(Event.SHOW, { |
|||
relatedTarget: relatedTarget |
|||
}); |
|||
|
|||
$(this._element).trigger(showEvent); |
|||
|
|||
if (this._isShown || showEvent.isDefaultPrevented()) { |
|||
return; |
|||
} |
|||
|
|||
this._isShown = true; |
|||
|
|||
this._checkScrollbar(); |
|||
this._setScrollbar(); |
|||
|
|||
$(document.body).addClass(ClassName.OPEN); |
|||
|
|||
this._setEscapeEvent(); |
|||
this._setResizeEvent(); |
|||
|
|||
$(this._element).on(Event.CLICK_DISMISS, Selector.DATA_DISMISS, $.proxy(this.hide, this)); |
|||
|
|||
$(this._dialog).on(Event.MOUSEDOWN_DISMISS, function () { |
|||
$(_this._element).one(Event.MOUSEUP_DISMISS, function (event) { |
|||
if ($(event.target).is(_this._element)) { |
|||
_this._ignoreBackdropClick = true; |
|||
} |
|||
}); |
|||
}); |
|||
|
|||
this._showBackdrop($.proxy(this._showElement, this, relatedTarget)); |
|||
} |
|||
}, { |
|||
key: 'hide', |
|||
value: function hide(event) { |
|||
if (event) { |
|||
event.preventDefault(); |
|||
} |
|||
|
|||
var hideEvent = $.Event(Event.HIDE); |
|||
|
|||
$(this._element).trigger(hideEvent); |
|||
|
|||
if (!this._isShown || hideEvent.isDefaultPrevented()) { |
|||
return; |
|||
} |
|||
|
|||
this._isShown = false; |
|||
|
|||
this._setEscapeEvent(); |
|||
this._setResizeEvent(); |
|||
|
|||
$(document).off(Event.FOCUSIN); |
|||
|
|||
$(this._element).removeClass(ClassName.IN); |
|||
|
|||
$(this._element).off(Event.CLICK_DISMISS); |
|||
$(this._dialog).off(Event.MOUSEDOWN_DISMISS); |
|||
|
|||
if (_util2.default.supportsTransitionEnd() && $(this._element).hasClass(ClassName.FADE)) { |
|||
|
|||
$(this._element).one(_util2.default.TRANSITION_END, $.proxy(this._hideModal, this)).emulateTransitionEnd(TRANSITION_DURATION); |
|||
} else { |
|||
this._hideModal(); |
|||
} |
|||
} |
|||
}, { |
|||
key: 'dispose', |
|||
value: function dispose() { |
|||
$.removeData(this._element, DATA_KEY); |
|||
|
|||
$(window).off(EVENT_KEY); |
|||
$(document).off(EVENT_KEY); |
|||
$(this._element).off(EVENT_KEY); |
|||
$(this._backdrop).off(EVENT_KEY); |
|||
|
|||
this._config = null; |
|||
this._element = null; |
|||
this._dialog = null; |
|||
this._backdrop = null; |
|||
this._isShown = null; |
|||
this._isBodyOverflowing = null; |
|||
this._ignoreBackdropClick = null; |
|||
this._originalBodyPadding = null; |
|||
this._scrollbarWidth = null; |
|||
} |
|||
}, { |
|||
key: '_getConfig', |
|||
value: function _getConfig(config) { |
|||
config = $.extend({}, Default, config); |
|||
_util2.default.typeCheckConfig(NAME, config, DefaultType); |
|||
return config; |
|||
} |
|||
}, { |
|||
key: '_showElement', |
|||
value: function _showElement(relatedTarget) { |
|||
var _this2 = this; |
|||
|
|||
var transition = _util2.default.supportsTransitionEnd() && $(this._element).hasClass(ClassName.FADE); |
|||
|
|||
if (!this._element.parentNode || this._element.parentNode.nodeType !== Node.ELEMENT_NODE) { |
|||
// don't move modals dom position
|
|||
document.body.appendChild(this._element); |
|||
} |
|||
|
|||
this._element.style.display = 'block'; |
|||
this._element.removeAttribute('aria-hidden'); |
|||
this._element.scrollTop = 0; |
|||
|
|||
if (transition) { |
|||
_util2.default.reflow(this._element); |
|||
} |
|||
|
|||
$(this._element).addClass(ClassName.IN); |
|||
|
|||
if (this._config.focus) { |
|||
this._enforceFocus(); |
|||
} |
|||
|
|||
var shownEvent = $.Event(Event.SHOWN, { |
|||
relatedTarget: relatedTarget |
|||
}); |
|||
|
|||
var transitionComplete = function transitionComplete() { |
|||
if (_this2._config.focus) { |
|||
_this2._element.focus(); |
|||
} |
|||
$(_this2._element).trigger(shownEvent); |
|||
}; |
|||
|
|||
if (transition) { |
|||
$(this._dialog).one(_util2.default.TRANSITION_END, transitionComplete).emulateTransitionEnd(TRANSITION_DURATION); |
|||
} else { |
|||
transitionComplete(); |
|||
} |
|||
} |
|||
}, { |
|||
key: '_enforceFocus', |
|||
value: function _enforceFocus() { |
|||
var _this3 = this; |
|||
|
|||
$(document).off(Event.FOCUSIN) // guard against infinite focus loop
|
|||
.on(Event.FOCUSIN, function (event) { |
|||
if (document !== event.target && _this3._element !== event.target && !$(_this3._element).has(event.target).length) { |
|||
_this3._element.focus(); |
|||
} |
|||
}); |
|||
} |
|||
}, { |
|||
key: '_setEscapeEvent', |
|||
value: function _setEscapeEvent() { |
|||
var _this4 = this; |
|||
|
|||
if (this._isShown && this._config.keyboard) { |
|||
$(this._element).on(Event.KEYDOWN_DISMISS, function (event) { |
|||
if (event.which === ESCAPE_KEYCODE) { |
|||
_this4.hide(); |
|||
} |
|||
}); |
|||
} else if (!this._isShown) { |
|||
$(this._element).off(Event.KEYDOWN_DISMISS); |
|||
} |
|||
} |
|||
}, { |
|||
key: '_setResizeEvent', |
|||
value: function _setResizeEvent() { |
|||
if (this._isShown) { |
|||
$(window).on(Event.RESIZE, $.proxy(this._handleUpdate, this)); |
|||
} else { |
|||
$(window).off(Event.RESIZE); |
|||
} |
|||
} |
|||
}, { |
|||
key: '_hideModal', |
|||
value: function _hideModal() { |
|||
var _this5 = this; |
|||
|
|||
this._element.style.display = 'none'; |
|||
this._element.setAttribute('aria-hidden', 'true'); |
|||
this._showBackdrop(function () { |
|||
$(document.body).removeClass(ClassName.OPEN); |
|||
_this5._resetAdjustments(); |
|||
_this5._resetScrollbar(); |
|||
$(_this5._element).trigger(Event.HIDDEN); |
|||
}); |
|||
} |
|||
}, { |
|||
key: '_removeBackdrop', |
|||
value: function _removeBackdrop() { |
|||
if (this._backdrop) { |
|||
$(this._backdrop).remove(); |
|||
this._backdrop = null; |
|||
} |
|||
} |
|||
}, { |
|||
key: '_showBackdrop', |
|||
value: function _showBackdrop(callback) { |
|||
var _this6 = this; |
|||
|
|||
var animate = $(this._element).hasClass(ClassName.FADE) ? ClassName.FADE : ''; |
|||
|
|||
if (this._isShown && this._config.backdrop) { |
|||
var doAnimate = _util2.default.supportsTransitionEnd() && animate; |
|||
|
|||
this._backdrop = document.createElement('div'); |
|||
this._backdrop.className = ClassName.BACKDROP; |
|||
|
|||
if (animate) { |
|||
$(this._backdrop).addClass(animate); |
|||
} |
|||
|
|||
$(this._backdrop).appendTo(document.body); |
|||
|
|||
$(this._element).on(Event.CLICK_DISMISS, function (event) { |
|||
if (_this6._ignoreBackdropClick) { |
|||
_this6._ignoreBackdropClick = false; |
|||
return; |
|||
} |
|||
if (event.target !== event.currentTarget) { |
|||
return; |
|||
} |
|||
if (_this6._config.backdrop === 'static') { |
|||
_this6._element.focus(); |
|||
} else { |
|||
_this6.hide(); |
|||
} |
|||
}); |
|||
|
|||
if (doAnimate) { |
|||
_util2.default.reflow(this._backdrop); |
|||
} |
|||
|
|||
$(this._backdrop).addClass(ClassName.IN); |
|||
|
|||
if (!callback) { |
|||
return; |
|||
} |
|||
|
|||
if (!doAnimate) { |
|||
callback(); |
|||
return; |
|||
} |
|||
|
|||
$(this._backdrop).one(_util2.default.TRANSITION_END, callback).emulateTransitionEnd(BACKDROP_TRANSITION_DURATION); |
|||
} else if (!this._isShown && this._backdrop) { |
|||
$(this._backdrop).removeClass(ClassName.IN); |
|||
|
|||
var callbackRemove = function callbackRemove() { |
|||
_this6._removeBackdrop(); |
|||
if (callback) { |
|||
callback(); |
|||
} |
|||
}; |
|||
|
|||
if (_util2.default.supportsTransitionEnd() && $(this._element).hasClass(ClassName.FADE)) { |
|||
$(this._backdrop).one(_util2.default.TRANSITION_END, callbackRemove).emulateTransitionEnd(BACKDROP_TRANSITION_DURATION); |
|||
} else { |
|||
callbackRemove(); |
|||
} |
|||
} else if (callback) { |
|||
callback(); |
|||
} |
|||
} |
|||
}, { |
|||
key: '_handleUpdate', |
|||
value: function _handleUpdate() { |
|||
this._adjustDialog(); |
|||
} |
|||
}, { |
|||
key: '_adjustDialog', |
|||
value: function _adjustDialog() { |
|||
var isModalOverflowing = this._element.scrollHeight > document.documentElement.clientHeight; |
|||
|
|||
if (!this._isBodyOverflowing && isModalOverflowing) { |
|||
this._element.style.paddingLeft = this._scrollbarWidth + 'px'; |
|||
} |
|||
|
|||
if (this._isBodyOverflowing && !isModalOverflowing) { |
|||
this._element.style.paddingRight = this._scrollbarWidth + 'px'; |
|||
} |
|||
} |
|||
}, { |
|||
key: '_resetAdjustments', |
|||
value: function _resetAdjustments() { |
|||
this._element.style.paddingLeft = ''; |
|||
this._element.style.paddingRight = ''; |
|||
} |
|||
}, { |
|||
key: '_checkScrollbar', |
|||
value: function _checkScrollbar() { |
|||
this._isBodyOverflowing = document.body.clientWidth < window.innerWidth; |
|||
this._scrollbarWidth = this._getScrollbarWidth(); |
|||
} |
|||
}, { |
|||
key: '_setScrollbar', |
|||
value: function _setScrollbar() { |
|||
var bodyPadding = parseInt($(Selector.FIXED_CONTENT).css('padding-right') || 0, 10); |
|||
|
|||
this._originalBodyPadding = document.body.style.paddingRight || ''; |
|||
|
|||
if (this._isBodyOverflowing) { |
|||
document.body.style.paddingRight = bodyPadding + this._scrollbarWidth + 'px'; |
|||
} |
|||
} |
|||
}, { |
|||
key: '_resetScrollbar', |
|||
value: function _resetScrollbar() { |
|||
document.body.style.paddingRight = this._originalBodyPadding; |
|||
} |
|||
}, { |
|||
key: '_getScrollbarWidth', |
|||
value: function _getScrollbarWidth() { |
|||
// thx d.walsh
|
|||
var scrollDiv = document.createElement('div'); |
|||
scrollDiv.className = ClassName.SCROLLBAR_MEASURER; |
|||
document.body.appendChild(scrollDiv); |
|||
var scrollbarWidth = scrollDiv.offsetWidth - scrollDiv.clientWidth; |
|||
document.body.removeChild(scrollDiv); |
|||
return scrollbarWidth; |
|||
} |
|||
}], [{ |
|||
key: '_jQueryInterface', |
|||
value: function _jQueryInterface(config, relatedTarget) { |
|||
return this.each(function () { |
|||
var data = $(this).data(DATA_KEY); |
|||
var _config = $.extend({}, Modal.Default, $(this).data(), (typeof config === 'undefined' ? 'undefined' : _typeof(config)) === 'object' && config); |
|||
|
|||
if (!data) { |
|||
data = new Modal(this, _config); |
|||
$(this).data(DATA_KEY, data); |
|||
} |
|||
|
|||
if (typeof config === 'string') { |
|||
if (data[config] === undefined) { |
|||
throw new Error('No method named "' + config + '"'); |
|||
} |
|||
data[config](relatedTarget); |
|||
} else if (_config.show) { |
|||
data.show(relatedTarget); |
|||
} |
|||
}); |
|||
} |
|||
}, { |
|||
key: 'VERSION', |
|||
get: function get() { |
|||
return VERSION; |
|||
} |
|||
}, { |
|||
key: 'Default', |
|||
get: function get() { |
|||
return Default; |
|||
} |
|||
}]); |
|||
|
|||
return Modal; |
|||
}(); |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Data Api implementation |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
$(document).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE, function (event) { |
|||
var _this7 = this; |
|||
|
|||
var target = void 0; |
|||
var selector = _util2.default.getSelectorFromElement(this); |
|||
|
|||
if (selector) { |
|||
target = $(selector)[0]; |
|||
} |
|||
|
|||
var config = $(target).data(DATA_KEY) ? 'toggle' : $.extend({}, $(target).data(), $(this).data()); |
|||
|
|||
if (this.tagName === 'A') { |
|||
event.preventDefault(); |
|||
} |
|||
|
|||
var $target = $(target).one(Event.SHOW, function (showEvent) { |
|||
if (showEvent.isDefaultPrevented()) { |
|||
// only register focus restorer if modal will actually get shown
|
|||
return; |
|||
} |
|||
|
|||
$target.one(Event.HIDDEN, function () { |
|||
if ($(_this7).is(':visible')) { |
|||
_this7.focus(); |
|||
} |
|||
}); |
|||
}); |
|||
|
|||
Modal._jQueryInterface.call($(target), config, this); |
|||
}); |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* jQuery |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
$.fn[NAME] = Modal._jQueryInterface; |
|||
$.fn[NAME].Constructor = Modal; |
|||
$.fn[NAME].noConflict = function () { |
|||
$.fn[NAME] = JQUERY_NO_CONFLICT; |
|||
return Modal._jQueryInterface; |
|||
}; |
|||
|
|||
return Modal; |
|||
}(jQuery); |
|||
|
|||
exports.default = Modal; |
|||
}); |
@ -0,0 +1,250 @@ |
|||
define(['exports', './tooltip'], function (exports, _tooltip) { |
|||
'use strict'; |
|||
|
|||
Object.defineProperty(exports, "__esModule", { |
|||
value: true |
|||
}); |
|||
|
|||
var _tooltip2 = _interopRequireDefault(_tooltip); |
|||
|
|||
function _interopRequireDefault(obj) { |
|||
return obj && obj.__esModule ? obj : { |
|||
default: obj |
|||
}; |
|||
} |
|||
|
|||
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { |
|||
return typeof obj; |
|||
} : function (obj) { |
|||
return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; |
|||
}; |
|||
|
|||
function _classCallCheck(instance, Constructor) { |
|||
if (!(instance instanceof Constructor)) { |
|||
throw new TypeError("Cannot call a class as a function"); |
|||
} |
|||
} |
|||
|
|||
var _createClass = function () { |
|||
function defineProperties(target, props) { |
|||
for (var i = 0; i < props.length; i++) { |
|||
var descriptor = props[i]; |
|||
descriptor.enumerable = descriptor.enumerable || false; |
|||
descriptor.configurable = true; |
|||
if ("value" in descriptor) descriptor.writable = true; |
|||
Object.defineProperty(target, descriptor.key, descriptor); |
|||
} |
|||
} |
|||
|
|||
return function (Constructor, protoProps, staticProps) { |
|||
if (protoProps) defineProperties(Constructor.prototype, protoProps); |
|||
if (staticProps) defineProperties(Constructor, staticProps); |
|||
return Constructor; |
|||
}; |
|||
}(); |
|||
|
|||
function _possibleConstructorReturn(self, call) { |
|||
if (!self) { |
|||
throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); |
|||
} |
|||
|
|||
return call && (typeof call === "object" || typeof call === "function") ? call : self; |
|||
} |
|||
|
|||
function _inherits(subClass, superClass) { |
|||
if (typeof superClass !== "function" && superClass !== null) { |
|||
throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); |
|||
} |
|||
|
|||
subClass.prototype = Object.create(superClass && superClass.prototype, { |
|||
constructor: { |
|||
value: subClass, |
|||
enumerable: false, |
|||
writable: true, |
|||
configurable: true |
|||
} |
|||
}); |
|||
if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; |
|||
} |
|||
|
|||
/** |
|||
* -------------------------------------------------------------------------- |
|||
* Bootstrap (v4.0.0-alpha.4): popover.js |
|||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|||
* -------------------------------------------------------------------------- |
|||
*/ |
|||
|
|||
var Popover = function ($) { |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Constants |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
var NAME = 'popover'; |
|||
var VERSION = '4.0.0-alpha.4'; |
|||
var DATA_KEY = 'bs.popover'; |
|||
var EVENT_KEY = '.' + DATA_KEY; |
|||
var JQUERY_NO_CONFLICT = $.fn[NAME]; |
|||
|
|||
var Default = $.extend({}, _tooltip2.default.Default, { |
|||
placement: 'right', |
|||
trigger: 'click', |
|||
content: '', |
|||
template: '<div class="popover" role="tooltip">' + '<div class="popover-arrow"></div>' + '<h3 class="popover-title"></h3>' + '<div class="popover-content"></div></div>' |
|||
}); |
|||
|
|||
var DefaultType = $.extend({}, _tooltip2.default.DefaultType, { |
|||
content: '(string|element|function)' |
|||
}); |
|||
|
|||
var ClassName = { |
|||
FADE: 'fade', |
|||
IN: 'in' |
|||
}; |
|||
|
|||
var Selector = { |
|||
TITLE: '.popover-title', |
|||
CONTENT: '.popover-content', |
|||
ARROW: '.popover-arrow' |
|||
}; |
|||
|
|||
var Event = { |
|||
HIDE: 'hide' + EVENT_KEY, |
|||
HIDDEN: 'hidden' + EVENT_KEY, |
|||
SHOW: 'show' + EVENT_KEY, |
|||
SHOWN: 'shown' + EVENT_KEY, |
|||
INSERTED: 'inserted' + EVENT_KEY, |
|||
CLICK: 'click' + EVENT_KEY, |
|||
FOCUSIN: 'focusin' + EVENT_KEY, |
|||
FOCUSOUT: 'focusout' + EVENT_KEY, |
|||
MOUSEENTER: 'mouseenter' + EVENT_KEY, |
|||
MOUSELEAVE: 'mouseleave' + EVENT_KEY |
|||
}; |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Class Definition |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
var Popover = function (_Tooltip) { |
|||
_inherits(Popover, _Tooltip); |
|||
|
|||
function Popover() { |
|||
_classCallCheck(this, Popover); |
|||
|
|||
return _possibleConstructorReturn(this, (Popover.__proto__ || Object.getPrototypeOf(Popover)).apply(this, arguments)); |
|||
} |
|||
|
|||
_createClass(Popover, [{ |
|||
key: 'isWithContent', |
|||
value: function isWithContent() { |
|||
return this.getTitle() || this._getContent(); |
|||
} |
|||
}, { |
|||
key: 'getTipElement', |
|||
value: function getTipElement() { |
|||
return this.tip = this.tip || $(this.config.template)[0]; |
|||
} |
|||
}, { |
|||
key: 'setContent', |
|||
value: function setContent() { |
|||
var $tip = $(this.getTipElement()); |
|||
|
|||
// we use append for html objects to maintain js events
|
|||
this.setElementContent($tip.find(Selector.TITLE), this.getTitle()); |
|||
this.setElementContent($tip.find(Selector.CONTENT), this._getContent()); |
|||
|
|||
$tip.removeClass(ClassName.FADE).removeClass(ClassName.IN); |
|||
|
|||
this.cleanupTether(); |
|||
} |
|||
}, { |
|||
key: '_getContent', |
|||
value: function _getContent() { |
|||
return this.element.getAttribute('data-content') || (typeof this.config.content === 'function' ? this.config.content.call(this.element) : this.config.content); |
|||
} |
|||
}], [{ |
|||
key: '_jQueryInterface', |
|||
value: function _jQueryInterface(config) { |
|||
return this.each(function () { |
|||
var data = $(this).data(DATA_KEY); |
|||
var _config = (typeof config === 'undefined' ? 'undefined' : _typeof(config)) === 'object' ? config : null; |
|||
|
|||
if (!data && /destroy|hide/.test(config)) { |
|||
return; |
|||
} |
|||
|
|||
if (!data) { |
|||
data = new Popover(this, _config); |
|||
$(this).data(DATA_KEY, data); |
|||
} |
|||
|
|||
if (typeof config === 'string') { |
|||
if (data[config] === undefined) { |
|||
throw new Error('No method named "' + config + '"'); |
|||
} |
|||
data[config](); |
|||
} |
|||
}); |
|||
} |
|||
}, { |
|||
key: 'VERSION', |
|||
get: function get() { |
|||
return VERSION; |
|||
} |
|||
}, { |
|||
key: 'Default', |
|||
get: function get() { |
|||
return Default; |
|||
} |
|||
}, { |
|||
key: 'NAME', |
|||
get: function get() { |
|||
return NAME; |
|||
} |
|||
}, { |
|||
key: 'DATA_KEY', |
|||
get: function get() { |
|||
return DATA_KEY; |
|||
} |
|||
}, { |
|||
key: 'Event', |
|||
get: function get() { |
|||
return Event; |
|||
} |
|||
}, { |
|||
key: 'EVENT_KEY', |
|||
get: function get() { |
|||
return EVENT_KEY; |
|||
} |
|||
}, { |
|||
key: 'DefaultType', |
|||
get: function get() { |
|||
return DefaultType; |
|||
} |
|||
}]); |
|||
|
|||
return Popover; |
|||
}(_tooltip2.default); |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* jQuery |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
$.fn[NAME] = Popover._jQueryInterface; |
|||
$.fn[NAME].Constructor = Popover; |
|||
$.fn[NAME].noConflict = function () { |
|||
$.fn[NAME] = JQUERY_NO_CONFLICT; |
|||
return Popover._jQueryInterface; |
|||
}; |
|||
|
|||
return Popover; |
|||
}(jQuery); |
|||
|
|||
exports.default = Popover; |
|||
}); |
@ -0,0 +1,353 @@ |
|||
define(['exports', './util'], function (exports, _util) { |
|||
'use strict'; |
|||
|
|||
Object.defineProperty(exports, "__esModule", { |
|||
value: true |
|||
}); |
|||
|
|||
var _util2 = _interopRequireDefault(_util); |
|||
|
|||
function _interopRequireDefault(obj) { |
|||
return obj && obj.__esModule ? obj : { |
|||
default: obj |
|||
}; |
|||
} |
|||
|
|||
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { |
|||
return typeof obj; |
|||
} : function (obj) { |
|||
return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; |
|||
}; |
|||
|
|||
function _classCallCheck(instance, Constructor) { |
|||
if (!(instance instanceof Constructor)) { |
|||
throw new TypeError("Cannot call a class as a function"); |
|||
} |
|||
} |
|||
|
|||
var _createClass = function () { |
|||
function defineProperties(target, props) { |
|||
for (var i = 0; i < props.length; i++) { |
|||
var descriptor = props[i]; |
|||
descriptor.enumerable = descriptor.enumerable || false; |
|||
descriptor.configurable = true; |
|||
if ("value" in descriptor) descriptor.writable = true; |
|||
Object.defineProperty(target, descriptor.key, descriptor); |
|||
} |
|||
} |
|||
|
|||
return function (Constructor, protoProps, staticProps) { |
|||
if (protoProps) defineProperties(Constructor.prototype, protoProps); |
|||
if (staticProps) defineProperties(Constructor, staticProps); |
|||
return Constructor; |
|||
}; |
|||
}(); |
|||
|
|||
/** |
|||
* -------------------------------------------------------------------------- |
|||
* Bootstrap (v4.0.0-alpha.4): scrollspy.js |
|||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|||
* -------------------------------------------------------------------------- |
|||
*/ |
|||
|
|||
var ScrollSpy = function ($) { |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Constants |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
var NAME = 'scrollspy'; |
|||
var VERSION = '4.0.0-alpha.4'; |
|||
var DATA_KEY = 'bs.scrollspy'; |
|||
var EVENT_KEY = '.' + DATA_KEY; |
|||
var DATA_API_KEY = '.data-api'; |
|||
var JQUERY_NO_CONFLICT = $.fn[NAME]; |
|||
|
|||
var Default = { |
|||
offset: 10, |
|||
method: 'auto', |
|||
target: '' |
|||
}; |
|||
|
|||
var DefaultType = { |
|||
offset: 'number', |
|||
method: 'string', |
|||
target: '(string|element)' |
|||
}; |
|||
|
|||
var Event = { |
|||
ACTIVATE: 'activate' + EVENT_KEY, |
|||
SCROLL: 'scroll' + EVENT_KEY, |
|||
LOAD_DATA_API: 'load' + EVENT_KEY + DATA_API_KEY |
|||
}; |
|||
|
|||
var ClassName = { |
|||
DROPDOWN_ITEM: 'dropdown-item', |
|||
DROPDOWN_MENU: 'dropdown-menu', |
|||
NAV_LINK: 'nav-link', |
|||
NAV: 'nav', |
|||
ACTIVE: 'active' |
|||
}; |
|||
|
|||
var Selector = { |
|||
DATA_SPY: '[data-spy="scroll"]', |
|||
ACTIVE: '.active', |
|||
LIST_ITEM: '.list-item', |
|||
LI: 'li', |
|||
LI_DROPDOWN: 'li.dropdown', |
|||
NAV_LINKS: '.nav-link', |
|||
DROPDOWN: '.dropdown', |
|||
DROPDOWN_ITEMS: '.dropdown-item', |
|||
DROPDOWN_TOGGLE: '.dropdown-toggle' |
|||
}; |
|||
|
|||
var OffsetMethod = { |
|||
OFFSET: 'offset', |
|||
POSITION: 'position' |
|||
}; |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Class Definition |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
var ScrollSpy = function () { |
|||
function ScrollSpy(element, config) { |
|||
_classCallCheck(this, ScrollSpy); |
|||
|
|||
this._element = element; |
|||
this._scrollElement = element.tagName === 'BODY' ? window : element; |
|||
this._config = this._getConfig(config); |
|||
this._selector = this._config.target + ' ' + Selector.NAV_LINKS + ',' + (this._config.target + ' ' + Selector.DROPDOWN_ITEMS); |
|||
this._offsets = []; |
|||
this._targets = []; |
|||
this._activeTarget = null; |
|||
this._scrollHeight = 0; |
|||
|
|||
$(this._scrollElement).on(Event.SCROLL, $.proxy(this._process, this)); |
|||
|
|||
this.refresh(); |
|||
this._process(); |
|||
} |
|||
|
|||
// getters
|
|||
|
|||
_createClass(ScrollSpy, [{ |
|||
key: 'refresh', |
|||
value: function refresh() { |
|||
var _this = this; |
|||
|
|||
var autoMethod = this._scrollElement !== this._scrollElement.window ? OffsetMethod.POSITION : OffsetMethod.OFFSET; |
|||
|
|||
var offsetMethod = this._config.method === 'auto' ? autoMethod : this._config.method; |
|||
|
|||
var offsetBase = offsetMethod === OffsetMethod.POSITION ? this._getScrollTop() : 0; |
|||
|
|||
this._offsets = []; |
|||
this._targets = []; |
|||
|
|||
this._scrollHeight = this._getScrollHeight(); |
|||
|
|||
var targets = $.makeArray($(this._selector)); |
|||
|
|||
targets.map(function (element) { |
|||
var target = void 0; |
|||
var targetSelector = _util2.default.getSelectorFromElement(element); |
|||
|
|||
if (targetSelector) { |
|||
target = $(targetSelector)[0]; |
|||
} |
|||
|
|||
if (target && (target.offsetWidth || target.offsetHeight)) { |
|||
// todo (fat): remove sketch reliance on jQuery position/offset
|
|||
return [$(target)[offsetMethod]().top + offsetBase, targetSelector]; |
|||
} |
|||
return null; |
|||
}).filter(function (item) { |
|||
return item; |
|||
}).sort(function (a, b) { |
|||
return a[0] - b[0]; |
|||
}).forEach(function (item) { |
|||
_this._offsets.push(item[0]); |
|||
_this._targets.push(item[1]); |
|||
}); |
|||
} |
|||
}, { |
|||
key: 'dispose', |
|||
value: function dispose() { |
|||
$.removeData(this._element, DATA_KEY); |
|||
$(this._scrollElement).off(EVENT_KEY); |
|||
|
|||
this._element = null; |
|||
this._scrollElement = null; |
|||
this._config = null; |
|||
this._selector = null; |
|||
this._offsets = null; |
|||
this._targets = null; |
|||
this._activeTarget = null; |
|||
this._scrollHeight = null; |
|||
} |
|||
}, { |
|||
key: '_getConfig', |
|||
value: function _getConfig(config) { |
|||
config = $.extend({}, Default, config); |
|||
|
|||
if (typeof config.target !== 'string') { |
|||
var id = $(config.target).attr('id'); |
|||
if (!id) { |
|||
id = _util2.default.getUID(NAME); |
|||
$(config.target).attr('id', id); |
|||
} |
|||
config.target = '#' + id; |
|||
} |
|||
|
|||
_util2.default.typeCheckConfig(NAME, config, DefaultType); |
|||
|
|||
return config; |
|||
} |
|||
}, { |
|||
key: '_getScrollTop', |
|||
value: function _getScrollTop() { |
|||
return this._scrollElement === window ? this._scrollElement.scrollY : this._scrollElement.scrollTop; |
|||
} |
|||
}, { |
|||
key: '_getScrollHeight', |
|||
value: function _getScrollHeight() { |
|||
return this._scrollElement.scrollHeight || Math.max(document.body.scrollHeight, document.documentElement.scrollHeight); |
|||
} |
|||
}, { |
|||
key: '_process', |
|||
value: function _process() { |
|||
var scrollTop = this._getScrollTop() + this._config.offset; |
|||
var scrollHeight = this._getScrollHeight(); |
|||
var maxScroll = this._config.offset + scrollHeight - this._scrollElement.offsetHeight; |
|||
|
|||
if (this._scrollHeight !== scrollHeight) { |
|||
this.refresh(); |
|||
} |
|||
|
|||
if (scrollTop >= maxScroll) { |
|||
var target = this._targets[this._targets.length - 1]; |
|||
|
|||
if (this._activeTarget !== target) { |
|||
this._activate(target); |
|||
} |
|||
} |
|||
|
|||
if (this._activeTarget && scrollTop < this._offsets[0]) { |
|||
this._activeTarget = null; |
|||
this._clear(); |
|||
return; |
|||
} |
|||
|
|||
for (var i = this._offsets.length; i--;) { |
|||
var isActiveTarget = this._activeTarget !== this._targets[i] && scrollTop >= this._offsets[i] && (this._offsets[i + 1] === undefined || scrollTop < this._offsets[i + 1]); |
|||
|
|||
if (isActiveTarget) { |
|||
this._activate(this._targets[i]); |
|||
} |
|||
} |
|||
} |
|||
}, { |
|||
key: '_activate', |
|||
value: function _activate(target) { |
|||
this._activeTarget = target; |
|||
|
|||
this._clear(); |
|||
|
|||
var queries = this._selector.split(','); |
|||
queries = queries.map(function (selector) { |
|||
return selector + '[data-target="' + target + '"],' + (selector + '[href="' + target + '"]'); |
|||
}); |
|||
|
|||
var $link = $(queries.join(',')); |
|||
|
|||
if ($link.hasClass(ClassName.DROPDOWN_ITEM)) { |
|||
$link.closest(Selector.DROPDOWN).find(Selector.DROPDOWN_TOGGLE).addClass(ClassName.ACTIVE); |
|||
$link.addClass(ClassName.ACTIVE); |
|||
} else { |
|||
// todo (fat) this is kinda sus...
|
|||
// recursively add actives to tested nav-links
|
|||
$link.parents(Selector.LI).find(Selector.NAV_LINKS).addClass(ClassName.ACTIVE); |
|||
} |
|||
|
|||
$(this._scrollElement).trigger(Event.ACTIVATE, { |
|||
relatedTarget: target |
|||
}); |
|||
} |
|||
}, { |
|||
key: '_clear', |
|||
value: function _clear() { |
|||
$(this._selector).filter(Selector.ACTIVE).removeClass(ClassName.ACTIVE); |
|||
} |
|||
}], [{ |
|||
key: '_jQueryInterface', |
|||
value: function _jQueryInterface(config) { |
|||
return this.each(function () { |
|||
var data = $(this).data(DATA_KEY); |
|||
var _config = (typeof config === 'undefined' ? 'undefined' : _typeof(config)) === 'object' && config || null; |
|||
|
|||
if (!data) { |
|||
data = new ScrollSpy(this, _config); |
|||
$(this).data(DATA_KEY, data); |
|||
} |
|||
|
|||
if (typeof config === 'string') { |
|||
if (data[config] === undefined) { |
|||
throw new Error('No method named "' + config + '"'); |
|||
} |
|||
data[config](); |
|||
} |
|||
}); |
|||
} |
|||
}, { |
|||
key: 'VERSION', |
|||
get: function get() { |
|||
return VERSION; |
|||
} |
|||
}, { |
|||
key: 'Default', |
|||
get: function get() { |
|||
return Default; |
|||
} |
|||
}]); |
|||
|
|||
return ScrollSpy; |
|||
}(); |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Data Api implementation |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
$(window).on(Event.LOAD_DATA_API, function () { |
|||
var scrollSpys = $.makeArray($(Selector.DATA_SPY)); |
|||
|
|||
for (var i = scrollSpys.length; i--;) { |
|||
var $spy = $(scrollSpys[i]); |
|||
ScrollSpy._jQueryInterface.call($spy, $spy.data()); |
|||
} |
|||
}); |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* jQuery |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
$.fn[NAME] = ScrollSpy._jQueryInterface; |
|||
$.fn[NAME].Constructor = ScrollSpy; |
|||
$.fn[NAME].noConflict = function () { |
|||
$.fn[NAME] = JQUERY_NO_CONFLICT; |
|||
return ScrollSpy._jQueryInterface; |
|||
}; |
|||
|
|||
return ScrollSpy; |
|||
}(jQuery); |
|||
|
|||
exports.default = ScrollSpy; |
|||
}); |
@ -0,0 +1,289 @@ |
|||
define(['exports', './util'], function (exports, _util) { |
|||
'use strict'; |
|||
|
|||
Object.defineProperty(exports, "__esModule", { |
|||
value: true |
|||
}); |
|||
|
|||
var _util2 = _interopRequireDefault(_util); |
|||
|
|||
function _interopRequireDefault(obj) { |
|||
return obj && obj.__esModule ? obj : { |
|||
default: obj |
|||
}; |
|||
} |
|||
|
|||
function _classCallCheck(instance, Constructor) { |
|||
if (!(instance instanceof Constructor)) { |
|||
throw new TypeError("Cannot call a class as a function"); |
|||
} |
|||
} |
|||
|
|||
var _createClass = function () { |
|||
function defineProperties(target, props) { |
|||
for (var i = 0; i < props.length; i++) { |
|||
var descriptor = props[i]; |
|||
descriptor.enumerable = descriptor.enumerable || false; |
|||
descriptor.configurable = true; |
|||
if ("value" in descriptor) descriptor.writable = true; |
|||
Object.defineProperty(target, descriptor.key, descriptor); |
|||
} |
|||
} |
|||
|
|||
return function (Constructor, protoProps, staticProps) { |
|||
if (protoProps) defineProperties(Constructor.prototype, protoProps); |
|||
if (staticProps) defineProperties(Constructor, staticProps); |
|||
return Constructor; |
|||
}; |
|||
}(); |
|||
|
|||
/** |
|||
* -------------------------------------------------------------------------- |
|||
* Bootstrap (v4.0.0-alpha.4): tab.js |
|||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|||
* -------------------------------------------------------------------------- |
|||
*/ |
|||
|
|||
var Tab = function ($) { |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Constants |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
var NAME = 'tab'; |
|||
var VERSION = '4.0.0-alpha.4'; |
|||
var DATA_KEY = 'bs.tab'; |
|||
var EVENT_KEY = '.' + DATA_KEY; |
|||
var DATA_API_KEY = '.data-api'; |
|||
var JQUERY_NO_CONFLICT = $.fn[NAME]; |
|||
var TRANSITION_DURATION = 150; |
|||
|
|||
var Event = { |
|||
HIDE: 'hide' + EVENT_KEY, |
|||
HIDDEN: 'hidden' + EVENT_KEY, |
|||
SHOW: 'show' + EVENT_KEY, |
|||
SHOWN: 'shown' + EVENT_KEY, |
|||
CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY |
|||
}; |
|||
|
|||
var ClassName = { |
|||
DROPDOWN_MENU: 'dropdown-menu', |
|||
ACTIVE: 'active', |
|||
FADE: 'fade', |
|||
IN: 'in' |
|||
}; |
|||
|
|||
var Selector = { |
|||
A: 'a', |
|||
LI: 'li', |
|||
DROPDOWN: '.dropdown', |
|||
UL: 'ul:not(.dropdown-menu)', |
|||
FADE_CHILD: '> .nav-item .fade, > .fade', |
|||
ACTIVE: '.active', |
|||
ACTIVE_CHILD: '> .nav-item > .active, > .active', |
|||
DATA_TOGGLE: '[data-toggle="tab"], [data-toggle="pill"]', |
|||
DROPDOWN_TOGGLE: '.dropdown-toggle', |
|||
DROPDOWN_ACTIVE_CHILD: '> .dropdown-menu .active' |
|||
}; |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Class Definition |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
var Tab = function () { |
|||
function Tab(element) { |
|||
_classCallCheck(this, Tab); |
|||
|
|||
this._element = element; |
|||
} |
|||
|
|||
// getters
|
|||
|
|||
_createClass(Tab, [{ |
|||
key: 'show', |
|||
value: function show() { |
|||
var _this = this; |
|||
|
|||
if (this._element.parentNode && this._element.parentNode.nodeType === Node.ELEMENT_NODE && $(this._element).hasClass(ClassName.ACTIVE)) { |
|||
return; |
|||
} |
|||
|
|||
var target = void 0; |
|||
var previous = void 0; |
|||
var ulElement = $(this._element).closest(Selector.UL)[0]; |
|||
var selector = _util2.default.getSelectorFromElement(this._element); |
|||
|
|||
if (ulElement) { |
|||
previous = $.makeArray($(ulElement).find(Selector.ACTIVE)); |
|||
previous = previous[previous.length - 1]; |
|||
} |
|||
|
|||
var hideEvent = $.Event(Event.HIDE, { |
|||
relatedTarget: this._element |
|||
}); |
|||
|
|||
var showEvent = $.Event(Event.SHOW, { |
|||
relatedTarget: previous |
|||
}); |
|||
|
|||
if (previous) { |
|||
$(previous).trigger(hideEvent); |
|||
} |
|||
|
|||
$(this._element).trigger(showEvent); |
|||
|
|||
if (showEvent.isDefaultPrevented() || hideEvent.isDefaultPrevented()) { |
|||
return; |
|||
} |
|||
|
|||
if (selector) { |
|||
target = $(selector)[0]; |
|||
} |
|||
|
|||
this._activate(this._element, ulElement); |
|||
|
|||
var complete = function complete() { |
|||
var hiddenEvent = $.Event(Event.HIDDEN, { |
|||
relatedTarget: _this._element |
|||
}); |
|||
|
|||
var shownEvent = $.Event(Event.SHOWN, { |
|||
relatedTarget: previous |
|||
}); |
|||
|
|||
$(previous).trigger(hiddenEvent); |
|||
$(_this._element).trigger(shownEvent); |
|||
}; |
|||
|
|||
if (target) { |
|||
this._activate(target, target.parentNode, complete); |
|||
} else { |
|||
complete(); |
|||
} |
|||
} |
|||
}, { |
|||
key: 'dispose', |
|||
value: function dispose() { |
|||
$.removeClass(this._element, DATA_KEY); |
|||
this._element = null; |
|||
} |
|||
}, { |
|||
key: '_activate', |
|||
value: function _activate(element, container, callback) { |
|||
var active = $(container).find(Selector.ACTIVE_CHILD)[0]; |
|||
var isTransitioning = callback && _util2.default.supportsTransitionEnd() && (active && $(active).hasClass(ClassName.FADE) || Boolean($(container).find(Selector.FADE_CHILD)[0])); |
|||
|
|||
var complete = $.proxy(this._transitionComplete, this, element, active, isTransitioning, callback); |
|||
|
|||
if (active && isTransitioning) { |
|||
$(active).one(_util2.default.TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION); |
|||
} else { |
|||
complete(); |
|||
} |
|||
|
|||
if (active) { |
|||
$(active).removeClass(ClassName.IN); |
|||
} |
|||
} |
|||
}, { |
|||
key: '_transitionComplete', |
|||
value: function _transitionComplete(element, active, isTransitioning, callback) { |
|||
if (active) { |
|||
$(active).removeClass(ClassName.ACTIVE); |
|||
|
|||
var dropdownChild = $(active).find(Selector.DROPDOWN_ACTIVE_CHILD)[0]; |
|||
|
|||
if (dropdownChild) { |
|||
$(dropdownChild).removeClass(ClassName.ACTIVE); |
|||
} |
|||
|
|||
active.setAttribute('aria-expanded', false); |
|||
} |
|||
|
|||
$(element).addClass(ClassName.ACTIVE); |
|||
element.setAttribute('aria-expanded', true); |
|||
|
|||
if (isTransitioning) { |
|||
_util2.default.reflow(element); |
|||
$(element).addClass(ClassName.IN); |
|||
} else { |
|||
$(element).removeClass(ClassName.FADE); |
|||
} |
|||
|
|||
if (element.parentNode && $(element.parentNode).hasClass(ClassName.DROPDOWN_MENU)) { |
|||
|
|||
var dropdownElement = $(element).closest(Selector.DROPDOWN)[0]; |
|||
if (dropdownElement) { |
|||
$(dropdownElement).find(Selector.DROPDOWN_TOGGLE).addClass(ClassName.ACTIVE); |
|||
} |
|||
|
|||
element.setAttribute('aria-expanded', true); |
|||
} |
|||
|
|||
if (callback) { |
|||
callback(); |
|||
} |
|||
} |
|||
}], [{ |
|||
key: '_jQueryInterface', |
|||
value: function _jQueryInterface(config) { |
|||
return this.each(function () { |
|||
var $this = $(this); |
|||
var data = $this.data(DATA_KEY); |
|||
|
|||
if (!data) { |
|||
data = data = new Tab(this); |
|||
$this.data(DATA_KEY, data); |
|||
} |
|||
|
|||
if (typeof config === 'string') { |
|||
if (data[config] === undefined) { |
|||
throw new Error('No method named "' + config + '"'); |
|||
} |
|||
data[config](); |
|||
} |
|||
}); |
|||
} |
|||
}, { |
|||
key: 'VERSION', |
|||
get: function get() { |
|||
return VERSION; |
|||
} |
|||
}]); |
|||
|
|||
return Tab; |
|||
}(); |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Data Api implementation |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
$(document).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE, function (event) { |
|||
event.preventDefault(); |
|||
Tab._jQueryInterface.call($(this), 'show'); |
|||
}); |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* jQuery |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
$.fn[NAME] = Tab._jQueryInterface; |
|||
$.fn[NAME].Constructor = Tab; |
|||
$.fn[NAME].noConflict = function () { |
|||
$.fn[NAME] = JQUERY_NO_CONFLICT; |
|||
return Tab._jQueryInterface; |
|||
}; |
|||
|
|||
return Tab; |
|||
}(jQuery); |
|||
|
|||
exports.default = Tab; |
|||
}); |
@ -0,0 +1,646 @@ |
|||
define(['exports', './util'], function (exports, _util) { |
|||
'use strict'; |
|||
|
|||
Object.defineProperty(exports, "__esModule", { |
|||
value: true |
|||
}); |
|||
|
|||
var _util2 = _interopRequireDefault(_util); |
|||
|
|||
function _interopRequireDefault(obj) { |
|||
return obj && obj.__esModule ? obj : { |
|||
default: obj |
|||
}; |
|||
} |
|||
|
|||
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { |
|||
return typeof obj; |
|||
} : function (obj) { |
|||
return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; |
|||
}; |
|||
|
|||
function _classCallCheck(instance, Constructor) { |
|||
if (!(instance instanceof Constructor)) { |
|||
throw new TypeError("Cannot call a class as a function"); |
|||
} |
|||
} |
|||
|
|||
var _createClass = function () { |
|||
function defineProperties(target, props) { |
|||
for (var i = 0; i < props.length; i++) { |
|||
var descriptor = props[i]; |
|||
descriptor.enumerable = descriptor.enumerable || false; |
|||
descriptor.configurable = true; |
|||
if ("value" in descriptor) descriptor.writable = true; |
|||
Object.defineProperty(target, descriptor.key, descriptor); |
|||
} |
|||
} |
|||
|
|||
return function (Constructor, protoProps, staticProps) { |
|||
if (protoProps) defineProperties(Constructor.prototype, protoProps); |
|||
if (staticProps) defineProperties(Constructor, staticProps); |
|||
return Constructor; |
|||
}; |
|||
}(); |
|||
|
|||
/** |
|||
* -------------------------------------------------------------------------- |
|||
* Bootstrap (v4.0.0-alpha.4): tooltip.js |
|||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|||
* -------------------------------------------------------------------------- |
|||
*/ |
|||
|
|||
var Tooltip = function ($) { |
|||
|
|||
/** |
|||
* Check for Tether dependency |
|||
* Tether - http://github.hubspot.com/tether/
|
|||
*/ |
|||
if (window.Tether === undefined) { |
|||
throw new Error('Bootstrap tooltips require Tether (http://github.hubspot.com/tether/)'); |
|||
} |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Constants |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
var NAME = 'tooltip'; |
|||
var VERSION = '4.0.0-alpha.4'; |
|||
var DATA_KEY = 'bs.tooltip'; |
|||
var EVENT_KEY = '.' + DATA_KEY; |
|||
var JQUERY_NO_CONFLICT = $.fn[NAME]; |
|||
var TRANSITION_DURATION = 150; |
|||
var CLASS_PREFIX = 'bs-tether'; |
|||
|
|||
var Default = { |
|||
animation: true, |
|||
template: '<div class="tooltip" role="tooltip">' + '<div class="tooltip-arrow"></div>' + '<div class="tooltip-inner"></div></div>', |
|||
trigger: 'hover focus', |
|||
title: '', |
|||
delay: 0, |
|||
html: false, |
|||
selector: false, |
|||
placement: 'top', |
|||
offset: '0 0', |
|||
constraints: [] |
|||
}; |
|||
|
|||
var DefaultType = { |
|||
animation: 'boolean', |
|||
template: 'string', |
|||
title: '(string|element|function)', |
|||
trigger: 'string', |
|||
delay: '(number|object)', |
|||
html: 'boolean', |
|||
selector: '(string|boolean)', |
|||
placement: '(string|function)', |
|||
offset: 'string', |
|||
constraints: 'array' |
|||
}; |
|||
|
|||
var AttachmentMap = { |
|||
TOP: 'bottom center', |
|||
RIGHT: 'middle left', |
|||
BOTTOM: 'top center', |
|||
LEFT: 'middle right' |
|||
}; |
|||
|
|||
var HoverState = { |
|||
IN: 'in', |
|||
OUT: 'out' |
|||
}; |
|||
|
|||
var Event = { |
|||
HIDE: 'hide' + EVENT_KEY, |
|||
HIDDEN: 'hidden' + EVENT_KEY, |
|||
SHOW: 'show' + EVENT_KEY, |
|||
SHOWN: 'shown' + EVENT_KEY, |
|||
INSERTED: 'inserted' + EVENT_KEY, |
|||
CLICK: 'click' + EVENT_KEY, |
|||
FOCUSIN: 'focusin' + EVENT_KEY, |
|||
FOCUSOUT: 'focusout' + EVENT_KEY, |
|||
MOUSEENTER: 'mouseenter' + EVENT_KEY, |
|||
MOUSELEAVE: 'mouseleave' + EVENT_KEY |
|||
}; |
|||
|
|||
var ClassName = { |
|||
FADE: 'fade', |
|||
IN: 'in' |
|||
}; |
|||
|
|||
var Selector = { |
|||
TOOLTIP: '.tooltip', |
|||
TOOLTIP_INNER: '.tooltip-inner' |
|||
}; |
|||
|
|||
var TetherClass = { |
|||
element: false, |
|||
enabled: false |
|||
}; |
|||
|
|||
var Trigger = { |
|||
HOVER: 'hover', |
|||
FOCUS: 'focus', |
|||
CLICK: 'click', |
|||
MANUAL: 'manual' |
|||
}; |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Class Definition |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
var Tooltip = function () { |
|||
function Tooltip(element, config) { |
|||
_classCallCheck(this, Tooltip); |
|||
|
|||
// private
|
|||
this._isEnabled = true; |
|||
this._timeout = 0; |
|||
this._hoverState = ''; |
|||
this._activeTrigger = {}; |
|||
this._tether = null; |
|||
|
|||
// protected
|
|||
this.element = element; |
|||
this.config = this._getConfig(config); |
|||
this.tip = null; |
|||
|
|||
this._setListeners(); |
|||
} |
|||
|
|||
// getters
|
|||
|
|||
_createClass(Tooltip, [{ |
|||
key: 'enable', |
|||
value: function enable() { |
|||
this._isEnabled = true; |
|||
} |
|||
}, { |
|||
key: 'disable', |
|||
value: function disable() { |
|||
this._isEnabled = false; |
|||
} |
|||
}, { |
|||
key: 'toggleEnabled', |
|||
value: function toggleEnabled() { |
|||
this._isEnabled = !this._isEnabled; |
|||
} |
|||
}, { |
|||
key: 'toggle', |
|||
value: function toggle(event) { |
|||
if (event) { |
|||
var dataKey = this.constructor.DATA_KEY; |
|||
var context = $(event.currentTarget).data(dataKey); |
|||
|
|||
if (!context) { |
|||
context = new this.constructor(event.currentTarget, this._getDelegateConfig()); |
|||
$(event.currentTarget).data(dataKey, context); |
|||
} |
|||
|
|||
context._activeTrigger.click = !context._activeTrigger.click; |
|||
|
|||
if (context._isWithActiveTrigger()) { |
|||
context._enter(null, context); |
|||
} else { |
|||
context._leave(null, context); |
|||
} |
|||
} else { |
|||
|
|||
if ($(this.getTipElement()).hasClass(ClassName.IN)) { |
|||
this._leave(null, this); |
|||
return; |
|||
} |
|||
|
|||
this._enter(null, this); |
|||
} |
|||
} |
|||
}, { |
|||
key: 'dispose', |
|||
value: function dispose() { |
|||
clearTimeout(this._timeout); |
|||
|
|||
this.cleanupTether(); |
|||
|
|||
$.removeData(this.element, this.constructor.DATA_KEY); |
|||
|
|||
$(this.element).off(this.constructor.EVENT_KEY); |
|||
|
|||
if (this.tip) { |
|||
$(this.tip).remove(); |
|||
} |
|||
|
|||
this._isEnabled = null; |
|||
this._timeout = null; |
|||
this._hoverState = null; |
|||
this._activeTrigger = null; |
|||
this._tether = null; |
|||
|
|||
this.element = null; |
|||
this.config = null; |
|||
this.tip = null; |
|||
} |
|||
}, { |
|||
key: 'show', |
|||
value: function show() { |
|||
var _this = this; |
|||
|
|||
var showEvent = $.Event(this.constructor.Event.SHOW); |
|||
|
|||
if (this.isWithContent() && this._isEnabled) { |
|||
$(this.element).trigger(showEvent); |
|||
|
|||
var isInTheDom = $.contains(this.element.ownerDocument.documentElement, this.element); |
|||
|
|||
if (showEvent.isDefaultPrevented() || !isInTheDom) { |
|||
return; |
|||
} |
|||
|
|||
var tip = this.getTipElement(); |
|||
var tipId = _util2.default.getUID(this.constructor.NAME); |
|||
|
|||
tip.setAttribute('id', tipId); |
|||
this.element.setAttribute('aria-describedby', tipId); |
|||
|
|||
this.setContent(); |
|||
|
|||
if (this.config.animation) { |
|||
$(tip).addClass(ClassName.FADE); |
|||
} |
|||
|
|||
var placement = typeof this.config.placement === 'function' ? this.config.placement.call(this, tip, this.element) : this.config.placement; |
|||
|
|||
var attachment = this._getAttachment(placement); |
|||
|
|||
$(tip).data(this.constructor.DATA_KEY, this).appendTo(document.body); |
|||
|
|||
$(this.element).trigger(this.constructor.Event.INSERTED); |
|||
|
|||
this._tether = new Tether({ |
|||
attachment: attachment, |
|||
element: tip, |
|||
target: this.element, |
|||
classes: TetherClass, |
|||
classPrefix: CLASS_PREFIX, |
|||
offset: this.config.offset, |
|||
constraints: this.config.constraints, |
|||
addTargetClasses: false |
|||
}); |
|||
|
|||
_util2.default.reflow(tip); |
|||
this._tether.position(); |
|||
|
|||
$(tip).addClass(ClassName.IN); |
|||
|
|||
var complete = function complete() { |
|||
var prevHoverState = _this._hoverState; |
|||
_this._hoverState = null; |
|||
|
|||
$(_this.element).trigger(_this.constructor.Event.SHOWN); |
|||
|
|||
if (prevHoverState === HoverState.OUT) { |
|||
_this._leave(null, _this); |
|||
} |
|||
}; |
|||
|
|||
if (_util2.default.supportsTransitionEnd() && $(this.tip).hasClass(ClassName.FADE)) { |
|||
$(this.tip).one(_util2.default.TRANSITION_END, complete).emulateTransitionEnd(Tooltip._TRANSITION_DURATION); |
|||
return; |
|||
} |
|||
|
|||
complete(); |
|||
} |
|||
} |
|||
}, { |
|||
key: 'hide', |
|||
value: function hide(callback) { |
|||
var _this2 = this; |
|||
|
|||
var tip = this.getTipElement(); |
|||
var hideEvent = $.Event(this.constructor.Event.HIDE); |
|||
var complete = function complete() { |
|||
if (_this2._hoverState !== HoverState.IN && tip.parentNode) { |
|||
tip.parentNode.removeChild(tip); |
|||
} |
|||
|
|||
_this2.element.removeAttribute('aria-describedby'); |
|||
$(_this2.element).trigger(_this2.constructor.Event.HIDDEN); |
|||
_this2.cleanupTether(); |
|||
|
|||
if (callback) { |
|||
callback(); |
|||
} |
|||
}; |
|||
|
|||
$(this.element).trigger(hideEvent); |
|||
|
|||
if (hideEvent.isDefaultPrevented()) { |
|||
return; |
|||
} |
|||
|
|||
$(tip).removeClass(ClassName.IN); |
|||
|
|||
if (_util2.default.supportsTransitionEnd() && $(this.tip).hasClass(ClassName.FADE)) { |
|||
|
|||
$(tip).one(_util2.default.TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION); |
|||
} else { |
|||
complete(); |
|||
} |
|||
|
|||
this._hoverState = ''; |
|||
} |
|||
}, { |
|||
key: 'isWithContent', |
|||
value: function isWithContent() { |
|||
return Boolean(this.getTitle()); |
|||
} |
|||
}, { |
|||
key: 'getTipElement', |
|||
value: function getTipElement() { |
|||
return this.tip = this.tip || $(this.config.template)[0]; |
|||
} |
|||
}, { |
|||
key: 'setContent', |
|||
value: function setContent() { |
|||
var $tip = $(this.getTipElement()); |
|||
|
|||
this.setElementContent($tip.find(Selector.TOOLTIP_INNER), this.getTitle()); |
|||
|
|||
$tip.removeClass(ClassName.FADE).removeClass(ClassName.IN); |
|||
|
|||
this.cleanupTether(); |
|||
} |
|||
}, { |
|||
key: 'setElementContent', |
|||
value: function setElementContent($element, content) { |
|||
var html = this.config.html; |
|||
if ((typeof content === 'undefined' ? 'undefined' : _typeof(content)) === 'object' && (content.nodeType || content.jquery)) { |
|||
// content is a DOM node or a jQuery
|
|||
if (html) { |
|||
if (!$(content).parent().is($element)) { |
|||
$element.empty().append(content); |
|||
} |
|||
} else { |
|||
$element.text($(content).text()); |
|||
} |
|||
} else { |
|||
$element[html ? 'html' : 'text'](content); |
|||
} |
|||
} |
|||
}, { |
|||
key: 'getTitle', |
|||
value: function getTitle() { |
|||
var title = this.element.getAttribute('data-original-title'); |
|||
|
|||
if (!title) { |
|||
title = typeof this.config.title === 'function' ? this.config.title.call(this.element) : this.config.title; |
|||
} |
|||
|
|||
return title; |
|||
} |
|||
}, { |
|||
key: 'cleanupTether', |
|||
value: function cleanupTether() { |
|||
if (this._tether) { |
|||
this._tether.destroy(); |
|||
} |
|||
} |
|||
}, { |
|||
key: '_getAttachment', |
|||
value: function _getAttachment(placement) { |
|||
return AttachmentMap[placement.toUpperCase()]; |
|||
} |
|||
}, { |
|||
key: '_setListeners', |
|||
value: function _setListeners() { |
|||
var _this3 = this; |
|||
|
|||
var triggers = this.config.trigger.split(' '); |
|||
|
|||
triggers.forEach(function (trigger) { |
|||
if (trigger === 'click') { |
|||
$(_this3.element).on(_this3.constructor.Event.CLICK, _this3.config.selector, $.proxy(_this3.toggle, _this3)); |
|||
} else if (trigger !== Trigger.MANUAL) { |
|||
var eventIn = trigger === Trigger.HOVER ? _this3.constructor.Event.MOUSEENTER : _this3.constructor.Event.FOCUSIN; |
|||
var eventOut = trigger === Trigger.HOVER ? _this3.constructor.Event.MOUSELEAVE : _this3.constructor.Event.FOCUSOUT; |
|||
|
|||
$(_this3.element).on(eventIn, _this3.config.selector, $.proxy(_this3._enter, _this3)).on(eventOut, _this3.config.selector, $.proxy(_this3._leave, _this3)); |
|||
} |
|||
}); |
|||
|
|||
if (this.config.selector) { |
|||
this.config = $.extend({}, this.config, { |
|||
trigger: 'manual', |
|||
selector: '' |
|||
}); |
|||
} else { |
|||
this._fixTitle(); |
|||
} |
|||
} |
|||
}, { |
|||
key: '_fixTitle', |
|||
value: function _fixTitle() { |
|||
var titleType = _typeof(this.element.getAttribute('data-original-title')); |
|||
if (this.element.getAttribute('title') || titleType !== 'string') { |
|||
this.element.setAttribute('data-original-title', this.element.getAttribute('title') || ''); |
|||
this.element.setAttribute('title', ''); |
|||
} |
|||
} |
|||
}, { |
|||
key: '_enter', |
|||
value: function _enter(event, context) { |
|||
var dataKey = this.constructor.DATA_KEY; |
|||
|
|||
context = context || $(event.currentTarget).data(dataKey); |
|||
|
|||
if (!context) { |
|||
context = new this.constructor(event.currentTarget, this._getDelegateConfig()); |
|||
$(event.currentTarget).data(dataKey, context); |
|||
} |
|||
|
|||
if (event) { |
|||
context._activeTrigger[event.type === 'focusin' ? Trigger.FOCUS : Trigger.HOVER] = true; |
|||
} |
|||
|
|||
if ($(context.getTipElement()).hasClass(ClassName.IN) || context._hoverState === HoverState.IN) { |
|||
context._hoverState = HoverState.IN; |
|||
return; |
|||
} |
|||
|
|||
clearTimeout(context._timeout); |
|||
|
|||
context._hoverState = HoverState.IN; |
|||
|
|||
if (!context.config.delay || !context.config.delay.show) { |
|||
context.show(); |
|||
return; |
|||
} |
|||
|
|||
context._timeout = setTimeout(function () { |
|||
if (context._hoverState === HoverState.IN) { |
|||
context.show(); |
|||
} |
|||
}, context.config.delay.show); |
|||
} |
|||
}, { |
|||
key: '_leave', |
|||
value: function _leave(event, context) { |
|||
var dataKey = this.constructor.DATA_KEY; |
|||
|
|||
context = context || $(event.currentTarget).data(dataKey); |
|||
|
|||
if (!context) { |
|||
context = new this.constructor(event.currentTarget, this._getDelegateConfig()); |
|||
$(event.currentTarget).data(dataKey, context); |
|||
} |
|||
|
|||
if (event) { |
|||
context._activeTrigger[event.type === 'focusout' ? Trigger.FOCUS : Trigger.HOVER] = false; |
|||
} |
|||
|
|||
if (context._isWithActiveTrigger()) { |
|||
return; |
|||
} |
|||
|
|||
clearTimeout(context._timeout); |
|||
|
|||
context._hoverState = HoverState.OUT; |
|||
|
|||
if (!context.config.delay || !context.config.delay.hide) { |
|||
context.hide(); |
|||
return; |
|||
} |
|||
|
|||
context._timeout = setTimeout(function () { |
|||
if (context._hoverState === HoverState.OUT) { |
|||
context.hide(); |
|||
} |
|||
}, context.config.delay.hide); |
|||
} |
|||
}, { |
|||
key: '_isWithActiveTrigger', |
|||
value: function _isWithActiveTrigger() { |
|||
for (var trigger in this._activeTrigger) { |
|||
if (this._activeTrigger[trigger]) { |
|||
return true; |
|||
} |
|||
} |
|||
|
|||
return false; |
|||
} |
|||
}, { |
|||
key: '_getConfig', |
|||
value: function _getConfig(config) { |
|||
config = $.extend({}, this.constructor.Default, $(this.element).data(), config); |
|||
|
|||
if (config.delay && typeof config.delay === 'number') { |
|||
config.delay = { |
|||
show: config.delay, |
|||
hide: config.delay |
|||
}; |
|||
} |
|||
|
|||
_util2.default.typeCheckConfig(NAME, config, this.constructor.DefaultType); |
|||
|
|||
return config; |
|||
} |
|||
}, { |
|||
key: '_getDelegateConfig', |
|||
value: function _getDelegateConfig() { |
|||
var config = {}; |
|||
|
|||
if (this.config) { |
|||
for (var key in this.config) { |
|||
if (this.constructor.Default[key] !== this.config[key]) { |
|||
config[key] = this.config[key]; |
|||
} |
|||
} |
|||
} |
|||
|
|||
return config; |
|||
} |
|||
}], [{ |
|||
key: '_jQueryInterface', |
|||
value: function _jQueryInterface(config) { |
|||
return this.each(function () { |
|||
var data = $(this).data(DATA_KEY); |
|||
var _config = (typeof config === 'undefined' ? 'undefined' : _typeof(config)) === 'object' ? config : null; |
|||
|
|||
if (!data && /destroy|hide/.test(config)) { |
|||
return; |
|||
} |
|||
|
|||
if (!data) { |
|||
data = new Tooltip(this, _config); |
|||
$(this).data(DATA_KEY, data); |
|||
} |
|||
|
|||
if (typeof config === 'string') { |
|||
if (data[config] === undefined) { |
|||
throw new Error('No method named "' + config + '"'); |
|||
} |
|||
data[config](); |
|||
} |
|||
}); |
|||
} |
|||
}, { |
|||
key: 'VERSION', |
|||
get: function get() { |
|||
return VERSION; |
|||
} |
|||
}, { |
|||
key: 'Default', |
|||
get: function get() { |
|||
return Default; |
|||
} |
|||
}, { |
|||
key: 'NAME', |
|||
get: function get() { |
|||
return NAME; |
|||
} |
|||
}, { |
|||
key: 'DATA_KEY', |
|||
get: function get() { |
|||
return DATA_KEY; |
|||
} |
|||
}, { |
|||
key: 'Event', |
|||
get: function get() { |
|||
return Event; |
|||
} |
|||
}, { |
|||
key: 'EVENT_KEY', |
|||
get: function get() { |
|||
return EVENT_KEY; |
|||
} |
|||
}, { |
|||
key: 'DefaultType', |
|||
get: function get() { |
|||
return DefaultType; |
|||
} |
|||
}]); |
|||
|
|||
return Tooltip; |
|||
}(); |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* jQuery |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
$.fn[NAME] = Tooltip._jQueryInterface; |
|||
$.fn[NAME].Constructor = Tooltip; |
|||
$.fn[NAME].noConflict = function () { |
|||
$.fn[NAME] = JQUERY_NO_CONFLICT; |
|||
return Tooltip._jQueryInterface; |
|||
}; |
|||
|
|||
return Tooltip; |
|||
}(jQuery); |
|||
|
|||
exports.default = Tooltip; |
|||
}); |
@ -0,0 +1,163 @@ |
|||
define(['exports'], function (exports) { |
|||
'use strict'; |
|||
|
|||
Object.defineProperty(exports, "__esModule", { |
|||
value: true |
|||
}); |
|||
/** |
|||
* -------------------------------------------------------------------------- |
|||
* Bootstrap (v4.0.0-alpha.4): util.js |
|||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|||
* -------------------------------------------------------------------------- |
|||
*/ |
|||
|
|||
var Util = function ($) { |
|||
|
|||
/** |
|||
* ------------------------------------------------------------------------ |
|||
* Private TransitionEnd Helpers |
|||
* ------------------------------------------------------------------------ |
|||
*/ |
|||
|
|||
var transition = false; |
|||
|
|||
var MAX_UID = 1000000; |
|||
|
|||
var TransitionEndEvent = { |
|||
WebkitTransition: 'webkitTransitionEnd', |
|||
MozTransition: 'transitionend', |
|||
OTransition: 'oTransitionEnd otransitionend', |
|||
transition: 'transitionend' |
|||
}; |
|||
|
|||
// shoutout AngusCroll (https://goo.gl/pxwQGp)
|
|||
function toType(obj) { |
|||
return {}.toString.call(obj).match(/\s([a-zA-Z]+)/)[1].toLowerCase(); |
|||
} |
|||
|
|||
function isElement(obj) { |
|||
return (obj[0] || obj).nodeType; |
|||
} |
|||
|
|||
function getSpecialTransitionEndEvent() { |
|||
return { |
|||
bindType: transition.end, |
|||
delegateType: transition.end, |
|||
handle: function handle(event) { |
|||
if ($(event.target).is(this)) { |
|||
return event.handleObj.handler.apply(this, arguments); // eslint-disable-line prefer-rest-params
|
|||
} |
|||
return undefined; |
|||
} |
|||
}; |
|||
} |
|||
|
|||
function transitionEndTest() { |
|||
if (window.QUnit) { |
|||
return false; |
|||
} |
|||
|
|||
var el = document.createElement('bootstrap'); |
|||
|
|||
for (var name in TransitionEndEvent) { |
|||
if (el.style[name] !== undefined) { |
|||
return { end: TransitionEndEvent[name] }; |
|||
} |
|||
} |
|||
|
|||
return false; |
|||
} |
|||
|
|||
function transitionEndEmulator(duration) { |
|||
var _this = this; |
|||
|
|||
var called = false; |
|||
|
|||
$(this).one(Util.TRANSITION_END, function () { |
|||
called = true; |
|||
}); |
|||
|
|||
setTimeout(function () { |
|||
if (!called) { |
|||
Util.triggerTransitionEnd(_this); |
|||
} |
|||
}, duration); |
|||
|
|||
return this; |
|||
} |
|||
|
|||
function setTransitionEndSupport() { |
|||
transition = transitionEndTest(); |
|||
|
|||
$.fn.emulateTransitionEnd = transitionEndEmulator; |
|||
|
|||
if (Util.supportsTransitionEnd()) { |
|||
$.event.special[Util.TRANSITION_END] = getSpecialTransitionEndEvent(); |
|||
} |
|||
} |
|||
|
|||
/** |
|||
* -------------------------------------------------------------------------- |
|||
* Public Util Api |
|||
* -------------------------------------------------------------------------- |
|||
*/ |
|||
|
|||
var Util = { |
|||
|
|||
TRANSITION_END: 'bsTransitionEnd', |
|||
|
|||
getUID: function getUID(prefix) { |
|||
do { |
|||
/* eslint-disable no-bitwise */ |
|||
prefix += ~~(Math.random() * MAX_UID); // "~~" acts like a faster Math.floor() here
|
|||
/* eslint-enable no-bitwise */ |
|||
} while (document.getElementById(prefix)); |
|||
return prefix; |
|||
}, |
|||
getSelectorFromElement: function getSelectorFromElement(element) { |
|||
var selector = element.getAttribute('data-target'); |
|||
|
|||
if (!selector) { |
|||
selector = element.getAttribute('href') || ''; |
|||
selector = /^#[a-z]/i.test(selector) ? selector : null; |
|||
} |
|||
|
|||
return selector; |
|||
}, |
|||
reflow: function reflow(element) { |
|||
new Function('bs', 'return bs')(element.offsetHeight); |
|||
}, |
|||
triggerTransitionEnd: function triggerTransitionEnd(element) { |
|||
$(element).trigger(transition.end); |
|||
}, |
|||
supportsTransitionEnd: function supportsTransitionEnd() { |
|||
return Boolean(transition); |
|||
}, |
|||
typeCheckConfig: function typeCheckConfig(componentName, config, configTypes) { |
|||
for (var property in configTypes) { |
|||
if (configTypes.hasOwnProperty(property)) { |
|||
var expectedTypes = configTypes[property]; |
|||
var value = config[property]; |
|||
var valueType = void 0; |
|||
|
|||
if (value && isElement(value)) { |
|||
valueType = 'element'; |
|||
} else { |
|||
valueType = toType(value); |
|||
} |
|||
|
|||
if (!new RegExp(expectedTypes).test(valueType)) { |
|||
throw new Error(componentName.toUpperCase() + ': ' + ('Option "' + property + '" provided type "' + valueType + '" ') + ('but expected type "' + expectedTypes + '".')); |
|||
} |
|||
} |
|||
} |
|||
} |
|||
}; |
|||
|
|||
setTransitionEndSupport(); |
|||
|
|||
return Util; |
|||
}(jQuery); |
|||
|
|||
exports.default = Util; |
|||
}); |
@ -0,0 +1,100 @@ |
|||
<?php |
|||
// This file is part of Moodle - http://moodle.org/ |
|||
// |
|||
// Moodle 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 3 of the License, or |
|||
// (at your option) any later version. |
|||
// |
|||
// Moodle 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. |
|||
// |
|||
// You should have received a copy of the GNU General Public License |
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. |
|||
|
|||
/** |
|||
* @package theme_ilb |
|||
* @copyright 2016 Ryan Wyllie |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
|
|||
defined('MOODLE_INTERNAL') || die(); |
|||
|
|||
/** |
|||
* @package theme_ilb |
|||
* @copyright 2016 Ryan Wyllie |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
class theme_ilb_admin_settingspage_tabs extends admin_settingpage { |
|||
|
|||
/** @var The tabs */ |
|||
protected $tabs = array(); |
|||
|
|||
/** |
|||
* Add a tab. |
|||
* |
|||
* @param admin_settingpage $tab A tab. |
|||
*/ |
|||
public function add_tab(admin_settingpage $tab) { |
|||
foreach ($tab->settings as $setting) { |
|||
$this->settings->{$setting->name} = $setting; |
|||
} |
|||
$this->tabs[] = $tab; |
|||
return true; |
|||
} |
|||
|
|||
public function add($tab) { |
|||
return $this->add_tab($tab); |
|||
} |
|||
|
|||
/** |
|||
* Get tabs. |
|||
* |
|||
* @return array |
|||
*/ |
|||
public function get_tabs() { |
|||
return $this->tabs; |
|||
} |
|||
|
|||
/** |
|||
* Generate the HTML output. |
|||
* |
|||
* @return string |
|||
*/ |
|||
public function output_html() { |
|||
global $OUTPUT; |
|||
|
|||
$activetab = optional_param('activetab', '', PARAM_TEXT); |
|||
$context = array('tabs' => array()); |
|||
$havesetactive = false; |
|||
|
|||
foreach ($this->get_tabs() as $tab) { |
|||
$active = false; |
|||
|
|||
// Default to first tab it not told otherwise. |
|||
if (empty($activetab) && !$havesetactive) { |
|||
$active = true; |
|||
$havesetactive = true; |
|||
} else if ($activetab === $tab->name) { |
|||
$active = true; |
|||
} |
|||
|
|||
$context['tabs'][] = array( |
|||
'name' => $tab->name, |
|||
'displayname' => $tab->visiblename, |
|||
'html' => $tab->output_html(), |
|||
'active' => $active, |
|||
); |
|||
} |
|||
|
|||
if (empty($context['tabs'])) { |
|||
return ''; |
|||
} |
|||
|
|||
return $OUTPUT->render_from_template('theme_ilb/admin_setting_tabs', $context); |
|||
} |
|||
|
|||
} |
|||
|
@ -0,0 +1,250 @@ |
|||
<?php |
|||
// This file is part of Moodle - http://moodle.org/ |
|||
// |
|||
// Moodle 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 3 of the License, or |
|||
// (at your option) any later version. |
|||
// |
|||
// Moodle 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. |
|||
// |
|||
// You should have received a copy of the GNU General Public License |
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. |
|||
|
|||
/** |
|||
* Autoprefixer. |
|||
* |
|||
* This autoprefixer has been developed to satisfy the basic needs of the |
|||
* theme Ilb when working with Bootstrap 4 alpha. We do not recommend |
|||
* that this tool is shared, nor used outside of this theme. |
|||
* |
|||
* @package theme_ilb |
|||
* @copyright 2016 Frédéric Massart - FMCorz.net |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
|
|||
namespace theme_ilb; |
|||
defined('MOODLE_INTERNAL') || die(); |
|||
|
|||
use Sabberworm\CSS\CSSList\CSSList; |
|||
use Sabberworm\CSS\CSSList\Document; |
|||
use Sabberworm\CSS\CSSList\KeyFrame; |
|||
use Sabberworm\CSS\OutputFormat; |
|||
use Sabberworm\CSS\Parser; |
|||
use Sabberworm\CSS\Property\AtRule; |
|||
use Sabberworm\CSS\Property\Selector; |
|||
use Sabberworm\CSS\Rule\Rule; |
|||
use Sabberworm\CSS\RuleSet\AtRuleSet; |
|||
use Sabberworm\CSS\RuleSet\DeclarationBlock; |
|||
use Sabberworm\CSS\RuleSet\RuleSet; |
|||
use Sabberworm\CSS\Settings; |
|||
use Sabberworm\CSS\Value\CSSFunction; |
|||
use Sabberworm\CSS\Value\CSSString; |
|||
use Sabberworm\CSS\Value\PrimitiveValue; |
|||
use Sabberworm\CSS\Value\RuleValueList; |
|||
use Sabberworm\CSS\Value\Size; |
|||
use Sabberworm\CSS\Value\ValueList; |
|||
|
|||
|
|||
/** |
|||
* Autoprefixer class. |
|||
* |
|||
* Very basic implementation covering simple needs for Bootstrap 4. |
|||
* |
|||
* @package theme_ilb |
|||
* @copyright 2016 Frédéric Massart - FMCorz.net |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
class autoprefixer { |
|||
|
|||
/** @var object The CSS tree. */ |
|||
protected $tree; |
|||
|
|||
/** @var string Pseudo classes regex. */ |
|||
protected $pseudosregex; |
|||
|
|||
/** @var array At rules prefixes. */ |
|||
protected static $atrules = [ |
|||
'keyframes' => ['-webkit-', '-o-'] |
|||
]; |
|||
|
|||
/** @var array Pseudo classes prefixes. */ |
|||
protected static $pseudos = [ |
|||
'::placeholder' => ['::-webkit-input-placeholder', '::-moz-placeholder', ':-ms-input-placeholder'] |
|||
]; |
|||
|
|||
/** @var array Rule properties prefixes. */ |
|||
protected static $rules = [ |
|||
'animation' => ['-webkit-'], |
|||
'appearance' => ['-webkit-', '-moz-'], |
|||
'backface-visibility' => ['-webkit-'], |
|||
'box-sizing' => ['-webkit-'], |
|||
'box-shadow' => ['-webkit-'], |
|||
'background-clip' => ['-webkit-'], |
|||
'background-size' => ['-webkit-'], |
|||
'box-shadow' => ['-webkit-'], |
|||
'column-count' => ['-webkit-', '-moz-'], |
|||
'column-gap' => ['-webkit-', '-moz-'], |
|||
'perspective' => ['-webkit-'], |
|||
'touch-action' => ['-ms-'], |
|||
'transform' => ['-webkit-', '-moz-', '-ms-', '-o-'], |
|||
'transition' => ['-webkit-', '-o-'], |
|||
'transition-timing-function' => ['-webkit-', '-o-'], |
|||
'transition-duration' => ['-webkit-', '-o-'], |
|||
'transition-property' => ['-webkit-', '-o-'], |
|||
'user-select' => ['-webkit-', '-moz-', '-ms-'], |
|||
]; |
|||
|
|||
/** |
|||
* Constructor. |
|||
* |
|||
* @param Document $tree The CSS tree. |
|||
*/ |
|||
public function __construct(Document $tree) { |
|||
$this->tree = $tree; |
|||
|
|||
$pseudos = array_map(function($pseudo) { |
|||
return '(' . preg_quote($pseudo) . ')'; |
|||
}, array_keys(self::$pseudos)); |
|||
$this->pseudosregex = '(' . implode('|', $pseudos) . ')'; |
|||
} |
|||
|
|||
/** |
|||
* Manipulate an array of rules to adapt their values. |
|||
* |
|||
* @param array $rules The rules. |
|||
* @return New array of rules. |
|||
*/ |
|||
protected function manipulateRuleValues(array $rules) { |
|||
$finalrules = []; |
|||
|
|||
foreach ($rules as $rule) { |
|||
$property = $rule->getRule(); |
|||
$value = $rule->getValue(); |
|||
|
|||
if ($property === 'position' && $value === 'sticky') { |
|||
$newrule = clone $rule; |
|||
$newrule->setValue('-webkit-sticky'); |
|||
$finalrules[] = $newrule; |
|||
|
|||
} else if ($property === 'background-image' && |
|||
$value instanceof CSSFunction && |
|||
$value->getName() === 'linear-gradient') { |
|||
|
|||
foreach (['-webkit-', '-o-'] as $prefix) { |
|||
$newfunction = clone $value; |
|||
$newfunction->setName($prefix . $value->getName()); |
|||
$newrule = clone $rule; |
|||
$newrule->setValue($newfunction); |
|||
$finalrules[] = $newrule; |
|||
} |
|||
} |
|||
|
|||
$finalrules[] = $rule; |
|||
} |
|||
|
|||
return $finalrules; |
|||
} |
|||
|
|||
/** |
|||
* Prefix all the things! |
|||
*/ |
|||
public function prefix() { |
|||
$this->processBlock($this->tree); |
|||
} |
|||
|
|||
/** |
|||
* Process block. |
|||
* |
|||
* @param object $block A block. |
|||
* @param object $parent The parent of the block. |
|||
*/ |
|||
protected function processBlock($block) { |
|||
foreach ($block->getContents() as $node) { |
|||
if ($node instanceof AtRule) { |
|||
|
|||
$name = $node->atRuleName(); |
|||
if (isset(self::$atrules[$name])) { |
|||
foreach (self::$atrules[$name] as $prefix) { |
|||
$newname = $prefix . $name; |
|||
$newnode = clone $node; |
|||
|
|||
if ($node instanceof KeyFrame) { |
|||
$newnode->setVendorKeyFrame($newname); |
|||
$block->insert($newnode, $node); |
|||
|
|||
} else { |
|||
debugging('Unhandled atRule prefixing.', DEBUG_DEVELOPER); |
|||
} |
|||
} |
|||
} |
|||
} |
|||
|
|||
if ($node instanceof CSSList) { |
|||
$this->processBlock($node); |
|||
|
|||
} else if ($node instanceof RuleSet) { |
|||
$this->processDeclaration($node, $block); |
|||
} |
|||
} |
|||
} |
|||
|
|||
/** |
|||
* Process declaration. |
|||
* |
|||
* @param object $node The declaration block. |
|||
* @param object $parent The parent. |
|||
*/ |
|||
protected function processDeclaration($node, $parent) { |
|||
$rules = []; |
|||
|
|||
foreach ($node->getRules() as $key => $rule) { |
|||
$name = $rule->getRule(); |
|||
$seen[$name] = true; |
|||
|
|||
if (!isset(self::$rules[$name])) { |
|||
$rules[] = $rule; |
|||
continue; |
|||
} |
|||
|
|||
foreach (self::$rules[$name] as $prefix) { |
|||
$newname = $prefix . $name; |
|||
if (isset($seen[$newname])) { |
|||
continue; |
|||
} |
|||
$newrule = clone $rule; |
|||
$newrule->setRule($newname); |
|||
$rules[] = $newrule; |
|||
} |
|||
|
|||
$rules[] = $rule; |
|||
} |
|||
|
|||
$node->setRules($this->manipulateRuleValues($rules)); |
|||
|
|||
if ($node instanceof DeclarationBlock) { |
|||
$selectors = $node->getSelectors(); |
|||
foreach ($selectors as $key => $selector) { |
|||
|
|||
$matches = []; |
|||
if (preg_match($this->pseudosregex, $selector->getSelector(), $matches)) { |
|||
|
|||
$newnode = clone $node; |
|||
foreach (self::$pseudos[$matches[1]] as $newpseudo) { |
|||
$newselector = new Selector(str_replace($matches[1], $newpseudo, $selector->getSelector())); |
|||
$selectors[$key] = $newselector; |
|||
$newnode = clone $node; |
|||
$newnode->setSelectors($selectors); |
|||
$parent->insert($newnode, $node); |
|||
} |
|||
|
|||
// We're only expecting one affected pseudo class per block. |
|||
break; |
|||
} |
|||
} |
|||
} |
|||
} |
|||
} |
@ -0,0 +1,50 @@ |
|||
<?php |
|||
// This file is part of Moodle - http://moodle.org/ |
|||
// |
|||
// Moodle 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 3 of the License, or |
|||
// (at your option) any later version. |
|||
// |
|||
// Moodle 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. |
|||
// |
|||
// You should have received a copy of the GNU General Public License |
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. |
|||
|
|||
/** |
|||
* Overriden block settings renderer. |
|||
* |
|||
* @package theme_ilb |
|||
* @copyright 2016 Frédéric Massart - FMCorz.net |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
|
|||
namespace theme_ilb\output; |
|||
defined('MOODLE_INTERNAL') || die(); |
|||
|
|||
require_once($CFG->dirroot . '/blocks/settings/renderer.php'); |
|||
|
|||
use moodle_url; |
|||
|
|||
/** |
|||
* Overriden block settings renderer. |
|||
* |
|||
* @package theme_ilb |
|||
* @copyright 2016 Frédéric Massart - FMCorz.net |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
class block_settings_renderer extends \block_settings_renderer { |
|||
|
|||
public function search_form(moodle_url $formtarget, $searchvalue) { |
|||
$data = [ |
|||
'action' => $formtarget->out(false), |
|||
'label' => get_string('searchinsettings', 'admin'), |
|||
'searchvalue' => $searchvalue |
|||
]; |
|||
return $this->render_from_template('block_settings/search_form', $data); |
|||
} |
|||
|
|||
} |
@ -0,0 +1,52 @@ |
|||
<?php |
|||
// This file is part of Moodle - http://moodle.org/ |
|||
// |
|||
// Moodle 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 3 of the License, or |
|||
// (at your option) any later version. |
|||
// |
|||
// Moodle 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. |
|||
// |
|||
// You should have received a copy of the GNU General Public License |
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. |
|||
|
|||
/** |
|||
* Admin renderer. |
|||
* |
|||
* @package theme_noanme |
|||
* @copyright 2016 Frédéric Massart - FMCorz.net |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
|
|||
namespace theme_ilb\output\core; |
|||
defined('MOODLE_INTERNAL') || die(); |
|||
|
|||
use moodle_url; |
|||
|
|||
require_once($CFG->dirroot . '/' . $CFG->admin . '/renderer.php'); |
|||
|
|||
/** |
|||
* Admin renderer class. |
|||
* |
|||
* @package theme_noanme |
|||
* @copyright 2016 Frédéric Massart - FMCorz.net |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
class admin_renderer extends \core_admin_renderer { |
|||
|
|||
/** |
|||
* Output a warning message. |
|||
* |
|||
* @param string $message the message to display. |
|||
* @param string $type type class |
|||
* @return string HTML to output. |
|||
*/ |
|||
protected function warning($message, $type = 'warning') { |
|||
return $this->box($message, 'generalbox m-b-1 admin' . $type); |
|||
} |
|||
|
|||
} |
@ -0,0 +1,81 @@ |
|||
<?php |
|||
// This file is part of Moodle - http://moodle.org/ |
|||
// |
|||
// Moodle 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 3 of the License, or |
|||
// (at your option) any later version. |
|||
// |
|||
// Moodle 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. |
|||
// |
|||
// You should have received a copy of the GNU General Public License |
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. |
|||
|
|||
/** |
|||
* Course renderer. |
|||
* |
|||
* @package theme_noanme |
|||
* @copyright 2016 Frédéric Massart - FMCorz.net |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
|
|||
namespace theme_ilb\output\core; |
|||
defined('MOODLE_INTERNAL') || die(); |
|||
|
|||
use moodle_url; |
|||
|
|||
require_once($CFG->dirroot . '/course/renderer.php'); |
|||
|
|||
/** |
|||
* Course renderer class. |
|||
* |
|||
* @package theme_noanme |
|||
* @copyright 2016 Frédéric Massart - FMCorz.net |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
class course_renderer extends \core_course_renderer { |
|||
|
|||
/** |
|||
* Renders html to display a course search form. |
|||
* |
|||
* @param string $value default value to populate the search field |
|||
* @param string $format display format - 'plain' (default), 'short' or 'navbar' |
|||
* @return string |
|||
*/ |
|||
public function course_search_form($value = '', $format = 'plain') { |
|||
static $count = 0; |
|||
$formid = 'coursesearch'; |
|||
if ((++$count) > 1) { |
|||
$formid .= $count; |
|||
} |
|||
|
|||
switch ($format) { |
|||
case 'navbar' : |
|||
$formid = 'coursesearchnavbar'; |
|||
$inputid = 'navsearchbox'; |
|||
$inputsize = 20; |
|||
break; |
|||
case 'short' : |
|||
$inputid = 'shortsearchbox'; |
|||
$inputsize = 12; |
|||
break; |
|||
default : |
|||
$inputid = 'coursesearchbox'; |
|||
$inputsize = 30; |
|||
} |
|||
|
|||
$data = (object) [ |
|||
'searchurl' => (new moodle_url('/course/search.php'))->out(false), |
|||
'id' => $formid, |
|||
'inputid' => $inputid, |
|||
'inputsize' => $inputsize, |
|||
'value' => $value |
|||
]; |
|||
|
|||
return $this->render_from_template('theme_ilb/course_search_form', $data); |
|||
} |
|||
|
|||
} |
@ -0,0 +1,140 @@ |
|||
<?php |
|||
// This file is part of Moodle - http://moodle.org/ |
|||
// |
|||
// Moodle 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 3 of the License, or |
|||
// (at your option) any later version. |
|||
// |
|||
// Moodle 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. |
|||
// |
|||
// You should have received a copy of the GNU General Public License |
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. |
|||
|
|||
namespace theme_ilb\output\core; |
|||
|
|||
use plugin_renderer_base; |
|||
|
|||
defined('MOODLE_INTERNAL') || die(); |
|||
|
|||
require_once($CFG->dirroot . '/files/renderer.php'); |
|||
|
|||
/** |
|||
* Rendering of files viewer related widgets. |
|||
* @package theme_ilb |
|||
* @copyright 2016 Damyon Wiese |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
|
|||
/** |
|||
* Rendering of files viewer related widgets. |
|||
* @package theme_ilb |
|||
* @copyright 2016 Damyon Wiese |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
class files_renderer extends \core_files_renderer { |
|||
/** |
|||
* FileManager JS template for window with file information/actions. |
|||
* |
|||
*/ |
|||
protected function fm_js_template_fileselectlayout() { |
|||
$context = [ |
|||
'helpicon' => $this->help_icon('setmainfile', 'repository') |
|||
]; |
|||
return $this->render_from_template('core/filemanager_fileselect', $context); |
|||
} |
|||
|
|||
/** |
|||
* FileManager JS template for popup confirm dialogue window. |
|||
* |
|||
* @return string |
|||
*/ |
|||
protected function fm_js_template_confirmdialog() { |
|||
return $this->render_from_template('core/filemanager_confirmdialog', []); |
|||
} |
|||
|
|||
/** |
|||
* Template for FilePicker with general layout (not QuickUpload). |
|||
* |
|||
* |
|||
* @return string |
|||
*/ |
|||
protected function fp_js_template_generallayout() { |
|||
return $this->render_from_template('core/filemanager_modal_generallayout', []); |
|||
} |
|||
|
|||
/** |
|||
* Returns html for displaying one file manager |
|||
* |
|||
* @param form_filemanager $fm |
|||
* @return string |
|||
*/ |
|||
protected function fm_print_generallayout($fm) { |
|||
$context = [ |
|||
'client_id' => $fm->options->client_id, |
|||
'helpicon' => $this->help_icon('setmainfile', 'repository'), |
|||
'restrictions' => $this->fm_print_restrictions($fm) |
|||
]; |
|||
return $this->render_from_template('core/filemanager_page_generallayout', $context); |
|||
} |
|||
|
|||
/** |
|||
* Returns HTML for default repository searchform to be passed to Filepicker |
|||
* |
|||
* This will be used as contents for search form defined in generallayout template |
|||
* (form with id {TOOLSEARCHID}). |
|||
* Default contents is one text input field with name="s" |
|||
*/ |
|||
public function repository_default_searchform() { |
|||
return $this->render_from_template('core/filemanager_default_searchform', []); |
|||
} |
|||
|
|||
/** |
|||
* FilePicker JS template for 'Upload file' repository |
|||
* |
|||
* @return string |
|||
*/ |
|||
protected function fp_js_template_uploadform() { |
|||
return $this->render_from_template('core/filemanager_uploadform', []); |
|||
} |
|||
|
|||
/** |
|||
* FilePicker JS template for repository login form including templates for each element type |
|||
* |
|||
* @return string |
|||
*/ |
|||
protected function fp_js_template_loginform() { |
|||
return $this->render_from_template('core/filemanager_loginform', []); |
|||
} |
|||
|
|||
/** |
|||
* FilePicker JS template for window appearing to select a file. |
|||
* |
|||
* @return string |
|||
*/ |
|||
protected function fp_js_template_selectlayout() { |
|||
return $this->render_from_template('core/filemanager_selectlayout', []); |
|||
} |
|||
|
|||
/** |
|||
* FilePicker JS template for popup dialogue window asking for action when file with the same name already exists |
|||
* (multiple-file version). |
|||
* |
|||
* @return string |
|||
*/ |
|||
protected function fp_js_template_processexistingfilemultiple() { |
|||
return $this->render_from_template('core/filemanager_processexistingfilemultiple', []); |
|||
} |
|||
|
|||
/** |
|||
* FilePicker JS template for popup dialogue window asking for action when file with the same name already exists. |
|||
* |
|||
* @return string |
|||
*/ |
|||
protected function fp_js_template_processexistingfile() { |
|||
return $this->render_from_template('core/filemanager_processexistingfile', []); |
|||
} |
|||
} |
@ -0,0 +1,773 @@ |
|||
<?php |
|||
// This file is part of Moodle - http://moodle.org/ |
|||
// |
|||
// Moodle 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 3 of the License, or |
|||
// (at your option) any later version. |
|||
// |
|||
// Moodle 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. |
|||
// |
|||
// You should have received a copy of the GNU General Public License |
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. |
|||
|
|||
namespace theme_ilb\output; |
|||
|
|||
use coding_exception; |
|||
use html_writer; |
|||
use tabobject; |
|||
use tabtree; |
|||
use custom_menu_item; |
|||
use custom_menu; |
|||
use block_contents; |
|||
use navigation_node; |
|||
use action_link; |
|||
use stdClass; |
|||
use moodle_url; |
|||
use preferences_groups; |
|||
use action_menu; |
|||
use help_icon; |
|||
use single_button; |
|||
use single_select; |
|||
use paging_bar; |
|||
use url_select; |
|||
use context_course; |
|||
use pix_icon; |
|||
|
|||
defined('MOODLE_INTERNAL') || die; |
|||
|
|||
/** |
|||
* Renderers to align Moodle's HTML with that expected by Bootstrap |
|||
* |
|||
* @package theme_ilb |
|||
* @copyright 2012 Bas Brands, www.basbrands.nl |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
|
|||
class core_renderer extends \core_renderer { |
|||
|
|||
/** @var custom_menu_item language The language menu if created */ |
|||
protected $language = null; |
|||
|
|||
/** |
|||
* Outputs the opening section of a box. |
|||
* |
|||
* @param string $classes A space-separated list of CSS classes |
|||
* @param string $id An optional ID |
|||
* @param array $attributes An array of other attributes to give the box. |
|||
* @return string the HTML to output. |
|||
*/ |
|||
public function box_start($classes = 'generalbox', $id = null, $attributes = array()) { |
|||
if (is_array($classes)) { |
|||
$classes = implode(' ', $classes); |
|||
} |
|||
return parent::box_start($classes . ' p-y-1', $id, $attributes); |
|||
} |
|||
|
|||
/** |
|||
* Wrapper for header elements. |
|||
* |
|||
* @return string HTML to display the main header. |
|||
*/ |
|||
public function full_header() { |
|||
global $PAGE; |
|||
|
|||
$html = html_writer::start_tag('header', array('id' => 'page-header', 'class' => 'row')); |
|||
$html .= html_writer::start_div('col-xs-12 p-a-1'); |
|||
$html .= html_writer::start_div('card'); |
|||
$html .= html_writer::start_div('card-block'); |
|||
$html .= html_writer::div($this->context_header_settings_menu(), 'pull-xs-right context-header-settings-menu'); |
|||
$html .= html_writer::start_div('pull-xs-left'); |
|||
$html .= $this->context_header(); |
|||
$html .= html_writer::end_div(); |
|||
$pageheadingbutton = $this->page_heading_button(); |
|||
if (empty($PAGE->layout_options['nonavbar'])) { |
|||
$html .= html_writer::start_div('clearfix w-100 pull-xs-left', array('id' => 'page-navbar')); |
|||
$html .= html_writer::tag('div', $this->navbar(), array('class' => 'breadcrumb-nav')); |
|||
$html .= html_writer::div($pageheadingbutton, 'breadcrumb-button pull-xs-right'); |
|||
$html .= html_writer::end_div(); |
|||
} else if ($pageheadingbutton) { |
|||
$html .= html_writer::div($pageheadingbutton, 'breadcrumb-button nonavbar pull-xs-right'); |
|||
} |
|||
$html .= html_writer::tag('div', $this->course_header(), array('id' => 'course-header')); |
|||
$html .= html_writer::end_div(); |
|||
$html .= html_writer::end_div(); |
|||
$html .= html_writer::end_div(); |
|||
$html .= html_writer::end_tag('header'); |
|||
return $html; |
|||
} |
|||
|
|||
/** |
|||
* The standard tags that should be included in the <head> tag |
|||
* including a meta description for the front page |
|||
* |
|||
* @return string HTML fragment. |
|||
*/ |
|||
public function standard_head_html() { |
|||
global $SITE, $PAGE; |
|||
|
|||
$output = parent::standard_head_html(); |
|||
if ($PAGE->pagelayout == 'frontpage') { |
|||
$summary = s(strip_tags(format_text($SITE->summary, FORMAT_HTML))); |
|||
if (!empty($summary)) { |
|||
$output .= "<meta name=\"description\" content=\"$summary\" />\n"; |
|||
} |
|||
} |
|||
|
|||
return $output; |
|||
} |
|||
|
|||
/* |
|||
* This renders the navbar. |
|||
* Uses bootstrap compatible html. |
|||
*/ |
|||
public function navbar() { |
|||
return $this->render_from_template('core/navbar', $this->page->navbar); |
|||
} |
|||
|
|||
/** |
|||
* We don't like these... |
|||
* |
|||
*/ |
|||
public function edit_button(moodle_url $url) { |
|||
return ''; |
|||
} |
|||
|
|||
/** |
|||
* Override to inject the logo. |
|||
* |
|||
* @param array $headerinfo The header info. |
|||
* @param int $headinglevel What level the 'h' tag will be. |
|||
* @return string HTML for the header bar. |
|||
*/ |
|||
public function context_header($headerinfo = null, $headinglevel = 1) { |
|||
global $SITE; |
|||
|
|||
if ($this->should_display_main_logo($headinglevel)) { |
|||
$sitename = format_string($SITE->fullname, true, array('context' => context_course::instance(SITEID))); |
|||
return html_writer::div(html_writer::empty_tag('img', [ |
|||
'src' => $this->get_logo_url(null, 150), 'alt' => $sitename]), 'logo'); |
|||
} |
|||
|
|||
return parent::context_header($headerinfo, $headinglevel); |
|||
} |
|||
|
|||
/** |
|||
* Get the compact logo URL. |
|||
* |
|||
* @return string |
|||
*/ |
|||
public function get_compact_logo_url($maxwidth = 100, $maxheight = 100) { |
|||
return parent::get_compact_logo_url(null, 70); |
|||
} |
|||
|
|||
/** |
|||
* Whether we should display the main logo. |
|||
* |
|||
* @return bool |
|||
*/ |
|||
public function should_display_main_logo($headinglevel = 1) { |
|||
global $PAGE; |
|||
|
|||
// Only render the logo if we're on the front page or login page and the we have a logo. |
|||
$logo = $this->get_logo_url(); |
|||
if ($headinglevel == 1 && !empty($logo)) { |
|||
if ($PAGE->pagelayout == 'frontpage' || $PAGE->pagelayout == 'login') { |
|||
return true; |
|||
} |
|||
} |
|||
|
|||
return false; |
|||
} |
|||
/** |
|||
* Whether we should display the logo in the navbar. |
|||
* |
|||
* We will when there are no main logos, and we have compact logo. |
|||
* |
|||
* @return bool |
|||
*/ |
|||
public function should_display_navbar_logo() { |
|||
$logo = $this->get_compact_logo_url(); |
|||
return !empty($logo) && !$this->should_display_main_logo(); |
|||
} |
|||
|
|||
/* |
|||
* Overriding the custom_menu function ensures the custom menu is |
|||
* always shown, even if no menu items are configured in the global |
|||
* theme settings page. |
|||
*/ |
|||
public function custom_menu($custommenuitems = '') { |
|||
global $CFG; |
|||
|
|||
if (empty($custommenuitems) && !empty($CFG->custommenuitems)) { |
|||
$custommenuitems = $CFG->custommenuitems; |
|||
} |
|||
$custommenu = new custom_menu($custommenuitems, current_language()); |
|||
return $this->render_custom_menu($custommenu); |
|||
} |
|||
|
|||
/** |
|||
* We want to show the custom menus as a list of links in the footer on small screens. |
|||
* Just return the menu object exported so we can render it differently. |
|||
*/ |
|||
public function custom_menu_flat() { |
|||
global $CFG; |
|||
$custommenuitems = ''; |
|||
|
|||
if (empty($custommenuitems) && !empty($CFG->custommenuitems)) { |
|||
$custommenuitems = $CFG->custommenuitems; |
|||
} |
|||
$custommenu = new custom_menu($custommenuitems, current_language()); |
|||
$langs = get_string_manager()->get_list_of_translations(); |
|||
$haslangmenu = $this->lang_menu() != ''; |
|||
|
|||
if ($haslangmenu) { |
|||
$strlang = get_string('language'); |
|||
$currentlang = current_language(); |
|||
if (isset($langs[$currentlang])) { |
|||
$currentlang = $langs[$currentlang]; |
|||
} else { |
|||
$currentlang = $strlang; |
|||
} |
|||
$this->language = $custommenu->add($currentlang, new moodle_url('#'), $strlang, 10000); |
|||
foreach ($langs as $langtype => $langname) { |
|||
$this->language->add($langname, new moodle_url($this->page->url, array('lang' => $langtype)), $langname); |
|||
} |
|||
} |
|||
|
|||
return $custommenu->export_for_template($this); |
|||
} |
|||
|
|||
/* |
|||
* This renders the bootstrap top menu. |
|||
* |
|||
* This renderer is needed to enable the Bootstrap style navigation. |
|||
*/ |
|||
protected function render_custom_menu(custom_menu $menu) { |
|||
global $CFG; |
|||
|
|||
$langs = get_string_manager()->get_list_of_translations(); |
|||
$haslangmenu = $this->lang_menu() != ''; |
|||
|
|||
if (!$menu->has_children() && !$haslangmenu) { |
|||
return ''; |
|||
} |
|||
|
|||
if ($haslangmenu) { |
|||
$strlang = get_string('language'); |
|||
$currentlang = current_language(); |
|||
if (isset($langs[$currentlang])) { |
|||
$currentlang = $langs[$currentlang]; |
|||
} else { |
|||
$currentlang = $strlang; |
|||
} |
|||
$this->language = $menu->add($currentlang, new moodle_url('#'), $strlang, 10000); |
|||
foreach ($langs as $langtype => $langname) { |
|||
$this->language->add($langname, new moodle_url($this->page->url, array('lang' => $langtype)), $langname); |
|||
} |
|||
} |
|||
|
|||
$content = ''; |
|||
foreach ($menu->get_children() as $item) { |
|||
$context = $item->export_for_template($this); |
|||
$content .= $this->render_from_template('core/custom_menu_item', $context); |
|||
} |
|||
|
|||
return $content; |
|||
} |
|||
|
|||
/** |
|||
* This code renders the navbar button to control the display of the custom menu |
|||
* on smaller screens. |
|||
* |
|||
* Do not display the button if the menu is empty. |
|||
* |
|||
* @return string HTML fragment |
|||
*/ |
|||
public function navbar_button() { |
|||
global $CFG; |
|||
|
|||
if (empty($CFG->custommenuitems) && $this->lang_menu() == '') { |
|||
return ''; |
|||
} |
|||
|
|||
$iconbar = html_writer::tag('span', '', array('class' => 'icon-bar')); |
|||
$button = html_writer::tag('a', $iconbar . "\n" . $iconbar. "\n" . $iconbar, array( |
|||
'class' => 'btn btn-navbar', |
|||
'data-toggle' => 'collapse', |
|||
'data-target' => '.nav-collapse' |
|||
)); |
|||
return $button; |
|||
} |
|||
|
|||
/** |
|||
* Renders tabtree |
|||
* |
|||
* @param tabtree $tabtree |
|||
* @return string |
|||
*/ |
|||
protected function render_tabtree(tabtree $tabtree) { |
|||
if (empty($tabtree->subtree)) { |
|||
return ''; |
|||
} |
|||
$data = $tabtree->export_for_template($this); |
|||
return $this->render_from_template('core/tabtree', $data); |
|||
} |
|||
|
|||
/** |
|||
* Renders tabobject (part of tabtree) |
|||
* |
|||
* This function is called from {@link core_renderer::render_tabtree()} |
|||
* and also it calls itself when printing the $tabobject subtree recursively. |
|||
* |
|||
* @param tabobject $tabobject |
|||
* @return string HTML fragment |
|||
*/ |
|||
protected function render_tabobject(tabobject $tab) { |
|||
throw new coding_exception('Tab objects should not be directly rendered.'); |
|||
} |
|||
|
|||
/** |
|||
* Prints a nice side block with an optional header. |
|||
* |
|||
* @param block_contents $bc HTML for the content |
|||
* @param string $region the region the block is appearing in. |
|||
* @return string the HTML to be output. |
|||
*/ |
|||
public function block(block_contents $bc, $region) { |
|||
$bc = clone($bc); // Avoid messing up the object passed in. |
|||
if (empty($bc->blockinstanceid) || !strip_tags($bc->title)) { |
|||
$bc->collapsible = block_contents::NOT_HIDEABLE; |
|||
} |
|||
|
|||
$id = !empty($bc->attributes['id']) ? $bc->attributes['id'] : uniqid('block-'); |
|||
$context = new stdClass(); |
|||
$context->skipid = $bc->skipid; |
|||
$context->blockinstanceid = $bc->blockinstanceid; |
|||
$context->dockable = $bc->dockable; |
|||
$context->id = $id; |
|||
$context->hidden = $bc->collapsible == block_contents::HIDDEN; |
|||
$context->skiptitle = strip_tags($bc->title); |
|||
$context->showskiplink = !empty($context->skiptitle); |
|||
$context->arialabel = $bc->arialabel; |
|||
$context->ariarole = !empty($bc->attributes['role']) ? $bc->attributes['role'] : 'complementary'; |
|||
$context->type = $bc->attributes['data-block']; |
|||
$context->title = $bc->title; |
|||
$context->content = $bc->content; |
|||
$context->annotation = $bc->annotation; |
|||
$context->footer = $bc->footer; |
|||
$context->hascontrols = !empty($bc->controls); |
|||
if ($context->hascontrols) { |
|||
$context->controls = $this->block_controls($bc->controls, $id); |
|||
} |
|||
|
|||
return $this->render_from_template('core/block', $context); |
|||
} |
|||
|
|||
/** |
|||
* Returns the CSS classes to apply to the body tag. |
|||
* |
|||
* @since Moodle 2.5.1 2.6 |
|||
* @param array $additionalclasses Any additional classes to apply. |
|||
* @return string |
|||
*/ |
|||
public function body_css_classes(array $additionalclasses = array()) { |
|||
return $this->page->bodyclasses . ' ' . implode(' ', $additionalclasses); |
|||
} |
|||
|
|||
/** |
|||
* Renders preferences groups. |
|||
* |
|||
* @param preferences_groups $renderable The renderable |
|||
* @return string The output. |
|||
*/ |
|||
public function render_preferences_groups(preferences_groups $renderable) { |
|||
return $this->render_from_template('core/preferences_groups', $renderable); |
|||
} |
|||
|
|||
/** |
|||
* Renders an action menu component. |
|||
* |
|||
* @param action_menu $menu |
|||
* @return string HTML |
|||
*/ |
|||
public function render_action_menu(action_menu $menu) { |
|||
|
|||
// We don't want the class icon there! |
|||
foreach ($menu->get_secondary_actions() as $action) { |
|||
if ($action instanceof \action_menu_link && $action->has_class('icon')) { |
|||
$action->attributes['class'] = preg_replace('/(^|\s+)icon(\s+|$)/i', '', $action->attributes['class']); |
|||
} |
|||
} |
|||
|
|||
if ($menu->is_empty()) { |
|||
return ''; |
|||
} |
|||
$context = $menu->export_for_template($this); |
|||
|
|||
// We do not want the icon with the caret, the caret is added by Bootstrap. |
|||
if (empty($context->primary->menutrigger)) { |
|||
$newurl = $this->pix_url('t/edit', 'moodle'); |
|||
$context->primary->icon['attributes'] = array_reduce($context->primary->icon['attributes'], |
|||
function($carry, $item) use ($newurl) { |
|||
if ($item['name'] === 'src') { |
|||
$item['value'] = $newurl->out(false); |
|||
} |
|||
$carry[] = $item; |
|||
return $carry; |
|||
}, [] |
|||
); |
|||
} |
|||
|
|||
return $this->render_from_template('core/action_menu', $context); |
|||
} |
|||
|
|||
/** |
|||
* Implementation of user image rendering. |
|||
* |
|||
* @param help_icon $helpicon A help icon instance |
|||
* @return string HTML fragment |
|||
*/ |
|||
protected function render_help_icon(help_icon $helpicon) { |
|||
$context = $helpicon->export_for_template($this); |
|||
return $this->render_from_template('core/help_icon', $context); |
|||
} |
|||
|
|||
/** |
|||
* Renders a single button widget. |
|||
* |
|||
* This will return HTML to display a form containing a single button. |
|||
* |
|||
* @param single_button $button |
|||
* @return string HTML fragment |
|||
*/ |
|||
protected function render_single_button(single_button $button) { |
|||
return $this->render_from_template('core/single_button', $button->export_for_template($this)); |
|||
} |
|||
|
|||
/** |
|||
* Renders a single select. |
|||
* |
|||
* @param single_select $select The object. |
|||
* @return string HTML |
|||
*/ |
|||
protected function render_single_select(single_select $select) { |
|||
return $this->render_from_template('core/single_select', $select->export_for_template($this)); |
|||
} |
|||
|
|||
/** |
|||
* Renders a paging bar. |
|||
* |
|||
* @param paging_bar $pagingbar The object. |
|||
* @return string HTML |
|||
*/ |
|||
protected function render_paging_bar(paging_bar $pagingbar) { |
|||
// Any more than 10 is not usable and causes wierd wrapping of the pagination in this theme. |
|||
$pagingbar->maxdisplay = 10; |
|||
return $this->render_from_template('core/paging_bar', $pagingbar->export_for_template($this)); |
|||
} |
|||
|
|||
/** |
|||
* Renders a url select. |
|||
* |
|||
* @param url_select $select The object. |
|||
* @return string HTML |
|||
*/ |
|||
protected function render_url_select(url_select $select) { |
|||
return $this->render_from_template('core/url_select', $select->export_for_template($this)); |
|||
} |
|||
|
|||
/** |
|||
* Renders a pix_icon widget and returns the HTML to display it. |
|||
* |
|||
* @param pix_icon $icon |
|||
* @return string HTML fragment |
|||
*/ |
|||
protected function render_pix_icon(pix_icon $icon) { |
|||
$data = $icon->export_for_template($this); |
|||
foreach ($data['attributes'] as $key => $item) { |
|||
$name = $item['name']; |
|||
$value = $item['value']; |
|||
if ($name == 'class') { |
|||
$data['extraclasses'] = $value; |
|||
unset($data['attributes'][$key]); |
|||
$data['attributes'] = array_values($data['attributes']); |
|||
break; |
|||
} |
|||
} |
|||
return $this->render_from_template('core/pix_icon', $data); |
|||
} |
|||
|
|||
/** |
|||
* Renders the login form. |
|||
* |
|||
* @param \core_auth\output\login $form The renderable. |
|||
* @return string |
|||
*/ |
|||
public function render_login(\core_auth\output\login $form) { |
|||
global $SITE; |
|||
|
|||
$context = $form->export_for_template($this); |
|||
|
|||
// Override because rendering is not supported in template yet. |
|||
$context->cookieshelpiconformatted = $this->help_icon('cookiesenabled'); |
|||
$context->errorformatted = $this->error_text($context->error); |
|||
$url = $this->get_logo_url(); |
|||
if ($url) { |
|||
$url = $url->out(false); |
|||
} |
|||
$context->logourl = $url; |
|||
$context->sitename = format_string($SITE->fullname, true, ['context' => context_course::instance(SITEID), "escape" => false]); |
|||
|
|||
return $this->render_from_template('core/login', $context); |
|||
} |
|||
|
|||
/** |
|||
* Render the login signup form into a nice template for the theme. |
|||
* |
|||
* @param mform $form |
|||
* @return string |
|||
*/ |
|||
public function render_login_signup_form($form) { |
|||
global $SITE; |
|||
|
|||
$context = $form->export_for_template($this); |
|||
$url = $this->get_logo_url(); |
|||
if ($url) { |
|||
$url = $url->out(false); |
|||
} |
|||
$context['logourl'] = $url; |
|||
$context['sitename'] = format_string($SITE->fullname, true, ['context' => context_course::instance(SITEID), "escape" => false]); |
|||
|
|||
return $this->render_from_template('core/signup_form_layout', $context); |
|||
} |
|||
|
|||
/** |
|||
* This is an optional menu that can be added to a layout by a theme. It contains the |
|||
* menu for the course administration, only on the course main page. |
|||
* |
|||
* @return string |
|||
*/ |
|||
public function context_header_settings_menu() { |
|||
$context = $this->page->context; |
|||
$menu = new action_menu(); |
|||
|
|||
$items = $this->page->navbar->get_items(); |
|||
$currentnode = end($items); |
|||
|
|||
$showcoursemenu = false; |
|||
$showfrontpagemenu = false; |
|||
$showusermenu = false; |
|||
|
|||
// We are on the course home page. |
|||
if (($context->contextlevel == CONTEXT_COURSE) && |
|||
!empty($currentnode) && |
|||
($currentnode->type == navigation_node::TYPE_COURSE || $currentnode->type == navigation_node::TYPE_SECTION)) { |
|||
$showcoursemenu = true; |
|||
} |
|||
|
|||
$courseformat = course_get_format($this->page->course); |
|||
// This is a single activity course format, always show the course menu on the activity main page. |
|||
if ($context->contextlevel == CONTEXT_MODULE && |
|||
!$courseformat->has_view_page()) { |
|||
|
|||
$this->page->navigation->initialise(); |
|||
$activenode = $this->page->navigation->find_active_node(); |
|||
// If the settings menu has been forced then show the menu. |
|||
if ($this->page->is_settings_menu_forced()) { |
|||
$showcoursemenu = true; |
|||
} else if (!empty($activenode) && ($activenode->type == navigation_node::TYPE_ACTIVITY || |
|||
$activenode->type == navigation_node::TYPE_RESOURCE)) { |
|||
|
|||
// We only want to show the menu on the first page of the activity. This means |
|||
// the breadcrumb has no additional nodes. |
|||
if ($currentnode && ($currentnode->key == $activenode->key && $currentnode->type == $activenode->type)) { |
|||
$showcoursemenu = true; |
|||
} |
|||
} |
|||
} |
|||
|
|||
// This is the site front page. |
|||
if ($context->contextlevel == CONTEXT_COURSE && |
|||
!empty($currentnode) && |
|||
$currentnode->key === 'home') { |
|||
$showfrontpagemenu = true; |
|||
} |
|||
|
|||
// This is the user profile page. |
|||
if ($context->contextlevel == CONTEXT_USER && |
|||
!empty($currentnode) && |
|||
($currentnode->key === 'myprofile')) { |
|||
$showusermenu = true; |
|||
} |
|||
|
|||
|
|||
if ($showfrontpagemenu) { |
|||
$settingsnode = $this->page->settingsnav->find('frontpage', navigation_node::TYPE_SETTING); |
|||
if ($settingsnode) { |
|||
// Build an action menu based on the visible nodes from this navigation tree. |
|||
$skipped = $this->build_action_menu_from_navigation($menu, $settingsnode, false, true); |
|||
|
|||
// We only add a list to the full settings menu if we didn't include every node in the short menu. |
|||
if ($skipped) { |
|||
$text = get_string('morenavigationlinks'); |
|||
$url = new moodle_url('/course/admin.php', array('courseid' => $this->page->course->id)); |
|||
$link = new action_link($url, $text, null, null, new pix_icon('t/edit', $text)); |
|||
$menu->add_secondary_action($link); |
|||
} |
|||
} |
|||
} else if ($showcoursemenu) { |
|||
$settingsnode = $this->page->settingsnav->find('courseadmin', navigation_node::TYPE_COURSE); |
|||
if ($settingsnode) { |
|||
// Build an action menu based on the visible nodes from this navigation tree. |
|||
$skipped = $this->build_action_menu_from_navigation($menu, $settingsnode, false, true); |
|||
|
|||
// We only add a list to the full settings menu if we didn't include every node in the short menu. |
|||
if ($skipped) { |
|||
$text = get_string('morenavigationlinks'); |
|||
$url = new moodle_url('/course/admin.php', array('courseid' => $this->page->course->id)); |
|||
$link = new action_link($url, $text, null, null, new pix_icon('t/edit', $text)); |
|||
$menu->add_secondary_action($link); |
|||
} |
|||
} |
|||
} else if ($showusermenu) { |
|||
// Get the course admin node from the settings navigation. |
|||
$settingsnode = $this->page->settingsnav->find('useraccount', navigation_node::TYPE_CONTAINER); |
|||
if ($settingsnode) { |
|||
// Build an action menu based on the visible nodes from this navigation tree. |
|||
$this->build_action_menu_from_navigation($menu, $settingsnode); |
|||
} |
|||
} |
|||
|
|||
return $this->render($menu); |
|||
} |
|||
|
|||
/** |
|||
* This is an optional menu that can be added to a layout by a theme. It contains the |
|||
* menu for the most specific thing from the settings block. E.g. Module administration. |
|||
* |
|||
* @return string |
|||
*/ |
|||
public function region_main_settings_menu() { |
|||
$context = $this->page->context; |
|||
$menu = new action_menu(); |
|||
|
|||
if ($context->contextlevel == CONTEXT_MODULE) { |
|||
|
|||
$this->page->navigation->initialise(); |
|||
$node = $this->page->navigation->find_active_node(); |
|||
$buildmenu = false; |
|||
// If the settings menu has been forced then show the menu. |
|||
if ($this->page->is_settings_menu_forced()) { |
|||
$buildmenu = true; |
|||
} else if (!empty($node) && ($node->type == navigation_node::TYPE_ACTIVITY || |
|||
$node->type == navigation_node::TYPE_RESOURCE)) { |
|||
|
|||
$items = $this->page->navbar->get_items(); |
|||
$navbarnode = end($items); |
|||
// We only want to show the menu on the first page of the activity. This means |
|||
// the breadcrumb has no additional nodes. |
|||
if ($navbarnode && ($navbarnode->key === $node->key && $navbarnode->type == $node->type)) { |
|||
$buildmenu = true; |
|||
} |
|||
} |
|||
if ($buildmenu) { |
|||
// Get the course admin node from the settings navigation. |
|||
$node = $this->page->settingsnav->find('modulesettings', navigation_node::TYPE_SETTING); |
|||
if ($node) { |
|||
// Build an action menu based on the visible nodes from this navigation tree. |
|||
$this->build_action_menu_from_navigation($menu, $node); |
|||
} |
|||
} |
|||
|
|||
} else if ($context->contextlevel == CONTEXT_COURSECAT) { |
|||
// For course category context, show category settings menu, if we're on the course category page. |
|||
if ($this->page->pagetype === 'course-index-category') { |
|||
$node = $this->page->settingsnav->find('categorysettings', navigation_node::TYPE_CONTAINER); |
|||
if ($node) { |
|||
// Build an action menu based on the visible nodes from this navigation tree. |
|||
$this->build_action_menu_from_navigation($menu, $node); |
|||
} |
|||
} |
|||
|
|||
} else { |
|||
$items = $this->page->navbar->get_items(); |
|||
$navbarnode = end($items); |
|||
|
|||
if ($navbarnode && ($navbarnode->key === 'participants')) { |
|||
$node = $this->page->settingsnav->find('users', navigation_node::TYPE_CONTAINER); |
|||
if ($node) { |
|||
// Build an action menu based on the visible nodes from this navigation tree. |
|||
$this->build_action_menu_from_navigation($menu, $node); |
|||
} |
|||
|
|||
} |
|||
} |
|||
return $this->render($menu); |
|||
} |
|||
|
|||
/** |
|||
* Take a node in the nav tree and make an action menu out of it. |
|||
* The links are injected in the action menu. |
|||
* |
|||
* @param action_menu $menu |
|||
* @param navigation_node $node |
|||
* @param boolean $indent |
|||
* @param boolean $onlytopleafnodes |
|||
* @return boolean nodesskipped - True if nodes were skipped in building the menu |
|||
*/ |
|||
private function build_action_menu_from_navigation(action_menu $menu, |
|||
navigation_node $node, |
|||
$indent = false, |
|||
$onlytopleafnodes = false) { |
|||
$skipped = false; |
|||
// Build an action menu based on the visible nodes from this navigation tree. |
|||
foreach ($node->children as $menuitem) { |
|||
if ($menuitem->display) { |
|||
if ($onlytopleafnodes && $menuitem->children->count()) { |
|||
$skipped = true; |
|||
continue; |
|||
} |
|||
if ($menuitem->action) { |
|||
if ($menuitem->action instanceof action_link) { |
|||
$link = $menuitem->action; |
|||
// Give preference to setting icon over action icon. |
|||
if (!empty($menuitem->icon)) { |
|||
$link->icon = $menuitem->icon; |
|||
} |
|||
} else { |
|||
$link = new action_link($menuitem->action, $menuitem->text, null, null, $menuitem->icon); |
|||
} |
|||
} else { |
|||
if ($onlytopleafnodes) { |
|||
$skipped = true; |
|||
continue; |
|||
} |
|||
$link = new action_link(new moodle_url('#'), $menuitem->text, null, ['disabled' => true], $menuitem->icon); |
|||
} |
|||
if ($indent) { |
|||
$link->add_class('m-l-1'); |
|||
} |
|||
if (!empty($menuitem->classes)) { |
|||
$link->add_class(implode(" ", $menuitem->classes)); |
|||
} |
|||
|
|||
$menu->add_secondary_action($link); |
|||
$skipped = $skipped || $this->build_action_menu_from_navigation($menu, $menuitem, true); |
|||
} |
|||
} |
|||
return $skipped; |
|||
} |
|||
|
|||
/** |
|||
* Secure login info. |
|||
* |
|||
* @return string |
|||
*/ |
|||
public function secure_login_info() { |
|||
return $this->login_info(false); |
|||
} |
|||
} |
@ -0,0 +1,197 @@ |
|||
<?php |
|||
// This file is part of Moodle - http://moodle.org/ |
|||
// |
|||
// Moodle 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 3 of the License, or |
|||
// (at your option) any later version. |
|||
// |
|||
// Moodle 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. |
|||
// |
|||
// You should have received a copy of the GNU General Public License |
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. |
|||
|
|||
|
|||
/** |
|||
* Overriden core maintenance renderer. |
|||
* |
|||
* @package theme_ilb |
|||
* @copyright 2016 Frédéric Massart - FMCorz.net |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
|
|||
namespace theme_ilb\output; |
|||
defined('MOODLE_INTERNAL') || die(); |
|||
|
|||
use coding_exception; |
|||
use moodle_page; |
|||
use block_contents; |
|||
use stdClass; |
|||
|
|||
/** |
|||
* The maintenance renderer. |
|||
* |
|||
* @package theme_ilb |
|||
* @copyright 2016 Frédéric Massart - FMCorz.net |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
class core_renderer_maintenance extends core_renderer { |
|||
|
|||
/** |
|||
* Initialises the renderer instance. |
|||
* |
|||
* @param moodle_page $page |
|||
* @param string $target |
|||
* @throws coding_exception |
|||
*/ |
|||
public function __construct(moodle_page $page, $target) { |
|||
if ($target !== RENDERER_TARGET_MAINTENANCE || $page->pagelayout !== 'maintenance') { |
|||
throw new coding_exception('Invalid request for the maintenance renderer.'); |
|||
} |
|||
parent::__construct($page, $target); |
|||
} |
|||
|
|||
/** |
|||
* Does nothing. The maintenance renderer cannot produce blocks. |
|||
* |
|||
* @param block_contents $bc |
|||
* @param string $region |
|||
* @return string |
|||
*/ |
|||
public function block(block_contents $bc, $region) { |
|||
return ''; |
|||
} |
|||
|
|||
/** |
|||
* Does nothing. The maintenance renderer cannot produce blocks. |
|||
* |
|||
* @param string $region |
|||
* @param array $classes |
|||
* @param string $tag |
|||
* @return string |
|||
*/ |
|||
public function blocks($region, $classes = array(), $tag = 'aside') { |
|||
return ''; |
|||
} |
|||
|
|||
/** |
|||
* Does nothing. The maintenance renderer cannot produce blocks. |
|||
* |
|||
* @param string $region |
|||
* @return string |
|||
*/ |
|||
public function blocks_for_region($region) { |
|||
return ''; |
|||
} |
|||
|
|||
/** |
|||
* Does nothing. The maintenance renderer cannot produce a course content header. |
|||
* |
|||
* @param bool $onlyifnotcalledbefore |
|||
* @return string |
|||
*/ |
|||
public function course_content_header($onlyifnotcalledbefore = false) { |
|||
return ''; |
|||
} |
|||
|
|||
/** |
|||
* Does nothing. The maintenance renderer cannot produce a course content footer. |
|||
* |
|||
* @param bool $onlyifnotcalledbefore |
|||
* @return string |
|||
*/ |
|||
public function course_content_footer($onlyifnotcalledbefore = false) { |
|||
return ''; |
|||
} |
|||
|
|||
/** |
|||
* Does nothing. The maintenance renderer cannot produce a course header. |
|||
* |
|||
* @return string |
|||
*/ |
|||
public function course_header() { |
|||
return ''; |
|||
} |
|||
|
|||
/** |
|||
* Does nothing. The maintenance renderer cannot produce a course footer. |
|||
* |
|||
* @return string |
|||
*/ |
|||
public function course_footer() { |
|||
return ''; |
|||
} |
|||
|
|||
/** |
|||
* Does nothing. The maintenance renderer cannot produce a custom menu. |
|||
* |
|||
* @param string $custommenuitems |
|||
* @return string |
|||
*/ |
|||
public function custom_menu($custommenuitems = '') { |
|||
return ''; |
|||
} |
|||
|
|||
/** |
|||
* Does nothing. The maintenance renderer cannot produce a file picker. |
|||
* |
|||
* @param array $options |
|||
* @return string |
|||
*/ |
|||
public function file_picker($options) { |
|||
return ''; |
|||
} |
|||
|
|||
/** |
|||
* Does nothing. The maintenance renderer cannot produce and HTML file tree. |
|||
* |
|||
* @param array $dir |
|||
* @return string |
|||
*/ |
|||
public function htmllize_file_tree($dir) { |
|||
return ''; |
|||
|
|||
} |
|||
|
|||
/** |
|||
* Does nothing. The maintenance renderer does not support JS. |
|||
* |
|||
* @param block_contents $bc |
|||
*/ |
|||
public function init_block_hider_js(block_contents $bc) { |
|||
// Does nothing. |
|||
} |
|||
|
|||
/** |
|||
* Does nothing. The maintenance renderer cannot produce language menus. |
|||
* |
|||
* @return string |
|||
*/ |
|||
public function lang_menu() { |
|||
return ''; |
|||
} |
|||
|
|||
/** |
|||
* Does nothing. The maintenance renderer has no need for login information. |
|||
* |
|||
* @param null $withlinks |
|||
* @return string |
|||
*/ |
|||
public function login_info($withlinks = null) { |
|||
return ''; |
|||
} |
|||
|
|||
/** |
|||
* Does nothing. The maintenance renderer cannot produce user pictures. |
|||
* |
|||
* @param stdClass $user |
|||
* @param array $options |
|||
* @return string |
|||
*/ |
|||
public function user_picture(stdClass $user, array $options = null) { |
|||
return ''; |
|||
} |
|||
} |
@ -0,0 +1,44 @@ |
|||
<?php |
|||
// This file is part of Moodle - http://moodle.org/ |
|||
// |
|||
// Moodle 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 3 of the License, or |
|||
// (at your option) any later version. |
|||
// |
|||
// Moodle 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. |
|||
// |
|||
// You should have received a copy of the GNU General Public License |
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. |
|||
|
|||
/** |
|||
* Overriden gradereport_history renderer. |
|||
* |
|||
* @package theme_ilb |
|||
* @copyright 2016 Frédéric Massart - FMCorz.net |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
|
|||
namespace theme_ilb\output; |
|||
defined('MOODLE_INTERNAL') || die(); |
|||
|
|||
use gradereport_history\output\user_button; |
|||
|
|||
/** |
|||
* Overriden gradereport_history renderer. |
|||
* |
|||
* @package theme_ilb |
|||
* @copyright 2016 Frédéric Massart - FMCorz.net |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
class gradereport_history_renderer extends \gradereport_history\output\renderer { |
|||
|
|||
public function render_user_button(user_button $button) { |
|||
$data = $button->export_for_template($this); |
|||
return $this->render_from_template('gradereport_history/user_button', $data); |
|||
} |
|||
|
|||
} |
@ -0,0 +1,265 @@ |
|||
<?php |
|||
// This file is part of Moodle - http://moodle.org/ |
|||
// |
|||
// Moodle 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 3 of the License, or |
|||
// (at your option) any later version. |
|||
// |
|||
// Moodle 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. |
|||
// |
|||
// You should have received a copy of the GNU General Public License |
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. |
|||
|
|||
/** |
|||
* Used to convert a bootswatch file from https://bootswatch.com/ to a Moodle preset. |
|||
* |
|||
* @package theme_ilb |
|||
* @subpackage cli |
|||
* @copyright 2016 Damyon Wiese |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
|
|||
define('CLI_SCRIPT', true); |
|||
|
|||
require(__DIR__.'/../../../config.php'); |
|||
require_once($CFG->libdir.'/clilib.php'); |
|||
|
|||
|
|||
// Now get cli options. |
|||
list($options, $unrecognized) = cli_get_params(array('help' => false), |
|||
array('h' => 'help', 'v' => 'variables', 'b' => 'bootswatch', 'p' => 'preset')); |
|||
|
|||
if ($unrecognized) { |
|||
$unrecognized = implode("\n ", $unrecognized); |
|||
cli_error(get_string('cliunknowoption', 'admin', $unrecognized)); |
|||
} |
|||
|
|||
if (!isset($options['variables'])) { |
|||
$options['variables'] = '_variables.scss'; |
|||
} |
|||
if (!isset($options['bootswatch'])) { |
|||
$options['bootswatch'] = '_bootswatch.scss'; |
|||
} |
|||
if (!isset($options['preset'])) { |
|||
$options['preset'] = 'preset.scss'; |
|||
} |
|||
|
|||
if ($options['help']) { |
|||
$help = "Convert a Bootswatch file from Bootstrap 3 to a Moodle preset file compatible with bootstrap 4. |
|||
|
|||
This scripts takes the scss files from a Bootstrap 3 Bootswatch and produces a Moodle compatible preset file. |
|||
|
|||
Options: |
|||
-h, --help Print out this help |
|||
-v, --variables=<variables file> |
|||
-b, --bootswatch=<bootswatch file> |
|||
-p, --preset=<preset file> |
|||
|
|||
Example: |
|||
\$import-bootswatch.php -v=_variables.scss -b=_bootswatch.scss -p=preset-paper.scss |
|||
"; |
|||
|
|||
echo $help; |
|||
die; |
|||
} |
|||
|
|||
cli_heading('Convert a Bootswatch file from Bootstrap 3 to a Moodle preset file compatible with bootstrap 4.'); |
|||
$variablesfile = $options['variables']; |
|||
$bootswatchfile = $options['bootswatch']; |
|||
$presetfile = $options['preset']; |
|||
|
|||
$sourcevariables = @file_get_contents($variablesfile); |
|||
if (!$sourcevariables) { |
|||
die('Could not read variables file: ' . $variablesfile . "\n"); |
|||
} |
|||
$sourcebootswatch = @file_get_contents($bootswatchfile); |
|||
if (!$sourcebootswatch) { |
|||
die('Could not read bootswatch file: ' . $bootswatchfile . "\n"); |
|||
} |
|||
|
|||
function str_replace_one($needle, $replace, $haystack) { |
|||
$pos = strpos($haystack, $needle); |
|||
if ($pos !== false) { |
|||
$newstring = substr_replace($haystack, $replace, $pos, strlen($needle)); |
|||
} |
|||
return $newstring; |
|||
} |
|||
|
|||
$out = @fopen($presetfile, "w"); |
|||
|
|||
if (!$out) { |
|||
die('Could not open preset file for writing: ' . $presetfile . "\n"); |
|||
} |
|||
|
|||
// Write the license (MIT). |
|||
|
|||
$license = <<<EOD |
|||
// |
|||
// The MIT License (MIT) |
|||
// |
|||
// Copyright (c) 2013 Thomas Park |
|||
// |
|||
// Permission is hereby granted, free of charge, to any person obtaining a copy |
|||
// of this software and associated documentation files (the "Software"), to deal |
|||
// in the Software without restriction, including without limitation the rights |
|||
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |
|||
// copies of the Software, and to permit persons to whom the Software is |
|||
// furnished to do so, subject to the following conditions: |
|||
// |
|||
// The above copyright notice and this permission notice shall be included in |
|||
// all copies or substantial portions of the Software. |
|||
// |
|||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
|||
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
|||
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |
|||
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
|||
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
|||
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN |
|||
// THE SOFTWARE. |
|||
// |
|||
|
|||
EOD; |
|||
|
|||
fwrite($out, $license); |
|||
|
|||
$workingvariables = $sourcevariables; |
|||
// Now start tweaking the variables strings. |
|||
|
|||
// Insert a lightest grey colour. |
|||
$newrule = '$gray-lightest: lighten($gray-lighter, 13.5%);'; |
|||
$nextline = '$brand-primary'; |
|||
$workingvariables = str_replace_one($nextline, "$newrule\n\n$nextline", $workingvariables); |
|||
|
|||
// Set body-color to text-color. |
|||
$newrule = '$body-color: $text-color;'; |
|||
$nextline = '//** Global textual link color.'; |
|||
$workingvariables = str_replace_one($nextline, "$newrule\n\n$nextline", $workingvariables); |
|||
|
|||
// Add a font-size-root the same as font-size-base. |
|||
$newrule = '$font-size-root: $font-size-base;'; |
|||
$nextline = '$font-size-large'; |
|||
$workingvariables = str_replace_one($nextline, "$newrule\n\n$nextline", $workingvariables); |
|||
|
|||
// Replace all 'large' with 'lg'. |
|||
$workingvariables = str_replace('large', 'lg', $workingvariables); |
|||
// Replace all 'small' with 'sm'. |
|||
$workingvariables = str_replace('small', 'sm', $workingvariables); |
|||
// Replace all 'vertical' with 'y'. |
|||
$workingvariables = str_replace('vertical', 'y', $workingvariables); |
|||
// Replace all 'horizontal' with 'x'. |
|||
$workingvariables = str_replace('horizontal', 'x', $workingvariables); |
|||
// Replace all 'border-radius-base' with 'border-radius'. |
|||
$workingvariables = str_replace('border-radius-base', 'border-radius', $workingvariables); |
|||
// Replace all 'condensed-cell' with 'sm-cell'. |
|||
$workingvariables = str_replace('condensed-cell', 'sm-cell', $workingvariables); |
|||
|
|||
|
|||
// Add styles for btn-secondary. |
|||
$newrule = '$btn-secondary-color: $btn-default-color; |
|||
$btn-secondary-bg: $btn-default-bg; |
|||
$btn-secondary-border: $btn-default-border; |
|||
|
|||
'; |
|||
$nextline = '$btn-primary-color'; |
|||
$workingvariables = str_replace_one($nextline, "$newrule\n\n$nextline", $workingvariables); |
|||
|
|||
// Add a input-border rule matching input-border-color. |
|||
$newrule = '$input-border-color: $input-border;'; |
|||
$nextline = '$input-border-radius:'; |
|||
$workingvariables = str_replace_one($nextline, "$newrule\n\n$nextline", $workingvariables); |
|||
// Replace all 'input-height-base:' with 'input-height:'. |
|||
$workingvariables = str_replace('input-height-base:', 'input-height:', $workingvariables); |
|||
|
|||
// Replace all '-default-' with '-light-'. |
|||
$workingvariables = str_replace('navbar-default-', 'navbar-light-', $workingvariables); |
|||
|
|||
// Replace all '-inverse-' with '-dark-'. |
|||
$workingvariables = str_replace('navbar-inverse-', 'navbar-dark-', $workingvariables); |
|||
|
|||
// Add a pagination-border-color rule matching pagination-border. |
|||
$newrule = '$pagination-border-color: $pagination-border;'; |
|||
$nextline = '$pagination-hover-color'; |
|||
$workingvariables = str_replace_one($nextline, "$newrule\n\n$nextline", $workingvariables); |
|||
|
|||
// Replace all 'label-' with 'tag-'. |
|||
$workingvariables = str_replace('label-', 'tag-', $workingvariables); |
|||
|
|||
// Replace all 'panel-' with 'card-'. |
|||
$workingvariables = str_replace('panel-', 'card-', $workingvariables); |
|||
|
|||
fwrite($out, $workingvariables); |
|||
|
|||
fwrite($out, ' |
|||
@import "moodle"; |
|||
'); |
|||
|
|||
// Now replacements on the bootswatch. |
|||
$workingbootswatch = $sourcebootswatch; |
|||
|
|||
$mixins = <<<EOD |
|||
|
|||
@mixin placeholder(\$text) { |
|||
placeholder: \$text; |
|||
} |
|||
@mixin box-shadow(\$text) { |
|||
box-shadow: \$text; |
|||
} |
|||
@mixin transform(\$transforms) { |
|||
transform: \$transforms; |
|||
} |
|||
@mixin rotate (\$deg) { |
|||
@include transform(rotate(#{\$deg}deg)); |
|||
} |
|||
@mixin scale(\$scale) { |
|||
@include transform(scale(\$scale)); |
|||
} |
|||
@mixin translate (\$x, \$y) { |
|||
@include transform(translate(\$x, \$y)); |
|||
} |
|||
@mixin skew (\$x, \$y) { |
|||
@include transform(skew(#{\$x}deg, #{\$y}deg)); |
|||
} |
|||
@mixin transform-origin (\$origin) { |
|||
transform-origin: \$origin; |
|||
} |
|||
|
|||
EOD; |
|||
// Prepend some mixins. |
|||
$workingbootswatch = $mixins . $workingbootswatch; |
|||
|
|||
// Replace all 'large' with 'lg'. |
|||
$workingbootswatch = str_replace('large', 'lg', $workingbootswatch); |
|||
// Replace all 'small' with 'sm'. |
|||
$workingbootswatch = str_replace('small', 'sm', $workingbootswatch); |
|||
// Replace all 'vertical' with 'y'. |
|||
$workingbootswatch = str_replace('vertical', 'y', $workingbootswatch); |
|||
// Replace all 'horizontal' with 'x'. |
|||
$workingbootswatch = str_replace('horizontal', 'x', $workingbootswatch); |
|||
// Replace all 'border-radius-base' with 'border-radius'. |
|||
$workingbootswatch = str_replace('border-radius-base', 'border-radius', $workingbootswatch); |
|||
// Replace all 'condensed-cell' with 'sm-cell'. |
|||
$workingbootswatch = str_replace('condensed-cell', 'sm-cell', $workingbootswatch); |
|||
|
|||
// Replace all 'input-height-base:' with 'input-height:'. |
|||
$workingbootswatch = str_replace('input-height-base:', 'input-height:', $workingbootswatch); |
|||
|
|||
// Replace all '-default-' with '-light-'. |
|||
$workingbootswatch = str_replace('navbar-default-', 'navbar-light-', $workingbootswatch); |
|||
|
|||
// Replace all '-inverse-' with '-dark-'. |
|||
$workingbootswatch = str_replace('navbar-inverse-', 'navbar-dark-', $workingbootswatch); |
|||
|
|||
// Replace all 'label-' with 'tag-'. |
|||
$workingbootswatch = str_replace('label-', 'tag-', $workingbootswatch); |
|||
|
|||
// Replace all 'panel-' with 'card-'. |
|||
$workingbootswatch = str_replace('panel-', 'card-', $workingbootswatch); |
|||
|
|||
fwrite($out, $workingbootswatch); |
|||
|
|||
fclose($out); |
|||
|
@ -0,0 +1,5 @@ |
|||
This CLI script can be used to convert a bootswatch file from https://bootswatch.com/ to a Moodle preset. |
|||
|
|||
To use it - download the _variables.scss and the _bootswatch.scss files for the chosen bootswatch into the current |
|||
folder and run "php import-bootswatch.php". This will generate a new file "preset.scss" which can be put |
|||
into the scss file as a Moodle preset. |
@ -0,0 +1,43 @@ |
|||
<?php |
|||
// This file is part of Moodle - http://moodle.org/ |
|||
// |
|||
// Moodle 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 3 of the License, or |
|||
// (at your option) any later version. |
|||
// |
|||
// Moodle 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. |
|||
// |
|||
// You should have received a copy of the GNU General Public License |
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. |
|||
|
|||
/** |
|||
* Language file. |
|||
* |
|||
* @package theme_ilb |
|||
* @copyright 2016 Frédéric Massart |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
|
|||
defined('MOODLE_INTERNAL') || die(); |
|||
|
|||
$string['advancedsettings'] = 'Advanced settings'; |
|||
$string['brandcolor'] = 'Brand colour'; |
|||
$string['brandcolor_desc'] = 'The accent colour.'; |
|||
$string['choosereadme'] = 'Ilb is a modern highly-customisable theme. This theme is intended to be used directly, or as a parent theme when creating new themes utilising Bootstrap 4.'; |
|||
$string['currentinparentheses'] = '(current)'; |
|||
$string['configtitle'] = 'Ilb'; |
|||
$string['generalsettings'] = 'General settings'; |
|||
$string['pluginname'] = 'Ilb'; |
|||
$string['presetfiles'] = 'Additional theme preset files'; |
|||
$string['presetfiles_desc'] = 'Preset files can be used to dramatically alter the appearance of the theme. See <a href=https://docs.moodle.org/dev/Ilb_Presets>Ilb presets</a> for information on creating and sharing your own preset files, and see the <a href=http://moodle.net/ilb>Presets repository</a> for presets that others have shared.'; |
|||
$string['preset'] = 'Theme preset'; |
|||
$string['preset_desc'] = 'Pick a preset to broadly change the look of the theme.'; |
|||
$string['rawscss'] = 'Raw SCSS'; |
|||
$string['rawscss_desc'] = 'Use this field to provide SCSS or CSS code which will be injected at the end of the style sheet.'; |
|||
$string['rawscsspre'] = 'Raw initial SCSS'; |
|||
$string['rawscsspre_desc'] = 'In this field you can provide initialising SCSS code, it will be injected before everything else. Most of the time you will use this setting to define variables.'; |
|||
$string['region-side-pre'] = 'Right'; |
@ -1,28 +0,0 @@ |
|||
<?php |
|||
// This file is part of Moodle - http://moodle.org/ |
|||
// |
|||
// Moodle 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 3 of the License, or |
|||
// (at your option) any later version. |
|||
// |
|||
// Moodle 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. |
|||
// |
|||
// You should have received a copy of the GNU General Public License |
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. |
|||
|
|||
/** |
|||
* Strings for component 'theme_ilb2014', language 'en'. |
|||
* |
|||
* @package theme_ilb2014 |
|||
* @copyright 2010 Patrick Malley |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
|
|||
$string['pluginname'] = 'ILB 2014 saberes theme'; |
|||
$string['region-side-post'] = 'Right'; |
|||
$string['region-side-pre'] = 'Left'; |
|||
$string['choosereadme'] = '<div class="clearfix"><div class="theme_screenshot"><h2>Leatherbound</h2><img src="ilb2014/pix/screenshot.jpg" /><h3>Theme Discussion Forum:</h3><p><a href="http://moodle.org/mod/forum/view.php?id=46">http://moodle.org/mod/forum/view.php?id=46</a></p><h3>Theme Credits</h3><p><a href="http://docs.moodle.org/en/Theme_credits">http://docs.moodle.org/en/Theme_credits</a></p><h3>Theme Documentation:</h3><p><a href="http://docs.moodle.org/en/Themes">http://docs.moodle.org/en/Themes</a></p><h3>Report a bug:</h3><p><a href="http://tracker.moodle.org">http://tracker.moodle.org</a></p></div><div class="theme_description"><h2>About</h2><p>Leatherbound is a fluid-width, three-column theme for Moodle 2.0 that was created by Patrick Malley.<h2>Tweaks</h2><p>This theme is built upon both Base and Canvas, two parent themes included in the Moodle core. If you want to modify this theme, we recommend that you first duplicate it then rename it before making your changes. This will prevent your customized theme from being overwritten by future Moodle upgrades, and you\'ll still have the original files if you make a mess. More information on modifying themes can be found in the <a href="http://docs.moodle.org/en/Theme">MoodleDocs</a>.</p><h2>Credits</h2><p>This theme was coded and is maintained by Patrick Malley of NewSchool Learning. He can be contacted by email at contact@newschoollearning.com. </p><h2>License</h2><p>This, and all other themes included in the Moodle core, are licensed under the <a href="http://www.gnu.org/licenses/gpl.html">GNU General Public License</a>.</div></div>'; |
@ -0,0 +1,39 @@ |
|||
<?php |
|||
// This file is part of Moodle - http://moodle.org/ |
|||
// |
|||
// Moodle 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 3 of the License, or |
|||
// (at your option) any later version. |
|||
// |
|||
// Moodle 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. |
|||
// |
|||
// You should have received a copy of the GNU General Public License |
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. |
|||
|
|||
/** |
|||
* A one column layout for the ilb theme. |
|||
* |
|||
* @package theme_ilb |
|||
* @copyright 2016 Damyon Wiese |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
|
|||
defined('MOODLE_INTERNAL') || die(); |
|||
|
|||
require_once($CFG->libdir . '/../config.php'); |
|||
|
|||
$bodyattributes = $OUTPUT->body_attributes([]); |
|||
|
|||
$templatecontext = [ |
|||
'sitename' => format_string($SITE->shortname, true, ['context' => context_course::instance(SITEID), "escape" => false]), |
|||
'output' => $OUTPUT, |
|||
'bodyattributes' => $bodyattributes, |
|||
'moodle_url' => $CFG->wwwroot |
|||
]; |
|||
|
|||
echo $OUTPUT->render_from_template('theme_ilb/columns1', $templatecontext); |
|||
|
@ -0,0 +1,57 @@ |
|||
<?php |
|||
// This file is part of Moodle - http://moodle.org/ |
|||
// |
|||
// Moodle 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 3 of the License, or |
|||
// (at your option) any later version. |
|||
// |
|||
// Moodle 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. |
|||
// |
|||
// You should have received a copy of the GNU General Public License |
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. |
|||
|
|||
/** |
|||
* A two column layout for the ilb theme. |
|||
* |
|||
* @package theme_ilb |
|||
* @copyright 2016 Damyon Wiese |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
|
|||
defined('MOODLE_INTERNAL') || die(); |
|||
|
|||
user_preference_allow_ajax_update('drawer-open-nav', PARAM_ALPHA); |
|||
require_once($CFG->libdir . '/behat/lib.php'); |
|||
require_once($CFG->libdir . '/../config.php'); |
|||
|
|||
if (isloggedin()) { |
|||
$navdraweropen = (get_user_preferences('drawer-open-nav', 'true') == 'true'); |
|||
} else { |
|||
$navdraweropen = false; |
|||
} |
|||
$extraclasses = []; |
|||
if ($navdraweropen) { |
|||
$extraclasses[] = 'drawer-open-left'; |
|||
} |
|||
$bodyattributes = $OUTPUT->body_attributes($extraclasses); |
|||
$blockshtml = $OUTPUT->blocks('side-pre'); |
|||
$hasblocks = strpos($blockshtml, 'data-block=') !== false; |
|||
$regionmainsettingsmenu = $OUTPUT->region_main_settings_menu(); |
|||
$templatecontext = [ |
|||
'sitename' => format_string($SITE->shortname, true, ['context' => context_course::instance(SITEID), "escape" => false]), |
|||
'output' => $OUTPUT, |
|||
'sidepreblocks' => $blockshtml, |
|||
'hasblocks' => $hasblocks, |
|||
'bodyattributes' => $bodyattributes, |
|||
'navdraweropen' => $navdraweropen, |
|||
'regionmainsettingsmenu' => $regionmainsettingsmenu, |
|||
'hasregionmainsettingsmenu' => !empty($regionmainsettingsmenu), |
|||
'moodle_url' => $CFG->wwwroot |
|||
]; |
|||
|
|||
$templatecontext['flatnavigation'] = $PAGE->flatnav; |
|||
echo $OUTPUT->render_from_template('theme_ilb/columns2', $templatecontext); |
@ -1,165 +0,0 @@ |
|||
<?php |
|||
|
|||
$hasheading = ($PAGE->heading); |
|||
$hasnavbar = (empty($PAGE->layout_options['nonavbar']) && $PAGE->has_navbar()); |
|||
$hasfooter = (empty($PAGE->layout_options['nofooter'])); |
|||
$hassidepre = $PAGE->blocks->region_has_content('side-pre', $OUTPUT); |
|||
$hassidepost = $PAGE->blocks->region_has_content('side-post', $OUTPUT); |
|||
$custommenu = $OUTPUT->custom_menu(); |
|||
$hascustommenu = (empty($PAGE->layout_options['nocustommenu']) && !empty($custommenu)); |
|||
|
|||
$courseheader = $coursecontentheader = $coursecontentfooter = $coursefooter = ''; |
|||
if (empty($PAGE->layout_options['nocourseheaderfooter'])) { |
|||
$courseheader = $OUTPUT->course_header(); |
|||
$coursecontentheader = $OUTPUT->course_content_header(); |
|||
if (empty($PAGE->layout_options['nocoursefooter'])) { |
|||
$coursecontentfooter = $OUTPUT->course_content_footer(); |
|||
$coursefooter = $OUTPUT->course_footer(); |
|||
} |
|||
} |
|||
|
|||
$bodyclasses = array(); |
|||
if ($hassidepre && !$hassidepost) { |
|||
$bodyclasses[] = 'side-pre-only'; |
|||
} else if ($hassidepost && !$hassidepre) { |
|||
$bodyclasses[] = 'side-post-only'; |
|||
} else if (!$hassidepost && !$hassidepre) { |
|||
$bodyclasses[] = 'content-only'; |
|||
} |
|||
if ($hascustommenu) { |
|||
$bodyclasses[] = 'has_custom_menu'; |
|||
} |
|||
|
|||
echo $OUTPUT->doctype() ?> |
|||
<html <?php echo $OUTPUT->htmlattributes() ?>> |
|||
<head> |
|||
<title><?php echo $PAGE->title ?></title> |
|||
<link rel="shortcut icon" href="<?php echo $OUTPUT->pix_url('favicon', 'theme')?>" /> |
|||
<?php echo $OUTPUT->standard_head_html() ?> |
|||
</head> |
|||
|
|||
<body id="<?php p($PAGE->bodyid) ?>" class="<?php p($PAGE->bodyclasses.' '.join(' ', $bodyclasses)) ?>"> |
|||
<?php echo $OUTPUT->standard_top_of_body_html() ?> |
|||
|
|||
<div id="page"> |
|||
<?php require_once "topo.php" ?> |
|||
|
|||
|
|||
<?php if ($hasheading) { ?> |
|||
<div id="page-header"> |
|||
<div id="page-header-wrapper" class="wrapper clearfix"> |
|||
<div class="course-logo-wrapper"> |
|||
<a href="<?php echo $CFG->wwwroot; ?>" title="<?php print_string('home'); ?>"> |
|||
<img src="<?php echo $OUTPUT->pix_url('logo-saberes', 'theme')?>" class="course-logo-header"> |
|||
</a> |
|||
</div> |
|||
<div class="heading-wrapper"> |
|||
<h1 class="headermain inside"><?php echo $PAGE->heading ?></h1> |
|||
</div> |
|||
<div class="headermenu"> |
|||
<?php |
|||
echo $OUTPUT->login_info(); |
|||
if (!empty($PAGE->layout_options['langmenu'])) { |
|||
echo $OUTPUT->lang_menu(); |
|||
} |
|||
echo $PAGE->headingmenu |
|||
?> |
|||
<div class="header-banners"> |
|||
<a href="http://www.interlegis.leg.br" target="_blank"> |
|||
<img src="<?php echo $OUTPUT->pix_url('logo-interlegis', 'theme')?>"> |
|||
</a> |
|||
<a href="http://www12.senado.gov.br/senado/ilb" target="_blank"> |
|||
<img src="<?php echo $OUTPUT->pix_url('logo-ilb', 'theme')?>"> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<?php } ?> |
|||
|
|||
<?php if ($hascustommenu) { ?> |
|||
<div id="custommenuwrap"><div id="custommenu"><?php echo $custommenu; ?></div></div> |
|||
<?php } ?> |
|||
|
|||
<?php if (!empty($courseheader)) { ?> |
|||
<div id="course-header"><?php echo $courseheader; ?></div> |
|||
<?php } ?> |
|||
|
|||
<?php if ($hasnavbar) { ?> |
|||
<div class="navbar"> |
|||
<div class="wrapper clearfix"> |
|||
<div class="breadcrumb"><?php echo $OUTPUT->navbar(); ?></div> |
|||
<div class="navbutton"> <?php echo $PAGE->button; ?></div> |
|||
</div> |
|||
</div> |
|||
<?php } ?> |
|||
|
|||
<!-- END OF HEADER --> |
|||
<div id="page-content-wrapper" class="wrapper clearfix"> |
|||
<div id="page-content"> |
|||
<div id="region-main-box"> |
|||
<div id="region-post-box"> |
|||
|
|||
<div id="region-main-wrap"> |
|||
<div id="region-main"> |
|||
<div class="region-content"> |
|||
<?php echo $coursecontentheader; ?> |
|||
<?php echo $OUTPUT->main_content() ?> |
|||
<?php echo $coursecontentfooter; ?> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
|
|||
<?php if ($hassidepre) { ?> |
|||
<div id="region-pre" class="block-region"> |
|||
<div class="region-content"> |
|||
<?php echo $OUTPUT->blocks_for_region('side-pre') ?> |
|||
</div> |
|||
</div> |
|||
<?php } ?> |
|||
|
|||
<?php if ($hassidepost) { ?> |
|||
<div id="region-post" class="block-region"> |
|||
<div class="region-content"> |
|||
<?php echo $OUTPUT->blocks_for_region('side-post') ?> |
|||
</div> |
|||
</div> |
|||
<?php } ?> |
|||
|
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
|
|||
<?php if (!empty($coursefooter)) { ?> |
|||
<div id="course-footer"><?php echo $coursefooter; ?></div> |
|||
<?php } ?> |
|||
|
|||
<!-- START OF FOOTER --> |
|||
<?php if ($hasfooter) { ?> |
|||
<div id="page-footer"> |
|||
<p class="helplink"><?php echo page_doc_link(get_string('moodledocslink')) ?></p> |
|||
<?php |
|||
echo $OUTPUT->login_info(); |
|||
//echo $OUTPUT->home_link(); |
|||
echo $OUTPUT->standard_footer_html(); |
|||
?> |
|||
<div class="footer-senado"> |
|||
<span class="vertical-helper"></span> |
|||
<div class="footer-left"> |
|||
</div> |
|||
<div class="footer-center"> |
|||
<span>Senado Federal - Praça dos Três Poderes - Brasília DF - CEP 70165-900</span> |
|||
</div> |
|||
<div class="footer-right"> |
|||
<a href="http://www.moodle.org" target="_blank"> |
|||
<img src="<?php echo $OUTPUT->pix_url('logo-moodle', 'theme')?>" class="logo-footer-right"> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<?php } ?> |
|||
</div> |
|||
<?php echo $OUTPUT->standard_end_of_body_html() ?> |
|||
</body> |
|||
</html> |
@ -0,0 +1,32 @@ |
|||
<?php |
|||
// This file is part of Moodle - http://moodle.org/ |
|||
// |
|||
// Moodle 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 3 of the License, or |
|||
// (at your option) any later version. |
|||
// |
|||
// Moodle 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. |
|||
// |
|||
// You should have received a copy of the GNU General Public License |
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. |
|||
|
|||
/** |
|||
* An embedded layout for the ilb theme. |
|||
* |
|||
* @package theme_ilb |
|||
* @copyright 2016 Damyon Wiese |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
|
|||
defined('MOODLE_INTERNAL') || die(); |
|||
|
|||
$templatecontext = [ |
|||
'sitename' => format_string($SITE->shortname, true, ['context' => context_course::instance(SITEID), "escape" => false]), |
|||
'output' => $OUTPUT |
|||
]; |
|||
|
|||
echo $OUTPUT->render_from_template('theme_ilb/embedded', $templatecontext); |
@ -1,152 +0,0 @@ |
|||
<?php |
|||
|
|||
$hasheading = ($PAGE->heading); |
|||
$hasnavbar = (empty($PAGE->layout_options['nonavbar']) && $PAGE->has_navbar()); |
|||
$hasfooter = (empty($PAGE->layout_options['nofooter'])); |
|||
|
|||
$hassidepre = $PAGE->blocks->region_has_content('side-pre', $OUTPUT); |
|||
$hassidepost = $PAGE->blocks->region_has_content('side-post', $OUTPUT); |
|||
|
|||
$showsidepre = ($hassidepre && !$PAGE->blocks->region_completely_docked('side-pre', $OUTPUT)); |
|||
$showsidepost = ($hassidepost && !$PAGE->blocks->region_completely_docked('side-post', $OUTPUT)); |
|||
$custommenu = $OUTPUT->custom_menu(); |
|||
$hascustommenu = (empty($PAGE->layout_options['nocustommenu']) && !empty($custommenu)); |
|||
|
|||
$bodyclasses = array(); |
|||
if ($showsidepre && !$showsidepost) { |
|||
$bodyclasses[] = 'side-pre-only'; |
|||
} else if ($showsidepost && !$showsidepre) { |
|||
$bodyclasses[] = 'side-post-only'; |
|||
} else if (!$showsidepost && !$showsidepre) { |
|||
$bodyclasses[] = 'content-only'; |
|||
} |
|||
if ($hascustommenu) { |
|||
$bodyclasses[] = 'has_custom_menu'; |
|||
} |
|||
|
|||
echo $OUTPUT->doctype() ?> |
|||
<html <?php echo $OUTPUT->htmlattributes() ?>> |
|||
<head> |
|||
<title><?php echo $PAGE->title ?></title> |
|||
<link rel="shortcut icon" href="<?php echo $OUTPUT->pix_url('favicon', 'theme')?>" /> |
|||
<meta name="description" content="<?php p(strip_tags(format_text($SITE->summary, FORMAT_HTML))) ?>" /> |
|||
<?php echo $OUTPUT->standard_head_html() ?> |
|||
</head> |
|||
|
|||
<body id="<?php p($PAGE->bodyid) ?>" class="<?php p($PAGE->bodyclasses.' '.join(' ', $bodyclasses)) ?>"> |
|||
<?php echo $OUTPUT->standard_top_of_body_html() ?> |
|||
|
|||
<div id="page"> |
|||
<?php require_once "topo.php" ?> |
|||
<!-- START OF HEADER --> |
|||
<div id="page-header"> |
|||
<div id="page-header-wrapper" class="wrapper clearfix"> |
|||
<div class="logo-wrapper"> |
|||
<a href="<?php echo $CFG->wwwroot; ?>" title="<?php print_string('home'); ?>"> |
|||
<img src="<?php echo $OUTPUT->pix_url('logo-saberes', 'theme')?>" class="logo-header"> |
|||
</a> |
|||
</div> |
|||
<div class="headermenu"> |
|||
<?php |
|||
echo $OUTPUT->login_info(); |
|||
if (!empty($PAGE->layout_options['langmenu'])) { |
|||
echo $OUTPUT->lang_menu(); |
|||
} |
|||
echo $PAGE->headingmenu |
|||
?> |
|||
<div class="header-banners"> |
|||
<a href="http://www.interlegis.leg.br" target="_blank"> |
|||
<img src="<?php echo $OUTPUT->pix_url('logo-interlegis', 'theme')?>"> |
|||
</a> |
|||
<a href="http://www12.senado.gov.br/senado/ilb" target="_blank"> |
|||
<img src="<?php echo $OUTPUT->pix_url('logo-ilb', 'theme')?>"> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
|
|||
</div> |
|||
</div> |
|||
|
|||
<!-- END OF HEADER --> |
|||
|
|||
<?php if ($hascustommenu) { ?> |
|||
<div id="custommenuwrap"><div id="custommenu"><?php echo $custommenu; ?></div></div> |
|||
<?php } ?> |
|||
|
|||
<!-- START OF CONTENT --> |
|||
|
|||
<div id="page-content-wrapper" class="wrapper clearfix"> |
|||
|
|||
|
|||
|
|||
|
|||
<div id="page-content"> |
|||
<div id="region-main-box"> |
|||
<div id="region-post-box"> |
|||
|
|||
<div id="region-main-wrap"> |
|||
<div id="region-main"> |
|||
<div class="region-content"> |
|||
<?php echo $OUTPUT->main_content() ?> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
|
|||
<?php if ($hassidepre) { ?> |
|||
<div id="region-pre" class="block-region"> |
|||
<div class="region-content"> |
|||
<?php echo $OUTPUT->blocks_for_region('side-pre') ?> |
|||
</div> |
|||
</div> |
|||
<?php } ?> |
|||
|
|||
<?php if ($hassidepost) { ?> |
|||
<div id="region-post" class="block-region"> |
|||
<div class="region-content"> |
|||
<?php echo $OUTPUT->blocks_for_region('side-post') ?> |
|||
</div> |
|||
</div> |
|||
<?php } ?> |
|||
|
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
|
|||
<!-- END OF CONTENT --> |
|||
|
|||
<!-- START OF FOOTER --> |
|||
|
|||
<div id="page-footer"> |
|||
<p class="helplink"> |
|||
<?php echo page_doc_link(get_string('moodledocslink')) ?> |
|||
</p> |
|||
<?php |
|||
echo $OUTPUT->login_info(); |
|||
//echo $OUTPUT->home_link(); |
|||
echo $OUTPUT->standard_footer_html(); |
|||
?> |
|||
<div class="footer-senado"> |
|||
<span class="vertical-helper"></span> |
|||
<div class="footer-left"> |
|||
</div> |
|||
<div class="footer-center"> |
|||
<span>Senado Federal - Praça dos Três Poderes - Brasília DF - CEP 70165-900</span> |
|||
</div> |
|||
<div class="footer-right"> |
|||
<a href="http://www.moodle.org" target="_blank"> |
|||
<img src="<?php echo $OUTPUT->pix_url('logo-moodle', 'theme')?>" class="logo-footer-right"> |
|||
</a> |
|||
</div> |
|||
|
|||
</div> |
|||
|
|||
</div> |
|||
|
|||
<!-- END OF FOOTER --> |
|||
|
|||
</div> |
|||
<?php echo $OUTPUT->standard_end_of_body_html() ?> |
|||
</body> |
|||
</html> |
@ -0,0 +1,106 @@ |
|||
<?php |
|||
// This file is part of Moodle - http://moodle.org/ |
|||
// |
|||
// Moodle 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 3 of the License, or |
|||
// (at your option) any later version. |
|||
// |
|||
// Moodle 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. |
|||
// |
|||
// You should have received a copy of the GNU General Public License |
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. |
|||
|
|||
/** |
|||
* A one column layout for the ilb theme. |
|||
* |
|||
* @package theme_ilb |
|||
* @copyright 2016 Damyon Wiese |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
|
|||
defined('MOODLE_INTERNAL') || die(); |
|||
|
|||
require_once($CFG->libdir . '/../config.php'); |
|||
|
|||
if (isloggedin()) { |
|||
user_preference_allow_ajax_update('drawer-open-nav', PARAM_ALPHA); |
|||
require_once($CFG->libdir . '/behat/lib.php'); |
|||
|
|||
$navdraweropen = (get_user_preferences('drawer-open-nav', 'true') == 'true'); |
|||
$extraclasses = []; |
|||
if ($navdraweropen) { |
|||
$extraclasses[] = 'drawer-open-left'; |
|||
} |
|||
//$bodyattributes = $OUTPUT->body_attributes($extraclasses); |
|||
$blockshtml = $OUTPUT->blocks('side-pre'); |
|||
$hasblocks = strpos($blockshtml, 'data-block=') !== false; |
|||
$regionmainsettingsmenu = $OUTPUT->region_main_settings_menu(); |
|||
|
|||
//$user_picture = false; |
|||
//if ($user->picture) { |
|||
//$user_picture = get_file_url($USER->id.'/'.$size['large'].'.jpg', null, 'user'); |
|||
//} |
|||
global $USER,$PAGE; |
|||
$user_picture=new user_picture($USER); |
|||
$user_picture_url=$user_picture->get_url($PAGE); |
|||
$user_profile_url=$CFG->wwwroot . "/user/profile.php?id=" . $USER->id . "&course=1"; |
|||
|
|||
|
|||
switch($USER->profile['situacaoaluno']) |
|||
{ |
|||
case '1': |
|||
$cpf1 = 'cpf1'; |
|||
break; |
|||
case '2': |
|||
$cpf2 = 'cpf2'; |
|||
break; |
|||
case '3': |
|||
$cpf3 = 'cpf3'; |
|||
break; |
|||
} |
|||
|
|||
$templatecontext = [ |
|||
'sitename' => format_string($SITE->shortname, true, ['context' => context_course::instance(SITEID), "escape" => false]), |
|||
'output' => $OUTPUT, |
|||
'sidepreblocks' => $blockshtml, |
|||
'hasblocks' => $hasblocks, |
|||
'bodyattributes' => $bodyattributes, |
|||
'navdraweropen' => $navdraweropen, |
|||
'regionmainsettingsmenu' => $regionmainsettingsmenu, |
|||
'hasregionmainsettingsmenu' => !empty($regionmainsettingsmenu), |
|||
'username' => $USER->username, |
|||
'firstname' => $USER->firstname, |
|||
'lastname' => $USER->lastname, |
|||
'sessKey' => $USER->sesskey, |
|||
'cpf1' => $cpf1, |
|||
'cpf2' => $cpf2, |
|||
'cpf3' => $cpf3, |
|||
'loginChangeNotification' => false, |
|||
'moodle_url' => $CFG->wwwroot, |
|||
'userpictureurl' => $user_picture_url, |
|||
'userprofileurl' => $user_profile_url, |
|||
]; |
|||
|
|||
$templatecontext['flatnavigation'] = $PAGE->flatnav; |
|||
// echo $OUTPUT->render_from_template('theme_ilb/frontpage_ilblogado', $templatecontext); |
|||
//echo $OUTPUT->render_from_template('theme_ilb/columns2', $templatecontext); |
|||
echo $OUTPUT->render_from_template('theme_ilb/frontpage_ilb', $templatecontext); |
|||
|
|||
} else { |
|||
$bodyattributes = $OUTPUT->body_attributes([]); |
|||
|
|||
$templatecontext = [ |
|||
'sitename' => format_string($SITE->shortname, true, ['context' => context_course::instance(SITEID), "escape" => false]), |
|||
'output' => $OUTPUT, |
|||
'bodyattributes' => $bodyattributes, |
|||
'moodle_url' => $CFG->wwwroot |
|||
]; |
|||
|
|||
|
|||
|
|||
echo $OUTPUT->render_from_template('theme_ilb/frontpage_ilb', $templatecontext); |
|||
} |
@ -1,162 +0,0 @@ |
|||
<?php |
|||
|
|||
$hasheading = ($PAGE->heading); |
|||
$hasnavbar = (empty($PAGE->layout_options['nonavbar']) && $PAGE->has_navbar()); |
|||
$hasfooter = (empty($PAGE->layout_options['nofooter'])); |
|||
$hassidepre = $PAGE->blocks->region_has_content('side-pre', $OUTPUT); |
|||
$hassidepost = $PAGE->blocks->region_has_content('side-post', $OUTPUT); |
|||
$custommenu = $OUTPUT->custom_menu(); |
|||
$hascustommenu = (empty($PAGE->layout_options['nocustommenu']) && !empty($custommenu)); |
|||
|
|||
$courseheader = $coursecontentheader = $coursecontentfooter = $coursefooter = ''; |
|||
if (empty($PAGE->layout_options['nocourseheaderfooter'])) { |
|||
$courseheader = $OUTPUT->course_header(); |
|||
$coursecontentheader = $OUTPUT->course_content_header(); |
|||
if (empty($PAGE->layout_options['nocoursefooter'])) { |
|||
$coursecontentfooter = $OUTPUT->course_content_footer(); |
|||
$coursefooter = $OUTPUT->course_footer(); |
|||
} |
|||
} |
|||
|
|||
$bodyclasses = array(); |
|||
if ($hassidepre && !$hassidepost) { |
|||
$bodyclasses[] = 'side-pre-only'; |
|||
} else if ($hassidepost && !$hassidepre) { |
|||
$bodyclasses[] = 'side-post-only'; |
|||
} else if (!$hassidepost && !$hassidepre) { |
|||
$bodyclasses[] = 'content-only'; |
|||
} |
|||
if ($hascustommenu) { |
|||
$bodyclasses[] = 'has_custom_menu'; |
|||
} |
|||
|
|||
echo $OUTPUT->doctype() ?> |
|||
<html <?php echo $OUTPUT->htmlattributes() ?>> |
|||
<head> |
|||
<title><?php echo $PAGE->title ?></title> |
|||
<link rel="shortcut icon" href="<?php echo $OUTPUT->pix_url('favicon', 'theme')?>" /> |
|||
<?php echo $OUTPUT->standard_head_html() ?> |
|||
</head> |
|||
|
|||
<body id="<?php p($PAGE->bodyid) ?>" class="<?php p($PAGE->bodyclasses.' '.join(' ', $bodyclasses)) ?>"> |
|||
<?php echo $OUTPUT->standard_top_of_body_html() ?> |
|||
|
|||
<div id="page"> |
|||
<?php require_once "topo.php" ?> |
|||
|
|||
|
|||
<?php if ($hasheading) { ?> |
|||
<div id="page-header"> |
|||
<div id="page-header-wrapper" class="wrapper clearfix"> |
|||
<div class="logo-wrapper"> |
|||
<a href="<?php echo $CFG->wwwroot; ?>" title="<?php print_string('home'); ?>"> |
|||
<img src="<?php echo $OUTPUT->pix_url('logo-saberes', 'theme')?>" class="logo-header"> |
|||
</a> |
|||
</div> |
|||
<div class="headermenu"> |
|||
<?php |
|||
echo $OUTPUT->login_info(); |
|||
if (!empty($PAGE->layout_options['langmenu'])) { |
|||
echo $OUTPUT->lang_menu(); |
|||
} |
|||
echo $PAGE->headingmenu |
|||
?> |
|||
<div class="header-banners"> |
|||
<a href="http://www.interlegis.leg.br" target="_blank"> |
|||
<img src="<?php echo $OUTPUT->pix_url('logo-interlegis', 'theme')?>"> |
|||
</a> |
|||
<a href="http://www12.senado.gov.br/senado/ilb" target="_blank"> |
|||
<img src="<?php echo $OUTPUT->pix_url('logo-ilb', 'theme')?>"> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<?php } ?> |
|||
|
|||
<?php if ($hascustommenu) { ?> |
|||
<div id="custommenuwrap"><div id="custommenu"><?php echo $custommenu; ?></div></div> |
|||
<?php } ?> |
|||
|
|||
<?php if (!empty($courseheader)) { ?> |
|||
<div id="course-header"><?php echo $courseheader; ?></div> |
|||
<?php } ?> |
|||
|
|||
<?php if ($hasnavbar) { ?> |
|||
<div class="navbar"> |
|||
<div class="wrapper clearfix"> |
|||
<div class="breadcrumb"><?php echo $OUTPUT->navbar(); ?></div> |
|||
<div class="navbutton"> <?php echo $PAGE->button; ?></div> |
|||
</div> |
|||
</div> |
|||
<?php } ?> |
|||
|
|||
<!-- END OF HEADER --> |
|||
<div id="page-content-wrapper" class="wrapper clearfix"> |
|||
<div id="page-content"> |
|||
<div id="region-main-box"> |
|||
<div id="region-post-box"> |
|||
|
|||
<div id="region-main-wrap"> |
|||
<div id="region-main"> |
|||
<div class="region-content"> |
|||
<?php echo $coursecontentheader; ?> |
|||
<?php echo $OUTPUT->main_content() ?> |
|||
<?php echo $coursecontentfooter; ?> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
|
|||
<?php if ($hassidepre) { ?> |
|||
<div id="region-pre" class="block-region"> |
|||
<div class="region-content"> |
|||
<?php echo $OUTPUT->blocks_for_region('side-pre') ?> |
|||
</div> |
|||
</div> |
|||
<?php } ?> |
|||
|
|||
<?php if ($hassidepost) { ?> |
|||
<div id="region-post" class="block-region"> |
|||
<div class="region-content"> |
|||
<?php echo $OUTPUT->blocks_for_region('side-post') ?> |
|||
</div> |
|||
</div> |
|||
<?php } ?> |
|||
|
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
|
|||
<?php if (!empty($coursefooter)) { ?> |
|||
<div id="course-footer"><?php echo $coursefooter; ?></div> |
|||
<?php } ?> |
|||
|
|||
<!-- START OF FOOTER --> |
|||
<?php if ($hasfooter) { ?> |
|||
<div id="page-footer"> |
|||
<p class="helplink"><?php echo page_doc_link(get_string('moodledocslink')) ?></p> |
|||
<?php |
|||
echo $OUTPUT->login_info(); |
|||
//echo $OUTPUT->home_link(); |
|||
echo $OUTPUT->standard_footer_html(); |
|||
?> |
|||
<div class="footer-senado"> |
|||
<span class="vertical-helper"></span> |
|||
<div class="footer-left"> |
|||
</div> |
|||
<div class="footer-center"> |
|||
<span>Senado Federal - Praça dos Três Poderes - Brasília DF - CEP 70165-900</span> |
|||
</div> |
|||
<div class="footer-right"> |
|||
<a href="http://www.moodle.org" target="_blank"> |
|||
<img src="<?php echo $OUTPUT->pix_url('logo-moodle', 'theme')?>" class="logo-footer-right"> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<?php } ?> |
|||
</div> |
|||
<?php echo $OUTPUT->standard_end_of_body_html() ?> |
|||
</body> |
|||
</html> |
@ -1,167 +0,0 @@ |
|||
<?php |
|||
|
|||
$hasheading = ($PAGE->heading); |
|||
$hasnavbar = (empty($PAGE->layout_options['nonavbar']) && $PAGE->has_navbar()); |
|||
$hasfooter = (empty($PAGE->layout_options['nofooter'])); |
|||
$hassidepre = $PAGE->blocks->region_has_content('side-pre', $OUTPUT); |
|||
$hassidepost = $PAGE->blocks->region_has_content('side-post', $OUTPUT); |
|||
$custommenu = $OUTPUT->custom_menu(); |
|||
$hascustommenu = (empty($PAGE->layout_options['nocustommenu']) && !empty($custommenu)); |
|||
|
|||
$courseheader = $coursecontentheader = $coursecontentfooter = $coursefooter = ''; |
|||
if (empty($PAGE->layout_options['nocourseheaderfooter'])) { |
|||
$courseheader = $OUTPUT->course_header(); |
|||
$coursecontentheader = $OUTPUT->course_content_header(); |
|||
if (empty($PAGE->layout_options['nocoursefooter'])) { |
|||
$coursecontentfooter = $OUTPUT->course_content_footer(); |
|||
$coursefooter = $OUTPUT->course_footer(); |
|||
} |
|||
} |
|||
|
|||
$bodyclasses = array(); |
|||
if ($hassidepre && !$hassidepost) { |
|||
$bodyclasses[] = 'side-pre-only'; |
|||
} else if ($hassidepost && !$hassidepre) { |
|||
$bodyclasses[] = 'side-post-only'; |
|||
} else if (!$hassidepost && !$hassidepre) { |
|||
$bodyclasses[] = 'content-only'; |
|||
} |
|||
if ($hascustommenu) { |
|||
$bodyclasses[] = 'has_custom_menu'; |
|||
} |
|||
|
|||
echo $OUTPUT->doctype() ?> |
|||
<html <?php echo $OUTPUT->htmlattributes() ?>> |
|||
<head> |
|||
<title><?php echo $PAGE->title ?></title> |
|||
<link rel="shortcut icon" href="<?php echo $OUTPUT->pix_url('favicon', 'theme')?>" /> |
|||
<?php echo $OUTPUT->standard_head_html() ?> |
|||
</head> |
|||
|
|||
<body id="<?php p($PAGE->bodyid) ?>" class="<?php p($PAGE->bodyclasses.' '.join(' ', $bodyclasses)) ?>"> |
|||
<?php echo $OUTPUT->standard_top_of_body_html() ?> |
|||
|
|||
<div id="page"> |
|||
<?php require_once "topo.php" ?> |
|||
|
|||
<?php if ($hasheading) { ?> |
|||
<div id="page-header"> |
|||
<div id="page-header-wrapper" class="wrapper clearfix"> |
|||
<div class="course-logo-wrapper"> |
|||
<a href="<?php echo $CFG->wwwroot; ?>" title="<?php print_string('home'); ?>"> |
|||
<img src="<?php echo $OUTPUT->pix_url('logo-saberes', 'theme')?>" class="course-logo-header"> |
|||
</a> |
|||
</div> |
|||
<div class="heading-wrapper"> |
|||
<h1 class="headermain inside"><?php echo $PAGE->heading ?></h1> |
|||
</div> |
|||
<div class="headermenu"> |
|||
<?php |
|||
echo $OUTPUT->login_info(); |
|||
if (!empty($PAGE->layout_options['langmenu'])) { |
|||
echo $OUTPUT->lang_menu(); |
|||
} |
|||
echo $PAGE->headingmenu |
|||
?> |
|||
<div class="header-banners"> |
|||
<a href="http://www.interlegis.leg.br" target="_blank"> |
|||
<img src="<?php echo $OUTPUT->pix_url('logo-interlegis', 'theme')?>"> |
|||
</a> |
|||
<a href="http://www12.senado.gov.br/senado/ilb" target="_blank"> |
|||
<img src="<?php echo $OUTPUT->pix_url('logo-ilb', 'theme')?>"> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
|
|||
</div> |
|||
<?php } ?> |
|||
|
|||
<?php if ($hascustommenu) { ?> |
|||
<div id="custommenuwrap"><div id="custommenu"><?php echo $custommenu; ?></div></div> |
|||
<?php } ?> |
|||
|
|||
<?php if (!empty($courseheader)) { ?> |
|||
<div id="course-header"><?php echo $courseheader; ?></div> |
|||
<?php } ?> |
|||
|
|||
<?php if ($hasnavbar) { ?> |
|||
<div class="navbar"> |
|||
<div class="wrapper clearfix"> |
|||
<div class="breadcrumb"><?php echo $OUTPUT->navbar(); ?></div> |
|||
<div class="navbutton"> <?php echo $PAGE->button; ?></div> |
|||
</div> |
|||
</div> |
|||
<?php } ?> |
|||
|
|||
<!-- END OF HEADER --> |
|||
<div id="page-content-wrapper" class="wrapper clearfix"> |
|||
<div id="page-content"> |
|||
<div id="region-main-box"> |
|||
<div id="region-post-box"> |
|||
|
|||
<div id="region-main-wrap"> |
|||
<div id="region-main"> |
|||
<div class="region-content"> |
|||
<?php echo $coursecontentheader; ?> |
|||
<?php echo $OUTPUT->main_content() ?> |
|||
<?php echo $coursecontentfooter; ?> |
|||
<div class="voltar-curso"> <a href="<?php global $DB; echo course_get_url($PAGE->course, $DB->get_field('course_sections', 'section', array('id' => $PAGE->cm->section))); ?>">Voltar ao curso</a></div> |
|||
|
|||
</div> |
|||
</div> |
|||
</div> |
|||
|
|||
<?php if ($hassidepre) { ?> |
|||
<div id="region-pre" class="block-region"> |
|||
<div class="region-content"> |
|||
<?php echo $OUTPUT->blocks_for_region('side-pre') ?> |
|||
</div> |
|||
</div> |
|||
<?php } ?> |
|||
|
|||
<?php if ($hassidepost) { ?> |
|||
<div id="region-post" class="block-region"> |
|||
<div class="region-content"> |
|||
<?php echo $OUTPUT->blocks_for_region('side-post') ?> |
|||
</div> |
|||
</div> |
|||
<?php } ?> |
|||
|
|||
</div> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
|
|||
<?php if (!empty($coursefooter)) { ?> |
|||
<div id="course-footer"><?php echo $coursefooter; ?></div> |
|||
<?php } ?> |
|||
|
|||
<!-- START OF FOOTER --> |
|||
<?php if ($hasfooter) { ?> |
|||
<div id="page-footer"> |
|||
<p class="helplink"><?php echo page_doc_link(get_string('moodledocslink')) ?></p> |
|||
<?php |
|||
echo $OUTPUT->login_info(); |
|||
//echo $OUTPUT->home_link(); |
|||
echo $OUTPUT->standard_footer_html(); |
|||
?> |
|||
<div class="footer-senado"> |
|||
<span class="vertical-helper"></span> |
|||
<div class="footer-left"> |
|||
</div> |
|||
<div class="footer-center"> |
|||
<span>Senado Federal - Praça dos Três Poderes - Brasília DF - CEP 70165-900</span> |
|||
</div> |
|||
<div class="footer-right"> |
|||
<a href="http://www.moodle.org" target="_blank"> |
|||
<img src="<?php echo $OUTPUT->pix_url('logo-moodle', 'theme')?>" class="logo-footer-right"> |
|||
</a> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<?php } ?> |
|||
</div> |
|||
<?php echo $OUTPUT->standard_end_of_body_html() ?> |
|||
</body> |
|||
</html> |
@ -0,0 +1,39 @@ |
|||
<?php |
|||
// This file is part of Moodle - http://moodle.org/ |
|||
// |
|||
// Moodle 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 3 of the License, or |
|||
// (at your option) any later version. |
|||
// |
|||
// Moodle 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. |
|||
// |
|||
// You should have received a copy of the GNU General Public License |
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. |
|||
|
|||
defined('MOODLE_INTERNAL') || die(); |
|||
|
|||
require_once($CFG->libdir . '/../config.php'); |
|||
|
|||
/** |
|||
* A login page layout for the ilb theme. |
|||
* |
|||
* @package theme_ilb |
|||
* @copyright 2016 Damyon Wiese |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
|
|||
$bodyattributes = $OUTPUT->body_attributes(); |
|||
|
|||
$templatecontext = [ |
|||
'sitename' => format_string($SITE->shortname, true, ['context' => context_course::instance(SITEID), "escape" => false]), |
|||
'output' => $OUTPUT, |
|||
'bodyattributes' => $bodyattributes, |
|||
'moodle_url' => $CFG->wwwroot |
|||
]; |
|||
|
|||
echo $OUTPUT->render_from_template('theme_ilb/login', $templatecontext); |
|||
|
@ -0,0 +1,36 @@ |
|||
<?php |
|||
// This file is part of Moodle - http://moodle.org/ |
|||
// |
|||
// Moodle 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 3 of the License, or |
|||
// (at your option) any later version. |
|||
// |
|||
// Moodle 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. |
|||
// |
|||
// You should have received a copy of the GNU General Public License |
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. |
|||
|
|||
defined('MOODLE_INTERNAL') || die(); |
|||
|
|||
/** |
|||
* A login page layout for the ilb theme. |
|||
* |
|||
* @package theme_ilb |
|||
* @copyright 2016 Damyon Wiese |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
|
|||
$bodyattributes = $OUTPUT->body_attributes(); |
|||
|
|||
$templatecontext = [ |
|||
'sitename' => format_string($SITE->shortname, true, ['context' => context_course::instance(SITEID), "escape" => false]), |
|||
'output' => $OUTPUT, |
|||
'bodyattributes' => $bodyattributes |
|||
]; |
|||
|
|||
echo $OUTPUT->render_from_template('theme_ilb/login_nova_conta', $templatecontext); |
|||
|
@ -0,0 +1,34 @@ |
|||
<?php |
|||
// This file is part of Moodle - http://moodle.org/ |
|||
// |
|||
// Moodle 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 3 of the License, or |
|||
// (at your option) any later version. |
|||
// |
|||
// Moodle 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. |
|||
// |
|||
// You should have received a copy of the GNU General Public License |
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. |
|||
|
|||
/** |
|||
* A maintenance layout for the ilb theme. |
|||
* |
|||
* @package theme_ilb |
|||
* @copyright 2016 Damyon Wiese |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
|
|||
defined('MOODLE_INTERNAL') || die(); |
|||
|
|||
$templatecontext = [ |
|||
// We cannot pass the context to format_string, this layout can be used during |
|||
// installation. At that stage database tables do not exist yet. |
|||
'sitename' => format_string($SITE->shortname, true, ["escape" => false]), |
|||
'output' => $OUTPUT |
|||
]; |
|||
|
|||
echo $OUTPUT->render_from_template('theme_ilb/maintenance', $templatecontext); |
@ -1,118 +0,0 @@ |
|||
<?php |
|||
|
|||
$hasheading = ($PAGE->heading); |
|||
$hasnavbar = (empty($PAGE->layout_options['nonavbar']) && $PAGE->has_navbar()); |
|||
$hasfooter = (empty($PAGE->layout_options['nofooter'])); |
|||
$hassidepre = $PAGE->blocks->region_has_content('side-pre', $OUTPUT); |
|||
$hassidepost = $PAGE->blocks->region_has_content('side-post', $OUTPUT); |
|||
$custommenu = $OUTPUT->custom_menu(); |
|||
$hascustommenu = (empty($PAGE->layout_options['nocustommenu']) && !empty($custommenu)); |
|||
|
|||
$courseheader = $coursecontentheader = $coursecontentfooter = $coursefooter = ''; |
|||
if (empty($PAGE->layout_options['nocourseheaderfooter'])) { |
|||
$courseheader = $OUTPUT->course_header(); |
|||
$coursecontentheader = $OUTPUT->course_content_header(); |
|||
if (empty($PAGE->layout_options['nocoursefooter'])) { |
|||
$coursecontentfooter = $OUTPUT->course_content_footer(); |
|||
$coursefooter = $OUTPUT->course_footer(); |
|||
} |
|||
} |
|||
|
|||
$bodyclasses = array(); |
|||
if ($hassidepre && !$hassidepost) { |
|||
$bodyclasses[] = 'side-pre-only'; |
|||
} else if ($hassidepost && !$hassidepre) { |
|||
$bodyclasses[] = 'side-post-only'; |
|||
} else if (!$hassidepost && !$hassidepre) { |
|||
$bodyclasses[] = 'content-only'; |
|||
} |
|||
if ($hascustommenu) { |
|||
$bodyclasses[] = 'has_custom_menu'; |
|||
} |
|||
|
|||
echo $OUTPUT->doctype() ?> |
|||
<html <?php echo $OUTPUT->htmlattributes() ?>> |
|||
<head> |
|||
<title><?php echo $PAGE->title ?></title> |
|||
<link rel="shortcut icon" href="<?php echo $OUTPUT->pix_url('favicon', 'theme')?>" /> |
|||
<?php echo $OUTPUT->standard_head_html() ?> |
|||
</head> |
|||
|
|||
<body id="<?php p($PAGE->bodyid) ?>" class="<?php p($PAGE->bodyclasses.' '.join(' ', $bodyclasses)) ?>"> |
|||
<?php echo $OUTPUT->standard_top_of_body_html() ?> |
|||
|
|||
<div id="page"> |
|||
<?php if ($hasheading) { ?> |
|||
<div id="page-header"> |
|||
<div id="page-header-wrapper" class="wrapper clearfix"> |
|||
<h1 class="headermain inside"><?php echo $PAGE->heading ?></h1> |
|||
<div class="headermenu"><?php |
|||
echo $OUTPUT->login_info(); |
|||
if (!empty($PAGE->layout_options['langmenu'])) { |
|||
echo $OUTPUT->lang_menu(); |
|||
} |
|||
echo $PAGE->headingmenu ?> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<?php } ?> |
|||
|
|||
<?php if ($hascustommenu) { ?> |
|||
<div id="custommenuwrap"><div id="custommenu"><?php echo $custommenu; ?></div></div> |
|||
<?php } ?> |
|||
|
|||
<?php if (!empty($courseheader)) { ?> |
|||
<div id="course-header"><?php echo $courseheader; ?></div> |
|||
<?php } ?> |
|||
|
|||
<?php if ($hasnavbar) { ?> |
|||
<div class="navbar"> |
|||
<div class="wrapper clearfix"> |
|||
<div class="breadcrumb"><?php echo $OUTPUT->navbar(); ?></div> |
|||
<div class="navbutton"> <?php echo $PAGE->button; ?></div> |
|||
</div> |
|||
</div> |
|||
<?php } ?> |
|||
|
|||
<!-- END OF HEADER --> |
|||
|
|||
<div id="page-content-wrapper" class="wrapper clearfix"> |
|||
<div id="page-content"> |
|||
<div id="report-main-content"> |
|||
<div class="region-content"> |
|||
<?php echo $coursecontentheader; ?> |
|||
<?php echo $OUTPUT->main_content() ?> |
|||
<?php echo $coursecontentfooter; ?> |
|||
</div> |
|||
</div> |
|||
<?php if ($hassidepre) { ?> |
|||
<div id="report-region-wrap"> |
|||
<div id="report-region-pre" class="block-region"> |
|||
<div class="region-content"> |
|||
<?php echo $OUTPUT->blocks_for_region('side-pre') ?> |
|||
</div> |
|||
</div> |
|||
</div> |
|||
<?php } ?> |
|||
</div> |
|||
</div> |
|||
|
|||
<?php if (!empty($coursefooter)) { ?> |
|||
<div id="course-footer"><?php echo $coursefooter; ?></div> |
|||
<?php } ?> |
|||
|
|||
<!-- START OF FOOTER --> |
|||
<?php if ($hasfooter) { ?> |
|||
<div id="page-footer" class="wrapper"> |
|||
<p class="helplink"><?php echo page_doc_link(get_string('moodledocslink')) ?></p> |
|||
<?php |
|||
echo $OUTPUT->login_info(); |
|||
echo $OUTPUT->home_link(); |
|||
echo $OUTPUT->standard_footer_html(); |
|||
?> |
|||
</div> |
|||
<?php } ?> |
|||
</div> |
|||
<?php echo $OUTPUT->standard_end_of_body_html() ?> |
|||
</body> |
|||
</html> |
@ -0,0 +1,40 @@ |
|||
<?php |
|||
// This file is part of Moodle - http://moodle.org/ |
|||
// |
|||
// Moodle 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 3 of the License, or |
|||
// (at your option) any later version. |
|||
// |
|||
// Moodle 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. |
|||
// |
|||
// You should have received a copy of the GNU General Public License |
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. |
|||
|
|||
/** |
|||
* A secure layout for the ilb theme. |
|||
* |
|||
* @package theme_ilb |
|||
* @copyright 2016 Damyon Wiese |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
|
|||
defined('MOODLE_INTERNAL') || die(); |
|||
|
|||
$blockshtml = $OUTPUT->blocks('side-pre'); |
|||
$hasblocks = strpos($blockshtml, 'data-block=') !== false; |
|||
$bodyattributes = $OUTPUT->body_attributes(); |
|||
|
|||
$templatecontext = [ |
|||
'sitename' => format_string($SITE->shortname, true, ['context' => context_course::instance(SITEID), "escape" => false]), |
|||
'output' => $OUTPUT, |
|||
'bodyattributes' => $bodyattributes, |
|||
'sidepreblocks' => $blockshtml, |
|||
'hasblocks' => $hasblocks |
|||
]; |
|||
|
|||
echo $OUTPUT->render_from_template('theme_ilb/secure', $templatecontext); |
|||
|
@ -1,59 +0,0 @@ |
|||
|
|||
<div id="topo"> |
|||
|
|||
<div id="topoPortal"> |
|||
|
|||
<a href="http://www.senado.gov.br/" title="Volta para a página inicial." class="logo"><img src="<?php echo $OUTPUT->pix_url('logo-senado-pb', 'theme')?>" alt="Volta para a página inicial"/></a> |
|||
|
|||
<div id="menuPortais"> |
|||
|
|||
<ul> |
|||
|
|||
<li> |
|||
|
|||
<div class="topo_portalmenu"> |
|||
|
|||
<img src="<?php echo $OUTPUT->pix_url('icoSelPortais', 'theme')?>" alt="Selecione o Portal desejado"/> |
|||
|
|||
</div> |
|||
|
|||
<ul> |
|||
|
|||
<li style="padding-top:15px;"><a href="http://www.senado.gov.br/senado/">O Senado</a></li> |
|||
|
|||
<li><a href="http://www.senado.gov.br/senadores/">Senadores</a></li> |
|||
|
|||
<li><a href="http://www.senado.gov.br/atividade/">Atividade Legislativa</a></li> |
|||
|
|||
<li><a href="http://www.senado.gov.br/legislacao/">Legislação</a></li> |
|||
|
|||
<li><a href="http://www.senado.gov.br/noticias/">Notícias</a></li> |
|||
|
|||
<li><a href="http://www.senado.gov.br/publicacoes/">Publicações</a></li> |
|||
|
|||
<li><a href="http://www12.senado.gov.br/orcamento">Orçamento</a></li> |
|||
|
|||
<li><a href="http://www.senado.gov.br/transparencia/">Transparência</a></li> |
|||
|
|||
<li><a href="http://www.senado.gov.br/ecidadania/">e-Cidadania</a></li> |
|||
|
|||
</ul> |
|||
|
|||
</li> |
|||
|
|||
</ul> |
|||
|
|||
</div> |
|||
|
|||
<div id="divLinksTopo"> |
|||
|
|||
<img src="<?php echo $OUTPUT->pix_url('separador-topo', 'theme')?>" alt="separador" /> |
|||
|
|||
</div> |
|||
|
|||
<div style="clear:both;" class="noprint"> |
|||
</div> |
|||
|
|||
</div> |
|||
|
|||
</div> |
@ -0,0 +1,108 @@ |
|||
<?php |
|||
// This file is part of Moodle - http://moodle.org/ |
|||
// |
|||
// Moodle 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 3 of the License, or |
|||
// (at your option) any later version. |
|||
// |
|||
// Moodle 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. |
|||
// |
|||
// You should have received a copy of the GNU General Public License |
|||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. |
|||
|
|||
/** |
|||
* Theme functions. |
|||
* |
|||
* @package theme_ilb |
|||
* @copyright 2016 Frédéric Massart - FMCorz.net |
|||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
|||
*/ |
|||
|
|||
defined('MOODLE_INTERNAL') || die(); |
|||
|
|||
/** |
|||
* Post process the CSS tree. |
|||
* |
|||
* @param string $tree The CSS tree. |
|||
* @param theme_config $theme The theme config object. |
|||
*/ |
|||
function theme_ilb_css_tree_post_processor($tree, $theme) { |
|||
$prefixer = new theme_ilb\autoprefixer($tree); |
|||
$prefixer->prefix(); |
|||
} |
|||
|
|||
/** |
|||
* Inject additional SCSS. |
|||
* |
|||
* @param theme_config $theme The theme config object. |
|||
* @return string |
|||
*/ |
|||
function theme_ilb_get_extra_scss($theme) { |
|||
return !empty($theme->settings->scss) ? $theme->settings->scss : ''; |
|||
} |
|||
|
|||
/** |
|||
* Returns the main SCSS content. |
|||
* |
|||
* @param theme_config $theme The theme config object. |
|||
* @return string |
|||
*/ |
|||
function theme_ilb_get_main_scss_content($theme) { |
|||
global $CFG; |
|||
|
|||
$scss = ''; |
|||
$filename = !empty($theme->settings->preset) ? $theme->settings->preset : null; |
|||
$fs = get_file_storage(); |
|||
|
|||
$context = context_system::instance(); |
|||
if ($filename == 'default.scss') { |
|||
$scss .= file_get_contents($CFG->dirroot . '/theme/ilb/scss/preset/default.scss'); |
|||
} else if ($filename == 'plain.scss') { |
|||
$scss .= file_get_contents($CFG->dirroot . '/theme/ilb/scss/preset/plain.scss'); |
|||
} else if ($filename && ($presetfile = $fs->get_file($context->id, 'theme_ilb', 'preset', 0, '/', $filename))) { |
|||
$scss .= $presetfile->get_content(); |
|||
} else { |
|||
// Safety fallback - maybe new installs etc. |
|||
$scss .= file_get_contents($CFG->dirroot . '/theme/ilb/scss/preset/default.scss'); |
|||
} |
|||
|
|||
return $scss; |
|||
} |
|||
|
|||
/** |
|||
* Get SCSS to prepend. |
|||
* |
|||
* @param theme_config $theme The theme config object. |
|||
* @return array |
|||
*/ |
|||
function theme_ilb_get_pre_scss($theme) { |
|||
global $CFG; |
|||
|
|||
$scss = ''; |
|||
$configurable = [ |
|||
// Config key => [variableName, ...]. |
|||
'brandcolor' => ['brand-primary'], |
|||
]; |
|||
|
|||
// Prepend variables first. |
|||
foreach ($configurable as $configkey => $targets) { |
|||
$value = isset($theme->settings->{$configkey}) ? $theme->settings->{$configkey} : null; |
|||
if (empty($value)) { |
|||
continue; |
|||
} |
|||
array_map(function($target) use (&$scss, $value) { |
|||
$scss .= '$' . $target . ': ' . $value . ";\n"; |
|||
}, (array) $targets); |
|||
} |
|||
|
|||
// Prepend pre-scss. |
|||
if (!empty($theme->settings->scsspre)) { |
|||
$scss .= $theme->settings->scsspre; |
|||
} |
|||
|
|||
return $scss; |
|||
} |
Before Width: | Height: | Size: 130 B |
Before Width: | Height: | Size: 955 B |
Before Width: | Height: | Size: 3.2 KiB After Width: | Height: | Size: 1.1 KiB |
After Width: | Height: | Size: 182 B |
After Width: | Height: | Size: 555 B |
After Width: | Height: | Size: 372 B |
After Width: | Height: | Size: 293 B |
After Width: | Height: | Size: 424 B |
After Width: | Height: | Size: 150 B |
After Width: | Height: | Size: 458 B |
After Width: | Height: | Size: 410 B |
After Width: | Height: | Size: 82 KiB |
After Width: | Height: | Size: 207 B |
After Width: | Height: | Size: 618 B |
After Width: | Height: | Size: 263 B |
After Width: | Height: | Size: 693 B |
After Width: | Height: | Size: 536 B |
After Width: | Height: | Size: 397 B |
After Width: | Height: | Size: 180 B |
After Width: | Height: | Size: 569 B |
After Width: | Height: | Size: 509 B |
After Width: | Height: | Size: 512 B |
After Width: | Height: | Size: 257 B |
After Width: | Height: | Size: 571 B |
After Width: | Height: | Size: 250 B |
After Width: | Height: | Size: 635 B |
After Width: | Height: | Size: 207 B |
After Width: | Height: | Size: 842 B |
After Width: | Height: | Size: 111 B |
After Width: | Height: | Size: 436 B |
After Width: | Height: | Size: 95 B |
After Width: | Height: | Size: 387 B |
After Width: | Height: | Size: 114 B |
After Width: | Height: | Size: 438 B |
Before Width: | Height: | Size: 499 B |
Before Width: | Height: | Size: 6.0 KiB |
Before Width: | Height: | Size: 14 KiB |
Before Width: | Height: | Size: 6.7 KiB |
Before Width: | Height: | Size: 6.9 KiB |
Before Width: | Height: | Size: 23 KiB |
Before Width: | Height: | Size: 1.2 KiB |