diff --git a/build/dat.gui.js b/build/dat.gui.js
new file mode 100644
index 0000000..edac2b3
--- /dev/null
+++ b/build/dat.gui.js
@@ -0,0 +1,4521 @@
+(function webpackUniversalModuleDefinition(root, factory) {
+ if(typeof exports === 'object' && typeof module === 'object')
+ module.exports = factory();
+ else if(typeof define === 'function' && define.amd)
+ define(factory);
+ else if(typeof exports === 'object')
+ exports["dat"] = factory();
+ else
+ root["dat"] = factory();
+})(this, function() {
+return /******/ (function(modules) { // webpackBootstrap
+/******/ // The module cache
+/******/ var installedModules = {};
+/******/
+/******/ // The require function
+/******/ function __webpack_require__(moduleId) {
+/******/
+/******/ // Check if module is in cache
+/******/ if(installedModules[moduleId])
+/******/ return installedModules[moduleId].exports;
+/******/
+/******/ // Create a new module (and put it into the cache)
+/******/ var module = installedModules[moduleId] = {
+/******/ exports: {},
+/******/ id: moduleId,
+/******/ loaded: false
+/******/ };
+/******/
+/******/ // Execute the module function
+/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
+/******/
+/******/ // Flag the module as loaded
+/******/ module.loaded = true;
+/******/
+/******/ // Return the exports of the module
+/******/ return module.exports;
+/******/ }
+/******/
+/******/
+/******/ // expose the modules object (__webpack_modules__)
+/******/ __webpack_require__.m = modules;
+/******/
+/******/ // expose the module cache
+/******/ __webpack_require__.c = installedModules;
+/******/
+/******/ // __webpack_public_path__
+/******/ __webpack_require__.p = "";
+/******/
+/******/ // Load entry module and return exports
+/******/ return __webpack_require__(0);
+/******/ })
+/************************************************************************/
+/******/ ([
+/* 0 */
+/***/ function(module, exports, __webpack_require__) {
+
+ 'use strict';
+
+ module.exports = __webpack_require__(1);
+
+/***/ },
+/* 1 */
+/***/ function(module, exports, __webpack_require__) {
+
+ 'use strict';
+
+ module.exports = {
+ color: {
+ Color: __webpack_require__(2),
+ math: __webpack_require__(6),
+ interpret: __webpack_require__(3)
+ },
+
+ controllers: {
+ Controller: __webpack_require__(7),
+ BooleanController: __webpack_require__(8),
+ OptionController: __webpack_require__(9),
+ StringController: __webpack_require__(11),
+ NumberController: __webpack_require__(12),
+ NumberControllerBox: __webpack_require__(13),
+ NumberControllerSlider: __webpack_require__(14),
+ FunctionController: __webpack_require__(20),
+ ColorController: __webpack_require__(21)
+ },
+
+ dom: {
+ dom: __webpack_require__(10)
+ },
+
+ gui: {
+ GUI: __webpack_require__(22)
+ },
+
+ GUI: __webpack_require__(22)
+ };
+
+/***/ },
+/* 2 */
+/***/ function(module, exports, __webpack_require__) {
+
+ /**
+ * dat-gui JavaScript Controller Library
+ * http://code.google.com/p/dat-gui
+ *
+ * Copyright 2011 Data Arts Team, Google Creative Lab
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ */
+
+ '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; }; })();
+
+ 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 _interpret = __webpack_require__(3);
+
+ var _interpret2 = _interopRequireDefault(_interpret);
+
+ var _math = __webpack_require__(6);
+
+ var _math2 = _interopRequireDefault(_math);
+
+ var _toString = __webpack_require__(4);
+
+ var _toString2 = _interopRequireDefault(_toString);
+
+ var _utilsCommon = __webpack_require__(5);
+
+ var _utilsCommon2 = _interopRequireDefault(_utilsCommon);
+
+ var Color = (function () {
+ function Color() {
+ _classCallCheck(this, Color);
+
+ this.__state = _interpret2['default'].apply(this, arguments);
+
+ if (this.__state === false) {
+ throw 'Failed to interpret color arguments';
+ }
+
+ this.__state.a = this.__state.a || 1;
+ }
+
+ _createClass(Color, [{
+ key: 'toString',
+ value: function toString() {
+ return (0, _toString2['default'])(this);
+ }
+ }, {
+ key: 'toOriginal',
+ value: function toOriginal() {
+ return this.__state.conversion.write(this);
+ }
+ }]);
+
+ return Color;
+ })();
+
+ Color.recalculateRGB = function (color, component, componentHexIndex) {
+ if (color.__state.space === 'HEX') {
+ color.__state[component] = _math2['default'].component_from_hex(color.__state.hex, componentHexIndex);
+ } else if (color.__state.space === 'HSV') {
+ _utilsCommon2['default'].extend(color.__state, _math2['default'].hsv_to_rgb(color.__state.h, color.__state.s, color.__state.v));
+ } else {
+ throw 'Corrupted color state';
+ }
+ };
+
+ Color.recalculateHSV = function (color) {
+ var result = _math2['default'].rgb_to_hsv(color.r, color.g, color.b);
+
+ _utilsCommon2['default'].extend(color.__state, {
+ s: result.s,
+ v: result.v
+ });
+
+ if (!_utilsCommon2['default'].isNaN(result.h)) {
+ color.__state.h = result.h;
+ } else if (_utilsCommon2['default'].isUndefined(color.__state.h)) {
+ color.__state.h = 0;
+ }
+ };
+
+ Color.COMPONENTS = ['r', 'g', 'b', 'h', 's', 'v', 'hex', 'a'];
+
+ defineRGBComponent(Color.prototype, 'r', 2);
+ defineRGBComponent(Color.prototype, 'g', 1);
+ defineRGBComponent(Color.prototype, 'b', 0);
+
+ defineHSVComponent(Color.prototype, 'h');
+ defineHSVComponent(Color.prototype, 's');
+ defineHSVComponent(Color.prototype, 'v');
+
+ Object.defineProperty(Color.prototype, 'a', {
+
+ get: function get() {
+ return this.__state.a;
+ },
+
+ set: function set(v) {
+ this.__state.a = v;
+ }
+ });
+
+ Object.defineProperty(Color.prototype, 'hex', {
+ get: function get() {
+ if (!this.__state.space !== 'HEX') {
+ this.__state.hex = _math2['default'].rgb_to_hex(this.r, this.g, this.b);
+ }
+
+ return this.__state.hex;
+ },
+
+ set: function set(v) {
+ this.__state.space = 'HEX';
+ this.__state.hex = v;
+ }
+ });
+
+ function defineRGBComponent(target, component, componentHexIndex) {
+
+ Object.defineProperty(target, component, {
+ get: function get() {
+ if (this.__state.space === 'RGB') {
+ return this.__state[component];
+ }
+
+ Color.recalculateRGB(this, component, componentHexIndex);
+
+ return this.__state[component];
+ },
+
+ set: function set(v) {
+ if (this.__state.space !== 'RGB') {
+ Color.recalculateRGB(this, component, componentHexIndex);
+ this.__state.space = 'RGB';
+ }
+
+ this.__state[component] = v;
+ }
+ });
+ }
+
+ function defineHSVComponent(target, component) {
+ Object.defineProperty(target, component, {
+ get: function get() {
+ if (this.__state.space === 'HSV') return this.__state[component];
+
+ Color.recalculateHSV(this);
+
+ return this.__state[component];
+ },
+
+ set: function set(v) {
+ if (this.__state.space !== 'HSV') {
+ Color.recalculateHSV(this);
+ this.__state.space = 'HSV';
+ }
+
+ this.__state[component] = v;
+ }
+ });
+ }
+
+ exports['default'] = Color;
+ module.exports = exports['default'];
+
+/***/ },
+/* 3 */
+/***/ function(module, exports, __webpack_require__) {
+
+ /**
+ * dat-gui JavaScript Controller Library
+ * http://code.google.com/p/dat-gui
+ *
+ * Copyright 2011 Data Arts Team, Google Creative Lab
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ */
+
+ 'use strict';
+
+ Object.defineProperty(exports, '__esModule', {
+ value: true
+ });
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
+
+ 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; } }
+
+ var _toString = __webpack_require__(4);
+
+ var toString = _interopRequireWildcard(_toString);
+
+ var _utilsCommon = __webpack_require__(5);
+
+ var _utilsCommon2 = _interopRequireDefault(_utilsCommon);
+
+ var result, toReturn;
+
+ var interpret = function interpret() {
+ toReturn = false;
+
+ var original = arguments.length > 1 ? _utilsCommon2['default'].toArray(arguments) : arguments[0];
+ _utilsCommon2['default'].each(INTERPRETATIONS, function (family) {
+
+ if (family.litmus(original)) {
+ _utilsCommon2['default'].each(family.conversions, function (conversion, conversionName) {
+ result = conversion.read(original);
+
+ if (toReturn === false && result !== false) {
+ toReturn = result;
+ result.conversionName = conversionName;
+ result.conversion = conversion;
+ return _utilsCommon2['default'].BREAK;
+ }
+ });
+
+ return _utilsCommon2['default'].BREAK;
+ }
+ });
+
+ return toReturn;
+ };
+
+ var INTERPRETATIONS = [
+ // Strings
+ {
+ litmus: _utilsCommon2['default'].isString,
+ conversions: {
+ THREE_CHAR_HEX: {
+ read: function read(original) {
+
+ var test = original.match(/^#([A-F0-9])([A-F0-9])([A-F0-9])$/i);
+ if (test === null) return false;
+
+ return {
+ space: 'HEX',
+ hex: parseInt('0x' + test[1].toString() + test[1].toString() + test[2].toString() + test[2].toString() + test[3].toString() + test[3].toString())
+ };
+ },
+
+ write: toString
+ },
+
+ SIX_CHAR_HEX: {
+ read: function read(original) {
+
+ var test = original.match(/^#([A-F0-9]{6})$/i);
+ if (test === null) return false;
+
+ return {
+ space: 'HEX',
+ hex: parseInt('0x' + test[1].toString())
+ };
+ },
+
+ write: toString
+ },
+
+ CSS_RGB: {
+ read: function read(original) {
+
+ var test = original.match(/^rgb\(\s*(.+)\s*,\s*(.+)\s*,\s*(.+)\s*\)/);
+ if (test === null) return false;
+
+ return {
+ space: 'RGB',
+ r: parseFloat(test[1]),
+ g: parseFloat(test[2]),
+ b: parseFloat(test[3])
+ };
+ },
+
+ write: toString
+ },
+
+ CSS_RGBA: {
+ read: function read(original) {
+
+ var test = original.match(/^rgba\(\s*(.+)\s*,\s*(.+)\s*,\s*(.+)\s*\,\s*(.+)\s*\)/);
+ if (test === null) return false;
+
+ return {
+ space: 'RGB',
+ r: parseFloat(test[1]),
+ g: parseFloat(test[2]),
+ b: parseFloat(test[3]),
+ a: parseFloat(test[4])
+ };
+ },
+
+ write: toString
+ }
+ }
+ },
+
+ // Numbers
+ {
+ litmus: _utilsCommon2['default'].isNumber,
+
+ conversions: {
+
+ HEX: {
+ read: function read(original) {
+ return {
+ space: 'HEX',
+ hex: original,
+ conversionName: 'HEX'
+ };
+ },
+
+ write: function write(color) {
+ return color.hex;
+ }
+ }
+
+ }
+
+ },
+
+ // Arrays
+ {
+ litmus: _utilsCommon2['default'].isArray,
+ conversions: {
+
+ RGB_ARRAY: {
+ read: function read(original) {
+ if (original.length != 3) return false;
+ return {
+ space: 'RGB',
+ r: original[0],
+ g: original[1],
+ b: original[2]
+ };
+ },
+
+ write: function write(color) {
+ return [color.r, color.g, color.b];
+ }
+ },
+
+ RGBA_ARRAY: {
+ read: function read(original) {
+ if (original.length != 4) return false;
+ return {
+ space: 'RGB',
+ r: original[0],
+ g: original[1],
+ b: original[2],
+ a: original[3]
+ };
+ },
+
+ write: function write(color) {
+ return [color.r, color.g, color.b, color.a];
+ }
+ }
+ }
+ },
+
+ // Objects
+ {
+
+ litmus: _utilsCommon2['default'].isObject,
+
+ conversions: {
+
+ RGBA_OBJ: {
+ read: function read(original) {
+ if (_utilsCommon2['default'].isNumber(original.r) && _utilsCommon2['default'].isNumber(original.g) && _utilsCommon2['default'].isNumber(original.b) && _utilsCommon2['default'].isNumber(original.a)) {
+ return {
+ space: 'RGB',
+ r: original.r,
+ g: original.g,
+ b: original.b,
+ a: original.a
+ };
+ }
+ return false;
+ },
+
+ write: function write(color) {
+ return {
+ r: color.r,
+ g: color.g,
+ b: color.b,
+ a: color.a
+ };
+ }
+ },
+
+ RGB_OBJ: {
+ read: function read(original) {
+ if (_utilsCommon2['default'].isNumber(original.r) && _utilsCommon2['default'].isNumber(original.g) && _utilsCommon2['default'].isNumber(original.b)) {
+ return {
+ space: 'RGB',
+ r: original.r,
+ g: original.g,
+ b: original.b
+ };
+ }
+ return false;
+ },
+
+ write: function write(color) {
+ return {
+ r: color.r,
+ g: color.g,
+ b: color.b
+ };
+ }
+ },
+
+ HSVA_OBJ: {
+ read: function read(original) {
+ if (_utilsCommon2['default'].isNumber(original.h) && _utilsCommon2['default'].isNumber(original.s) && _utilsCommon2['default'].isNumber(original.v) && _utilsCommon2['default'].isNumber(original.a)) {
+ return {
+ space: 'HSV',
+ h: original.h,
+ s: original.s,
+ v: original.v,
+ a: original.a
+ };
+ }
+ return false;
+ },
+
+ write: function write(color) {
+ return {
+ h: color.h,
+ s: color.s,
+ v: color.v,
+ a: color.a
+ };
+ }
+ },
+
+ HSV_OBJ: {
+ read: function read(original) {
+ if (_utilsCommon2['default'].isNumber(original.h) && _utilsCommon2['default'].isNumber(original.s) && _utilsCommon2['default'].isNumber(original.v)) {
+ return {
+ space: 'HSV',
+ h: original.h,
+ s: original.s,
+ v: original.v
+ };
+ }
+ return false;
+ },
+
+ write: function write(color) {
+ return {
+ h: color.h,
+ s: color.s,
+ v: color.v
+ };
+ }
+ }
+ }
+ }];
+
+ exports['default'] = interpret;
+ module.exports = exports['default'];
+
+/***/ },
+/* 4 */
+/***/ function(module, exports, __webpack_require__) {
+
+ /**
+ * dat-gui JavaScript Controller Library
+ * http://code.google.com/p/dat-gui
+ *
+ * Copyright 2011 Data Arts Team, Google Creative Lab
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ */
+
+ 'use strict';
+
+ Object.defineProperty(exports, '__esModule', {
+ value: true
+ });
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
+
+ var _utilsCommon = __webpack_require__(5);
+
+ var _utilsCommon2 = _interopRequireDefault(_utilsCommon);
+
+ var colorToString = function colorToString(color) {
+ if (color.a == 1 || _utilsCommon2['default'].isUndefined(color.a)) {
+ var s = color.hex.toString(16);
+ while (s.length < 6) {
+ s = '0' + s;
+ }
+
+ return '#' + s;
+ } else {
+ return 'rgba(' + Math.round(color.r) + ',' + Math.round(color.g) + ',' + Math.round(color.b) + ',' + color.a + ')';
+ }
+ };
+
+ exports['default'] = colorToString;
+ module.exports = exports['default'];
+
+/***/ },
+/* 5 */
+/***/ function(module, exports) {
+
+ /**
+ * dat-gui JavaScript Controller Library
+ * http://code.google.com/p/dat-gui
+ *
+ * Copyright 2011 Data Arts Team, Google Creative Lab
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ */
+
+ 'use strict';
+
+ var ARR_EACH = Array.prototype.forEach;
+ var ARR_SLICE = Array.prototype.slice;
+
+ /**
+ * Band-aid methods for things that should be a lot easier in JavaScript.
+ * Implementation and structure inspired by underscore.js
+ * http://documentcloud.github.com/underscore/
+ */
+
+ var Common = {
+
+ BREAK: {},
+
+ extend: function extend(target) {
+
+ this.each(ARR_SLICE.call(arguments, 1), function (obj) {
+
+ for (var key in obj) if (!this.isUndefined(obj[key])) target[key] = obj[key];
+ }, this);
+
+ return target;
+ },
+
+ defaults: function defaults(target) {
+
+ this.each(ARR_SLICE.call(arguments, 1), function (obj) {
+
+ for (var key in obj) if (this.isUndefined(target[key])) target[key] = obj[key];
+ }, this);
+
+ return target;
+ },
+
+ compose: function compose() {
+ var toCall = ARR_SLICE.call(arguments);
+ return function () {
+ var args = ARR_SLICE.call(arguments);
+ for (var i = toCall.length - 1; i >= 0; i--) {
+ args = [toCall[i].apply(this, args)];
+ }
+ return args[0];
+ };
+ },
+
+ each: function each(obj, itr, scope) {
+
+ if (!obj) return;
+
+ if (ARR_EACH && obj.forEach && obj.forEach === ARR_EACH) {
+
+ obj.forEach(itr, scope);
+ } else if (obj.length === obj.length + 0) {
+ // Is number but not NaN
+
+ for (var key = 0, l = obj.length; key < l; key++) if (key in obj && itr.call(scope, obj[key], key) === this.BREAK) return;
+ } else {
+
+ for (var key in obj) if (itr.call(scope, obj[key], key) === this.BREAK) return;
+ }
+ },
+
+ defer: function defer(fnc) {
+ setTimeout(fnc, 0);
+ },
+
+ toArray: function toArray(obj) {
+ if (obj.toArray) return obj.toArray();
+ return ARR_SLICE.call(obj);
+ },
+
+ isUndefined: function isUndefined(obj) {
+ return obj === undefined;
+ },
+
+ isNull: function isNull(obj) {
+ return obj === null;
+ },
+
+ isNaN: function isNaN(obj) {
+ return obj !== obj;
+ },
+
+ isArray: Array.isArray || function (obj) {
+ return obj.constructor === Array;
+ },
+
+ isObject: function isObject(obj) {
+ return obj === Object(obj);
+ },
+
+ isNumber: function isNumber(obj) {
+ return obj === obj + 0;
+ },
+
+ isString: function isString(obj) {
+ return obj === obj + '';
+ },
+
+ isBoolean: function isBoolean(obj) {
+ return obj === false || obj === true;
+ },
+
+ isFunction: function isFunction(obj) {
+ return Object.prototype.toString.call(obj) === '[object Function]';
+ }
+
+ };
+
+ module.exports = Common;
+
+/***/ },
+/* 6 */
+/***/ function(module, exports) {
+
+ /**
+ * dat-gui JavaScript Controller Library
+ * http://code.google.com/p/dat-gui
+ *
+ * Copyright 2011 Data Arts Team, Google Creative Lab
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ */
+
+ "use strict";
+
+ Object.defineProperty(exports, "__esModule", {
+ value: true
+ });
+ var tmpComponent;
+
+ var ColorMath = {
+
+ hsv_to_rgb: function hsv_to_rgb(h, s, v) {
+
+ var hi = Math.floor(h / 60) % 6;
+
+ var f = h / 60 - Math.floor(h / 60);
+ var p = v * (1.0 - s);
+ var q = v * (1.0 - f * s);
+ var t = v * (1.0 - (1.0 - f) * s);
+ var c = [[v, t, p], [q, v, p], [p, v, t], [p, q, v], [t, p, v], [v, p, q]][hi];
+
+ return {
+ r: c[0] * 255,
+ g: c[1] * 255,
+ b: c[2] * 255
+ };
+ },
+
+ rgb_to_hsv: function rgb_to_hsv(r, g, b) {
+
+ var min = Math.min(r, g, b),
+ max = Math.max(r, g, b),
+ delta = max - min,
+ h,
+ s;
+
+ if (max != 0) {
+ s = delta / max;
+ } else {
+ return {
+ h: NaN,
+ s: 0,
+ v: 0
+ };
+ }
+
+ if (r == max) {
+ h = (g - b) / delta;
+ } else if (g == max) {
+ h = 2 + (b - r) / delta;
+ } else {
+ h = 4 + (r - g) / delta;
+ }
+ h /= 6;
+ if (h < 0) {
+ h += 1;
+ }
+
+ return {
+ h: h * 360,
+ s: s,
+ v: max / 255
+ };
+ },
+
+ rgb_to_hex: function rgb_to_hex(r, g, b) {
+ var hex = this.hex_with_component(0, 2, r);
+ hex = this.hex_with_component(hex, 1, g);
+ hex = this.hex_with_component(hex, 0, b);
+ return hex;
+ },
+
+ component_from_hex: function component_from_hex(hex, componentIndex) {
+ return hex >> componentIndex * 8 & 0xFF;
+ },
+
+ hex_with_component: function hex_with_component(hex, componentIndex, value) {
+ return value << (tmpComponent = componentIndex * 8) | hex & ~(0xFF << tmpComponent);
+ }
+ };
+
+ exports["default"] = ColorMath;
+ module.exports = exports["default"];
+
+/***/ },
+/* 7 */
+/***/ function(module, exports, __webpack_require__) {
+
+ /**
+ * dat-gui JavaScript Controller Library
+ * http://code.google.com/p/dat-gui
+ *
+ * Copyright 2011 Data Arts Team, Google Creative Lab
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ */
+
+ '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; }; })();
+
+ 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 _utilsCommon = __webpack_require__(5);
+
+ var _utilsCommon2 = _interopRequireDefault(_utilsCommon);
+
+ /**
+ * @class An "abstract" class that represents a given property of an object.
+ *
+ * @param {Object} object The object to be manipulated
+ * @param {string} property The name of the property to be manipulated
+ *
+ * @member dat.controllers
+ */
+
+ var Controller = (function () {
+ function Controller(object, property) {
+ _classCallCheck(this, Controller);
+
+ this.initialValue = object[property];
+
+ /**
+ * Those who extend this class will put their DOM elements in here.
+ * @type {DOMElement}
+ */
+ this.domElement = document.createElement('div');
+
+ /**
+ * The object to manipulate
+ * @type {Object}
+ */
+ this.object = object;
+
+ /**
+ * The name of the property to manipulate
+ * @type {String}
+ */
+ this.property = property;
+
+ /**
+ * The function to be called on change.
+ * @type {Function}
+ * @ignore
+ */
+ this.__onChange = undefined;
+
+ /**
+ * The function to be called on finishing change.
+ * @type {Function}
+ * @ignore
+ */
+ this.__onFinishChange = undefined;
+ }
+
+ /**
+ * Specify that a function fire every time someone changes the value with
+ * this Controller.
+ *
+ * @param {Function} fnc This function will be called whenever the value
+ * is modified via this Controller.
+ * @returns {dat.controllers.Controller} this
+ */
+
+ _createClass(Controller, [{
+ key: 'onChange',
+ value: function onChange(fnc) {
+ this.__onChange = fnc;
+ return this;
+ }
+
+ /**
+ * Specify that a function fire every time someone "finishes" changing
+ * the value wih this Controller. Useful for values that change
+ * incrementally like numbers or strings.
+ *
+ * @param {Function} fnc This function will be called whenever
+ * someone "finishes" changing the value via this Controller.
+ * @returns {dat.controllers.Controller} this
+ */
+ }, {
+ key: 'onFinishChange',
+ value: function onFinishChange(fnc) {
+ this.__onFinishChange = fnc;
+ return this;
+ }
+
+ /**
+ * Change the value of object[property]
+ *
+ * @param {Object} newValue The new value of object[property]
+ */
+ }, {
+ key: 'setValue',
+ value: function setValue(newValue) {
+ this.object[this.property] = newValue;
+ if (this.__onChange) {
+ this.__onChange.call(this, newValue);
+ }
+ this.updateDisplay();
+ return this;
+ }
+
+ /**
+ * Gets the value of object[property]
+ *
+ * @returns {Object} The current value of object[property]
+ */
+ }, {
+ key: 'getValue',
+ value: function getValue() {
+ return this.object[this.property];
+ }
+
+ /**
+ * Refreshes the visual display of a Controller in order to keep sync
+ * with the object's current value.
+ * @returns {dat.controllers.Controller} this
+ */
+ }, {
+ key: 'updateDisplay',
+ value: function updateDisplay() {
+ return this;
+ }
+
+ /**
+ * @returns {Boolean} true if the value has deviated from initialValue
+ */
+ }, {
+ key: 'isModified',
+ value: function isModified() {
+ return this.initialValue !== this.getValue();
+ }
+ }]);
+
+ return Controller;
+ })();
+
+ exports['default'] = Controller;
+ module.exports = exports['default'];
+
+/***/ },
+/* 8 */
+/***/ function(module, exports, __webpack_require__) {
+
+ /**
+ * dat-gui JavaScript Controller Library
+ * http://code.google.com/p/dat-gui
+ *
+ * Copyright 2011 Data Arts Team, Google Creative Lab
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ */
+
+ '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 _get = function get(_x, _x2, _x3) { var _again = true; _function: while (_again) { var object = _x, property = _x2, receiver = _x3; desc = parent = getter = undefined; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x = parent; _x2 = property; _x3 = receiver; _again = true; continue _function; } } else if ('value' in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };
+
+ 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 _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; }
+
+ var _Controller2 = __webpack_require__(7);
+
+ var _Controller3 = _interopRequireDefault(_Controller2);
+
+ var _domDom = __webpack_require__(10);
+
+ var _domDom2 = _interopRequireDefault(_domDom);
+
+ var _utilsCommon = __webpack_require__(5);
+
+ var _utilsCommon2 = _interopRequireDefault(_utilsCommon);
+
+ /**
+ * @class Provides a checkbox input to alter the boolean property of an object.
+ * @extends dat.controllers.Controller
+ *
+ * @param {Object} object The object to be manipulated
+ * @param {string} property The name of the property to be manipulated
+ *
+ * @member dat.controllers
+ */
+
+ var BooleanController = (function (_Controller) {
+ _inherits(BooleanController, _Controller);
+
+ function BooleanController(object, property) {
+ _classCallCheck(this, BooleanController);
+
+ _get(Object.getPrototypeOf(BooleanController.prototype), 'constructor', this).call(this, object, property);
+
+ var _this = this;
+ this.__prev = this.getValue();
+
+ this.__checkbox = document.createElement('input');
+ this.__checkbox.setAttribute('type', 'checkbox');
+
+ function onChange() {
+ _this.setValue(!_this.__prev);
+ }
+
+ _domDom2['default'].bind(this.__checkbox, 'change', onChange, false);
+
+ this.domElement.appendChild(this.__checkbox);
+
+ // Match original value
+ this.updateDisplay();
+ }
+
+ _createClass(BooleanController, [{
+ key: 'setValue',
+ value: function setValue(v) {
+ var toReturn = _get(Object.getPrototypeOf(BooleanController.prototype), 'setValue', this).call(this, v);
+ if (this.__onFinishChange) {
+ this.__onFinishChange.call(this, this.getValue());
+ }
+ this.__prev = this.getValue();
+ return toReturn;
+ }
+ }, {
+ key: 'updateDisplay',
+ value: function updateDisplay() {
+ if (this.getValue() === true) {
+ this.__checkbox.setAttribute('checked', 'checked');
+ this.__checkbox.checked = true;
+ } else {
+ this.__checkbox.checked = false;
+ }
+
+ return _get(Object.getPrototypeOf(BooleanController.prototype), 'updateDisplay', this).call(this);
+ }
+ }]);
+
+ return BooleanController;
+ })(_Controller3['default']);
+
+ exports['default'] = BooleanController;
+ module.exports = exports['default'];
+
+/***/ },
+/* 9 */
+/***/ function(module, exports, __webpack_require__) {
+
+ /**
+ * dat-gui JavaScript Controller Library
+ * http://code.google.com/p/dat-gui
+ *
+ * Copyright 2011 Data Arts Team, Google Creative Lab
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ */
+
+ '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 _get = function get(_x, _x2, _x3) { var _again = true; _function: while (_again) { var object = _x, property = _x2, receiver = _x3; desc = parent = getter = undefined; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x = parent; _x2 = property; _x3 = receiver; _again = true; continue _function; } } else if ('value' in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };
+
+ 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 _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; }
+
+ var _Controller2 = __webpack_require__(7);
+
+ var _Controller3 = _interopRequireDefault(_Controller2);
+
+ var _domDom = __webpack_require__(10);
+
+ var _domDom2 = _interopRequireDefault(_domDom);
+
+ var _utilsCommon = __webpack_require__(5);
+
+ var _utilsCommon2 = _interopRequireDefault(_utilsCommon);
+
+ /**
+ * @class Provides a select input to alter the property of an object, using a
+ * list of accepted values.
+ *
+ * @extends dat.controllers.Controller
+ *
+ * @param {Object} object The object to be manipulated
+ * @param {string} property The name of the property to be manipulated
+ * @param {Object|string[]} options A map of labels to acceptable values, or
+ * a list of acceptable string values.
+ *
+ * @member dat.controllers
+ */
+
+ var OptionController = (function (_Controller) {
+ _inherits(OptionController, _Controller);
+
+ function OptionController(object, property, options) {
+ _classCallCheck(this, OptionController);
+
+ _get(Object.getPrototypeOf(OptionController.prototype), 'constructor', this).call(this, object, property);
+
+ var _this = this;
+
+ /**
+ * The drop down menu
+ * @ignore
+ */
+ this.__select = document.createElement('select');
+
+ if (_utilsCommon2['default'].isArray(options)) {
+ var map = {};
+ _utilsCommon2['default'].each(options, function (element) {
+ map[element] = element;
+ });
+ options = map;
+ }
+
+ _utilsCommon2['default'].each(options, function (value, key) {
+
+ var opt = document.createElement('option');
+ opt.innerHTML = key;
+ opt.setAttribute('value', value);
+ _this.__select.appendChild(opt);
+ });
+
+ // Acknowledge original value
+ this.updateDisplay();
+
+ _domDom2['default'].bind(this.__select, 'change', function () {
+ var desiredValue = this.options[this.selectedIndex].value;
+ _this.setValue(desiredValue);
+ });
+
+ this.domElement.appendChild(this.__select);
+ }
+
+ _createClass(OptionController, [{
+ key: 'setValue',
+ value: function setValue(v) {
+ var toReturn = _get(Object.getPrototypeOf(OptionController.prototype), 'setValue', this).call(this, v);
+
+ if (this.__onFinishChange) {
+ this.__onFinishChange.call(this, this.getValue());
+ }
+ return toReturn;
+ }
+ }, {
+ key: 'updateDisplay',
+ value: function updateDisplay() {
+ this.__select.value = this.getValue();
+ return _get(Object.getPrototypeOf(OptionController.prototype), 'updateDisplay', this).call(this);
+ }
+ }]);
+
+ return OptionController;
+ })(_Controller3['default']);
+
+ exports['default'] = OptionController;
+ module.exports = exports['default'];
+
+/***/ },
+/* 10 */
+/***/ function(module, exports, __webpack_require__) {
+
+ /**
+ * dat-gui JavaScript Controller Library
+ * http://code.google.com/p/dat-gui
+ *
+ * Copyright 2011 Data Arts Team, Google Creative Lab
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ */
+
+ 'use strict';
+
+ Object.defineProperty(exports, '__esModule', {
+ value: true
+ });
+
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
+
+ var _utilsCommon = __webpack_require__(5);
+
+ var _utilsCommon2 = _interopRequireDefault(_utilsCommon);
+
+ var EVENT_MAP = {
+ 'HTMLEvents': ['change'],
+ 'MouseEvents': ['click', 'mousemove', 'mousedown', 'mouseup', 'mouseover'],
+ 'KeyboardEvents': ['keydown']
+ };
+
+ var EVENT_MAP_INV = {};
+ _utilsCommon2['default'].each(EVENT_MAP, function (v, k) {
+ _utilsCommon2['default'].each(v, function (e) {
+ EVENT_MAP_INV[e] = k;
+ });
+ });
+
+ var CSS_VALUE_PIXELS = /(\d+(\.\d+)?)px/;
+
+ function cssValueToPixels(val) {
+
+ if (val === '0' || _utilsCommon2['default'].isUndefined(val)) return 0;
+
+ var match = val.match(CSS_VALUE_PIXELS);
+
+ if (!_utilsCommon2['default'].isNull(match)) {
+ return parseFloat(match[1]);
+ }
+
+ // TODO ...ems? %?
+
+ return 0;
+ }
+
+ /**
+ * @namespace
+ * @member dat.dom
+ */
+ var dom = {
+
+ /**
+ *
+ * @param elem
+ * @param selectable
+ */
+ makeSelectable: function makeSelectable(elem, selectable) {
+
+ if (elem === undefined || elem.style === undefined) return;
+
+ elem.onselectstart = selectable ? function () {
+ return false;
+ } : function () {};
+
+ elem.style.MozUserSelect = selectable ? 'auto' : 'none';
+ elem.style.KhtmlUserSelect = selectable ? 'auto' : 'none';
+ elem.unselectable = selectable ? 'on' : 'off';
+ },
+
+ /**
+ *
+ * @param elem
+ * @param horizontal
+ * @param vertical
+ */
+ makeFullscreen: function makeFullscreen(elem, horizontal, vertical) {
+
+ if (_utilsCommon2['default'].isUndefined(horizontal)) horizontal = true;
+ if (_utilsCommon2['default'].isUndefined(vertical)) vertical = true;
+
+ elem.style.position = 'absolute';
+
+ if (horizontal) {
+ elem.style.left = 0;
+ elem.style.right = 0;
+ }
+ if (vertical) {
+ elem.style.top = 0;
+ elem.style.bottom = 0;
+ }
+ },
+
+ /**
+ *
+ * @param elem
+ * @param eventType
+ * @param params
+ */
+ fakeEvent: function fakeEvent(elem, eventType, params, aux) {
+ params = params || {};
+ var className = EVENT_MAP_INV[eventType];
+ if (!className) {
+ throw new Error('Event type ' + eventType + ' not supported.');
+ }
+ var evt = document.createEvent(className);
+ switch (className) {
+ case 'MouseEvents':
+ var clientX = params.x || params.clientX || 0;
+ var clientY = params.y || params.clientY || 0;
+ evt.initMouseEvent(eventType, params.bubbles || false, params.cancelable || true, window, params.clickCount || 1, 0, //screen X
+ 0, //screen Y
+ clientX, //client X
+ clientY, //client Y
+ false, false, false, false, 0, null);
+ break;
+ case 'KeyboardEvents':
+ var init = evt.initKeyboardEvent || evt.initKeyEvent; // webkit || moz
+ _utilsCommon2['default'].defaults(params, {
+ cancelable: true,
+ ctrlKey: false,
+ altKey: false,
+ shiftKey: false,
+ metaKey: false,
+ keyCode: undefined,
+ charCode: undefined
+ });
+ init(eventType, params.bubbles || false, params.cancelable, window, params.ctrlKey, params.altKey, params.shiftKey, params.metaKey, params.keyCode, params.charCode);
+ break;
+ default:
+ evt.initEvent(eventType, params.bubbles || false, params.cancelable || true);
+ break;
+ }
+ _utilsCommon2['default'].defaults(evt, aux);
+ elem.dispatchEvent(evt);
+ },
+
+ /**
+ *
+ * @param elem
+ * @param event
+ * @param func
+ * @param bool
+ */
+ bind: function bind(elem, event, func, bool) {
+ bool = bool || false;
+ if (elem.addEventListener) elem.addEventListener(event, func, bool);else if (elem.attachEvent) elem.attachEvent('on' + event, func);
+ return dom;
+ },
+
+ /**
+ *
+ * @param elem
+ * @param event
+ * @param func
+ * @param bool
+ */
+ unbind: function unbind(elem, event, func, bool) {
+ bool = bool || false;
+ if (elem.removeEventListener) elem.removeEventListener(event, func, bool);else if (elem.detachEvent) elem.detachEvent('on' + event, func);
+ return dom;
+ },
+
+ /**
+ *
+ * @param elem
+ * @param className
+ */
+ addClass: function addClass(elem, className) {
+ if (elem.className === undefined) {
+ elem.className = className;
+ } else if (elem.className !== className) {
+ var classes = elem.className.split(/ +/);
+ if (classes.indexOf(className) == -1) {
+ classes.push(className);
+ elem.className = classes.join(' ').replace(/^\s+/, '').replace(/\s+$/, '');
+ }
+ }
+ return dom;
+ },
+
+ /**
+ *
+ * @param elem
+ * @param className
+ */
+ removeClass: function removeClass(elem, className) {
+ if (className) {
+ if (elem.className === undefined) {
+ // elem.className = className;
+ } else if (elem.className === className) {
+ elem.removeAttribute('class');
+ } else {
+ var classes = elem.className.split(/ +/);
+ var index = classes.indexOf(className);
+ if (index != -1) {
+ classes.splice(index, 1);
+ elem.className = classes.join(' ');
+ }
+ }
+ } else {
+ elem.className = undefined;
+ }
+ return dom;
+ },
+
+ hasClass: function hasClass(elem, className) {
+ return new RegExp('(?:^|\\s+)' + className + '(?:\\s+|$)').test(elem.className) || false;
+ },
+
+ /**
+ *
+ * @param elem
+ */
+ getWidth: function getWidth(elem) {
+
+ var style = getComputedStyle(elem);
+
+ return cssValueToPixels(style['border-left-width']) + cssValueToPixels(style['border-right-width']) + cssValueToPixels(style['padding-left']) + cssValueToPixels(style['padding-right']) + cssValueToPixels(style['width']);
+ },
+
+ /**
+ *
+ * @param elem
+ */
+ getHeight: function getHeight(elem) {
+
+ var style = getComputedStyle(elem);
+
+ return cssValueToPixels(style['border-top-width']) + cssValueToPixels(style['border-bottom-width']) + cssValueToPixels(style['padding-top']) + cssValueToPixels(style['padding-bottom']) + cssValueToPixels(style['height']);
+ },
+
+ /**
+ *
+ * @param elem
+ */
+ getOffset: function getOffset(elem) {
+ var offset = { left: 0, top: 0 };
+ if (elem.offsetParent) {
+ do {
+ offset.left += elem.offsetLeft;
+ offset.top += elem.offsetTop;
+ } while (elem = elem.offsetParent);
+ }
+ return offset;
+ },
+
+ // http://stackoverflow.com/posts/2684561/revisions
+ /**
+ *
+ * @param elem
+ */
+ isActive: function isActive(elem) {
+ return elem === document.activeElement && (elem.type || elem.href);
+ }
+
+ };
+
+ exports['default'] = dom;
+ module.exports = exports['default'];
+
+/***/ },
+/* 11 */
+/***/ function(module, exports, __webpack_require__) {
+
+ /**
+ * dat-gui JavaScript Controller Library
+ * http://code.google.com/p/dat-gui
+ *
+ * Copyright 2011 Data Arts Team, Google Creative Lab
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ */
+
+ '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 _get = function get(_x, _x2, _x3) { var _again = true; _function: while (_again) { var object = _x, property = _x2, receiver = _x3; desc = parent = getter = undefined; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x = parent; _x2 = property; _x3 = receiver; _again = true; continue _function; } } else if ('value' in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };
+
+ 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 _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; }
+
+ var _Controller2 = __webpack_require__(7);
+
+ var _Controller3 = _interopRequireDefault(_Controller2);
+
+ var _domDom = __webpack_require__(10);
+
+ var _domDom2 = _interopRequireDefault(_domDom);
+
+ var _utilsCommon = __webpack_require__(5);
+
+ var _utilsCommon2 = _interopRequireDefault(_utilsCommon);
+
+ /**
+ * @class Provides a text input to alter the string property of an object.
+ *
+ * @extends dat.controllers.Controller
+ *
+ * @param {Object} object The object to be manipulated
+ * @param {string} property The name of the property to be manipulated
+ *
+ * @member dat.controllers
+ */
+
+ var StringController = (function (_Controller) {
+ _inherits(StringController, _Controller);
+
+ function StringController(object, property) {
+ _classCallCheck(this, StringController);
+
+ _get(Object.getPrototypeOf(StringController.prototype), 'constructor', this).call(this, object, property);
+
+ var _this = this;
+
+ this.__input = document.createElement('input');
+ this.__input.setAttribute('type', 'text');
+
+ _domDom2['default'].bind(this.__input, 'keyup', onChange);
+ _domDom2['default'].bind(this.__input, 'change', onChange);
+ _domDom2['default'].bind(this.__input, 'blur', onBlur);
+ _domDom2['default'].bind(this.__input, 'keydown', function (e) {
+ if (e.keyCode === 13) {
+ this.blur();
+ }
+ });
+
+ function onChange() {
+ _this.setValue(_this.__input.value);
+ }
+
+ function onBlur() {
+ if (_this.__onFinishChange) {
+ _this.__onFinishChange.call(_this, _this.getValue());
+ }
+ }
+
+ this.updateDisplay();
+
+ this.domElement.appendChild(this.__input);
+ }
+
+ _createClass(StringController, [{
+ key: 'updateDisplay',
+ value: function updateDisplay() {
+ // Stops the caret from moving on account of:
+ // keyup -> setValue -> updateDisplay
+ if (!_domDom2['default'].isActive(this.__input)) {
+ this.__input.value = this.getValue();
+ }
+ return _get(Object.getPrototypeOf(StringController.prototype), 'updateDisplay', this).call(this);
+ }
+ }]);
+
+ return StringController;
+ })(_Controller3['default']);
+
+ exports['default'] = StringController;
+ module.exports = exports['default'];
+
+/***/ },
+/* 12 */
+/***/ function(module, exports, __webpack_require__) {
+
+ /**
+ * dat-gui JavaScript Controller Library
+ * http://code.google.com/p/dat-gui
+ *
+ * Copyright 2011 Data Arts Team, Google Creative Lab
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ */
+
+ '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 _get = function get(_x, _x2, _x3) { var _again = true; _function: while (_again) { var object = _x, property = _x2, receiver = _x3; desc = parent = getter = undefined; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x = parent; _x2 = property; _x3 = receiver; _again = true; continue _function; } } else if ('value' in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };
+
+ 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 _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; }
+
+ var _Controller2 = __webpack_require__(7);
+
+ var _Controller3 = _interopRequireDefault(_Controller2);
+
+ var _utilsCommon = __webpack_require__(5);
+
+ var _utilsCommon2 = _interopRequireDefault(_utilsCommon);
+
+ function numDecimals(x) {
+ x = x.toString();
+ if (x.indexOf('.') > -1) {
+ return x.length - x.indexOf('.') - 1;
+ } else {
+ return 0;
+ }
+ }
+
+ /**
+ * @class Represents a given property of an object that is a number.
+ *
+ * @extends dat.controllers.Controller
+ *
+ * @param {Object} object The object to be manipulated
+ * @param {string} property The name of the property to be manipulated
+ * @param {Object} [params] Optional parameters
+ * @param {Number} [params.min] Minimum allowed value
+ * @param {Number} [params.max] Maximum allowed value
+ * @param {Number} [params.step] Increment by which to change value
+ *
+ * @member dat.controllers
+ */
+
+ var NumberController = (function (_Controller) {
+ _inherits(NumberController, _Controller);
+
+ function NumberController(object, property, params) {
+ _classCallCheck(this, NumberController);
+
+ _get(Object.getPrototypeOf(NumberController.prototype), 'constructor', this).call(this, object, property);
+
+ params = params || {};
+
+ this.__min = params.min;
+ this.__max = params.max;
+ this.__step = params.step;
+
+ if (_utilsCommon2['default'].isUndefined(this.__step)) {
+
+ if (this.initialValue == 0) {
+ this.__impliedStep = 1; // What are we, psychics?
+ } else {
+ // Hey Doug, check this out.
+ this.__impliedStep = Math.pow(10, Math.floor(Math.log(Math.abs(this.initialValue)) / Math.LN10)) / 10;
+ }
+ } else {
+
+ this.__impliedStep = this.__step;
+ }
+
+ this.__precision = numDecimals(this.__impliedStep);
+ }
+
+ _createClass(NumberController, [{
+ key: 'setValue',
+ value: function setValue(v) {
+ if (this.__min !== undefined && v < this.__min) {
+ v = this.__min;
+ } else if (this.__max !== undefined && v > this.__max) {
+ v = this.__max;
+ }
+
+ if (this.__step !== undefined && v % this.__step != 0) {
+ v = Math.round(v / this.__step) * this.__step;
+ }
+
+ return _get(Object.getPrototypeOf(NumberController.prototype), 'setValue', this).call(this, v);
+ }
+
+ /**
+ * Specify a minimum value for object[property]
.
+ *
+ * @param {Number} minValue The minimum value for
+ * object[property]
+ * @returns {dat.controllers.NumberController} this
+ */
+ }, {
+ key: 'min',
+ value: function min(v) {
+ this.__min = v;
+ return this;
+ }
+
+ /**
+ * Specify a maximum value for object[property]
.
+ *
+ * @param {Number} maxValue The maximum value for
+ * object[property]
+ * @returns {dat.controllers.NumberController} this
+ */
+ }, {
+ key: 'max',
+ value: function max(v) {
+ this.__max = v;
+ return this;
+ }
+
+ /**
+ * Specify a step value that dat.controllers.NumberController
+ * increments by.
+ *
+ * @param {Number} stepValue The step value for
+ * dat.controllers.NumberController
+ * @default if minimum and maximum specified increment is 1% of the
+ * difference otherwise stepValue is 1
+ * @returns {dat.controllers.NumberController} this
+ */
+ }, {
+ key: 'step',
+ value: function step(v) {
+ this.__step = v;
+ this.__impliedStep = v;
+ this.__precision = numDecimals(v);
+ return this;
+ }
+ }]);
+
+ return NumberController;
+ })(_Controller3['default']);
+
+ exports['default'] = NumberController;
+ module.exports = exports['default'];
+
+/***/ },
+/* 13 */
+/***/ function(module, exports, __webpack_require__) {
+
+ /**
+ * dat-gui JavaScript Controller Library
+ * http://code.google.com/p/dat-gui
+ *
+ * Copyright 2011 Data Arts Team, Google Creative Lab
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ */
+
+ '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 _get = function get(_x, _x2, _x3) { var _again = true; _function: while (_again) { var object = _x, property = _x2, receiver = _x3; desc = parent = getter = undefined; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x = parent; _x2 = property; _x3 = receiver; _again = true; continue _function; } } else if ('value' in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };
+
+ 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 _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; }
+
+ var _NumberController2 = __webpack_require__(12);
+
+ var _NumberController3 = _interopRequireDefault(_NumberController2);
+
+ var _domDom = __webpack_require__(10);
+
+ var _domDom2 = _interopRequireDefault(_domDom);
+
+ var _utilsCommon = __webpack_require__(5);
+
+ var _utilsCommon2 = _interopRequireDefault(_utilsCommon);
+
+ function roundToDecimal(value, decimals) {
+ var tenTo = Math.pow(10, decimals);
+ return Math.round(value * tenTo) / tenTo;
+ }
+
+ /**
+ * @class Represents a given property of an object that is a number and
+ * provides an input element with which to manipulate it.
+ *
+ * @extends dat.controllers.Controller
+ * @extends dat.controllers.NumberController
+ *
+ * @param {Object} object The object to be manipulated
+ * @param {string} property The name of the property to be manipulated
+ * @param {Object} [params] Optional parameters
+ * @param {Number} [params.min] Minimum allowed value
+ * @param {Number} [params.max] Maximum allowed value
+ * @param {Number} [params.step] Increment by which to change value
+ *
+ * @member dat.controllers
+ */
+
+ var NumberControllerBox = (function (_NumberController) {
+ _inherits(NumberControllerBox, _NumberController);
+
+ function NumberControllerBox(object, property, params) {
+ _classCallCheck(this, NumberControllerBox);
+
+ _get(Object.getPrototypeOf(NumberControllerBox.prototype), 'constructor', this).call(this, object, property, params);
+
+ this.__truncationSuspended = false;
+
+ var _this = this;
+
+ /**
+ * {Number} Previous mouse y position
+ * @ignore
+ */
+ var prev_y;
+
+ this.__input = document.createElement('input');
+ this.__input.setAttribute('type', 'text');
+
+ // Makes it so manually specified values are not truncated.
+
+ _domDom2['default'].bind(this.__input, 'change', onChange);
+ _domDom2['default'].bind(this.__input, 'blur', onBlur);
+ _domDom2['default'].bind(this.__input, 'mousedown', onMouseDown);
+ _domDom2['default'].bind(this.__input, 'keydown', function (e) {
+
+ // When pressing entire, you can be as precise as you want.
+ if (e.keyCode === 13) {
+ _this.__truncationSuspended = true;
+ this.blur();
+ _this.__truncationSuspended = false;
+ }
+ });
+
+ function onChange() {
+ var attempted = parseFloat(_this.__input.value);
+ if (!_utilsCommon2['default'].isNaN(attempted)) _this.setValue(attempted);
+ }
+
+ function onBlur() {
+ onChange();
+ if (_this.__onFinishChange) {
+ _this.__onFinishChange.call(_this, _this.getValue());
+ }
+ }
+
+ function onMouseDown(e) {
+ _domDom2['default'].bind(window, 'mousemove', onMouseDrag);
+ _domDom2['default'].bind(window, 'mouseup', onMouseUp);
+ prev_y = e.clientY;
+ }
+
+ function onMouseDrag(e) {
+
+ var diff = prev_y - e.clientY;
+ _this.setValue(_this.getValue() + diff * _this.__impliedStep);
+
+ prev_y = e.clientY;
+ }
+
+ function onMouseUp() {
+ _domDom2['default'].unbind(window, 'mousemove', onMouseDrag);
+ _domDom2['default'].unbind(window, 'mouseup', onMouseUp);
+ }
+
+ this.updateDisplay();
+
+ this.domElement.appendChild(this.__input);
+ }
+
+ _createClass(NumberControllerBox, [{
+ key: 'updateDisplay',
+ value: function updateDisplay() {
+
+ this.__input.value = this.__truncationSuspended ? this.getValue() : roundToDecimal(this.getValue(), this.__precision);
+ return _get(Object.getPrototypeOf(NumberControllerBox.prototype), 'updateDisplay', this).call(this);
+ }
+ }]);
+
+ return NumberControllerBox;
+ })(_NumberController3['default']);
+
+ exports['default'] = NumberControllerBox;
+ module.exports = exports['default'];
+
+/***/ },
+/* 14 */
+/***/ function(module, exports, __webpack_require__) {
+
+ /**
+ * dat-gui JavaScript Controller Library
+ * http://code.google.com/p/dat-gui
+ *
+ * Copyright 2011 Data Arts Team, Google Creative Lab
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ */
+
+ '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 _get = function get(_x, _x2, _x3) { var _again = true; _function: while (_again) { var object = _x, property = _x2, receiver = _x3; desc = parent = getter = undefined; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x = parent; _x2 = property; _x3 = receiver; _again = true; continue _function; } } else if ('value' in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };
+
+ 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 _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; }
+
+ var _NumberController2 = __webpack_require__(12);
+
+ var _NumberController3 = _interopRequireDefault(_NumberController2);
+
+ var _domDom = __webpack_require__(10);
+
+ var _domDom2 = _interopRequireDefault(_domDom);
+
+ var _utilsCss = __webpack_require__(15);
+
+ var _utilsCss2 = _interopRequireDefault(_utilsCss);
+
+ var _utilsCommon = __webpack_require__(5);
+
+ var _utilsCommon2 = _interopRequireDefault(_utilsCommon);
+
+ var _styleCssSassNumberControllerSliderScss = __webpack_require__(16);
+
+ var _styleCssSassNumberControllerSliderScss2 = _interopRequireDefault(_styleCssSassNumberControllerSliderScss);
+
+ function map(v, i1, i2, o1, o2) {
+ return o1 + (o2 - o1) * ((v - i1) / (i2 - i1));
+ }
+
+ /**
+ * @class Represents a given property of an object that is a number, contains
+ * a minimum and maximum, and provides a slider element with which to
+ * manipulate it. It should be noted that the slider element is made up of
+ * <div>
tags, not the html5
+ * <slider>
element.
+ *
+ * @extends dat.controllers.Controller
+ * @extends dat.controllers.NumberController
+ *
+ * @param {Object} object The object to be manipulated
+ * @param {string} property The name of the property to be manipulated
+ * @param {Number} minValue Minimum allowed value
+ * @param {Number} maxValue Maximum allowed value
+ * @param {Number} stepValue Increment by which to change value
+ *
+ * @member dat.controllers
+ */
+
+ var NumberControllerSlider = (function (_NumberController) {
+ _inherits(NumberControllerSlider, _NumberController);
+
+ function NumberControllerSlider(object, property, min, max, step) {
+ _classCallCheck(this, NumberControllerSlider);
+
+ _get(Object.getPrototypeOf(NumberControllerSlider.prototype), 'constructor', this).call(this, object, property, { min: min, max: max, step: step });
+
+ var _this = this;
+
+ this.__background = document.createElement('div');
+ this.__foreground = document.createElement('div');
+
+ _domDom2['default'].bind(this.__background, 'mousedown', onMouseDown);
+
+ _domDom2['default'].addClass(this.__background, 'slider');
+ _domDom2['default'].addClass(this.__foreground, 'slider-fg');
+
+ function onMouseDown(e) {
+
+ _domDom2['default'].bind(window, 'mousemove', onMouseDrag);
+ _domDom2['default'].bind(window, 'mouseup', onMouseUp);
+
+ onMouseDrag(e);
+ }
+
+ function onMouseDrag(e) {
+
+ e.preventDefault();
+
+ var offset = _domDom2['default'].getOffset(_this.__background);
+ var width = _domDom2['default'].getWidth(_this.__background);
+
+ _this.setValue(map(e.clientX, offset.left, offset.left + width, _this.__min, _this.__max));
+
+ return false;
+ }
+
+ function onMouseUp() {
+ _domDom2['default'].unbind(window, 'mousemove', onMouseDrag);
+ _domDom2['default'].unbind(window, 'mouseup', onMouseUp);
+ if (_this.__onFinishChange) {
+ _this.__onFinishChange.call(_this, _this.getValue());
+ }
+ }
+
+ this.updateDisplay();
+
+ this.__background.appendChild(this.__foreground);
+ this.domElement.appendChild(this.__background);
+ }
+
+ /**
+ * Injects default stylesheet for slider elements.
+ */
+
+ _createClass(NumberControllerSlider, [{
+ key: 'updateDisplay',
+ value: function updateDisplay() {
+ var pct = (this.getValue() - this.__min) / (this.__max - this.__min);
+ this.__foreground.style.width = pct * 100 + '%';
+ return _get(Object.getPrototypeOf(NumberControllerSlider.prototype), 'updateDisplay', this).call(this);
+ }
+ }]);
+
+ return NumberControllerSlider;
+ })(_NumberController3['default']);
+
+ NumberControllerSlider.useDefaultStyles = function () {
+ _utilsCss2['default'].inject(_styleCssSassNumberControllerSliderScss2['default']);
+ };
+
+ exports['default'] = NumberControllerSlider;
+ module.exports = exports['default'];
+
+/***/ },
+/* 15 */
+/***/ function(module, exports) {
+
+ /**
+ * dat-gui JavaScript Controller Library
+ * http://code.google.com/p/dat-gui
+ *
+ * Copyright 2011 Data Arts Team, Google Creative Lab
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ */
+
+ 'use strict';
+
+ module.exports = {
+ load: function load(url, doc) {
+ doc = doc || document;
+ var link = doc.createElement('link');
+ link.type = 'text/css';
+ link.rel = 'stylesheet';
+ link.href = url;
+ doc.getElementsByTagName('head')[0].appendChild(link);
+ },
+ inject: function inject(css, doc) {
+ doc = doc || document;
+ var injected = document.createElement('style');
+ injected.type = 'text/css';
+ injected.innerHTML = css;
+ doc.getElementsByTagName('head')[0].appendChild(injected);
+ }
+ };
+
+/***/ },
+/* 16 */
+/***/ function(module, exports, __webpack_require__) {
+
+ // style-loader: Adds some css to the DOM by adding a