Files
OfficialSite/www/assets/scripts/app.js
dominiclord f07a6aba23 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
2016-05-18 23:12:36 -04:00

356 lines
22 KiB
JavaScript

(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})({1:[function(require,module,exports){
'use strict';
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() {
_classCallCheck(this, App);
this.modules = modules;
this.currentModules = [];
}
/**
* Execute global functions and settings
* @return {Object}
*/
_createClass(App, [{
key: 'initGlobals',
value: function initGlobals() {
(0, _globals2.default)();
return this;
}
/**
* Find modules and initialize them
* @return {Object} this Allows chaining
*/
}, {
key: 'initModules',
value: function initModules() {
// Elements with module
var moduleEls = document.querySelectorAll('[data-module]');
// Loop through elements
var i = 0;
var elsLen = moduleEls.length;
for (; i < elsLen; i++) {
// Current element
var el = moduleEls[i];
// All data- attributes considered as options
var options = this.getElemData(el);
// Add current DOM element and jQuery element
options.el = el;
options.$el = $(el);
// Module does exist at this point
var attr = options.module;
// Splitting modules found in the data-attribute
var moduleIdents = attr.replace(/\s/g, '').split(',');
// Loop modules
var j = 0;
var modulesLen = moduleIdents.length;
for (; j < modulesLen; j++) {
var moduleAttr = moduleIdents[j];
if (typeof this.modules[moduleAttr] === 'function') {
var module = new this.modules[moduleAttr](options);
this.currentModules.push(module);
}
}
}
return this;
}
/**
* Get element data attributes
* @param {DOMElement} el
* @return {Array} data
*/
}, {
key: 'getElemData',
value: function getElemData(el) {
// All attributes
var attributes = el.attributes;
// Regex Pattern
var pattern = /^data\-(.+)$/;
// Output
var data = {};
for (var i in attributes) {
// Attributes name (ex: data-module)
var name = attributes[i].name;
// This happens.
if (!name) {
continue;
}
var match = name.match(pattern);
if (!match) {
continue;
}
// If this throws an error, you have some
// serious problems in your HTML.
data[match[1]] = el.getAttribute(name);
}
return data;
}
/**
* Initialize app after document ready
*/
}, {
key: 'init',
value: function init() {
this.initGlobals().initModules();
}
}]);
return App;
}();
$(function () {
window.app = new App();
window.app.init();
});
},{"./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 _Button = require('./modules/Button');
Object.defineProperty(exports, 'Button', {
enumerable: true,
get: function get() {
return _interopRequireDefault(_Button).default;
}
});
var _Title = require('./modules/Title');
Object.defineProperty(exports, 'Title', {
enumerable: true,
get: function get() {
return _interopRequireDefault(_Title).default;
}
});
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
},{"./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", {
value: true
});
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 _AbstractModule2 = require('./AbstractModule');
var _AbstractModule3 = _interopRequireDefault(_AbstractModule2);
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; } /* jshint esnext: true */
var _class = function (_AbstractModule) {
_inherits(_class, _AbstractModule);
function _class(options) {
_classCallCheck(this, _class);
var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(_class).call(this, options));
_this.$el.on('click', function (event) {
_this.$document.trigger('title.changeLabel', [$(event.currentTarget).val()]);
});
return _this;
}
_createClass(_class, [{
key: 'destroy',
value: function destroy() {
this.$el.off('.Button');
}
}]);
return _class;
}(_AbstractModule3.default);
exports.default = _class;
},{"./AbstractModule":4}],6:[function(require,module,exports){
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
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 _AbstractModule2 = require('./AbstractModule');
var _AbstractModule3 = _interopRequireDefault(_AbstractModule2);
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; } /* jshint esnext: true */
var _class = function (_AbstractModule) {
_inherits(_class, _AbstractModule);
function _class(options) {
_classCallCheck(this, _class);
var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(_class).call(this, options));
_this.$label = _this.$el.find('.js-label');
_this.$document.on('title.changeLabel', function (event, value) {
_this.changeLabel(value);
});
return _this;
}
_createClass(_class, [{
key: 'changeLabel',
value: function changeLabel(value) {
this.$label.text(value);
}
}, {
key: 'destroy',
value: function destroy() {
this.$document.off('title.changeLabel');
this.$el.off('.Title');
}
}]);
return _class;
}(_AbstractModule3.default);
exports.default = _class;
},{"./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"]}