From f07a6aba236c9a27b34706e6ed4aaf87fadff362 Mon Sep 17 00:00:00 2001 From: dominiclord Date: Wed, 18 May 2016 23:12:36 -0400 Subject: [PATCH] Restructuring of scripts for better use of ES6 concepts - Optimized use of common properties (, , ...) - Dispatching events in an attempt to de-globalize certain variables used in the past - Attempt to organize files in a more logical manner --- assets/scripts/App.js | 13 +- assets/scripts/global/svg.js | 4 + assets/scripts/modules.js | 1 - assets/scripts/modules/AbstractModule.js | 17 ++ assets/scripts/modules/Button.js | 13 +- assets/scripts/modules/Globals.js | 12 -- assets/scripts/modules/Module.js | 14 -- assets/scripts/modules/Svg.js | 15 -- assets/scripts/modules/Title.js | 14 +- assets/scripts/utils/environment.js | 6 + assets/scripts/utils/globals.js | 6 + www/assets/scripts/app.js | 257 ++++++++++------------- 12 files changed, 159 insertions(+), 213 deletions(-) create mode 100644 assets/scripts/global/svg.js create mode 100644 assets/scripts/modules/AbstractModule.js delete mode 100644 assets/scripts/modules/Globals.js delete mode 100644 assets/scripts/modules/Module.js delete mode 100644 assets/scripts/modules/Svg.js create mode 100644 assets/scripts/utils/environment.js create mode 100644 assets/scripts/utils/globals.js diff --git a/assets/scripts/App.js b/assets/scripts/App.js index b44266b..33165eb 100644 --- a/assets/scripts/App.js +++ b/assets/scripts/App.js @@ -1,8 +1,9 @@ /* jshint esnext: true */ +import globals from './utils/globals'; import * as modules from './modules'; class App { - constructor(options) { + constructor() { this.modules = modules; this.currentModules = []; } @@ -12,7 +13,7 @@ class App { * @return {Object} */ initGlobals() { - this.globals = new this.modules.Globals(); + globals(); return this; } @@ -22,7 +23,7 @@ class App { */ initModules() { // Elements with module - const moduleEls = document.querySelectorAll('[data-module]'); + var moduleEls = document.querySelectorAll('[data-module]'); // Loop through elements var i = 0; @@ -65,8 +66,8 @@ class App { /** * Get element data attributes - * @param {DOMElement} el - * @return {Array} data + * @param {DOMElement} el + * @return {Array} data */ getElemData(el) { // All attributes @@ -108,8 +109,6 @@ class App { } } -// Document ready -// ========================================================================= $(function() { window.app = new App(); window.app.init(); diff --git a/assets/scripts/global/svg.js b/assets/scripts/global/svg.js new file mode 100644 index 0000000..561b033 --- /dev/null +++ b/assets/scripts/global/svg.js @@ -0,0 +1,4 @@ +/* jshint esnext: true */ +export default function() { + svg4everybody(); +} diff --git a/assets/scripts/modules.js b/assets/scripts/modules.js index 37c0a4f..1423218 100644 --- a/assets/scripts/modules.js +++ b/assets/scripts/modules.js @@ -1,4 +1,3 @@ /* jshint esnext: true */ -export {default as Globals} from './modules/Globals'; export {default as Button} from './modules/Button'; export {default as Title} from './modules/Title'; diff --git a/assets/scripts/modules/AbstractModule.js b/assets/scripts/modules/AbstractModule.js new file mode 100644 index 0000000..b61278c --- /dev/null +++ b/assets/scripts/modules/AbstractModule.js @@ -0,0 +1,17 @@ +import { $document, $window, $html, $body } from '../utils/environment'; + +/** + * Abstract module + * Gives access to generic jQuery nodes + */ +class AbstractModule { + constructor(options) { + this.$document = $document; + this.$window = $window; + this.$html = $html; + this.$body = $body; + this.$el = options.$el; + } +} + +export default AbstractModule; diff --git a/assets/scripts/modules/Button.js b/assets/scripts/modules/Button.js index a9ca0ec..0115547 100644 --- a/assets/scripts/modules/Button.js +++ b/assets/scripts/modules/Button.js @@ -1,21 +1,16 @@ /* jshint esnext: true */ -import Module from './Module'; +import AbstractModule from './AbstractModule'; -class Generic extends Module { +export default class extends AbstractModule { constructor(options) { - super(); - this.$el = options.$el; + super(options); this.$el.on('click', (event) => { this.$document.trigger('title.changeLabel', [$(event.currentTarget).val()]); }); } - // Destroy - // ========================================================================== destroy() { - this.$el.off(); + this.$el.off('.Button'); } } - -export default Generic; diff --git a/assets/scripts/modules/Globals.js b/assets/scripts/modules/Globals.js deleted file mode 100644 index 1618cc6..0000000 --- a/assets/scripts/modules/Globals.js +++ /dev/null @@ -1,12 +0,0 @@ -// ========================================================================== -// Globals module -// ========================================================================== -import Svg from './Svg'; - -class Globals { - constructor() { - new Svg(); - } -} - -export default Globals; diff --git a/assets/scripts/modules/Module.js b/assets/scripts/modules/Module.js deleted file mode 100644 index c3129f6..0000000 --- a/assets/scripts/modules/Module.js +++ /dev/null @@ -1,14 +0,0 @@ -// ========================================================================== -// Module -// ========================================================================== - -class Module { - constructor() { - this.$document = $(document); - this.$window = $(window); - this.$html = $(document.documentElement); - this.$body = $(document.body); - } -} - -export default Module; diff --git a/assets/scripts/modules/Svg.js b/assets/scripts/modules/Svg.js deleted file mode 100644 index 6636f32..0000000 --- a/assets/scripts/modules/Svg.js +++ /dev/null @@ -1,15 +0,0 @@ -// ========================================================================== -// Svg module -// ========================================================================== -import Module from './Module'; - -class Svg extends Module { - constructor() { - super(); - - svg4everybody(); - } -} - -export default Svg; -  diff --git a/assets/scripts/modules/Title.js b/assets/scripts/modules/Title.js index b57fb50..b12c33d 100644 --- a/assets/scripts/modules/Title.js +++ b/assets/scripts/modules/Title.js @@ -1,10 +1,10 @@ /* jshint esnext: true */ -import Module from './Module'; +import AbstractModule from './AbstractModule'; -class Title extends Module { +export default class extends AbstractModule { constructor(options) { - super(); - this.$el = options.$el; + super(options); + this.$label = this.$el.find('.js-label'); this.$document.on('title.changeLabel', (event, value) => { @@ -16,12 +16,8 @@ class Title extends Module { this.$label.text(value); } - // Destroy - // ========================================================================== destroy() { this.$document.off('title.changeLabel'); - this.$el.off(); + this.$el.off('.Title'); } } - -export default Title; diff --git a/assets/scripts/utils/environment.js b/assets/scripts/utils/environment.js new file mode 100644 index 0000000..7505149 --- /dev/null +++ b/assets/scripts/utils/environment.js @@ -0,0 +1,6 @@ +const $document = $(document); +const $window = $(window); +const $html = $(document.documentElement); +const $body = $(document.body); + +export { $document, $window, $html, $body }; diff --git a/assets/scripts/utils/globals.js b/assets/scripts/utils/globals.js new file mode 100644 index 0000000..0c6fcf4 --- /dev/null +++ b/assets/scripts/utils/globals.js @@ -0,0 +1,6 @@ +/* jshint esnext: true */ +import svg from '../global/svg'; + +export default function() { + svg(); +} diff --git a/www/assets/scripts/app.js b/www/assets/scripts/app.js index 09faec5..ba60384 100644 --- a/www/assets/scripts/app.js +++ b/www/assets/scripts/app.js @@ -4,16 +4,22 @@ 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; }; }(); /* jshint esnext: true */ +var _globals = require('./utils/globals'); + +var _globals2 = _interopRequireDefault(_globals); + var _modules = require('./modules'); var modules = _interopRequireWildcard(_modules); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } } +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 App = function () { - function App(options) { + function App() { _classCallCheck(this, App); this.modules = modules; @@ -29,7 +35,7 @@ var App = function () { _createClass(App, [{ key: 'initGlobals', value: function initGlobals() { - this.globals = new this.modules.Globals(); + (0, _globals2.default)(); return this; } @@ -85,8 +91,8 @@ var App = function () { /** * Get element data attributes - * @param {DOMElement} el - * @return {Array} data + * @param {DOMElement} el + * @return {Array} data */ }, { @@ -137,31 +143,29 @@ var App = function () { return App; }(); -// Document ready -// ========================================================================= - - $(function () { window.app = new App(); window.app.init(); }); -},{"./modules":2}],2:[function(require,module,exports){ +},{"./modules":3,"./utils/globals":8}],2:[function(require,module,exports){ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +exports.default = function () { + svg4everybody(); +}; + +},{}],3:[function(require,module,exports){ 'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); -var _Globals = require('./modules/Globals'); - -Object.defineProperty(exports, 'Globals', { - enumerable: true, - get: function get() { - return _interopRequireDefault(_Globals).default; - } -}); - var _Button = require('./modules/Button'); Object.defineProperty(exports, 'Button', { @@ -182,7 +186,35 @@ Object.defineProperty(exports, 'Title', { function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } -},{"./modules/Button":3,"./modules/Globals":4,"./modules/Title":7}],3:[function(require,module,exports){ +},{"./modules/Button":5,"./modules/Title":6}],4:[function(require,module,exports){ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +var _environment = require('../utils/environment'); + +function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } + +/** + * Abstract module + * Gives access to generic jQuery nodes + */ + +var AbstractModule = function AbstractModule(options) { + _classCallCheck(this, AbstractModule); + + this.$document = _environment.$document; + this.$window = _environment.$window; + this.$html = _environment.$html; + this.$body = _environment.$body; + this.$el = options.$el; +}; + +exports.default = AbstractModule; + +},{"../utils/environment":7}],5:[function(require,module,exports){ 'use strict'; Object.defineProperty(exports, "__esModule", { @@ -191,9 +223,9 @@ Object.defineProperty(exports, "__esModule", { 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; }; }(); -var _Module2 = require('./Module'); +var _AbstractModule2 = require('./AbstractModule'); -var _Module3 = _interopRequireDefault(_Module2); +var _AbstractModule3 = _interopRequireDefault(_AbstractModule2); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } @@ -204,15 +236,13 @@ function _possibleConstructorReturn(self, call) { if (!self) { throw new Referen 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; } /* jshint esnext: true */ -var Generic = function (_Module) { - _inherits(Generic, _Module); +var _class = function (_AbstractModule) { + _inherits(_class, _AbstractModule); - function Generic(options) { - _classCallCheck(this, Generic); + function _class(options) { + _classCallCheck(this, _class); - var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(Generic).call(this)); - - _this.$el = options.$el; + var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(_class).call(this, options)); _this.$el.on('click', function (event) { _this.$document.trigger('title.changeLabel', [$(event.currentTarget).val()]); @@ -220,112 +250,19 @@ var Generic = function (_Module) { return _this; } - // Destroy - // ========================================================================== - - - _createClass(Generic, [{ + _createClass(_class, [{ key: 'destroy', value: function destroy() { - this.$el.off(); + this.$el.off('.Button'); } }]); - return Generic; -}(_Module3.default); + return _class; +}(_AbstractModule3.default); -exports.default = Generic; +exports.default = _class; -},{"./Module":5}],4:[function(require,module,exports){ -'use strict'; - -Object.defineProperty(exports, "__esModule", { - value: true -}); - -var _Svg = require('./Svg'); - -var _Svg2 = _interopRequireDefault(_Svg); - -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"); } } // ========================================================================== -// Globals module -// ========================================================================== - - -var Globals = function Globals() { - _classCallCheck(this, Globals); - - new _Svg2.default(); -}; - -exports.default = Globals; - -},{"./Svg":6}],5:[function(require,module,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"); } } - -// ========================================================================== -// Module -// ========================================================================== - -var Module = function Module() { - _classCallCheck(this, Module); - - this.$document = $(document); - this.$window = $(window); - this.$html = $(document.documentElement); - this.$body = $(document.body); -}; - -exports.default = Module; - -},{}],6:[function(require,module,exports){ -'use strict'; - -Object.defineProperty(exports, "__esModule", { - value: true -}); - -var _Module2 = require('./Module'); - -var _Module3 = _interopRequireDefault(_Module2); - -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"); } } - -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; } // ========================================================================== -// Svg module -// ========================================================================== - - -var Svg = function (_Module) { - _inherits(Svg, _Module); - - function Svg() { - _classCallCheck(this, Svg); - - var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(Svg).call(this)); - - svg4everybody(); - return _this; - } - - return Svg; -}(_Module3.default); - -exports.default = Svg; - -},{"./Module":5}],7:[function(require,module,exports){ +},{"./AbstractModule":4}],6:[function(require,module,exports){ 'use strict'; Object.defineProperty(exports, "__esModule", { @@ -334,9 +271,9 @@ Object.defineProperty(exports, "__esModule", { 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; }; }(); -var _Module2 = require('./Module'); +var _AbstractModule2 = require('./AbstractModule'); -var _Module3 = _interopRequireDefault(_Module2); +var _AbstractModule3 = _interopRequireDefault(_AbstractModule2); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } @@ -347,15 +284,14 @@ function _possibleConstructorReturn(self, call) { if (!self) { throw new Referen 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; } /* jshint esnext: true */ -var Title = function (_Module) { - _inherits(Title, _Module); +var _class = function (_AbstractModule) { + _inherits(_class, _AbstractModule); - function Title(options) { - _classCallCheck(this, Title); + function _class(options) { + _classCallCheck(this, _class); - var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(Title).call(this)); + var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(_class).call(this, options)); - _this.$el = options.$el; _this.$label = _this.$el.find('.js-label'); _this.$document.on('title.changeLabel', function (event, value) { @@ -364,27 +300,56 @@ var Title = function (_Module) { return _this; } - _createClass(Title, [{ + _createClass(_class, [{ key: 'changeLabel', value: function changeLabel(value) { this.$label.text(value); } - - // Destroy - // ========================================================================== - }, { key: 'destroy', value: function destroy() { this.$document.off('title.changeLabel'); - this.$el.off(); + this.$el.off('.Title'); } }]); - return Title; -}(_Module3.default); + return _class; +}(_AbstractModule3.default); -exports.default = Title; +exports.default = _class; -},{"./Module":5}]},{},[1,2,3,4,5,6,7]) -//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/grunt-browserify/node_modules/browserify/node_modules/browser-pack/_prelude.js","assets/scripts/App.js","assets/scripts/modules.js","assets/scripts/modules/Button.js","assets/scripts/modules/Globals.js","assets/scripts/modules/Module.js","assets/scripts/modules/Svg.js","assets/scripts/modules/Title.js"],"names":[],"mappings":"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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","/* jshint esnext: true */\nimport * as modules from './modules';\n\nclass App {\n\tconstructor(options) {\n\t\tthis.modules = modules;\n\t\tthis.currentModules = [];\n\t}\n\n\t/**\n\t * Execute global functions and settings\n\t * @return {Object}\n\t */\n\tinitGlobals() {\n\t\tthis.globals = new this.modules.Globals();\n\t\treturn this;\n\t}\n\n\t/**\n\t * Find modules and initialize them\n\t * @return  {Object}  this  Allows chaining\n\t */\n\tinitModules() {\n\t\t// Elements with module\n\t\tconst moduleEls = document.querySelectorAll('[data-module]');\n\n\t\t// Loop through elements\n\t\tvar i = 0;\n\t\tvar elsLen = moduleEls.length;\n\n\t\tfor (; i < elsLen; i++) {\n\n\t\t\t// Current element\n\t\t\tlet el = moduleEls[i];\n\n\t\t\t// All data- attributes considered as options\n\t\t\tlet options = this.getElemData(el);\n\n\t\t\t// Add current DOM element and jQuery element\n\t\t\toptions.el = el;\n\t\t\toptions.$el = $(el);\n\n\t\t\t// Module does exist at this point\n\t\t\tlet attr = options.module;\n\n\t\t\t// Splitting modules found in the data-attribute\n\t\t\tlet moduleIdents = attr.replace(/\\s/g, '').split(',');\n\n\t\t\t// Loop modules\n\t\t\tlet j = 0;\n\t\t\tlet modulesLen = moduleIdents.length;\n\n\t\t\tfor (; j < modulesLen; j++) {\n\t\t\t\tlet moduleAttr = moduleIdents[j];\n\n\t\t\t\tif (typeof this.modules[moduleAttr] === 'function') {\n\t\t\t\t\tlet module = new this.modules[moduleAttr](options);\n\t\t\t\t\tthis.currentModules.push(module);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Get element data attributes\n\t * @param {DOMElement} el\n\t * @return {Array} data\n\t */\n\tgetElemData(el) {\n\t\t// All attributes\n\t\tvar attributes = el.attributes;\n\n\t\t// Regex Pattern\n\t\tvar pattern = /^data\\-(.+)$/;\n\n\t\t// Output\n\t\tvar data = {};\n\n\t\tfor (let i in attributes) {\n\t\t\t// Attributes name (ex: data-module)\n\t\t\tlet name = attributes[i].name;\n\n\t\t\t// This happens.\n\t\t\tif (!name) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tlet match = name.match(pattern);\n\t\t\tif (!match) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\t// If this throws an error, you have some\n\t\t\t// serious problems in your HTML.\n\t\t\tdata[match[1]] = el.getAttribute(name);\n\t\t}\n\n\t\treturn data;\n\t}\n\n\t/**\n\t * Initialize app after document ready\n\t */\n\tinit() {\n\t\tthis.initGlobals().initModules();\n\t}\n}\n\n// Document ready\n// =========================================================================\n$(function() {\n\twindow.app = new App();\n\twindow.app.init();\n});\n","/* jshint esnext: true */\nexport {default as Globals} from './modules/Globals';\nexport {default as Button} from './modules/Button';\nexport {default as Title} from './modules/Title';\n","/* jshint esnext: true */\nimport Module from './Module';\n\nclass Generic extends Module {\n\tconstructor(options) {\n\t\tsuper();\n\t\tthis.$el = options.$el;\n\n\t\tthis.$el.on('click', (event) => {\n\t\t\tthis.$document.trigger('title.changeLabel', [$(event.currentTarget).val()]);\n\t\t});\n\t}\n\n\t// Destroy\n\t// ==========================================================================\n\tdestroy() {\n\t\tthis.$el.off();\n\t}\n}\n\nexport default Generic;\n","// ==========================================================================\n// Globals module\n// ==========================================================================\nimport Svg from './Svg';\n\nclass Globals {\n\tconstructor() {\n\t\tnew Svg();\n\t}\n}\n\nexport default Globals;\n","// ==========================================================================\n// Module\n// ==========================================================================\n\nclass Module {\n\tconstructor() {\n        this.$document = $(document);\n\t\tthis.$window = $(window);\n\t\tthis.$html = $(document.documentElement);\n\t\tthis.$body = $(document.body);\n\t}\n}\n\nexport default Module;\n","// ==========================================================================\n// Svg module\n// ==========================================================================\nimport Module from './Module';\n\nclass Svg extends Module {\n\tconstructor() {\n\t\tsuper();\n\n\t\tsvg4everybody();\n\t}\n}\n\nexport default Svg;\n \n","/* jshint esnext: true */\nimport Module from './Module';\n\nclass Title extends Module {\n\tconstructor(options) {\n\t\tsuper();\n\t\tthis.$el = options.$el;\n\t\tthis.$label = this.$el.find('.js-label');\n\n\t\tthis.$document.on('title.changeLabel', (event, value) => {\n\t\t\tthis.changeLabel(value);\n\t\t});\n\t}\n\n\tchangeLabel(value) {\n\t\tthis.$label.text(value);\n\t}\n\n\t// Destroy\n\t// ==========================================================================\n\tdestroy() {\n\t\tthis.$document.off('title.changeLabel');\n\t\tthis.$el.off();\n\t}\n}\n\nexport default Title;\n"]} +},{"./AbstractModule":4}],7:[function(require,module,exports){ +"use strict"; + +Object.defineProperty(exports, "__esModule", { + value: true +}); +var $document = $(document); +var $window = $(window); +var $html = $(document.documentElement); +var $body = $(document.body); + +exports.$document = $document; +exports.$window = $window; +exports.$html = $html; +exports.$body = $body; + +},{}],8:[function(require,module,exports){ +'use strict'; + +Object.defineProperty(exports, "__esModule", { + value: true +}); + +exports.default = function () { + (0, _svg2.default)(); +}; + +var _svg = require('../global/svg'); + +var _svg2 = _interopRequireDefault(_svg); + +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + +},{"../global/svg":2}]},{},[1,2,3,4,5,6,7,8]) +//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/grunt-browserify/node_modules/browserify/node_modules/browser-pack/_prelude.js","assets/scripts/App.js","assets/scripts/global/svg.js","assets/scripts/modules.js","assets/scripts/modules/AbstractModule.js","assets/scripts/modules/Button.js","assets/scripts/modules/Title.js","assets/scripts/utils/environment.js","assets/scripts/utils/globals.js"],"names":[],"mappings":"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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","/* jshint esnext: true */\nimport globals from './utils/globals';\nimport * as modules from './modules';\n\nclass App {\n\tconstructor() {\n\t\tthis.modules = modules;\n\t\tthis.currentModules = [];\n\t}\n\n\t/**\n\t * Execute global functions and settings\n\t * @return {Object}\n\t */\n\tinitGlobals() {\n\t\tglobals();\n\t\treturn this;\n\t}\n\n\t/**\n\t * Find modules and initialize them\n\t * @return  {Object}  this  Allows chaining\n\t */\n\tinitModules() {\n\t\t// Elements with module\n\t\tvar moduleEls = document.querySelectorAll('[data-module]');\n\n\t\t// Loop through elements\n\t\tvar i = 0;\n\t\tvar elsLen = moduleEls.length;\n\n\t\tfor (; i < elsLen; i++) {\n\n\t\t\t// Current element\n\t\t\tlet el = moduleEls[i];\n\n\t\t\t// All data- attributes considered as options\n\t\t\tlet options = this.getElemData(el);\n\n\t\t\t// Add current DOM element and jQuery element\n\t\t\toptions.el = el;\n\t\t\toptions.$el = $(el);\n\n\t\t\t// Module does exist at this point\n\t\t\tlet attr = options.module;\n\n\t\t\t// Splitting modules found in the data-attribute\n\t\t\tlet moduleIdents = attr.replace(/\\s/g, '').split(',');\n\n\t\t\t// Loop modules\n\t\t\tlet j = 0;\n\t\t\tlet modulesLen = moduleIdents.length;\n\n\t\t\tfor (; j < modulesLen; j++) {\n\t\t\t\tlet moduleAttr = moduleIdents[j];\n\n\t\t\t\tif (typeof this.modules[moduleAttr] === 'function') {\n\t\t\t\t\tlet module = new this.modules[moduleAttr](options);\n\t\t\t\t\tthis.currentModules.push(module);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t}\n\n\t/**\n\t * Get element data attributes\n\t * @param   {DOMElement}  el\n\t * @return  {Array}       data\n\t */\n\tgetElemData(el) {\n\t\t// All attributes\n\t\tvar attributes = el.attributes;\n\n\t\t// Regex Pattern\n\t\tvar pattern = /^data\\-(.+)$/;\n\n\t\t// Output\n\t\tvar data = {};\n\n\t\tfor (let i in attributes) {\n\t\t\t// Attributes name (ex: data-module)\n\t\t\tlet name = attributes[i].name;\n\n\t\t\t// This happens.\n\t\t\tif (!name) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tlet match = name.match(pattern);\n\t\t\tif (!match) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\t// If this throws an error, you have some\n\t\t\t// serious problems in your HTML.\n\t\t\tdata[match[1]] = el.getAttribute(name);\n\t\t}\n\n\t\treturn data;\n\t}\n\n\t/**\n\t * Initialize app after document ready\n\t */\n\tinit() {\n\t\tthis.initGlobals().initModules();\n\t}\n}\n\n$(function() {\n\twindow.app = new App();\n\twindow.app.init();\n});\n","/* jshint esnext: true */\nexport default function() {\n\tsvg4everybody();\n}\n","/* jshint esnext: true */\nexport {default as Button} from './modules/Button';\nexport {default as Title} from './modules/Title';\n","import { $document, $window, $html, $body } from '../utils/environment';\n\n/**\n * Abstract module\n * Gives access to generic jQuery nodes\n */\nclass AbstractModule {\n\tconstructor(options) {\n\t\tthis.$document = $document;\n\t\tthis.$window = $window;\n\t\tthis.$html = $html;\n\t\tthis.$body = $body;\n\t\tthis.$el = options.$el;\n\t}\n}\n\nexport default AbstractModule;\n","/* jshint esnext: true */\nimport AbstractModule from './AbstractModule';\n\nexport default class extends AbstractModule {\n\tconstructor(options) {\n\t\tsuper(options);\n\n\t\tthis.$el.on('click', (event) => {\n\t\t\tthis.$document.trigger('title.changeLabel', [$(event.currentTarget).val()]);\n\t\t});\n\t}\n\n\tdestroy() {\n\t\tthis.$el.off('.Button');\n\t}\n}\n","/* jshint esnext: true */\nimport AbstractModule from './AbstractModule';\n\nexport default class extends AbstractModule {\n\tconstructor(options) {\n\t\tsuper(options);\n\n\t\tthis.$label = this.$el.find('.js-label');\n\n\t\tthis.$document.on('title.changeLabel', (event, value) => {\n\t\t\tthis.changeLabel(value);\n\t\t});\n\t}\n\n\tchangeLabel(value) {\n\t\tthis.$label.text(value);\n\t}\n\n\tdestroy() {\n\t\tthis.$document.off('title.changeLabel');\n\t\tthis.$el.off('.Title');\n\t}\n}\n","const $document = $(document);\nconst $window = $(window);\nconst $html = $(document.documentElement);\nconst $body = $(document.body);\n\nexport { $document, $window, $html, $body };\n","/* jshint esnext: true */\nimport svg from '../global/svg';\n\nexport default function() {\n\tsvg();\n}\n"]}