UNPKG

5.05 kBJavaScriptView Raw
1"use strict";function _interopDefault(t){return t&&"object"==typeof t&&"default"in t?t.default:t}var Util=_interopDefault(require("../util.js")),extendStatics=function(t,e){return(extendStatics=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var n in e)e.hasOwnProperty(n)&&(t[n]=e[n])})(t,e)};function __extends(t,e){function n(){this.constructor=t}extendStatics(t,e),t.prototype=null===e?Object.create(e):(n.prototype=e.prototype,new n)}var Size,Color,Direction,Component=function(){function t(t,e,n){var r=this;this.template="",this.id=null,this.eventHandlers=[],this.registeredElements=[],this.name=t;var o="string"==typeof n.element?document.querySelector(n.element):n.element,i={};if(o){var s=Util.Selector.attrConfig(o);s&&(i=s)}this.defaultProps=e,this.props=Object.assign(e,i,n,{element:o}),this.id=this.uid(),this.elementListener=function(t){return r.onBeforeElementEvent(t)},this.setEventsHandler()}return t.prototype.setTemplate=function(t){this.template=t},t.prototype.getTemplate=function(){return this.template},t.prototype.getElement=function(){return this.getProp("element")||null},t.prototype.setElement=function(t){this.props.element=t},t.prototype.getId=function(){return this.id},t.prototype.uid=function(){return Math.random().toString(36).substr(2,10)},t.prototype.getName=function(){return this.name},t.prototype.getProps=function(){return this.props},t.prototype.getProp=function(t){var e=this.defaultProps[t];return void 0!==this.props[t]?this.props[t]:e},t.prototype.setProps=function(t){var e=Object.assign({},t);this.props=Object.assign(this.props,e)},t.prototype.setProp=function(t,e){if(void 0===this.props[t])throw new Error("Cannot set an invalid prop");this.props[t]=e},t.prototype.registerElements=function(t){var e=this;t.forEach(function(t){return e.registerElement(t)})},t.prototype.registerElement=function(t){t.target.addEventListener(t.event,this.elementListener),this.registeredElements.push(t)},t.prototype.unregisterElements=function(){var e=this;this.registeredElements.forEach(function(t){e.unregisterElement(t)})},t.prototype.unregisterElement=function(e){var t=this.registeredElements.findIndex(function(t){return t.target===e.target&&t.event===e.event});-1<t?(e.target.removeEventListener(e.event,this.elementListener),this.registeredElements.splice(t,1)):console.error("Warning! Could not remove element: "+e.target+" with event: "+e.event+".")},t.prototype.triggerEvent=function(t,e,n){var r=this;void 0===e&&(e={}),void 0===n&&(n=!1);var o=t.split(".").reduce(function(t,e,n){return 0===n?e:t+e.charAt(0).toUpperCase()+e.slice(1)}),i="on"+o.charAt(0).toUpperCase()+o.slice(1),s=this.getProps();if(this.eventHandlers.forEach(function(t){"function"==typeof t[o]&&t[o].apply(r,[e]),"function"==typeof t[i]&&s[i].apply(r,[e])}),!n){var p=this.getElement();p?Util.Dispatch.elementEvent(p,t,this.name,e):Util.Dispatch.winDocEvent(t,this.name,e)}},t.prototype.preventClosable=function(){return!1},t.prototype.destroy=function(){this.unregisterElements()},t.prototype.onElementEvent=function(t){},t.prototype.setEventsHandler=function(){var n=this.getProps(),t=Object.keys(n).reduce(function(t,e){return"function"==typeof n[e]&&(t[e]=n[e]),t},{});0<Object.keys(t).length&&this.eventHandlers.push(t)},t.prototype.onBeforeElementEvent=function(t){this.preventClosable()||this.onElementEvent(t)},t}();!function(t){t.sm="sm",t.md="md",t.lg="lg",t.xl="xl"}(Size||(Size={})),function(t){t.primary="primary",t.secondary="secondary",t.success="success",t.warning="warning",t.danger="danger"}(Color||(Color={})),function(t){t.top="top",t.right="right",t.bottom="bottom",t.left="left"}(Direction||(Direction={}));var Loader=function(e){function t(t){return void 0===t&&(t={color:Color.primary,size:Size.md}),e.call(this,"loader",{fade:!0,size:Size.md,color:Color.primary},t)||this}return __extends(t,e),t.prototype.show=function(){var t=this.getElement();t.classList.contains("hide")&&t.classList.remove("hide"),this.triggerEvent(Util.Event.SHOW);var e=this.getProp("size");Util.Selector.removeClasses(t,Object.values(Size),"loader"),t.classList.add("loader-"+e);var n=this.getProp("color"),r=this.getSpinner();return Util.Selector.removeClasses(r,Object.values(Color),"loader"),r.classList.add("loader-"+n),this.triggerEvent(Util.Event.SHOWN),!0},t.prototype.animate=function(t){void 0===t&&(t=!0),t?this.show():this.hide();var e=this.getSpinner();return t&&!e.classList.contains("loader-spinner-animated")?e.classList.add("loader-spinner-animated"):!t&&e.classList.contains("loader-spinner-animated")&&e.classList.remove("loader-spinner-animated"),!0},t.prototype.hide=function(){var t=this.getElement();return t.classList.contains("hide")||t.classList.add("hide"),this.triggerEvent(Util.Event.HIDE),this.triggerEvent(Util.Event.HIDDEN),!0},t.prototype.getSpinner=function(){return this.getElement().querySelector(".loader-spinner")},t}(Component);module.exports=Loader;
2//# sourceMappingURL=/home/qathom/Workspaces/Web/phonon/dist/js/components/loader.min.js.map
\No newline at end of file