diff --git a/build/dat.gui.css b/build/dat.gui.css deleted file mode 100644 index 9c21e93..0000000 --- a/build/dat.gui.css +++ /dev/null @@ -1,299 +0,0 @@ -.dg { - /** Clear list styles */ - /* Auto-place container */ - /* Auto-placed GUI's */ - /* Line items that don't contain folders. */ - /** Folder names */ - /** Hides closed items */ - /** Controller row */ - /** Name-half (left) */ - /** Controller-half (right) */ - /** Controller placement */ - /** Shorter number boxes when slider is present. */ - /** Ensure the entire boolean and function row shows a hand */ - /** allow overflow for color selector */ } - .dg ul { - list-style: none; - margin: 0; - padding: 0; - width: 100%; - clear: both; } - .dg.ac { - position: fixed; - top: 0; - left: 0; - right: 0; - height: 0; - z-index: 0; } - .dg:not(.ac) .main { - /** Exclude mains in ac so that we don't hide close button */ - overflow: hidden; } - .dg.main { - -webkit-transition: opacity 0.1s linear; - -o-transition: opacity 0.1s linear; - -moz-transition: opacity 0.1s linear; - transition: opacity 0.1s linear; } - .dg.main.taller-than-window { - overflow-y: auto; } - .dg.main.taller-than-window .close-button { - opacity: 1; - /* TODO, these are style notes */ - margin-top: -1px; - border-top: 1px solid #2c2c2c; } - .dg.main ul.closed .close-button { - opacity: 1 !important; } - .dg.main:hover .close-button, - .dg.main .close-button.drag { - opacity: 1; } - .dg.main .close-button { - /*opacity: 0;*/ - -webkit-transition: opacity 0.1s linear; - -o-transition: opacity 0.1s linear; - -moz-transition: opacity 0.1s linear; - transition: opacity 0.1s linear; - border: 0; - line-height: 19px; - height: 20px; - /* TODO, these are style notes */ - cursor: pointer; - text-align: center; - background-color: #000; } - .dg.main .close-button.close-top { - position: relative; } - .dg.main .close-button.close-bottom { - position: absolute; } - .dg.main .close-button:hover { - background-color: #111; } - .dg.a { - float: right; - margin-right: 15px; - overflow-y: visible; } - .dg.a.has-save > ul.close-top { - margin-top: 0; } - .dg.a.has-save > ul.close-bottom { - margin-top: 27px; } - .dg.a.has-save > ul.closed { - margin-top: 0; } - .dg.a .save-row { - top: 0; - z-index: 1002; } - .dg.a .save-row.close-top { - position: relative; } - .dg.a .save-row.close-bottom { - position: fixed; } - .dg li { - -webkit-transition: height 0.1s ease-out; - -o-transition: height 0.1s ease-out; - -moz-transition: height 0.1s ease-out; - transition: height 0.1s ease-out; - -webkit-transition: overflow 0.1s linear; - -o-transition: overflow 0.1s linear; - -moz-transition: overflow 0.1s linear; - transition: overflow 0.1s linear; } - .dg li:not(.folder) { - cursor: auto; - height: 27px; - line-height: 27px; - padding: 0 4px 0 5px; } - .dg li.folder { - padding: 0; - border-left: 4px solid transparent; } - .dg li.title { - cursor: pointer; - margin-left: -4px; } - .dg .closed li:not(.title), - .dg .closed ul li, - .dg .closed ul li > * { - height: 0; - overflow: hidden; - border: 0; } - .dg .cr { - clear: both; - padding-left: 3px; - height: 27px; - overflow: hidden; } - .dg .property-name { - cursor: default; - float: left; - clear: left; - width: 40%; - overflow: hidden; - text-overflow: ellipsis; } - .dg .c { - float: left; - width: 60%; - position: relative; } - .dg .c input[type=text] { - border: 0; - margin-top: 4px; - padding: 3px; - width: 100%; - float: right; } - .dg .has-slider input[type=text] { - width: 30%; - /*display: none;*/ - margin-left: 0; } - .dg .slider { - float: left; - width: 66%; - margin-left: -5px; - margin-right: 0; - height: 19px; - margin-top: 4px; } - .dg .slider-fg { - height: 100%; } - .dg .c input[type=checkbox] { - margin-top: 7px; } - .dg .c select { - margin-top: 5px; } - .dg .cr.function, - .dg .cr.function .property-name, - .dg .cr.function *, - .dg .cr.boolean, - .dg .cr.boolean * { - cursor: pointer; } - .dg .cr.color { - overflow: visible; } - .dg .selector { - display: none; - position: absolute; - margin-left: -9px; - margin-top: 23px; - z-index: 10; } - .dg .c:hover .selector, - .dg .selector.drag { - display: block; } - .dg li.save-row { - padding: 0; } - .dg li.save-row .button { - display: inline-block; - padding: 0px 6px; } - .dg.dialogue { - background-color: #222; - width: 460px; - padding: 15px; - font-size: 13px; - line-height: 15px; } - -/* TODO Separate style and structure */ -#dg-new-constructor { - padding: 10px; - color: #222; - font-family: Monaco, monospace; - font-size: 10px; - border: 0; - resize: none; - box-shadow: inset 1px 1px 1px #888; - word-wrap: break-word; - margin: 12px 0; - display: block; - width: 440px; - overflow-y: scroll; - height: 100px; - position: relative; } - -#dg-local-explain { - display: none; - font-size: 11px; - line-height: 17px; - border-radius: 3px; - background-color: #333; - padding: 8px; - margin-top: 10px; } - #dg-local-explain code { - font-size: 10px; } - -#dat-gui-save-locally { - display: none; } - -/** Main type */ -.dg { - color: #eee; - font: 11px 'Lucida Grande', sans-serif; - text-shadow: 0 -1px 0 #111; - /** Auto place */ - /* Controller row,
object[property]
- *
- * @param {Object} newValue The new value of object[property]
- */
-
-
- Controller.prototype.setValue = 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]
- */
-
-
- Controller.prototype.getValue = 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 {Controller} this
- */
-
-
- Controller.prototype.updateDisplay = function updateDisplay() {
- return this;
- };
-
- /**
- * @returns {Boolean} true if the value has deviated from initialValue
- */
-
-
- Controller.prototype.isModified = function isModified() {
- return this.initialValue !== this.getValue();
- };
-
- return Controller;
- }();
-
- exports.default = Controller;
- module.exports = exports['default'];
-
-/***/ },
-/* 8 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _Controller2 = __webpack_require__(7);
-
- var _Controller3 = _interopRequireDefault(_Controller2);
-
- var _dom = __webpack_require__(9);
-
- var _dom2 = _interopRequireDefault(_dom);
-
- 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; } /**
- * 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
- */
-
- /**
- * @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
- */
- var BooleanController = function (_Controller) {
- _inherits(BooleanController, _Controller);
-
- function BooleanController(object, property) {
- _classCallCheck(this, BooleanController);
-
- var _this2 = _possibleConstructorReturn(this, _Controller.call(this, object, property));
-
- var _this = _this2;
- _this2.__prev = _this2.getValue();
-
- _this2.__checkbox = document.createElement('input');
- _this2.__checkbox.setAttribute('type', 'checkbox');
-
- function onChange() {
- _this.setValue(!_this.__prev);
- }
-
- _dom2.default.bind(_this2.__checkbox, 'change', onChange, false);
-
- _this2.domElement.appendChild(_this2.__checkbox);
-
- // Match original value
- _this2.updateDisplay();
- return _this2;
- }
-
- BooleanController.prototype.setValue = function setValue(v) {
- var toReturn = _Controller.prototype.setValue.call(this, v);
- if (this.__onFinishChange) {
- this.__onFinishChange.call(this, this.getValue());
- }
- this.__prev = this.getValue();
- return toReturn;
- };
-
- BooleanController.prototype.updateDisplay = function updateDisplay() {
- if (this.getValue() === true) {
- this.__checkbox.setAttribute('checked', 'checked');
- this.__checkbox.checked = true;
- this.__prev = true;
- } else {
- this.__checkbox.checked = false;
- this.__prev = false;
- }
-
- return _Controller.prototype.updateDisplay.call(this);
- };
-
- return BooleanController;
- }(_Controller3.default);
-
- exports.default = BooleanController;
- module.exports = exports['default'];
-
-/***/ },
-/* 9 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _common = __webpack_require__(5);
-
- var _common2 = _interopRequireDefault(_common);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- var EVENT_MAP = {
- HTMLEvents: ['change'],
- MouseEvents: ['click', 'mousemove', 'mousedown', 'mouseup', 'mouseover'],
- KeyboardEvents: ['keydown']
- }; /**
- * 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
- */
-
- var EVENT_MAP_INV = {};
- _common2.default.each(EVENT_MAP, function (v, k) {
- _common2.default.each(v, function (e) {
- EVENT_MAP_INV[e] = k;
- });
- });
-
- var CSS_VALUE_PIXELS = /(\d+(\.\d+)?)px/;
-
- function cssValueToPixels(val) {
- if (val === '0' || _common2.default.isUndefined(val)) {
- return 0;
- }
-
- var match = val.match(CSS_VALUE_PIXELS);
-
- if (!_common2.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 vert
- */
- makeFullscreen: function makeFullscreen(elem, hor, vert) {
- var vertical = vert;
- var horizontal = hor;
-
- if (_common2.default.isUndefined(horizontal)) {
- horizontal = true;
- }
-
- if (_common2.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, pars, aux) {
- var params = pars || {};
- 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
- _common2.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;
- }
- }
- _common2.default.defaults(evt, aux);
- elem.dispatchEvent(evt);
- },
-
- /**
- *
- * @param elem
- * @param event
- * @param func
- * @param bool
- */
- bind: function bind(elem, event, func, newBool) {
- var bool = newBool || 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, newBool) {
- var bool = newBool || 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 === 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 el
- */
- getOffset: function getOffset(el) {
- var elem = el;
- var offset = { left: 0, top: 0 };
- if (elem.offsetParent) {
- do {
- offset.left += elem.offsetLeft;
- offset.top += elem.offsetTop;
- elem = elem.offsetParent;
- } while (elem);
- }
- 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'];
-
-/***/ },
-/* 10 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _Controller2 = __webpack_require__(7);
-
- var _Controller3 = _interopRequireDefault(_Controller2);
-
- var _dom = __webpack_require__(9);
-
- var _dom2 = _interopRequireDefault(_dom);
-
- var _common = __webpack_require__(5);
-
- var _common2 = _interopRequireDefault(_common);
-
- 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; } /**
- * 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
- */
-
- /**
- * @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.
- */
- var OptionController = function (_Controller) {
- _inherits(OptionController, _Controller);
-
- function OptionController(object, property, opts) {
- _classCallCheck(this, OptionController);
-
- var _this2 = _possibleConstructorReturn(this, _Controller.call(this, object, property));
-
- var options = opts;
-
- var _this = _this2;
-
- /**
- * The drop down menu
- * @ignore
- */
- _this2.__select = document.createElement('select');
-
- if (_common2.default.isArray(options)) {
- var map = {};
- _common2.default.each(options, function (element) {
- map[element] = element;
- });
- options = map;
- }
-
- _common2.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
- _this2.updateDisplay();
-
- _dom2.default.bind(_this2.__select, 'change', function () {
- var desiredValue = this.options[this.selectedIndex].value;
- _this.setValue(desiredValue);
- });
-
- _this2.domElement.appendChild(_this2.__select);
- return _this2;
- }
-
- OptionController.prototype.setValue = function setValue(v) {
- var toReturn = _Controller.prototype.setValue.call(this, v);
-
- if (this.__onFinishChange) {
- this.__onFinishChange.call(this, this.getValue());
- }
- return toReturn;
- };
-
- OptionController.prototype.updateDisplay = function updateDisplay() {
- if (_dom2.default.isActive(this.__select)) return this; // prevent number from updating if user is trying to manually update
- this.__select.value = this.getValue();
- return _Controller.prototype.updateDisplay.call(this);
- };
-
- return OptionController;
- }(_Controller3.default);
-
- exports.default = OptionController;
- module.exports = exports['default'];
-
-/***/ },
-/* 11 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _Controller2 = __webpack_require__(7);
-
- var _Controller3 = _interopRequireDefault(_Controller2);
-
- var _dom = __webpack_require__(9);
-
- var _dom2 = _interopRequireDefault(_dom);
-
- 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; } /**
- * 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
- */
-
- /**
- * @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
- */
- var StringController = function (_Controller) {
- _inherits(StringController, _Controller);
-
- function StringController(object, property) {
- _classCallCheck(this, StringController);
-
- var _this2 = _possibleConstructorReturn(this, _Controller.call(this, object, property));
-
- var _this = _this2;
-
- function onChange() {
- _this.setValue(_this.__input.value);
- }
-
- function onBlur() {
- if (_this.__onFinishChange) {
- _this.__onFinishChange.call(_this, _this.getValue());
- }
- }
-
- _this2.__input = document.createElement('input');
- _this2.__input.setAttribute('type', 'text');
-
- _dom2.default.bind(_this2.__input, 'keyup', onChange);
- _dom2.default.bind(_this2.__input, 'change', onChange);
- _dom2.default.bind(_this2.__input, 'blur', onBlur);
- _dom2.default.bind(_this2.__input, 'keydown', function (e) {
- if (e.keyCode === 13) {
- this.blur();
- }
- });
-
- _this2.updateDisplay();
-
- _this2.domElement.appendChild(_this2.__input);
- return _this2;
- }
-
- StringController.prototype.updateDisplay = function updateDisplay() {
- // Stops the caret from moving on account of:
- // keyup -> setValue -> updateDisplay
- if (!_dom2.default.isActive(this.__input)) {
- this.__input.value = this.getValue();
- }
- return _Controller.prototype.updateDisplay.call(this);
- };
-
- return StringController;
- }(_Controller3.default);
-
- exports.default = StringController;
- module.exports = exports['default'];
-
-/***/ },
-/* 12 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _Controller2 = __webpack_require__(7);
-
- var _Controller3 = _interopRequireDefault(_Controller2);
-
- var _common = __webpack_require__(5);
-
- var _common2 = _interopRequireDefault(_common);
-
- 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; } /**
- * 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
- */
-
- function numDecimals(x) {
- var _x = x.toString();
- if (_x.indexOf('.') > -1) {
- return _x.length - _x.indexOf('.') - 1;
- }
-
- 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
- */
-
- var NumberController = function (_Controller) {
- _inherits(NumberController, _Controller);
-
- function NumberController(object, property, params) {
- _classCallCheck(this, NumberController);
-
- var _this = _possibleConstructorReturn(this, _Controller.call(this, object, property));
-
- var _params = params || {};
-
- _this.__min = _params.min;
- _this.__max = _params.max;
- _this.__step = _params.step;
-
- if (_common2.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);
- return _this;
- }
-
- NumberController.prototype.setValue = function setValue(v) {
- var _v = 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 _Controller.prototype.setValue.call(this, _v);
- };
-
- /**
- * Specify a minimum value for object[property]
.
- *
- * @param {Number} minValue The minimum value for
- * object[property]
- * @returns {dat.controllers.NumberController} this
- */
-
-
- NumberController.prototype.min = function min(minValue) {
- this.__min = minValue;
- return this;
- };
-
- /**
- * Specify a maximum value for object[property]
.
- *
- * @param {Number} maxValue The maximum value for
- * object[property]
- * @returns {dat.controllers.NumberController} this
- */
-
-
- NumberController.prototype.max = function max(maxValue) {
- this.__max = maxValue;
- 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
- */
-
-
- NumberController.prototype.step = function step(stepValue) {
- this.__step = stepValue;
- this.__impliedStep = stepValue;
- this.__precision = numDecimals(stepValue);
- return this;
- };
-
- return NumberController;
- }(_Controller3.default);
-
- exports.default = NumberController;
- module.exports = exports['default'];
-
-/***/ },
-/* 13 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _NumberController2 = __webpack_require__(12);
-
- var _NumberController3 = _interopRequireDefault(_NumberController2);
-
- var _dom = __webpack_require__(9);
-
- var _dom2 = _interopRequireDefault(_dom);
-
- var _common = __webpack_require__(5);
-
- var _common2 = _interopRequireDefault(_common);
-
- 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; } /**
- * 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
- */
-
- 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
- */
-
- var NumberControllerBox = function (_NumberController) {
- _inherits(NumberControllerBox, _NumberController);
-
- function NumberControllerBox(object, property, params) {
- _classCallCheck(this, NumberControllerBox);
-
- var _this2 = _possibleConstructorReturn(this, _NumberController.call(this, object, property, params));
-
- _this2.__truncationSuspended = false;
-
- var _this = _this2;
-
- /**
- * {Number} Previous mouse y position
- * @ignore
- */
- var prevY = void 0;
-
- var mousewheelevt = /Firefox/i.test(navigator.userAgent) ? 'DOMMouseScroll' : 'mousewheel';
-
- function onMouseWheel(e) {
- var value = _this.getValue();
- var delta = (e.deltaY || -e.wheelDelta || e.detail) >> 10 || 1;
- e.preventDefault();
-
- if (delta < 0) value += _this.__impliedStep;else value -= _this.__impliedStep;
- _this.setValue(value);
- }
-
- function onChange() {
- var attempted = parseFloat(_this.__input.value);
- if (!_common2.default.isNaN(attempted)) {
- _this.setValue(attempted);
- }
- }
-
- function onFinish() {
- if (_this.__onFinishChange) {
- _this.__onFinishChange.call(_this, _this.getValue());
- }
- }
-
- function onBlur() {
- onFinish();
- }
-
- function onMouseDrag(e) {
- var diff = prevY - e.clientY;
- _this.setValue(_this.getValue() + diff * _this.__impliedStep);
-
- prevY = e.clientY;
- }
-
- function onMouseUp() {
- _dom2.default.unbind(window, 'mousemove', onMouseDrag);
- _dom2.default.unbind(window, 'mouseup', onMouseUp);
- onFinish();
- }
-
- function onMouseDown(e) {
- _dom2.default.bind(window, 'mousemove', onMouseDrag);
- _dom2.default.bind(window, 'mouseup', onMouseUp);
- prevY = e.clientY;
- }
-
- _this2.__input = document.createElement('input');
- _this2.__input.setAttribute('type', 'text');
-
- // Makes it so manually specified values are not truncated.
-
- _dom2.default.bind(_this2.__input, 'change', onChange);
- _dom2.default.bind(_this2.__input, 'blur', onBlur);
- _dom2.default.bind(_this2.__input, 'mousedown', onMouseDown);
- _dom2.default.bind(_this2.__input, mousewheelevt, onMouseWheel);
- _dom2.default.bind(_this2.__input, 'keydown', function (e) {
- // When pressing enter, you can be as precise as you want.
- if (e.keyCode === 13) {
- _this.__truncationSuspended = true;
- this.blur();
- _this.__truncationSuspended = false;
- onFinish();
- }
- });
-
- _this2.updateDisplay();
-
- _this2.domElement.appendChild(_this2.__input);
- return _this2;
- }
-
- NumberControllerBox.prototype.updateDisplay = function updateDisplay() {
- this.__input.value = this.__truncationSuspended ? this.getValue() : roundToDecimal(this.getValue(), this.__precision);
- return _NumberController.prototype.updateDisplay.call(this);
- };
-
- return NumberControllerBox;
- }(_NumberController3.default);
-
- exports.default = NumberControllerBox;
- module.exports = exports['default'];
-
-/***/ },
-/* 14 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _NumberController2 = __webpack_require__(12);
-
- var _NumberController3 = _interopRequireDefault(_NumberController2);
-
- var _dom = __webpack_require__(9);
-
- var _dom2 = _interopRequireDefault(_dom);
-
- 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; } /**
- * 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
- */
-
- 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
- */
-
- var NumberControllerSlider = function (_NumberController) {
- _inherits(NumberControllerSlider, _NumberController);
-
- function NumberControllerSlider(object, property, min, max, step) {
- _classCallCheck(this, NumberControllerSlider);
-
- var _this2 = _possibleConstructorReturn(this, _NumberController.call(this, object, property, { min: min, max: max, step: step }));
-
- var _this = _this2;
-
- _this2.__background = document.createElement('div');
- _this2.__foreground = document.createElement('div');
-
- _dom2.default.bind(_this2.__background, 'mousedown', onMouseDown);
-
- var mousewheelevt = /Firefox/i.test(navigator.userAgent) ? 'DOMMouseScroll' : 'mousewheel';
- _dom2.default.bind(_this2.__background, mousewheelevt, onMouseWheel);
-
- _dom2.default.addClass(_this2.__background, 'slider');
- _dom2.default.addClass(_this2.__foreground, 'slider-fg');
-
- function onMouseWheel(e) {
- var value = _this.getValue();
- var delta = (e.deltaY || -e.wheelDelta || e.detail) >> 10 || 1;
- e.preventDefault();
- document.activeElement.blur();
-
- if (delta < 0) value += _this.__impliedStep;else value -= _this.__impliedStep;
- _this.setValue(value);
- }
-
- function onMouseDown(e) {
- document.activeElement.blur();
-
- _dom2.default.bind(window, 'mousemove', onMouseDrag);
- _dom2.default.bind(window, 'mouseup', onMouseUp);
-
- onMouseDrag(e);
- }
-
- function onMouseDrag(e) {
- e.preventDefault();
-
- var bgRect = _this.__background.getBoundingClientRect();
-
- _this.setValue(map(e.clientX, bgRect.left, bgRect.right, _this.__min, _this.__max));
-
- return false;
- }
-
- function onMouseUp() {
- _dom2.default.unbind(window, 'mousemove', onMouseDrag);
- _dom2.default.unbind(window, 'mouseup', onMouseUp);
- if (_this.__onFinishChange) {
- _this.__onFinishChange.call(_this, _this.getValue());
- }
- }
-
- _this2.updateDisplay();
-
- _this2.__background.appendChild(_this2.__foreground);
- _this2.domElement.appendChild(_this2.__background);
- return _this2;
- }
-
- NumberControllerSlider.prototype.updateDisplay = function updateDisplay() {
- var pct = (this.getValue() - this.__min) / (this.__max - this.__min);
- this.__foreground.style.width = pct * 100 + '%';
- return _NumberController.prototype.updateDisplay.call(this);
- };
-
- return NumberControllerSlider;
- }(_NumberController3.default);
-
- exports.default = NumberControllerSlider;
- module.exports = exports['default'];
-
-/***/ },
-/* 15 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _Controller2 = __webpack_require__(7);
-
- var _Controller3 = _interopRequireDefault(_Controller2);
-
- var _dom = __webpack_require__(9);
-
- var _dom2 = _interopRequireDefault(_dom);
-
- 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; } /**
- * 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
- */
-
- /**
- * @class Provides a GUI interface to fire a specified method, a 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
- */
- var FunctionController = function (_Controller) {
- _inherits(FunctionController, _Controller);
-
- function FunctionController(object, property, text) {
- _classCallCheck(this, FunctionController);
-
- var _this2 = _possibleConstructorReturn(this, _Controller.call(this, object, property));
-
- var _this = _this2;
-
- _this2.__button = document.createElement('div');
- _this2.__button.innerHTML = text === undefined ? 'Fire' : text;
-
- _dom2.default.bind(_this2.__button, 'click', function (e) {
- e.preventDefault();
- _this.fire();
- return false;
- });
-
- _dom2.default.addClass(_this2.__button, 'button');
-
- _this2.domElement.appendChild(_this2.__button);
- return _this2;
- }
-
- FunctionController.prototype.fire = function fire() {
- if (this.__onChange) {
- this.__onChange.call(this);
- }
- this.getValue().call(this.object);
- if (this.__onFinishChange) {
- this.__onFinishChange.call(this, this.getValue());
- }
- };
-
- return FunctionController;
- }(_Controller3.default);
-
- exports.default = FunctionController;
- module.exports = exports['default'];
-
-/***/ },
-/* 16 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _Controller2 = __webpack_require__(7);
-
- var _Controller3 = _interopRequireDefault(_Controller2);
-
- var _dom = __webpack_require__(9);
-
- var _dom2 = _interopRequireDefault(_dom);
-
- var _Color = __webpack_require__(2);
-
- var _Color2 = _interopRequireDefault(_Color);
-
- var _interpret = __webpack_require__(3);
-
- var _interpret2 = _interopRequireDefault(_interpret);
-
- var _common = __webpack_require__(5);
-
- var _common2 = _interopRequireDefault(_common);
-
- 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; } /**
- * 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
- */
-
- /**
- * @class Represents a given property of an object that is a color.
- * @param {Object} object
- * @param {string} property
- */
- var ColorController = function (_Controller) {
- _inherits(ColorController, _Controller);
-
- function ColorController(object, property) {
- _classCallCheck(this, ColorController);
-
- var _this2 = _possibleConstructorReturn(this, _Controller.call(this, object, property));
-
- _this2.__color = new _Color2.default(_this2.getValue());
- _this2.__temp = new _Color2.default(0);
-
- var _this = _this2;
-
- _this2.domElement = document.createElement('div');
-
- _dom2.default.makeSelectable(_this2.domElement, false);
-
- _this2.__selector = document.createElement('div');
- _this2.__selector.className = 'selector';
-
- _this2.__saturation_field = document.createElement('div');
- _this2.__saturation_field.className = 'saturation-field';
-
- _this2.__field_knob = document.createElement('div');
- _this2.__field_knob.className = 'field-knob';
- _this2.__field_knob_border = '2px solid ';
-
- _this2.__hue_knob = document.createElement('div');
- _this2.__hue_knob.className = 'hue-knob';
-
- _this2.__hue_field = document.createElement('div');
- _this2.__hue_field.className = 'hue-field';
-
- _this2.__input = document.createElement('input');
- _this2.__input.type = 'text';
- _this2.__input_textShadow = '0 1px 1px ';
-
- _dom2.default.bind(_this2.__input, 'keydown', function (e) {
- if (e.keyCode === 13) {
- // on enter
- onBlur.call(this);
- }
- });
-
- _dom2.default.bind(_this2.__input, 'blur', onBlur);
-
- _dom2.default.bind(_this2.__selector, 'mousedown', function () /* e */{
- _dom2.default.addClass(this, 'drag').bind(window, 'mouseup', function () /* e */{
- _dom2.default.removeClass(_this.__selector, 'drag');
- });
- });
-
- var valueField = document.createElement('div');
-
- _common2.default.extend(_this2.__selector.style, {
- width: '122px',
- height: '102px',
- padding: '3px',
- backgroundColor: '#222',
- boxShadow: '0px 1px 3px rgba(0,0,0,0.3)'
- });
-
- _common2.default.extend(_this2.__field_knob.style, {
- position: 'absolute',
- width: '12px',
- height: '12px',
- border: _this2.__field_knob_border + (_this2.__color.v < 0.5 ? '#fff' : '#000'),
- boxShadow: '0px 1px 3px rgba(0,0,0,0.5)',
- borderRadius: '12px',
- zIndex: 1
- });
-
- _common2.default.extend(_this2.__hue_knob.style, {
- position: 'absolute',
- width: '15px',
- height: '2px',
- borderRight: '4px solid #fff',
- zIndex: 1
- });
-
- _common2.default.extend(_this2.__saturation_field.style, {
- width: '100px',
- height: '100px',
- border: '1px solid #555',
- marginRight: '3px',
- display: 'inline-block',
- cursor: 'pointer'
- });
-
- _common2.default.extend(valueField.style, {
- width: '100%',
- height: '100%',
- background: 'none'
- });
-
- linearGradient(valueField, 'top', 'rgba(0,0,0,0)', '#000');
-
- _common2.default.extend(_this2.__hue_field.style, {
- width: '15px',
- height: '100px',
- border: '1px solid #555',
- cursor: 'ns-resize',
- position: 'absolute',
- top: '3px',
- right: '3px'
- });
-
- hueGradient(_this2.__hue_field);
-
- _common2.default.extend(_this2.__input.style, {
- outline: 'none',
- // width: '120px',
- textAlign: 'center',
- // padding: '4px',
- // marginBottom: '6px',
- color: '#fff',
- border: 0,
- fontWeight: 'bold',
- textShadow: _this2.__input_textShadow + 'rgba(0,0,0,0.7)'
- });
-
- _dom2.default.bind(_this2.__saturation_field, 'mousedown', fieldDown);
- _dom2.default.bind(_this2.__field_knob, 'mousedown', fieldDown);
-
- _dom2.default.bind(_this2.__hue_field, 'mousedown', function (e) {
- setH(e);
- _dom2.default.bind(window, 'mousemove', setH);
- _dom2.default.bind(window, 'mouseup', fieldUpH);
- });
-
- function fieldDown(e) {
- setSV(e);
- // document.body.style.cursor = 'none';
- _dom2.default.bind(window, 'mousemove', setSV);
- _dom2.default.bind(window, 'mouseup', fieldUpSV);
- }
-
- function fieldUpSV() {
- _dom2.default.unbind(window, 'mousemove', setSV);
- _dom2.default.unbind(window, 'mouseup', fieldUpSV);
- // document.body.style.cursor = 'default';
- onFinish();
- }
-
- function onBlur() {
- var i = (0, _interpret2.default)(this.value);
- if (i !== false) {
- _this.__color.__state = i;
- _this.setValue(_this.__color.toOriginal());
- } else {
- this.value = _this.__color.toString();
- }
- }
-
- function fieldUpH() {
- _dom2.default.unbind(window, 'mousemove', setH);
- _dom2.default.unbind(window, 'mouseup', fieldUpH);
- onFinish();
- }
-
- function onFinish() {
- if (_this.__onFinishChange) {
- _this.__onFinishChange.call(_this, _this.__color.toOriginal());
- }
- }
-
- _this2.__saturation_field.appendChild(valueField);
- _this2.__selector.appendChild(_this2.__field_knob);
- _this2.__selector.appendChild(_this2.__saturation_field);
- _this2.__selector.appendChild(_this2.__hue_field);
- _this2.__hue_field.appendChild(_this2.__hue_knob);
-
- _this2.domElement.appendChild(_this2.__input);
- _this2.domElement.appendChild(_this2.__selector);
-
- _this2.updateDisplay();
-
- function setSV(e) {
- e.preventDefault();
-
- var fieldRect = _this.__saturation_field.getBoundingClientRect();
- var s = (e.clientX - fieldRect.left) / (fieldRect.right - fieldRect.left);
- var v = 1 - (e.clientY - fieldRect.top) / (fieldRect.bottom - fieldRect.top);
-
- if (v > 1) {
- v = 1;
- } else if (v < 0) {
- v = 0;
- }
-
- if (s > 1) {
- s = 1;
- } else if (s < 0) {
- s = 0;
- }
-
- _this.__color.v = v;
- _this.__color.s = s;
-
- _this.setValue(_this.__color.toOriginal());
-
- return false;
- }
-
- function setH(e) {
- e.preventDefault();
-
- var fieldRect = _this.__hue_field.getBoundingClientRect();
- var h = 1 - (e.clientY - fieldRect.top) / (fieldRect.bottom - fieldRect.top);
-
- if (h > 1) {
- h = 1;
- } else if (h < 0) {
- h = 0;
- }
-
- _this.__color.h = h * 360;
-
- _this.setValue(_this.__color.toOriginal());
-
- return false;
- }
- return _this2;
- }
-
- ColorController.prototype.updateDisplay = function updateDisplay() {
- var i = (0, _interpret2.default)(this.getValue());
-
- if (i !== false) {
- var mismatch = false;
-
- // Check for mismatch on the interpreted value.
-
- _common2.default.each(_Color2.default.COMPONENTS, function (component) {
- if (!_common2.default.isUndefined(i[component]) && !_common2.default.isUndefined(this.__color.__state[component]) && i[component] !== this.__color.__state[component]) {
- mismatch = true;
- return {}; // break
- }
- }, this);
-
- // If nothing diverges, we keep our previous values
- // for statefulness, otherwise we recalculate fresh
- if (mismatch) {
- _common2.default.extend(this.__color.__state, i);
- }
- }
-
- _common2.default.extend(this.__temp.__state, this.__color.__state);
-
- this.__temp.a = 1;
-
- var flip = this.__color.v < 0.5 || this.__color.s > 0.5 ? 255 : 0;
- var _flip = 255 - flip;
-
- _common2.default.extend(this.__field_knob.style, {
- marginLeft: 100 * this.__color.s - 7 + 'px',
- marginTop: 100 * (1 - this.__color.v) - 7 + 'px',
- backgroundColor: this.__temp.toHexString(),
- border: this.__field_knob_border + 'rgb(' + flip + ',' + flip + ',' + flip + ')'
- });
-
- this.__hue_knob.style.marginTop = (1 - this.__color.h / 360) * 100 + 'px';
-
- this.__temp.s = 1;
- this.__temp.v = 1;
-
- linearGradient(this.__saturation_field, 'left', '#fff', this.__temp.toHexString());
-
- this.__input.value = this.__color.toString();
-
- _common2.default.extend(this.__input.style, {
- backgroundColor: this.__color.toHexString(),
- color: 'rgb(' + flip + ',' + flip + ',' + flip + ')',
- textShadow: this.__input_textShadow + 'rgba(' + _flip + ',' + _flip + ',' + _flip + ',.7)'
- });
- };
-
- return ColorController;
- }(_Controller3.default);
-
- var vendors = ['-moz-', '-o-', '-webkit-', '-ms-', ''];
-
- function linearGradient(elem, x, a, b) {
- elem.style.background = '';
- _common2.default.each(vendors, function (vendor) {
- elem.style.cssText += 'background: ' + vendor + 'linear-gradient(' + x + ', ' + a + ' 0%, ' + b + ' 100%); ';
- });
- }
-
- function hueGradient(elem) {
- elem.style.background = '';
- elem.style.cssText += 'background: -moz-linear-gradient(top, #ff0000 0%, #ff00ff 17%, #0000ff 34%, #00ffff 50%, #00ff00 67%, #ffff00 84%, #ff0000 100%);';
- elem.style.cssText += 'background: -webkit-linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);';
- elem.style.cssText += 'background: -o-linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);';
- elem.style.cssText += 'background: -ms-linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);';
- elem.style.cssText += 'background: linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);';
- }
-
- exports.default = ColorController;
- module.exports = exports['default'];
-
-/***/ },
-/* 17 */
-/***/ function(module, exports, __webpack_require__) {
-
- 'use strict';
-
- exports.__esModule = true;
-
- var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; /**
- * 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
- */
-
- var _css = __webpack_require__(18);
-
- var _css2 = _interopRequireDefault(_css);
-
- var _saveDialogue = __webpack_require__(19);
-
- var _saveDialogue2 = _interopRequireDefault(_saveDialogue);
-
- var _ControllerFactory = __webpack_require__(20);
-
- var _ControllerFactory2 = _interopRequireDefault(_ControllerFactory);
-
- var _Controller = __webpack_require__(7);
-
- var _Controller2 = _interopRequireDefault(_Controller);
-
- var _BooleanController = __webpack_require__(8);
-
- var _BooleanController2 = _interopRequireDefault(_BooleanController);
-
- var _FunctionController = __webpack_require__(15);
-
- var _FunctionController2 = _interopRequireDefault(_FunctionController);
-
- var _NumberControllerBox = __webpack_require__(13);
-
- var _NumberControllerBox2 = _interopRequireDefault(_NumberControllerBox);
-
- var _NumberControllerSlider = __webpack_require__(14);
-
- var _NumberControllerSlider2 = _interopRequireDefault(_NumberControllerSlider);
-
- var _ColorController = __webpack_require__(16);
-
- var _ColorController2 = _interopRequireDefault(_ColorController);
-
- var _requestAnimationFrame = __webpack_require__(21);
-
- var _requestAnimationFrame2 = _interopRequireDefault(_requestAnimationFrame);
-
- var _CenteredDiv = __webpack_require__(22);
-
- var _CenteredDiv2 = _interopRequireDefault(_CenteredDiv);
-
- var _dom = __webpack_require__(9);
-
- var _dom2 = _interopRequireDefault(_dom);
-
- var _common = __webpack_require__(5);
-
- var _common2 = _interopRequireDefault(_common);
-
- var _style = __webpack_require__(23);
-
- var _style2 = _interopRequireDefault(_style);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- // CSS to embed in build
-
- _css2.default.inject(_style2.default);
-
- /** @ignore Outer-most className for GUI's */
- var CSS_NAMESPACE = 'dg';
-
- var HIDE_KEY_CODE = 72;
-
- /** @ignore The only value shared between the JS and SCSS. Use caution. */
- var CLOSE_BUTTON_HEIGHT = 20;
-
- var DEFAULT_DEFAULT_PRESET_NAME = 'Default';
-
- var SUPPORTS_LOCAL_STORAGE = function () {
- try {
- return 'localStorage' in window && window.localStorage !== null;
- } catch (e) {
- return false;
- }
- }();
-
- var SAVE_DIALOGUE = void 0;
-
- /** @ignore Have we yet to create an autoPlace GUI? */
- var autoPlaceVirgin = true;
-
- /** @ignore Fixed position div that auto place GUI's go inside */
- var autoPlaceContainer = void 0;
-
- /** @ignore Are we hiding the GUI's ? */
- var hide = false;
-
- /** @private GUI's which should be hidden */
- var hideableGuis = [];
-
- /**
- * @class A lightweight controller library for JavaScript. It allows you to easily
- * manipulate variables and fire functions on the fly.
- *
- * @typicalname gui
- *
- * @example
- * // Creating a GUI with options.
- * var gui = new dat.GUI({name: 'My GUI'});
- *
- * @example
- * // Creating a GUI and a subfolder.
- * var gui = new dat.GUI();
- * var folder1 = gui.addFolder('Flow Field');
- *
- * @param {Object} [params]
- * @param {String} [params.name] The name of this GUI.
- * @param {Object} [params.load] JSON object representing the saved state of
- * this GUI.
- * @param {Boolean} [params.auto=true]
- * @param {dat.gui.GUI} [params.parent] The GUI I'm nested in.
- * @param {Boolean} [params.closed] If true, starts closed
- * @param {Boolean} [params.closeOnTop] If true, close/open button shows on top of the GUI
- */
- var GUI = function GUI(pars) {
- var _this = this;
-
- var params = pars || {};
-
- /**
- * Outermost DOM Element
- * @type {DOMElement}
- */
- this.domElement = document.createElement('div');
- this.__ul = document.createElement('ul');
- this.domElement.appendChild(this.__ul);
-
- _dom2.default.addClass(this.domElement, CSS_NAMESPACE);
-
- /**
- * Nested GUI's by name
- * @ignore
- */
- this.__folders = {};
-
- this.__controllers = [];
-
- /**
- * List of objects I'm remembering for save, only used in top level GUI
- * @ignore
- */
- this.__rememberedObjects = [];
-
- /**
- * Maps the index of remembered objects to a map of controllers, only used
- * in top level GUI.
- *
- * @private
- * @ignore
- *
- * @example
- * [
- * {
- * propertyName: Controller,
- * anotherPropertyName: Controller
- * },
- * {
- * propertyName: Controller
- * }
- * ]
- */
- this.__rememberedObjectIndecesToControllers = [];
-
- this.__listening = [];
-
- // Default parameters
- params = _common2.default.defaults(params, {
- closeOnTop: false,
- autoPlace: true,
- width: GUI.DEFAULT_WIDTH
- });
-
- params = _common2.default.defaults(params, {
- resizable: params.autoPlace,
- hideable: params.autoPlace
- });
-
- if (!_common2.default.isUndefined(params.load)) {
- // Explicit preset
- if (params.preset) {
- params.load.preset = params.preset;
- }
- } else {
- params.load = { preset: DEFAULT_DEFAULT_PRESET_NAME };
- }
-
- if (_common2.default.isUndefined(params.parent) && params.hideable) {
- hideableGuis.push(this);
- }
-
- // Only root level GUI's are resizable.
- params.resizable = _common2.default.isUndefined(params.parent) && params.resizable;
-
- if (params.autoPlace && _common2.default.isUndefined(params.scrollable)) {
- params.scrollable = true;
- }
- // params.scrollable = common.isUndefined(params.parent) && params.scrollable === true;
-
- // Not part of params because I don't want people passing this in via
- // constructor. Should be a 'remembered' value.
- var useLocalStorage = SUPPORTS_LOCAL_STORAGE && localStorage.getItem(getLocalStorageHash(this, 'isLocal')) === 'true';
-
- var saveToLocalStorage = void 0;
-
- Object.defineProperties(this,
- /** @lends GUI.prototype */
- {
- /**
- * The parent GUI
- * @type dat.gui.GUI
- */
- parent: {
- get: function get() {
- return params.parent;
- }
- },
-
- scrollable: {
- get: function get() {
- return params.scrollable;
- }
- },
-
- /**
- * Handles GUI
's element placement for you
- * @type Boolean
- */
- autoPlace: {
- get: function get() {
- return params.autoPlace;
- }
- },
-
- /**
- * Handles GUI
's position of open/close button
- * @type Boolean
- */
- closeOnTop: {
- get: function get() {
- return params.closeOnTop;
- }
- },
-
- /**
- * The identifier for a set of saved values
- * @type String
- */
- preset: {
- get: function get() {
- if (_this.parent) {
- return _this.getRoot().preset;
- }
-
- return params.load.preset;
- },
-
- set: function set(v) {
- if (_this.parent) {
- _this.getRoot().preset = v;
- } else {
- params.load.preset = v;
- }
- setPresetSelectIndex(this);
- _this.revert();
- }
- },
-
- /**
- * The width of GUI
element
- * @type Number
- */
- width: {
- get: function get() {
- return params.width;
- },
- set: function set(v) {
- params.width = v;
- setWidth(_this, v);
- }
- },
-
- /**
- * The name of GUI
. Used for folders. i.e
- * a folder's name
- * @type String
- */
- name: {
- get: function get() {
- return params.name;
- },
- set: function set(v) {
- // TODO Check for collisions among sibling folders
- params.name = v;
- if (titleRowName) {
- titleRowName.innerHTML = params.name;
- }
- }
- },
-
- /**
- * Whether the GUI
is collapsed or not
- * @type Boolean
- */
- closed: {
- get: function get() {
- return params.closed;
- },
- set: function set(v) {
- params.closed = v;
- if (params.closed) {
- _dom2.default.addClass(_this.__ul, GUI.CLASS_CLOSED);
- } else {
- _dom2.default.removeClass(_this.__ul, GUI.CLASS_CLOSED);
- }
- // For browsers that aren't going to respect the CSS transition,
- // Lets just check our height against the window height right off
- // the bat.
- this.onResize();
-
- if (_this.__closeButton) {
- _this.__closeButton.innerHTML = v ? GUI.TEXT_OPEN : GUI.TEXT_CLOSED;
- }
- }
- },
-
- /**
- * Contains all presets
- * @type Object
- */
- load: {
- get: function get() {
- return params.load;
- }
- },
-
- /**
- * Determines whether or not to use localStorage as the means for
- * remember
ing
- * @type Boolean
- */
- useLocalStorage: {
-
- get: function get() {
- return useLocalStorage;
- },
- set: function set(bool) {
- if (SUPPORTS_LOCAL_STORAGE) {
- useLocalStorage = bool;
- if (bool) {
- _dom2.default.bind(window, 'unload', saveToLocalStorage);
- } else {
- _dom2.default.unbind(window, 'unload', saveToLocalStorage);
- }
- localStorage.setItem(getLocalStorageHash(_this, 'isLocal'), bool);
- }
- }
- }
- });
-
- // Are we a root level GUI?
- if (_common2.default.isUndefined(params.parent)) {
- params.closed = false;
-
- _dom2.default.addClass(this.domElement, GUI.CLASS_MAIN);
- _dom2.default.makeSelectable(this.domElement, false);
-
- // Are we supposed to be loading locally?
- if (SUPPORTS_LOCAL_STORAGE) {
- if (useLocalStorage) {
- _this.useLocalStorage = true;
-
- var savedGui = localStorage.getItem(getLocalStorageHash(this, 'gui'));
-
- if (savedGui) {
- params.load = JSON.parse(savedGui);
- }
- }
- }
-
- this.__closeButton = document.createElement('div');
- this.__closeButton.innerHTML = GUI.TEXT_CLOSED;
- _dom2.default.addClass(this.__closeButton, GUI.CLASS_CLOSE_BUTTON);
- if (params.closeOnTop) {
- _dom2.default.addClass(this.__closeButton, GUI.CLASS_CLOSE_TOP);
- this.domElement.insertBefore(this.__closeButton, this.domElement.childNodes[0]);
- } else {
- _dom2.default.addClass(this.__closeButton, GUI.CLASS_CLOSE_BOTTOM);
- this.domElement.appendChild(this.__closeButton);
- }
-
- _dom2.default.bind(this.__closeButton, 'click', function () {
- _this.closed = !_this.closed;
- });
- // Oh, you're a nested GUI!
- } else {
- if (params.closed === undefined) {
- params.closed = true;
- }
-
- var _titleRowName = document.createTextNode(params.name);
- _dom2.default.addClass(_titleRowName, 'controller-name');
-
- var titleRow = addRow(_this, _titleRowName);
-
- var onClickTitle = function onClickTitle(e) {
- e.preventDefault();
- _this.closed = !_this.closed;
- return false;
- };
-
- _dom2.default.addClass(this.__ul, GUI.CLASS_CLOSED);
-
- _dom2.default.addClass(titleRow, 'title');
- _dom2.default.bind(titleRow, 'click', onClickTitle);
-
- if (!params.closed) {
- this.closed = false;
- }
- }
-
- if (params.autoPlace) {
- if (_common2.default.isUndefined(params.parent)) {
- if (autoPlaceVirgin) {
- autoPlaceContainer = document.createElement('div');
- _dom2.default.addClass(autoPlaceContainer, CSS_NAMESPACE);
- _dom2.default.addClass(autoPlaceContainer, GUI.CLASS_AUTO_PLACE_CONTAINER);
- document.body.appendChild(autoPlaceContainer);
- autoPlaceVirgin = false;
- }
-
- // Put it in the dom for you.
- autoPlaceContainer.appendChild(this.domElement);
-
- // Apply the auto styles
- _dom2.default.addClass(this.domElement, GUI.CLASS_AUTO_PLACE);
- }
-
- // Make it not elastic.
- if (!this.parent) {
- setWidth(_this, params.width);
- }
- }
-
- this.__resizeHandler = function () {
- _this.onResizeDebounced();
- };
-
- _dom2.default.bind(window, 'resize', this.__resizeHandler);
- _dom2.default.bind(this.__ul, 'webkitTransitionEnd', this.__resizeHandler);
- _dom2.default.bind(this.__ul, 'transitionend', this.__resizeHandler);
- _dom2.default.bind(this.__ul, 'oTransitionEnd', this.__resizeHandler);
- this.onResize();
-
- if (params.resizable) {
- addResizeHandle(this);
- }
-
- saveToLocalStorage = function saveToLocalStorage() {
- if (SUPPORTS_LOCAL_STORAGE && localStorage.getItem(getLocalStorageHash(_this, 'isLocal')) === 'true') {
- localStorage.setItem(getLocalStorageHash(_this, 'gui'), JSON.stringify(_this.getSaveObject()));
- }
- };
-
- // expose this method publicly
- this.saveToLocalStorageIfPossible = saveToLocalStorage;
-
- function resetWidth() {
- var root = _this.getRoot();
- root.width += 1;
- _common2.default.defer(function () {
- root.width -= 1;
- });
- }
-
- if (!params.parent) {
- resetWidth();
- }
- };
-
- GUI.toggleHide = function () {
- hide = !hide;
- _common2.default.each(hideableGuis, function (gui) {
- gui.domElement.style.display = hide ? 'none' : '';
- });
- };
-
- GUI.CLASS_AUTO_PLACE = 'a';
- GUI.CLASS_AUTO_PLACE_CONTAINER = 'ac';
- GUI.CLASS_MAIN = 'main';
- GUI.CLASS_CONTROLLER_ROW = 'cr';
- GUI.CLASS_TOO_TALL = 'taller-than-window';
- GUI.CLASS_CLOSED = 'closed';
- GUI.CLASS_CLOSE_BUTTON = 'close-button';
- GUI.CLASS_CLOSE_TOP = 'close-top';
- GUI.CLASS_CLOSE_BOTTOM = 'close-bottom';
- GUI.CLASS_DRAG = 'drag';
-
- GUI.DEFAULT_WIDTH = 245;
- GUI.TEXT_CLOSED = 'Close Controls';
- GUI.TEXT_OPEN = 'Open Controls';
-
- GUI._keydownHandler = function (e) {
- if (document.activeElement.type !== 'text' && (e.which === HIDE_KEY_CODE || e.keyCode === HIDE_KEY_CODE)) {
- GUI.toggleHide();
- }
- };
- _dom2.default.bind(window, 'keydown', GUI._keydownHandler, false);
-
- _common2.default.extend(GUI.prototype,
-
- /** @lends GUI.prototype */
- {
-
- /**
- * Adds a new {@link Controller} to the GUI. The type of controller created
- * is inferred from the initial value of object[property]
. For
- * color properties, see {@link addColor}.
- *
- * @param {Object} object The object to be manipulated
- * @param {String} property The name of the property to be manipulated
- * @param {Number} [min] Minimum allowed value
- * @param {Number} [max] Maximum allowed value
- * @param {Number} [step] Increment by which to change value
- * @returns {Controller} The controller that was added to the GUI.
- * @instance
- *
- * @example
- * // Add a string controller.
- * var person = {name: 'Sam'};
- * gui.add(person, 'name');
- *
- * @example
- * // Add a number controller slider.
- * var person = {age: 45};
- * gui.add(person, 'age', 0, 100);
- */
- add: function add(object, property) {
- return _add(this, object, property, {
- factoryArgs: Array.prototype.slice.call(arguments, 2)
- });
- },
-
- /**
- * Adds a new color controller to the GUI.
- *
- * @param object
- * @param property
- * @returns {Controller} The controller that was added to the GUI.
- * @instance
- *
- * @example
- * var palette = {
- * color1: '#FF0000', // CSS string
- * color2: [ 0, 128, 255 ], // RGB array
- * color3: [ 0, 128, 255, 0.3 ], // RGB with alpha
- * color4: { h: 350, s: 0.9, v: 0.3 } // Hue, saturation, value
- * };
- * gui.addColor(palette, 'color1');
- * gui.addColor(palette, 'color2');
- * gui.addColor(palette, 'color3');
- * gui.addColor(palette, 'color4');
- */
- addColor: function addColor(object, property) {
- return _add(this, object, property, {
- color: true
- });
- },
-
- /**
- * Removes the given controller from the GUI.
- * @param {Controller} controller
- * @instance
- */
- remove: function remove(controller) {
- // TODO listening?
- this.__ul.removeChild(controller.__li);
- this.__controllers.splice(this.__controllers.indexOf(controller), 1);
- var _this = this;
- _common2.default.defer(function () {
- _this.onResize();
- });
- },
-
- /**
- * Removes the GUI from the document and unbinds all event listeners.
- * @instance
- */
- destroy: function destroy() {
- if (this.autoPlace) {
- autoPlaceContainer.removeChild(this.domElement);
- }
-
- _dom2.default.unbind(window, 'keydown', GUI._keydownHandler, false);
- _dom2.default.unbind(window, 'resize', this.__resizeHandler);
-
- if (this.saveToLocalStorageIfPossible) {
- _dom2.default.unbind(window, 'unload', this.saveToLocalStorageIfPossible);
- }
- },
-
- /**
- * Creates a new subfolder GUI instance.
- * @param name
- * @returns {dat.gui.GUI} The new folder.
- * @throws {Error} if this GUI already has a folder by the specified
- * name
- * @instance
- */
- addFolder: function addFolder(name) {
- // We have to prevent collisions on names in order to have a key
- // by which to remember saved values
- if (this.__folders[name] !== undefined) {
- throw new Error('You already have a folder in this GUI by the' + ' name "' + name + '"');
- }
-
- var newGuiParams = { name: name, parent: this };
-
- // We need to pass down the autoPlace trait so that we can
- // attach event listeners to open/close folder actions to
- // ensure that a scrollbar appears if the window is too short.
- newGuiParams.autoPlace = this.autoPlace;
-
- // Do we have saved appearance data for this folder?
- if (this.load && // Anything loaded?
- this.load.folders && // Was my parent a dead-end?
- this.load.folders[name]) {
- // Did daddy remember me?
- // Start me closed if I was closed
- newGuiParams.closed = this.load.folders[name].closed;
-
- // Pass down the loaded data
- newGuiParams.load = this.load.folders[name];
- }
-
- var gui = new GUI(newGuiParams);
- this.__folders[name] = gui;
-
- var li = addRow(this, gui.domElement);
- _dom2.default.addClass(li, 'folder');
- return gui;
- },
-
- /**
- * Opens the GUI.
- */
- open: function open() {
- this.closed = false;
- },
-
- /**
- * Closes the GUI.
- */
- close: function close() {
- this.closed = true;
- },
-
- onResize: function onResize() {
- // we debounce this function to prevent performance issues when rotating on tablet/mobile
- var root = this.getRoot();
- if (root.scrollable) {
- var top = _dom2.default.getOffset(root.__ul).top;
- var h = 0;
-
- _common2.default.each(root.__ul.childNodes, function (node) {
- if (!(root.autoPlace && node === root.__save_row)) {
- h += _dom2.default.getHeight(node);
- }
- });
-
- if (window.innerHeight - top - CLOSE_BUTTON_HEIGHT < h) {
- _dom2.default.addClass(root.domElement, GUI.CLASS_TOO_TALL);
- root.__ul.style.height = window.innerHeight - top - CLOSE_BUTTON_HEIGHT + 'px';
- } else {
- _dom2.default.removeClass(root.domElement, GUI.CLASS_TOO_TALL);
- root.__ul.style.height = 'auto';
- }
- }
-
- if (root.__resize_handle) {
- _common2.default.defer(function () {
- root.__resize_handle.style.height = root.__ul.offsetHeight + 'px';
- });
- }
-
- if (root.__closeButton) {
- root.__closeButton.style.width = root.width + 'px';
- }
- },
-
- onResizeDebounced: _common2.default.debounce(function () {
- this.onResize();
- }, 50),
-
- /**
- * Mark objects for saving. The order of these objects cannot change as
- * the GUI grows. When remembering new objects, append them to the end
- * of the list.
- *
- * @param {...Object} objects
- * @throws {Error} if not called on a top level GUI.
- * @instance
- * @ignore
- */
- remember: function remember() {
- if (_common2.default.isUndefined(SAVE_DIALOGUE)) {
- SAVE_DIALOGUE = new _CenteredDiv2.default();
- SAVE_DIALOGUE.domElement.innerHTML = _saveDialogue2.default;
- }
-
- if (this.parent) {
- throw new Error('You can only call remember on a top level GUI.');
- }
-
- var _this = this;
-
- _common2.default.each(Array.prototype.slice.call(arguments), function (object) {
- if (_this.__rememberedObjects.length === 0) {
- addSaveMenu(_this);
- }
- if (_this.__rememberedObjects.indexOf(object) === -1) {
- _this.__rememberedObjects.push(object);
- }
- });
-
- if (this.autoPlace) {
- // Set save row width
- setWidth(this, this.width);
- }
- },
-
- /**
- * @returns {dat.gui.GUI} the topmost parent GUI of a nested GUI.
- * @instance
- */
- getRoot: function getRoot() {
- var gui = this;
- while (gui.parent) {
- gui = gui.parent;
- }
- return gui;
- },
-
- /**
- * @returns {Object} a JSON object representing the current state of
- * this GUI as well as its remembered properties.
- * @instance
- */
- getSaveObject: function getSaveObject() {
- var toReturn = this.load;
- toReturn.closed = this.closed;
-
- // Am I remembering any values?
- if (this.__rememberedObjects.length > 0) {
- toReturn.preset = this.preset;
-
- if (!toReturn.remembered) {
- toReturn.remembered = {};
- }
-
- toReturn.remembered[this.preset] = getCurrentPreset(this);
- }
-
- toReturn.folders = {};
- _common2.default.each(this.__folders, function (element, key) {
- toReturn.folders[key] = element.getSaveObject();
- });
-
- return toReturn;
- },
-
- save: function save() {
- if (!this.load.remembered) {
- this.load.remembered = {};
- }
-
- this.load.remembered[this.preset] = getCurrentPreset(this);
- markPresetModified(this, false);
- this.saveToLocalStorageIfPossible();
- },
-
- saveAs: function saveAs(presetName) {
- if (!this.load.remembered) {
- // Retain default values upon first save
- this.load.remembered = {};
- this.load.remembered[DEFAULT_DEFAULT_PRESET_NAME] = getCurrentPreset(this, true);
- }
-
- this.load.remembered[presetName] = getCurrentPreset(this);
- this.preset = presetName;
- addPresetOption(this, presetName, true);
- this.saveToLocalStorageIfPossible();
- },
-
- revert: function revert(gui) {
- _common2.default.each(this.__controllers, function (controller) {
- // Make revert work on Default.
- if (!this.getRoot().load.remembered) {
- controller.setValue(controller.initialValue);
- } else {
- recallSavedValue(gui || this.getRoot(), controller);
- }
-
- // fire onFinishChange callback
- if (controller.__onFinishChange) {
- controller.__onFinishChange.call(controller, controller.getValue());
- }
- }, this);
-
- _common2.default.each(this.__folders, function (folder) {
- folder.revert(folder);
- });
-
- if (!gui) {
- markPresetModified(this.getRoot(), false);
- }
- },
-
- listen: function listen(controller) {
- var init = this.__listening.length === 0;
- this.__listening.push(controller);
- if (init) {
- updateDisplays(this.__listening);
- }
- },
-
- updateDisplay: function updateDisplay() {
- _common2.default.each(this.__controllers, function (controller) {
- controller.updateDisplay();
- });
- _common2.default.each(this.__folders, function (folder) {
- folder.updateDisplay();
- });
- }
- });
-
- /**
- * Add a row to the end of the GUI or before another row.
- *
- * @param gui
- * @param [newDom] If specified, inserts the dom content in the new row
- * @param [liBefore] If specified, places the new row before another row
- *
- * @ignore
- */
- function addRow(gui, newDom, liBefore) {
- var li = document.createElement('li');
- if (newDom) {
- li.appendChild(newDom);
- }
-
- if (liBefore) {
- gui.__ul.insertBefore(li, liBefore);
- } else {
- gui.__ul.appendChild(li);
- }
- gui.onResize();
- return li;
- }
-
- function markPresetModified(gui, modified) {
- var opt = gui.__preset_select[gui.__preset_select.selectedIndex];
-
- // console.log('mark', modified, opt);
- if (modified) {
- opt.innerHTML = opt.value + '*';
- } else {
- opt.innerHTML = opt.value;
- }
- }
-
- function augmentController(gui, li, controller) {
- controller.__li = li;
- controller.__gui = gui;
-
- _common2.default.extend(controller, {
- options: function options(_options) {
- if (arguments.length > 1) {
- var nextSibling = controller.__li.nextElementSibling;
- controller.remove();
-
- return _add(gui, controller.object, controller.property, {
- before: nextSibling,
- factoryArgs: [_common2.default.toArray(arguments)]
- });
- }
-
- if (_common2.default.isArray(_options) || _common2.default.isObject(_options)) {
- var _nextSibling = controller.__li.nextElementSibling;
- controller.remove();
-
- return _add(gui, controller.object, controller.property, {
- before: _nextSibling,
- factoryArgs: [_options]
- });
- }
- },
-
- name: function name(v) {
- controller.__li.firstElementChild.firstElementChild.innerHTML = v;
- return controller;
- },
-
- listen: function listen() {
- controller.__gui.listen(controller);
- return controller;
- },
-
- remove: function remove() {
- controller.__gui.remove(controller);
- return controller;
- }
- });
-
- // All sliders should be accompanied by a box.
- if (controller instanceof _NumberControllerSlider2.default) {
- var box = new _NumberControllerBox2.default(controller.object, controller.property, { min: controller.__min, max: controller.__max, step: controller.__step });
-
- _common2.default.each(['updateDisplay', 'onChange', 'onFinishChange', 'step'], function (method) {
- var pc = controller[method];
- var pb = box[method];
- controller[method] = box[method] = function () {
- var args = Array.prototype.slice.call(arguments);
- pb.apply(box, args);
- return pc.apply(controller, args);
- };
- });
-
- _dom2.default.addClass(li, 'has-slider');
- controller.domElement.insertBefore(box.domElement, controller.domElement.firstElementChild);
- } else if (controller instanceof _NumberControllerBox2.default) {
- var r = function r(returned) {
- // Have we defined both boundaries?
- if (_common2.default.isNumber(controller.__min) && _common2.default.isNumber(controller.__max)) {
- // Well, then lets just replace this with a slider.
-
- // lets remember if the old controller had a specific name or was listening
- var oldName = controller.__li.firstElementChild.firstElementChild.innerHTML;
- var wasListening = controller.__gui.__listening.indexOf(controller) > -1;
-
- controller.remove();
- var newController = _add(gui, controller.object, controller.property, {
- before: controller.__li.nextElementSibling,
- factoryArgs: [controller.__min, controller.__max, controller.__step]
- });
-
- newController.name(oldName);
- if (wasListening) newController.listen();
-
- return newController;
- }
-
- return returned;
- };
-
- controller.min = _common2.default.compose(r, controller.min);
- controller.max = _common2.default.compose(r, controller.max);
- } else if (controller instanceof _BooleanController2.default) {
- _dom2.default.bind(li, 'click', function () {
- _dom2.default.fakeEvent(controller.__checkbox, 'click');
- });
-
- _dom2.default.bind(controller.__checkbox, 'click', function (e) {
- e.stopPropagation(); // Prevents double-toggle
- });
- } else if (controller instanceof _FunctionController2.default) {
- _dom2.default.bind(li, 'click', function () {
- _dom2.default.fakeEvent(controller.__button, 'click');
- });
-
- _dom2.default.bind(li, 'mouseover', function () {
- _dom2.default.addClass(controller.__button, 'hover');
- });
-
- _dom2.default.bind(li, 'mouseout', function () {
- _dom2.default.removeClass(controller.__button, 'hover');
- });
- } else if (controller instanceof _ColorController2.default) {
- _dom2.default.addClass(li, 'color');
- controller.updateDisplay = _common2.default.compose(function (val) {
- li.style.borderLeftColor = controller.__color.toString();
- return val;
- }, controller.updateDisplay);
-
- controller.updateDisplay();
- }
-
- controller.setValue = _common2.default.compose(function (val) {
- if (gui.getRoot().__preset_select && controller.isModified()) {
- markPresetModified(gui.getRoot(), true);
- }
-
- return val;
- }, controller.setValue);
- }
-
- function recallSavedValue(gui, controller) {
- // Find the topmost GUI, that's where remembered objects live.
- var root = gui.getRoot();
-
- // Does the object we're controlling match anything we've been told to
- // remember?
- var matchedIndex = root.__rememberedObjects.indexOf(controller.object);
-
- // Why yes, it does!
- if (matchedIndex !== -1) {
- // Let me fetch a map of controllers for thcommon.isObject.
- var controllerMap = root.__rememberedObjectIndecesToControllers[matchedIndex];
-
- // Ohp, I believe this is the first controller we've created for this
- // object. Lets make the map fresh.
- if (controllerMap === undefined) {
- controllerMap = {};
- root.__rememberedObjectIndecesToControllers[matchedIndex] = controllerMap;
- }
-
- // Keep track of this controller
- controllerMap[controller.property] = controller;
-
- // Okay, now have we saved any values for this controller?
- if (root.load && root.load.remembered) {
- var presetMap = root.load.remembered;
-
- // Which preset are we trying to load?
- var preset = void 0;
-
- if (presetMap[gui.preset]) {
- preset = presetMap[gui.preset];
- } else if (presetMap[DEFAULT_DEFAULT_PRESET_NAME]) {
- // Uhh, you can have the default instead?
- preset = presetMap[DEFAULT_DEFAULT_PRESET_NAME];
- } else {
- // Nada.
- return;
- }
-
- // Did the loaded object remember thcommon.isObject? && Did we remember this particular property?
- if (preset[matchedIndex] && preset[matchedIndex][controller.property] !== undefined) {
- // We did remember something for this guy ...
- var value = preset[matchedIndex][controller.property];
-
- // And that's what it is.
- controller.initialValue = value;
- controller.setValue(value);
- }
- }
- }
- }
-
- function _add(gui, object, property, params) {
- if (object[property] === undefined) {
- throw new Error('Object "' + object + '" has no property "' + property + '"');
- }
-
- var controller = void 0;
-
- if (params.color) {
- controller = new _ColorController2.default(object, property);
- } else {
- var factoryArgs = [object, property].concat(params.factoryArgs);
- controller = _ControllerFactory2.default.apply(gui, factoryArgs);
- }
-
- if (params.before instanceof _Controller2.default) {
- params.before = params.before.__li;
- }
-
- recallSavedValue(gui, controller);
-
- _dom2.default.addClass(controller.domElement, 'c');
-
- var name = document.createElement('span');
- _dom2.default.addClass(name, 'property-name');
- name.innerHTML = controller.property;
-
- var container = document.createElement('div');
- container.appendChild(name);
- container.appendChild(controller.domElement);
-
- var li = addRow(gui, container, params.before);
-
- _dom2.default.addClass(li, GUI.CLASS_CONTROLLER_ROW);
- if (controller instanceof _ColorController2.default) {
- _dom2.default.addClass(li, 'color');
- } else {
- _dom2.default.addClass(li, _typeof(controller.getValue()));
- }
-
- augmentController(gui, li, controller);
-
- gui.__controllers.push(controller);
-
- return controller;
- }
-
- function getLocalStorageHash(gui, key) {
- // TODO how does this deal with multiple GUI's?
- return document.location.href + '.' + key;
- }
-
- function addPresetOption(gui, name, setSelected) {
- var opt = document.createElement('option');
- opt.innerHTML = name;
- opt.value = name;
- gui.__preset_select.appendChild(opt);
- if (setSelected) {
- gui.__preset_select.selectedIndex = gui.__preset_select.length - 1;
- }
- }
-
- function showHideExplain(gui, explain) {
- explain.style.display = gui.useLocalStorage ? 'block' : 'none';
- }
-
- function addSaveMenu(gui) {
- var div = gui.__save_row = document.createElement('li');
-
- _dom2.default.addClass(gui.domElement, 'has-save');
-
- gui.__ul.insertBefore(div, gui.__ul.firstChild);
-
- _dom2.default.addClass(div, 'save-row');
-
- var gears = document.createElement('span');
- gears.innerHTML = ' ';
- _dom2.default.addClass(gears, 'button gears');
-
- // TODO replace with FunctionController
- var button = document.createElement('span');
- button.innerHTML = 'Save';
- _dom2.default.addClass(button, 'button');
- _dom2.default.addClass(button, 'save');
-
- var button2 = document.createElement('span');
- button2.innerHTML = 'New';
- _dom2.default.addClass(button2, 'button');
- _dom2.default.addClass(button2, 'save-as');
-
- var button3 = document.createElement('span');
- button3.innerHTML = 'Revert';
- _dom2.default.addClass(button3, 'button');
- _dom2.default.addClass(button3, 'revert');
-
- var select = gui.__preset_select = document.createElement('select');
-
- if (gui.load && gui.load.remembered) {
- _common2.default.each(gui.load.remembered, function (value, key) {
- addPresetOption(gui, key, key === gui.preset);
- });
- } else {
- addPresetOption(gui, DEFAULT_DEFAULT_PRESET_NAME, false);
- }
-
- _dom2.default.bind(select, 'change', function () {
- for (var index = 0; index < gui.__preset_select.length; index++) {
- gui.__preset_select[index].innerHTML = gui.__preset_select[index].value;
- }
-
- gui.preset = this.value;
- });
-
- div.appendChild(select);
- div.appendChild(gears);
- div.appendChild(button);
- div.appendChild(button2);
- div.appendChild(button3);
-
- if (SUPPORTS_LOCAL_STORAGE) {
- var explain = document.getElementById('dg-local-explain');
- var localStorageCheckBox = document.getElementById('dg-local-storage');
- var saveLocally = document.getElementById('dg-save-locally');
-
- saveLocally.style.display = 'block';
-
- if (localStorage.getItem(getLocalStorageHash(gui, 'isLocal')) === 'true') {
- localStorageCheckBox.setAttribute('checked', 'checked');
- }
-
- showHideExplain(gui, explain);
-
- // TODO: Use a boolean controller, fool!
- _dom2.default.bind(localStorageCheckBox, 'change', function () {
- gui.useLocalStorage = !gui.useLocalStorage;
- showHideExplain(gui, explain);
- });
- }
-
- var newConstructorTextArea = document.getElementById('dg-new-constructor');
-
- _dom2.default.bind(newConstructorTextArea, 'keydown', function (e) {
- if (e.metaKey && (e.which === 67 || e.keyCode === 67)) {
- SAVE_DIALOGUE.hide();
- }
- });
-
- _dom2.default.bind(gears, 'click', function () {
- newConstructorTextArea.innerHTML = JSON.stringify(gui.getSaveObject(), undefined, 2);
- SAVE_DIALOGUE.show();
- newConstructorTextArea.focus();
- newConstructorTextArea.select();
- });
-
- _dom2.default.bind(button, 'click', function () {
- gui.save();
- });
-
- _dom2.default.bind(button2, 'click', function () {
- var presetName = prompt('Enter a new preset name.');
- if (presetName) {
- gui.saveAs(presetName);
- }
- });
-
- _dom2.default.bind(button3, 'click', function () {
- gui.revert();
- });
-
- // div.appendChild(button2);
- }
-
- function addResizeHandle(gui) {
- var pmouseX = void 0;
-
- gui.__resize_handle = document.createElement('div');
-
- _common2.default.extend(gui.__resize_handle.style, {
-
- width: '6px',
- marginLeft: '-3px',
- height: '200px',
- cursor: 'ew-resize',
- position: 'absolute'
- // border: '1px solid blue'
-
- });
-
- function drag(e) {
- e.preventDefault();
-
- gui.width += pmouseX - e.clientX;
- gui.onResize();
- pmouseX = e.clientX;
-
- return false;
- }
-
- function dragStop() {
- _dom2.default.removeClass(gui.__closeButton, GUI.CLASS_DRAG);
- _dom2.default.unbind(window, 'mousemove', drag);
- _dom2.default.unbind(window, 'mouseup', dragStop);
- }
-
- function dragStart(e) {
- e.preventDefault();
-
- pmouseX = e.clientX;
-
- _dom2.default.addClass(gui.__closeButton, GUI.CLASS_DRAG);
- _dom2.default.bind(window, 'mousemove', drag);
- _dom2.default.bind(window, 'mouseup', dragStop);
-
- return false;
- }
-
- _dom2.default.bind(gui.__resize_handle, 'mousedown', dragStart);
- _dom2.default.bind(gui.__closeButton, 'mousedown', dragStart);
-
- gui.domElement.insertBefore(gui.__resize_handle, gui.domElement.firstElementChild);
- }
-
- function setWidth(gui, w) {
- gui.domElement.style.width = w + 'px';
- // Auto placed save-rows are position fixed, so we have to
- // set the width manually if we want it to bleed to the edge
- if (gui.__save_row && gui.autoPlace) {
- gui.__save_row.style.width = w + 'px';
- }
- if (gui.__closeButton) {
- gui.__closeButton.style.width = w + 'px';
- }
- }
-
- function getCurrentPreset(gui, useInitialValues) {
- var toReturn = {};
-
- // For each object I'm remembering
- _common2.default.each(gui.__rememberedObjects, function (val, index) {
- var savedValues = {};
-
- // The controllers I've made for thcommon.isObject by property
- var controllerMap = gui.__rememberedObjectIndecesToControllers[index];
-
- // Remember each value for each property
- _common2.default.each(controllerMap, function (controller, property) {
- savedValues[property] = useInitialValues ? controller.initialValue : controller.getValue();
- });
-
- // Save the values for thcommon.isObject
- toReturn[index] = savedValues;
- });
-
- return toReturn;
- }
-
- function setPresetSelectIndex(gui) {
- for (var index = 0; index < gui.__preset_select.length; index++) {
- if (gui.__preset_select[index].value === gui.preset) {
- gui.__preset_select.selectedIndex = index;
- }
- }
- }
-
- function updateDisplays(controllerArray) {
- if (controllerArray.length !== 0) {
- _requestAnimationFrame2.default.call(window, function () {
- updateDisplays(controllerArray);
- });
- }
-
- _common2.default.each(controllerArray, function (c) {
- c.updateDisplay();
- });
- }
-
- exports.default = GUI;
- module.exports = exports['default'];
-
-/***/ },
-/* 18 */
-/***/ function(module, exports) {
-
- 'use strict';
-
- /**
- * 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
- */
-
- module.exports = {
- load: function load(url, indoc) {
- var doc = indoc || 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, indoc) {
- var doc = indoc || document;
- var injected = document.createElement('style');
- injected.type = 'text/css';
- injected.innerHTML = css;
- var head = doc.getElementsByTagName('head')[0];
- try {
- head.appendChild(injected);
- } catch (e) {// Unable to inject CSS, probably because of a Content Security Policy
- }
- }
- };
-
-/***/ },
-/* 19 */
-/***/ function(module, exports) {
-
- module.exports = "GUI
's constructor:\n\n \n\n localStorage
on exit.\n\n localStorage
will\n override those passed to dat.GUI
's constructor. This makes it\n easier to work incrementally, but localStorage
is fragile,\n and your friends may not see the same values you do.\n\n object[property]
\n *\n * @param {Object} newValue The new value of object[property]
\n */\n setValue(newValue) {\n this.object[this.property] = newValue;\n if (this.__onChange) {\n this.__onChange.call(this, newValue);\n }\n\n this.updateDisplay();\n return this;\n }\n\n /**\n * Gets the value of object[property]
\n *\n * @returns {Object} The current value of object[property]
\n */\n getValue() {\n return this.object[this.property];\n }\n\n /**\n * Refreshes the visual display of a Controller in order to keep sync\n * with the object's current value.\n * @returns {Controller} this\n */\n updateDisplay() {\n return this;\n }\n\n /**\n * @returns {Boolean} true if the value has deviated from initialValue\n */\n isModified() {\n return this.initialValue !== this.getValue();\n }\n}\n\nexport default Controller;\n\n\n\n// WEBPACK FOOTER //\n// ./dat/controllers/Controller.js","/**\n * dat-gui JavaScript Controller Library\n * http://code.google.com/p/dat-gui\n *\n * Copyright 2011 Data Arts Team, Google Creative Lab\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n */\n\nimport Controller from './Controller';\nimport dom from '../dom/dom';\n\n/**\n * @class Provides a checkbox input to alter the boolean property of an object.\n *\n * @extends dat.controllers.Controller\n *\n * @param {Object} object The object to be manipulated\n * @param {string} property The name of the property to be manipulated\n */\nclass BooleanController extends Controller {\n constructor(object, property) {\n super(object, property);\n\n const _this = this;\n this.__prev = this.getValue();\n\n this.__checkbox = document.createElement('input');\n this.__checkbox.setAttribute('type', 'checkbox');\n\n function onChange() {\n _this.setValue(!_this.__prev);\n }\n\n dom.bind(this.__checkbox, 'change', onChange, false);\n\n this.domElement.appendChild(this.__checkbox);\n\n // Match original value\n this.updateDisplay();\n }\n\n setValue(v) {\n const toReturn = super.setValue(v);\n if (this.__onFinishChange) {\n this.__onFinishChange.call(this, this.getValue());\n }\n this.__prev = this.getValue();\n return toReturn;\n }\n\n updateDisplay() {\n if (this.getValue() === true) {\n this.__checkbox.setAttribute('checked', 'checked');\n this.__checkbox.checked = true;\n this.__prev = true;\n } else {\n this.__checkbox.checked = false;\n this.__prev = false;\n }\n\n return super.updateDisplay();\n }\n}\n\nexport default BooleanController;\n\n\n\n// WEBPACK FOOTER //\n// ./dat/controllers/BooleanController.js","/**\n * dat-gui JavaScript Controller Library\n * http://code.google.com/p/dat-gui\n *\n * Copyright 2011 Data Arts Team, Google Creative Lab\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n */\n\nimport common from '../utils/common';\n\nconst EVENT_MAP = {\n HTMLEvents: ['change'],\n MouseEvents: ['click', 'mousemove', 'mousedown', 'mouseup', 'mouseover'],\n KeyboardEvents: ['keydown']\n};\n\nconst EVENT_MAP_INV = {};\ncommon.each(EVENT_MAP, function(v, k) {\n common.each(v, function(e) {\n EVENT_MAP_INV[e] = k;\n });\n});\n\nconst CSS_VALUE_PIXELS = /(\\d+(\\.\\d+)?)px/;\n\nfunction cssValueToPixels(val) {\n if (val === '0' || common.isUndefined(val)) {\n return 0;\n }\n\n const match = val.match(CSS_VALUE_PIXELS);\n\n if (!common.isNull(match)) {\n return parseFloat(match[1]);\n }\n\n // TODO ...ems? %?\n\n return 0;\n}\n\n/**\n * @namespace\n * @member dat.dom\n */\nconst dom = {\n\n /**\n *\n * @param elem\n * @param selectable\n */\n makeSelectable: function(elem, selectable) {\n if (elem === undefined || elem.style === undefined) return;\n\n elem.onselectstart = selectable ? function() {\n return false;\n } : function() {\n };\n\n elem.style.MozUserSelect = selectable ? 'auto' : 'none';\n elem.style.KhtmlUserSelect = selectable ? 'auto' : 'none';\n elem.unselectable = selectable ? 'on' : 'off';\n },\n\n /**\n *\n * @param elem\n * @param horizontal\n * @param vert\n */\n makeFullscreen: function(elem, hor, vert) {\n let vertical = vert;\n let horizontal = hor;\n\n if (common.isUndefined(horizontal)) {\n horizontal = true;\n }\n\n if (common.isUndefined(vertical)) {\n vertical = true;\n }\n\n elem.style.position = 'absolute';\n\n if (horizontal) {\n elem.style.left = 0;\n elem.style.right = 0;\n }\n if (vertical) {\n elem.style.top = 0;\n elem.style.bottom = 0;\n }\n },\n\n /**\n *\n * @param elem\n * @param eventType\n * @param params\n */\n fakeEvent: function(elem, eventType, pars, aux) {\n const params = pars || {};\n const className = EVENT_MAP_INV[eventType];\n if (!className) {\n throw new Error('Event type ' + eventType + ' not supported.');\n }\n const evt = document.createEvent(className);\n switch (className) {\n case 'MouseEvents':\n {\n const clientX = params.x || params.clientX || 0;\n const clientY = params.y || params.clientY || 0;\n evt.initMouseEvent(eventType, params.bubbles || false,\n params.cancelable || true, window, params.clickCount || 1,\n 0, // screen X\n 0, // screen Y\n clientX, // client X\n clientY, // client Y\n false, false, false, false, 0, null);\n break;\n }\n case 'KeyboardEvents':\n {\n const init = evt.initKeyboardEvent || evt.initKeyEvent; // webkit || moz\n common.defaults(params, {\n cancelable: true,\n ctrlKey: false,\n altKey: false,\n shiftKey: false,\n metaKey: false,\n keyCode: undefined,\n charCode: undefined\n });\n init(eventType, params.bubbles || false,\n params.cancelable, window,\n params.ctrlKey, params.altKey,\n params.shiftKey, params.metaKey,\n params.keyCode, params.charCode);\n break;\n }\n default:\n {\n evt.initEvent(eventType, params.bubbles || false, params.cancelable || true);\n break;\n }\n }\n common.defaults(evt, aux);\n elem.dispatchEvent(evt);\n },\n\n /**\n *\n * @param elem\n * @param event\n * @param func\n * @param bool\n */\n bind: function(elem, event, func, newBool) {\n const bool = newBool || false;\n if (elem.addEventListener) {\n elem.addEventListener(event, func, bool);\n } else if (elem.attachEvent) {\n elem.attachEvent('on' + event, func);\n }\n return dom;\n },\n\n /**\n *\n * @param elem\n * @param event\n * @param func\n * @param bool\n */\n unbind: function(elem, event, func, newBool) {\n const bool = newBool || false;\n if (elem.removeEventListener) {\n elem.removeEventListener(event, func, bool);\n } else if (elem.detachEvent) {\n elem.detachEvent('on' + event, func);\n }\n return dom;\n },\n\n /**\n *\n * @param elem\n * @param className\n */\n addClass: function(elem, className) {\n if (elem.className === undefined) {\n elem.className = className;\n } else if (elem.className !== className) {\n const classes = elem.className.split(/ +/);\n if (classes.indexOf(className) === -1) {\n classes.push(className);\n elem.className = classes.join(' ').replace(/^\\s+/, '').replace(/\\s+$/, '');\n }\n }\n return dom;\n },\n\n /**\n *\n * @param elem\n * @param className\n */\n removeClass: function(elem, className) {\n if (className) {\n if (elem.className === className) {\n elem.removeAttribute('class');\n } else {\n const classes = elem.className.split(/ +/);\n const index = classes.indexOf(className);\n if (index !== -1) {\n classes.splice(index, 1);\n elem.className = classes.join(' ');\n }\n }\n } else {\n elem.className = undefined;\n }\n return dom;\n },\n\n hasClass: function(elem, className) {\n return new RegExp('(?:^|\\\\s+)' + className + '(?:\\\\s+|$)').test(elem.className) || false;\n },\n\n /**\n *\n * @param elem\n */\n getWidth: function(elem) {\n const style = getComputedStyle(elem);\n\n return cssValueToPixels(style['border-left-width']) +\n cssValueToPixels(style['border-right-width']) +\n cssValueToPixels(style['padding-left']) +\n cssValueToPixels(style['padding-right']) +\n cssValueToPixels(style.width);\n },\n\n /**\n *\n * @param elem\n */\n getHeight: function(elem) {\n const style = getComputedStyle(elem);\n\n return cssValueToPixels(style['border-top-width']) +\n cssValueToPixels(style['border-bottom-width']) +\n cssValueToPixels(style['padding-top']) +\n cssValueToPixels(style['padding-bottom']) +\n cssValueToPixels(style.height);\n },\n\n /**\n *\n * @param el\n */\n getOffset: function(el) {\n let elem = el;\n const offset = { left: 0, top: 0 };\n if (elem.offsetParent) {\n do {\n offset.left += elem.offsetLeft;\n offset.top += elem.offsetTop;\n elem = elem.offsetParent;\n } while (elem);\n }\n return offset;\n },\n\n // http://stackoverflow.com/posts/2684561/revisions\n /**\n *\n * @param elem\n */\n isActive: function(elem) {\n return elem === document.activeElement && (elem.type || elem.href);\n }\n\n};\n\nexport default dom;\n\n\n\n// WEBPACK FOOTER //\n// ./dat/dom/dom.js","/**\n * dat-gui JavaScript Controller Library\n * http://code.google.com/p/dat-gui\n *\n * Copyright 2011 Data Arts Team, Google Creative Lab\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n */\n\nimport Controller from './Controller';\nimport dom from '../dom/dom';\nimport common from '../utils/common';\n\n/**\n * @class Provides a select input to alter the property of an object, using a\n * list of accepted values.\n *\n * @extends dat.controllers.Controller\n *\n * @param {Object} object The object to be manipulated\n * @param {string} property The name of the property to be manipulated\n * @param {Object|string[]} options A map of labels to acceptable values, or\n * a list of acceptable string values.\n */\nclass OptionController extends Controller {\n constructor(object, property, opts) {\n super(object, property);\n\n let options = opts;\n\n const _this = this;\n\n /**\n * The drop down menu\n * @ignore\n */\n this.__select = document.createElement('select');\n\n if (common.isArray(options)) {\n const map = {};\n common.each(options, function(element) {\n map[element] = element;\n });\n options = map;\n }\n\n common.each(options, function(value, key) {\n const opt = document.createElement('option');\n opt.innerHTML = key;\n opt.setAttribute('value', value);\n _this.__select.appendChild(opt);\n });\n\n // Acknowledge original value\n this.updateDisplay();\n\n dom.bind(this.__select, 'change', function() {\n const desiredValue = this.options[this.selectedIndex].value;\n _this.setValue(desiredValue);\n });\n\n this.domElement.appendChild(this.__select);\n }\n\n setValue(v) {\n const toReturn = super.setValue(v);\n\n if (this.__onFinishChange) {\n this.__onFinishChange.call(this, this.getValue());\n }\n return toReturn;\n }\n\n updateDisplay() {\n if (dom.isActive(this.__select)) return this; // prevent number from updating if user is trying to manually update\n this.__select.value = this.getValue();\n return super.updateDisplay();\n }\n}\n\nexport default OptionController;\n\n\n\n// WEBPACK FOOTER //\n// ./dat/controllers/OptionController.js","/**\n * dat-gui JavaScript Controller Library\n * http://code.google.com/p/dat-gui\n *\n * Copyright 2011 Data Arts Team, Google Creative Lab\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n */\n\nimport Controller from './Controller';\nimport dom from '../dom/dom';\n\n/**\n * @class Provides a text input to alter the string property of an object.\n *\n * @extends dat.controllers.Controller\n *\n * @param {Object} object The object to be manipulated\n * @param {string} property The name of the property to be manipulated\n */\nclass StringController extends Controller {\n constructor(object, property) {\n super(object, property);\n\n const _this = this;\n\n function onChange() {\n _this.setValue(_this.__input.value);\n }\n\n function onBlur() {\n if (_this.__onFinishChange) {\n _this.__onFinishChange.call(_this, _this.getValue());\n }\n }\n\n this.__input = document.createElement('input');\n this.__input.setAttribute('type', 'text');\n\n dom.bind(this.__input, 'keyup', onChange);\n dom.bind(this.__input, 'change', onChange);\n dom.bind(this.__input, 'blur', onBlur);\n dom.bind(this.__input, 'keydown', function(e) {\n if (e.keyCode === 13) {\n this.blur();\n }\n });\n\n this.updateDisplay();\n\n this.domElement.appendChild(this.__input);\n }\n\n updateDisplay() {\n // Stops the caret from moving on account of:\n // keyup -> setValue -> updateDisplay\n if (!dom.isActive(this.__input)) {\n this.__input.value = this.getValue();\n }\n return super.updateDisplay();\n }\n}\n\nexport default StringController;\n\n\n\n// WEBPACK FOOTER //\n// ./dat/controllers/StringController.js","/**\n * dat-gui JavaScript Controller Library\n * http://code.google.com/p/dat-gui\n *\n * Copyright 2011 Data Arts Team, Google Creative Lab\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n */\n\nimport Controller from './Controller';\nimport common from '../utils/common';\n\nfunction numDecimals(x) {\n const _x = x.toString();\n if (_x.indexOf('.') > -1) {\n return _x.length - _x.indexOf('.') - 1;\n }\n\n return 0;\n}\n\n/**\n * @class Represents a given property of an object that is a number.\n *\n * @extends dat.controllers.Controller\n *\n * @param {Object} object The object to be manipulated\n * @param {string} property The name of the property to be manipulated\n * @param {Object} [params] Optional parameters\n * @param {Number} [params.min] Minimum allowed value\n * @param {Number} [params.max] Maximum allowed value\n * @param {Number} [params.step] Increment by which to change value\n */\nclass NumberController extends Controller {\n constructor(object, property, params) {\n super(object, property);\n\n const _params = params || {};\n\n this.__min = _params.min;\n this.__max = _params.max;\n this.__step = _params.step;\n\n if (common.isUndefined(this.__step)) {\n if (this.initialValue === 0) {\n this.__impliedStep = 1; // What are we, psychics?\n } else {\n // Hey Doug, check this out.\n this.__impliedStep = Math.pow(10, Math.floor(Math.log(Math.abs(this.initialValue)) / Math.LN10)) / 10;\n }\n } else {\n this.__impliedStep = this.__step;\n }\n\n this.__precision = numDecimals(this.__impliedStep);\n }\n\n setValue(v) {\n let _v = v;\n\n if (this.__min !== undefined && _v < this.__min) {\n _v = this.__min;\n } else if (this.__max !== undefined && _v > this.__max) {\n _v = this.__max;\n }\n\n if (this.__step !== undefined && _v % this.__step !== 0) {\n _v = Math.round(_v / this.__step) * this.__step;\n }\n\n return super.setValue(_v);\n }\n\n /**\n * Specify a minimum value for object[property]
.\n *\n * @param {Number} minValue The minimum value for\n * object[property]
\n * @returns {dat.controllers.NumberController} this\n */\n min(minValue) {\n this.__min = minValue;\n return this;\n }\n\n /**\n * Specify a maximum value for object[property]
.\n *\n * @param {Number} maxValue The maximum value for\n * object[property]
\n * @returns {dat.controllers.NumberController} this\n */\n max(maxValue) {\n this.__max = maxValue;\n return this;\n }\n\n /**\n * Specify a step value that dat.controllers.NumberController\n * increments by.\n *\n * @param {Number} stepValue The step value for\n * dat.controllers.NumberController\n * @default if minimum and maximum specified increment is 1% of the\n * difference otherwise stepValue is 1\n * @returns {dat.controllers.NumberController} this\n */\n step(stepValue) {\n this.__step = stepValue;\n this.__impliedStep = stepValue;\n this.__precision = numDecimals(stepValue);\n return this;\n }\n}\n\nexport default NumberController;\n\n\n\n// WEBPACK FOOTER //\n// ./dat/controllers/NumberController.js","/**\n * dat-gui JavaScript Controller Library\n * http://code.google.com/p/dat-gui\n *\n * Copyright 2011 Data Arts Team, Google Creative Lab\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n */\n\nimport NumberController from './NumberController';\nimport dom from '../dom/dom';\nimport common from '../utils/common';\n\nfunction roundToDecimal(value, decimals) {\n const tenTo = Math.pow(10, decimals);\n return Math.round(value * tenTo) / tenTo;\n}\n\n/**\n * @class Represents a given property of an object that is a number and\n * provides an input element with which to manipulate it.\n *\n * @extends dat.controllers.Controller\n * @extends dat.controllers.NumberController\n *\n * @param {Object} object The object to be manipulated\n * @param {string} property The name of the property to be manipulated\n * @param {Object} [params] Optional parameters\n * @param {Number} [params.min] Minimum allowed value\n * @param {Number} [params.max] Maximum allowed value\n * @param {Number} [params.step] Increment by which to change value\n */\nclass NumberControllerBox extends NumberController {\n constructor(object, property, params) {\n super(object, property, params);\n\n this.__truncationSuspended = false;\n\n const _this = this;\n\n /**\n * {Number} Previous mouse y position\n * @ignore\n */\n let prevY;\n\n const mousewheelevt = (/Firefox/i.test(navigator.userAgent)) ? 'DOMMouseScroll' : 'mousewheel';\n\n function onMouseWheel(e) {\n let value = _this.getValue();\n const delta = ((e.deltaY || -e.wheelDelta || e.detail) >> 10) || 1;\n e.preventDefault();\n\n if (delta < 0) value += _this.__impliedStep;\n else value -= _this.__impliedStep;\n _this.setValue(value);\n }\n\n function onChange() {\n const attempted = parseFloat(_this.__input.value);\n if (!common.isNaN(attempted)) {\n _this.setValue(attempted);\n }\n }\n\n function onFinish() {\n if (_this.__onFinishChange) {\n _this.__onFinishChange.call(_this, _this.getValue());\n }\n }\n\n function onBlur() {\n onFinish();\n }\n\n function onMouseDrag(e) {\n const diff = prevY - e.clientY;\n _this.setValue(_this.getValue() + diff * _this.__impliedStep);\n\n prevY = e.clientY;\n }\n\n function onMouseUp() {\n dom.unbind(window, 'mousemove', onMouseDrag);\n dom.unbind(window, 'mouseup', onMouseUp);\n onFinish();\n }\n\n function onMouseDown(e) {\n dom.bind(window, 'mousemove', onMouseDrag);\n dom.bind(window, 'mouseup', onMouseUp);\n prevY = e.clientY;\n }\n\n this.__input = document.createElement('input');\n this.__input.setAttribute('type', 'text');\n\n // Makes it so manually specified values are not truncated.\n\n dom.bind(this.__input, 'change', onChange);\n dom.bind(this.__input, 'blur', onBlur);\n dom.bind(this.__input, 'mousedown', onMouseDown);\n dom.bind(this.__input, mousewheelevt, onMouseWheel);\n dom.bind(this.__input, 'keydown', function(e) {\n // When pressing enter, you can be as precise as you want.\n if (e.keyCode === 13) {\n _this.__truncationSuspended = true;\n this.blur();\n _this.__truncationSuspended = false;\n onFinish();\n }\n });\n\n this.updateDisplay();\n\n this.domElement.appendChild(this.__input);\n }\n\n updateDisplay() {\n this.__input.value = this.__truncationSuspended ? this.getValue() : roundToDecimal(this.getValue(), this.__precision);\n return super.updateDisplay();\n }\n}\n\nexport default NumberControllerBox;\n\n\n\n// WEBPACK FOOTER //\n// ./dat/controllers/NumberControllerBox.js","/**\n * dat-gui JavaScript Controller Library\n * http://code.google.com/p/dat-gui\n *\n * Copyright 2011 Data Arts Team, Google Creative Lab\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n */\n\nimport NumberController from './NumberController';\nimport dom from '../dom/dom';\n\nfunction map(v, i1, i2, o1, o2) {\n return o1 + (o2 - o1) * ((v - i1) / (i2 - i1));\n}\n\n/**\n * @class Represents a given property of an object that is a number, contains\n * a minimum and maximum, and provides a slider element with which to\n * manipulate it. It should be noted that the slider element is made up of\n * <div>
tags, not the html5\n * <slider>
element.\n *\n * @extends dat.controllers.Controller\n * @extends dat.controllers.NumberController\n *\n * @param {Object} object The object to be manipulated\n * @param {string} property The name of the property to be manipulated\n * @param {Number} minValue Minimum allowed value\n * @param {Number} maxValue Maximum allowed value\n * @param {Number} stepValue Increment by which to change value\n */\nclass NumberControllerSlider extends NumberController {\n constructor(object, property, min, max, step) {\n super(object, property, { min: min, max: max, step: step });\n\n const _this = this;\n\n this.__background = document.createElement('div');\n this.__foreground = document.createElement('div');\n\n dom.bind(this.__background, 'mousedown', onMouseDown);\n\n const mousewheelevt = (/Firefox/i.test(navigator.userAgent)) ? 'DOMMouseScroll' : 'mousewheel';\n dom.bind(this.__background, mousewheelevt, onMouseWheel);\n\n dom.addClass(this.__background, 'slider');\n dom.addClass(this.__foreground, 'slider-fg');\n\n function onMouseWheel(e) {\n let value = _this.getValue();\n const delta = ((e.deltaY || -e.wheelDelta || e.detail) >> 10) || 1;\n e.preventDefault();\n document.activeElement.blur();\n\n if (delta < 0) value += _this.__impliedStep;\n else value -= _this.__impliedStep;\n _this.setValue(value);\n }\n\n function onMouseDown(e) {\n document.activeElement.blur();\n\n dom.bind(window, 'mousemove', onMouseDrag);\n dom.bind(window, 'mouseup', onMouseUp);\n\n onMouseDrag(e);\n }\n\n function onMouseDrag(e) {\n e.preventDefault();\n\n const bgRect = _this.__background.getBoundingClientRect();\n\n _this.setValue(\n map(e.clientX, bgRect.left, bgRect.right, _this.__min, _this.__max)\n );\n\n return false;\n }\n\n function onMouseUp() {\n dom.unbind(window, 'mousemove', onMouseDrag);\n dom.unbind(window, 'mouseup', onMouseUp);\n if (_this.__onFinishChange) {\n _this.__onFinishChange.call(_this, _this.getValue());\n }\n }\n\n this.updateDisplay();\n\n this.__background.appendChild(this.__foreground);\n this.domElement.appendChild(this.__background);\n }\n\n updateDisplay() {\n const pct = (this.getValue() - this.__min) / (this.__max - this.__min);\n this.__foreground.style.width = pct * 100 + '%';\n return super.updateDisplay();\n }\n}\n\nexport default NumberControllerSlider;\n\n\n\n// WEBPACK FOOTER //\n// ./dat/controllers/NumberControllerSlider.js","/**\n * dat-gui JavaScript Controller Library\n * http://code.google.com/p/dat-gui\n *\n * Copyright 2011 Data Arts Team, Google Creative Lab\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n */\n\nimport Controller from './Controller';\nimport dom from '../dom/dom';\n\n/**\n * @class Provides a GUI interface to fire a specified method, a property of an object.\n *\n * @extends dat.controllers.Controller\n *\n * @param {Object} object The object to be manipulated\n * @param {string} property The name of the property to be manipulated\n */\nclass FunctionController extends Controller {\n constructor(object, property, text) {\n super(object, property);\n\n const _this = this;\n\n this.__button = document.createElement('div');\n this.__button.innerHTML = text === undefined ? 'Fire' : text;\n\n dom.bind(this.__button, 'click', function(e) {\n e.preventDefault();\n _this.fire();\n return false;\n });\n\n dom.addClass(this.__button, 'button');\n\n this.domElement.appendChild(this.__button);\n }\n\n fire() {\n if (this.__onChange) {\n this.__onChange.call(this);\n }\n this.getValue().call(this.object);\n if (this.__onFinishChange) {\n this.__onFinishChange.call(this, this.getValue());\n }\n }\n}\n\nexport default FunctionController;\n\n\n\n// WEBPACK FOOTER //\n// ./dat/controllers/FunctionController.js","/**\n * dat-gui JavaScript Controller Library\n * http://code.google.com/p/dat-gui\n *\n * Copyright 2011 Data Arts Team, Google Creative Lab\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n */\n\nimport Controller from './Controller';\nimport dom from '../dom/dom';\nimport Color from '../color/Color';\nimport interpret from '../color/interpret';\nimport common from '../utils/common';\n\n/**\n * @class Represents a given property of an object that is a color.\n * @param {Object} object\n * @param {string} property\n */\nclass ColorController extends Controller {\n constructor(object, property) {\n super(object, property);\n\n this.__color = new Color(this.getValue());\n this.__temp = new Color(0);\n\n const _this = this;\n\n this.domElement = document.createElement('div');\n\n dom.makeSelectable(this.domElement, false);\n\n this.__selector = document.createElement('div');\n this.__selector.className = 'selector';\n\n this.__saturation_field = document.createElement('div');\n this.__saturation_field.className = 'saturation-field';\n\n this.__field_knob = document.createElement('div');\n this.__field_knob.className = 'field-knob';\n this.__field_knob_border = '2px solid ';\n\n this.__hue_knob = document.createElement('div');\n this.__hue_knob.className = 'hue-knob';\n\n this.__hue_field = document.createElement('div');\n this.__hue_field.className = 'hue-field';\n\n this.__input = document.createElement('input');\n this.__input.type = 'text';\n this.__input_textShadow = '0 1px 1px ';\n\n dom.bind(this.__input, 'keydown', function(e) {\n if (e.keyCode === 13) { // on enter\n onBlur.call(this);\n }\n });\n\n dom.bind(this.__input, 'blur', onBlur);\n\n dom.bind(this.__selector, 'mousedown', function(/* e */) {\n dom\n .addClass(this, 'drag')\n .bind(window, 'mouseup', function(/* e */) {\n dom.removeClass(_this.__selector, 'drag');\n });\n });\n\n const valueField = document.createElement('div');\n\n common.extend(this.__selector.style, {\n width: '122px',\n height: '102px',\n padding: '3px',\n backgroundColor: '#222',\n boxShadow: '0px 1px 3px rgba(0,0,0,0.3)'\n });\n\n common.extend(this.__field_knob.style, {\n position: 'absolute',\n width: '12px',\n height: '12px',\n border: this.__field_knob_border + (this.__color.v < 0.5 ? '#fff' : '#000'),\n boxShadow: '0px 1px 3px rgba(0,0,0,0.5)',\n borderRadius: '12px',\n zIndex: 1\n });\n\n common.extend(this.__hue_knob.style, {\n position: 'absolute',\n width: '15px',\n height: '2px',\n borderRight: '4px solid #fff',\n zIndex: 1\n });\n\n common.extend(this.__saturation_field.style, {\n width: '100px',\n height: '100px',\n border: '1px solid #555',\n marginRight: '3px',\n display: 'inline-block',\n cursor: 'pointer'\n });\n\n common.extend(valueField.style, {\n width: '100%',\n height: '100%',\n background: 'none'\n });\n\n linearGradient(valueField, 'top', 'rgba(0,0,0,0)', '#000');\n\n common.extend(this.__hue_field.style, {\n width: '15px',\n height: '100px',\n border: '1px solid #555',\n cursor: 'ns-resize',\n position: 'absolute',\n top: '3px',\n right: '3px'\n });\n\n hueGradient(this.__hue_field);\n\n common.extend(this.__input.style, {\n outline: 'none',\n// width: '120px',\n textAlign: 'center',\n// padding: '4px',\n// marginBottom: '6px',\n color: '#fff',\n border: 0,\n fontWeight: 'bold',\n textShadow: this.__input_textShadow + 'rgba(0,0,0,0.7)'\n });\n\n dom.bind(this.__saturation_field, 'mousedown', fieldDown);\n dom.bind(this.__field_knob, 'mousedown', fieldDown);\n\n dom.bind(this.__hue_field, 'mousedown', function(e) {\n setH(e);\n dom.bind(window, 'mousemove', setH);\n dom.bind(window, 'mouseup', fieldUpH);\n });\n\n function fieldDown(e) {\n setSV(e);\n // document.body.style.cursor = 'none';\n dom.bind(window, 'mousemove', setSV);\n dom.bind(window, 'mouseup', fieldUpSV);\n }\n\n function fieldUpSV() {\n dom.unbind(window, 'mousemove', setSV);\n dom.unbind(window, 'mouseup', fieldUpSV);\n // document.body.style.cursor = 'default';\n onFinish();\n }\n\n function onBlur() {\n const i = interpret(this.value);\n if (i !== false) {\n _this.__color.__state = i;\n _this.setValue(_this.__color.toOriginal());\n } else {\n this.value = _this.__color.toString();\n }\n }\n\n function fieldUpH() {\n dom.unbind(window, 'mousemove', setH);\n dom.unbind(window, 'mouseup', fieldUpH);\n onFinish();\n }\n\n function onFinish() {\n if (_this.__onFinishChange) {\n _this.__onFinishChange.call(_this, _this.__color.toOriginal());\n }\n }\n\n this.__saturation_field.appendChild(valueField);\n this.__selector.appendChild(this.__field_knob);\n this.__selector.appendChild(this.__saturation_field);\n this.__selector.appendChild(this.__hue_field);\n this.__hue_field.appendChild(this.__hue_knob);\n\n this.domElement.appendChild(this.__input);\n this.domElement.appendChild(this.__selector);\n\n this.updateDisplay();\n\n function setSV(e) {\n e.preventDefault();\n\n const fieldRect = _this.__saturation_field.getBoundingClientRect();\n let s = (e.clientX - fieldRect.left) / (fieldRect.right - fieldRect.left);\n let v = 1 - (e.clientY - fieldRect.top) / (fieldRect.bottom - fieldRect.top);\n\n if (v > 1) {\n v = 1;\n } else if (v < 0) {\n v = 0;\n }\n\n if (s > 1) {\n s = 1;\n } else if (s < 0) {\n s = 0;\n }\n\n _this.__color.v = v;\n _this.__color.s = s;\n\n _this.setValue(_this.__color.toOriginal());\n\n\n return false;\n }\n\n function setH(e) {\n e.preventDefault();\n\n const fieldRect = _this.__hue_field.getBoundingClientRect();\n let h = 1 - (e.clientY - fieldRect.top) / (fieldRect.bottom - fieldRect.top);\n\n if (h > 1) {\n h = 1;\n } else if (h < 0) {\n h = 0;\n }\n\n _this.__color.h = h * 360;\n\n _this.setValue(_this.__color.toOriginal());\n\n return false;\n }\n }\n\n updateDisplay() {\n const i = interpret(this.getValue());\n\n if (i !== false) {\n let mismatch = false;\n\n // Check for mismatch on the interpreted value.\n\n common.each(Color.COMPONENTS, function(component) {\n if (!common.isUndefined(i[component]) && !common.isUndefined(this.__color.__state[component]) &&\n i[component] !== this.__color.__state[component]) {\n mismatch = true;\n return {}; // break\n }\n }, this);\n\n // If nothing diverges, we keep our previous values\n // for statefulness, otherwise we recalculate fresh\n if (mismatch) {\n common.extend(this.__color.__state, i);\n }\n }\n\n common.extend(this.__temp.__state, this.__color.__state);\n\n this.__temp.a = 1;\n\n const flip = (this.__color.v < 0.5 || this.__color.s > 0.5) ? 255 : 0;\n const _flip = 255 - flip;\n\n common.extend(this.__field_knob.style, {\n marginLeft: 100 * this.__color.s - 7 + 'px',\n marginTop: 100 * (1 - this.__color.v) - 7 + 'px',\n backgroundColor: this.__temp.toHexString(),\n border: this.__field_knob_border + 'rgb(' + flip + ',' + flip + ',' + flip + ')'\n });\n\n this.__hue_knob.style.marginTop = (1 - this.__color.h / 360) * 100 + 'px';\n\n this.__temp.s = 1;\n this.__temp.v = 1;\n\n linearGradient(this.__saturation_field, 'left', '#fff', this.__temp.toHexString());\n\n this.__input.value = this.__color.toString();\n\n common.extend(this.__input.style, {\n backgroundColor: this.__color.toHexString(),\n color: 'rgb(' + flip + ',' + flip + ',' + flip + ')',\n textShadow: this.__input_textShadow + 'rgba(' + _flip + ',' + _flip + ',' + _flip + ',.7)'\n });\n }\n}\n\nconst vendors = ['-moz-', '-o-', '-webkit-', '-ms-', ''];\n\nfunction linearGradient(elem, x, a, b) {\n elem.style.background = '';\n common.each(vendors, function(vendor) {\n elem.style.cssText += 'background: ' + vendor + 'linear-gradient(' + x + ', ' + a + ' 0%, ' + b + ' 100%); ';\n });\n}\n\nfunction hueGradient(elem) {\n elem.style.background = '';\n elem.style.cssText += 'background: -moz-linear-gradient(top, #ff0000 0%, #ff00ff 17%, #0000ff 34%, #00ffff 50%, #00ff00 67%, #ffff00 84%, #ff0000 100%);';\n elem.style.cssText += 'background: -webkit-linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);';\n elem.style.cssText += 'background: -o-linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);';\n elem.style.cssText += 'background: -ms-linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);';\n elem.style.cssText += 'background: linear-gradient(top, #ff0000 0%,#ff00ff 17%,#0000ff 34%,#00ffff 50%,#00ff00 67%,#ffff00 84%,#ff0000 100%);';\n}\n\nexport default ColorController;\n\n\n\n// WEBPACK FOOTER //\n// ./dat/controllers/ColorController.js","/**\n * dat-gui JavaScript Controller Library\n * http://code.google.com/p/dat-gui\n *\n * Copyright 2011 Data Arts Team, Google Creative Lab\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n */\n\nimport css from '../utils/css';\nimport saveDialogueContents from './saveDialogue.html';\nimport ControllerFactory from '../controllers/ControllerFactory';\nimport Controller from '../controllers/Controller';\nimport BooleanController from '../controllers/BooleanController';\nimport FunctionController from '../controllers/FunctionController';\nimport NumberControllerBox from '../controllers/NumberControllerBox';\nimport NumberControllerSlider from '../controllers/NumberControllerSlider';\nimport ColorController from '../controllers/ColorController';\nimport requestAnimationFrame from '../utils/requestAnimationFrame';\nimport CenteredDiv from '../dom/CenteredDiv';\nimport dom from '../dom/dom';\nimport common from '../utils/common';\n\nimport styleSheet from './style.scss'; // CSS to embed in build\n\ncss.inject(styleSheet);\n\n/** @ignore Outer-most className for GUI's */\nconst CSS_NAMESPACE = 'dg';\n\nconst HIDE_KEY_CODE = 72;\n\n/** @ignore The only value shared between the JS and SCSS. Use caution. */\nconst CLOSE_BUTTON_HEIGHT = 20;\n\nconst DEFAULT_DEFAULT_PRESET_NAME = 'Default';\n\nconst SUPPORTS_LOCAL_STORAGE = (function() {\n try {\n return 'localStorage' in window && window.localStorage !== null;\n } catch (e) {\n return false;\n }\n}());\n\nlet SAVE_DIALOGUE;\n\n/** @ignore Have we yet to create an autoPlace GUI? */\nlet autoPlaceVirgin = true;\n\n/** @ignore Fixed position div that auto place GUI's go inside */\nlet autoPlaceContainer;\n\n/** @ignore Are we hiding the GUI's ? */\nlet hide = false;\n\n/** @private GUI's which should be hidden */\nconst hideableGuis = [];\n\n/**\n * @class A lightweight controller library for JavaScript. It allows you to easily\n * manipulate variables and fire functions on the fly.\n *\n * @typicalname gui\n *\n * @example\n * // Creating a GUI with options.\n * var gui = new dat.GUI({name: 'My GUI'});\n *\n * @example\n * // Creating a GUI and a subfolder.\n * var gui = new dat.GUI();\n * var folder1 = gui.addFolder('Flow Field');\n *\n * @param {Object} [params]\n * @param {String} [params.name] The name of this GUI.\n * @param {Object} [params.load] JSON object representing the saved state of\n * this GUI.\n * @param {Boolean} [params.auto=true]\n * @param {dat.gui.GUI} [params.parent] The GUI I'm nested in.\n * @param {Boolean} [params.closed] If true, starts closed\n * @param {Boolean} [params.closeOnTop] If true, close/open button shows on top of the GUI\n */\nconst GUI = function(pars) {\n const _this = this;\n\n let params = pars || {};\n\n /**\n * Outermost DOM Element\n * @type {DOMElement}\n */\n this.domElement = document.createElement('div');\n this.__ul = document.createElement('ul');\n this.domElement.appendChild(this.__ul);\n\n dom.addClass(this.domElement, CSS_NAMESPACE);\n\n /**\n * Nested GUI's by name\n * @ignore\n */\n this.__folders = {};\n\n this.__controllers = [];\n\n /**\n * List of objects I'm remembering for save, only used in top level GUI\n * @ignore\n */\n this.__rememberedObjects = [];\n\n /**\n * Maps the index of remembered objects to a map of controllers, only used\n * in top level GUI.\n *\n * @private\n * @ignore\n *\n * @example\n * [\n * {\n * propertyName: Controller,\n * anotherPropertyName: Controller\n * },\n * {\n * propertyName: Controller\n * }\n * ]\n */\n this.__rememberedObjectIndecesToControllers = [];\n\n this.__listening = [];\n\n // Default parameters\n params = common.defaults(params, {\n closeOnTop: false,\n autoPlace: true,\n width: GUI.DEFAULT_WIDTH\n });\n\n params = common.defaults(params, {\n resizable: params.autoPlace,\n hideable: params.autoPlace\n });\n\n if (!common.isUndefined(params.load)) {\n // Explicit preset\n if (params.preset) {\n params.load.preset = params.preset;\n }\n } else {\n params.load = { preset: DEFAULT_DEFAULT_PRESET_NAME };\n }\n\n if (common.isUndefined(params.parent) && params.hideable) {\n hideableGuis.push(this);\n }\n\n // Only root level GUI's are resizable.\n params.resizable = common.isUndefined(params.parent) && params.resizable;\n\n if (params.autoPlace && common.isUndefined(params.scrollable)) {\n params.scrollable = true;\n }\n// params.scrollable = common.isUndefined(params.parent) && params.scrollable === true;\n\n // Not part of params because I don't want people passing this in via\n // constructor. Should be a 'remembered' value.\n let useLocalStorage =\n SUPPORTS_LOCAL_STORAGE &&\n localStorage.getItem(getLocalStorageHash(this, 'isLocal')) === 'true';\n\n let saveToLocalStorage;\n\n Object.defineProperties(this,\n /** @lends GUI.prototype */\n {\n /**\n * The parent GUI
\n * @type dat.gui.GUI\n */\n parent: {\n get: function() {\n return params.parent;\n }\n },\n\n scrollable: {\n get: function() {\n return params.scrollable;\n }\n },\n\n /**\n * Handles GUI
's element placement for you\n * @type Boolean\n */\n autoPlace: {\n get: function() {\n return params.autoPlace;\n }\n },\n\n /**\n * Handles GUI
's position of open/close button\n * @type Boolean\n */\n closeOnTop: {\n get: function() {\n return params.closeOnTop;\n }\n },\n\n /**\n * The identifier for a set of saved values\n * @type String\n */\n preset: {\n get: function() {\n if (_this.parent) {\n return _this.getRoot().preset;\n }\n\n return params.load.preset;\n },\n\n set: function(v) {\n if (_this.parent) {\n _this.getRoot().preset = v;\n } else {\n params.load.preset = v;\n }\n setPresetSelectIndex(this);\n _this.revert();\n }\n },\n\n /**\n * The width of GUI
element\n * @type Number\n */\n width: {\n get: function() {\n return params.width;\n },\n set: function(v) {\n params.width = v;\n setWidth(_this, v);\n }\n },\n\n /**\n * The name of GUI
. Used for folders. i.e\n * a folder's name\n * @type String\n */\n name: {\n get: function() {\n return params.name;\n },\n set: function(v) {\n // TODO Check for collisions among sibling folders\n params.name = v;\n if (titleRowName) {\n titleRowName.innerHTML = params.name;\n }\n }\n },\n\n /**\n * Whether the GUI
is collapsed or not\n * @type Boolean\n */\n closed: {\n get: function() {\n return params.closed;\n },\n set: function(v) {\n params.closed = v;\n if (params.closed) {\n dom.addClass(_this.__ul, GUI.CLASS_CLOSED);\n } else {\n dom.removeClass(_this.__ul, GUI.CLASS_CLOSED);\n }\n // For browsers that aren't going to respect the CSS transition,\n // Lets just check our height against the window height right off\n // the bat.\n this.onResize();\n\n if (_this.__closeButton) {\n _this.__closeButton.innerHTML = v ? GUI.TEXT_OPEN : GUI.TEXT_CLOSED;\n }\n }\n },\n\n /**\n * Contains all presets\n * @type Object\n */\n load: {\n get: function() {\n return params.load;\n }\n },\n\n /**\n * Determines whether or not to use localStorage as the means for\n * remember
ing\n * @type Boolean\n */\n useLocalStorage: {\n\n get: function() {\n return useLocalStorage;\n },\n set: function(bool) {\n if (SUPPORTS_LOCAL_STORAGE) {\n useLocalStorage = bool;\n if (bool) {\n dom.bind(window, 'unload', saveToLocalStorage);\n } else {\n dom.unbind(window, 'unload', saveToLocalStorage);\n }\n localStorage.setItem(getLocalStorageHash(_this, 'isLocal'), bool);\n }\n }\n }\n });\n\n // Are we a root level GUI?\n if (common.isUndefined(params.parent)) {\n params.closed = false;\n\n dom.addClass(this.domElement, GUI.CLASS_MAIN);\n dom.makeSelectable(this.domElement, false);\n\n // Are we supposed to be loading locally?\n if (SUPPORTS_LOCAL_STORAGE) {\n if (useLocalStorage) {\n _this.useLocalStorage = true;\n\n const savedGui = localStorage.getItem(getLocalStorageHash(this, 'gui'));\n\n if (savedGui) {\n params.load = JSON.parse(savedGui);\n }\n }\n }\n\n this.__closeButton = document.createElement('div');\n this.__closeButton.innerHTML = GUI.TEXT_CLOSED;\n dom.addClass(this.__closeButton, GUI.CLASS_CLOSE_BUTTON);\n if (params.closeOnTop) {\n dom.addClass(this.__closeButton, GUI.CLASS_CLOSE_TOP);\n this.domElement.insertBefore(this.__closeButton, this.domElement.childNodes[0]);\n } else {\n dom.addClass(this.__closeButton, GUI.CLASS_CLOSE_BOTTOM);\n this.domElement.appendChild(this.__closeButton);\n }\n\n dom.bind(this.__closeButton, 'click', function() {\n _this.closed = !_this.closed;\n });\n // Oh, you're a nested GUI!\n } else {\n if (params.closed === undefined) {\n params.closed = true;\n }\n\n const titleRowName = document.createTextNode(params.name);\n dom.addClass(titleRowName, 'controller-name');\n\n const titleRow = addRow(_this, titleRowName);\n\n const onClickTitle = function(e) {\n e.preventDefault();\n _this.closed = !_this.closed;\n return false;\n };\n\n dom.addClass(this.__ul, GUI.CLASS_CLOSED);\n\n dom.addClass(titleRow, 'title');\n dom.bind(titleRow, 'click', onClickTitle);\n\n if (!params.closed) {\n this.closed = false;\n }\n }\n\n if (params.autoPlace) {\n if (common.isUndefined(params.parent)) {\n if (autoPlaceVirgin) {\n autoPlaceContainer = document.createElement('div');\n dom.addClass(autoPlaceContainer, CSS_NAMESPACE);\n dom.addClass(autoPlaceContainer, GUI.CLASS_AUTO_PLACE_CONTAINER);\n document.body.appendChild(autoPlaceContainer);\n autoPlaceVirgin = false;\n }\n\n // Put it in the dom for you.\n autoPlaceContainer.appendChild(this.domElement);\n\n // Apply the auto styles\n dom.addClass(this.domElement, GUI.CLASS_AUTO_PLACE);\n }\n\n\n // Make it not elastic.\n if (!this.parent) {\n setWidth(_this, params.width);\n }\n }\n\n this.__resizeHandler = function() {\n _this.onResizeDebounced();\n };\n\n dom.bind(window, 'resize', this.__resizeHandler);\n dom.bind(this.__ul, 'webkitTransitionEnd', this.__resizeHandler);\n dom.bind(this.__ul, 'transitionend', this.__resizeHandler);\n dom.bind(this.__ul, 'oTransitionEnd', this.__resizeHandler);\n this.onResize();\n\n if (params.resizable) {\n addResizeHandle(this);\n }\n\n saveToLocalStorage = function() {\n if (SUPPORTS_LOCAL_STORAGE && localStorage.getItem(getLocalStorageHash(_this, 'isLocal')) === 'true') {\n localStorage.setItem(getLocalStorageHash(_this, 'gui'), JSON.stringify(_this.getSaveObject()));\n }\n };\n\n // expose this method publicly\n this.saveToLocalStorageIfPossible = saveToLocalStorage;\n\n function resetWidth() {\n const root = _this.getRoot();\n root.width += 1;\n common.defer(function() {\n root.width -= 1;\n });\n }\n\n if (!params.parent) {\n resetWidth();\n }\n};\n\nGUI.toggleHide = function() {\n hide = !hide;\n common.each(hideableGuis, function(gui) {\n gui.domElement.style.display = hide ? 'none' : '';\n });\n};\n\nGUI.CLASS_AUTO_PLACE = 'a';\nGUI.CLASS_AUTO_PLACE_CONTAINER = 'ac';\nGUI.CLASS_MAIN = 'main';\nGUI.CLASS_CONTROLLER_ROW = 'cr';\nGUI.CLASS_TOO_TALL = 'taller-than-window';\nGUI.CLASS_CLOSED = 'closed';\nGUI.CLASS_CLOSE_BUTTON = 'close-button';\nGUI.CLASS_CLOSE_TOP = 'close-top';\nGUI.CLASS_CLOSE_BOTTOM = 'close-bottom';\nGUI.CLASS_DRAG = 'drag';\n\nGUI.DEFAULT_WIDTH = 245;\nGUI.TEXT_CLOSED = 'Close Controls';\nGUI.TEXT_OPEN = 'Open Controls';\n\nGUI._keydownHandler = function(e) {\n if (document.activeElement.type !== 'text' &&\n (e.which === HIDE_KEY_CODE || e.keyCode === HIDE_KEY_CODE)) {\n GUI.toggleHide();\n }\n};\ndom.bind(window, 'keydown', GUI._keydownHandler, false);\n\ncommon.extend(\n GUI.prototype,\n\n /** @lends GUI.prototype */\n {\n\n /**\n * Adds a new {@link Controller} to the GUI. The type of controller created\n * is inferred from the initial value of object[property]
. For\n * color properties, see {@link addColor}.\n *\n * @param {Object} object The object to be manipulated\n * @param {String} property The name of the property to be manipulated\n * @param {Number} [min] Minimum allowed value\n * @param {Number} [max] Maximum allowed value\n * @param {Number} [step] Increment by which to change value\n * @returns {Controller} The controller that was added to the GUI.\n * @instance\n *\n * @example\n * // Add a string controller.\n * var person = {name: 'Sam'};\n * gui.add(person, 'name');\n *\n * @example\n * // Add a number controller slider.\n * var person = {age: 45};\n * gui.add(person, 'age', 0, 100);\n */\n add: function(object, property) {\n return add(\n this,\n object,\n property,\n {\n factoryArgs: Array.prototype.slice.call(arguments, 2)\n }\n );\n },\n\n /**\n * Adds a new color controller to the GUI.\n *\n * @param object\n * @param property\n * @returns {Controller} The controller that was added to the GUI.\n * @instance\n *\n * @example\n * var palette = {\n * color1: '#FF0000', // CSS string\n * color2: [ 0, 128, 255 ], // RGB array\n * color3: [ 0, 128, 255, 0.3 ], // RGB with alpha\n * color4: { h: 350, s: 0.9, v: 0.3 } // Hue, saturation, value\n * };\n * gui.addColor(palette, 'color1');\n * gui.addColor(palette, 'color2');\n * gui.addColor(palette, 'color3');\n * gui.addColor(palette, 'color4');\n */\n addColor: function(object, property) {\n return add(\n this,\n object,\n property,\n {\n color: true\n }\n );\n },\n\n /**\n * Removes the given controller from the GUI.\n * @param {Controller} controller\n * @instance\n */\n remove: function(controller) {\n // TODO listening?\n this.__ul.removeChild(controller.__li);\n this.__controllers.splice(this.__controllers.indexOf(controller), 1);\n const _this = this;\n common.defer(function() {\n _this.onResize();\n });\n },\n\n /**\n * Removes the GUI from the document and unbinds all event listeners.\n * @instance\n */\n destroy: function() {\n if (this.autoPlace) {\n autoPlaceContainer.removeChild(this.domElement);\n }\n\n dom.unbind(window, 'keydown', GUI._keydownHandler, false);\n dom.unbind(window, 'resize', this.__resizeHandler);\n\n if (this.saveToLocalStorageIfPossible) {\n dom.unbind(window, 'unload', this.saveToLocalStorageIfPossible);\n }\n },\n\n /**\n * Creates a new subfolder GUI instance.\n * @param name\n * @returns {dat.gui.GUI} The new folder.\n * @throws {Error} if this GUI already has a folder by the specified\n * name\n * @instance\n */\n addFolder: function(name) {\n // We have to prevent collisions on names in order to have a key\n // by which to remember saved values\n if (this.__folders[name] !== undefined) {\n throw new Error('You already have a folder in this GUI by the' +\n ' name \"' + name + '\"');\n }\n\n const newGuiParams = { name: name, parent: this };\n\n // We need to pass down the autoPlace trait so that we can\n // attach event listeners to open/close folder actions to\n // ensure that a scrollbar appears if the window is too short.\n newGuiParams.autoPlace = this.autoPlace;\n\n // Do we have saved appearance data for this folder?\n if (this.load && // Anything loaded?\n this.load.folders && // Was my parent a dead-end?\n this.load.folders[name]) { // Did daddy remember me?\n // Start me closed if I was closed\n newGuiParams.closed = this.load.folders[name].closed;\n\n // Pass down the loaded data\n newGuiParams.load = this.load.folders[name];\n }\n\n const gui = new GUI(newGuiParams);\n this.__folders[name] = gui;\n\n const li = addRow(this, gui.domElement);\n dom.addClass(li, 'folder');\n return gui;\n },\n\n /**\n * Opens the GUI.\n */\n open: function() {\n this.closed = false;\n },\n\n /**\n * Closes the GUI.\n */\n close: function() {\n this.closed = true;\n },\n\n\n onResize: function() {\n // we debounce this function to prevent performance issues when rotating on tablet/mobile\n const root = this.getRoot();\n if (root.scrollable) {\n const top = dom.getOffset(root.__ul).top;\n let h = 0;\n\n common.each(root.__ul.childNodes, function(node) {\n if (!(root.autoPlace && node === root.__save_row)) {\n h += dom.getHeight(node);\n }\n });\n\n if (window.innerHeight - top - CLOSE_BUTTON_HEIGHT < h) {\n dom.addClass(root.domElement, GUI.CLASS_TOO_TALL);\n root.__ul.style.height = window.innerHeight - top - CLOSE_BUTTON_HEIGHT + 'px';\n } else {\n dom.removeClass(root.domElement, GUI.CLASS_TOO_TALL);\n root.__ul.style.height = 'auto';\n }\n }\n\n if (root.__resize_handle) {\n common.defer(function() {\n root.__resize_handle.style.height = root.__ul.offsetHeight + 'px';\n });\n }\n\n if (root.__closeButton) {\n root.__closeButton.style.width = root.width + 'px';\n }\n },\n\n onResizeDebounced: common.debounce(function() { this.onResize(); }, 50),\n\n /**\n * Mark objects for saving. The order of these objects cannot change as\n * the GUI grows. When remembering new objects, append them to the end\n * of the list.\n *\n * @param {...Object} objects\n * @throws {Error} if not called on a top level GUI.\n * @instance\n * @ignore\n */\n remember: function() {\n if (common.isUndefined(SAVE_DIALOGUE)) {\n SAVE_DIALOGUE = new CenteredDiv();\n SAVE_DIALOGUE.domElement.innerHTML = saveDialogueContents;\n }\n\n if (this.parent) {\n throw new Error('You can only call remember on a top level GUI.');\n }\n\n const _this = this;\n\n common.each(Array.prototype.slice.call(arguments), function(object) {\n if (_this.__rememberedObjects.length === 0) {\n addSaveMenu(_this);\n }\n if (_this.__rememberedObjects.indexOf(object) === -1) {\n _this.__rememberedObjects.push(object);\n }\n });\n\n if (this.autoPlace) {\n // Set save row width\n setWidth(this, this.width);\n }\n },\n\n /**\n * @returns {dat.gui.GUI} the topmost parent GUI of a nested GUI.\n * @instance\n */\n getRoot: function() {\n let gui = this;\n while (gui.parent) {\n gui = gui.parent;\n }\n return gui;\n },\n\n /**\n * @returns {Object} a JSON object representing the current state of\n * this GUI as well as its remembered properties.\n * @instance\n */\n getSaveObject: function() {\n const toReturn = this.load;\n toReturn.closed = this.closed;\n\n // Am I remembering any values?\n if (this.__rememberedObjects.length > 0) {\n toReturn.preset = this.preset;\n\n if (!toReturn.remembered) {\n toReturn.remembered = {};\n }\n\n toReturn.remembered[this.preset] = getCurrentPreset(this);\n }\n\n toReturn.folders = {};\n common.each(this.__folders, function(element, key) {\n toReturn.folders[key] = element.getSaveObject();\n });\n\n return toReturn;\n },\n\n save: function() {\n if (!this.load.remembered) {\n this.load.remembered = {};\n }\n\n this.load.remembered[this.preset] = getCurrentPreset(this);\n markPresetModified(this, false);\n this.saveToLocalStorageIfPossible();\n },\n\n saveAs: function(presetName) {\n if (!this.load.remembered) {\n // Retain default values upon first save\n this.load.remembered = {};\n this.load.remembered[DEFAULT_DEFAULT_PRESET_NAME] = getCurrentPreset(this, true);\n }\n\n this.load.remembered[presetName] = getCurrentPreset(this);\n this.preset = presetName;\n addPresetOption(this, presetName, true);\n this.saveToLocalStorageIfPossible();\n },\n\n revert: function(gui) {\n common.each(this.__controllers, function(controller) {\n // Make revert work on Default.\n if (!this.getRoot().load.remembered) {\n controller.setValue(controller.initialValue);\n } else {\n recallSavedValue(gui || this.getRoot(), controller);\n }\n\n // fire onFinishChange callback\n if (controller.__onFinishChange) {\n controller.__onFinishChange.call(controller, controller.getValue());\n }\n }, this);\n\n common.each(this.__folders, function(folder) {\n folder.revert(folder);\n });\n\n if (!gui) {\n markPresetModified(this.getRoot(), false);\n }\n },\n\n listen: function(controller) {\n const init = this.__listening.length === 0;\n this.__listening.push(controller);\n if (init) {\n updateDisplays(this.__listening);\n }\n },\n\n updateDisplay: function() {\n common.each(this.__controllers, function(controller) {\n controller.updateDisplay();\n });\n common.each(this.__folders, function(folder) {\n folder.updateDisplay();\n });\n }\n }\n);\n\n/**\n * Add a row to the end of the GUI or before another row.\n *\n * @param gui\n * @param [newDom] If specified, inserts the dom content in the new row\n * @param [liBefore] If specified, places the new row before another row\n *\n * @ignore\n */\nfunction addRow(gui, newDom, liBefore) {\n const li = document.createElement('li');\n if (newDom) {\n li.appendChild(newDom);\n }\n\n if (liBefore) {\n gui.__ul.insertBefore(li, liBefore);\n } else {\n gui.__ul.appendChild(li);\n }\n gui.onResize();\n return li;\n}\n\nfunction markPresetModified(gui, modified) {\n const opt = gui.__preset_select[gui.__preset_select.selectedIndex];\n\n // console.log('mark', modified, opt);\n if (modified) {\n opt.innerHTML = opt.value + '*';\n } else {\n opt.innerHTML = opt.value;\n }\n}\n\nfunction augmentController(gui, li, controller) {\n controller.__li = li;\n controller.__gui = gui;\n\n common.extend(controller, {\n options: function(options) {\n if (arguments.length > 1) {\n const nextSibling = controller.__li.nextElementSibling;\n controller.remove();\n\n return add(\n gui,\n controller.object,\n controller.property,\n {\n before: nextSibling,\n factoryArgs: [common.toArray(arguments)]\n }\n );\n }\n\n if (common.isArray(options) || common.isObject(options)) {\n const nextSibling = controller.__li.nextElementSibling;\n controller.remove();\n\n return add(\n gui,\n controller.object,\n controller.property,\n {\n before: nextSibling,\n factoryArgs: [options]\n }\n );\n }\n },\n\n name: function(v) {\n controller.__li.firstElementChild.firstElementChild.innerHTML = v;\n return controller;\n },\n\n listen: function() {\n controller.__gui.listen(controller);\n return controller;\n },\n\n remove: function() {\n controller.__gui.remove(controller);\n return controller;\n }\n });\n\n // All sliders should be accompanied by a box.\n if (controller instanceof NumberControllerSlider) {\n const box = new NumberControllerBox(controller.object, controller.property,\n { min: controller.__min, max: controller.__max, step: controller.__step });\n\n common.each(['updateDisplay', 'onChange', 'onFinishChange', 'step'], function(method) {\n const pc = controller[method];\n const pb = box[method];\n controller[method] = box[method] = function() {\n const args = Array.prototype.slice.call(arguments);\n pb.apply(box, args);\n return pc.apply(controller, args);\n };\n });\n\n dom.addClass(li, 'has-slider');\n controller.domElement.insertBefore(box.domElement, controller.domElement.firstElementChild);\n } else if (controller instanceof NumberControllerBox) {\n const r = function(returned) {\n // Have we defined both boundaries?\n if (common.isNumber(controller.__min) && common.isNumber(controller.__max)) {\n // Well, then lets just replace this with a slider.\n\n // lets remember if the old controller had a specific name or was listening\n const oldName = controller.__li.firstElementChild.firstElementChild.innerHTML;\n const wasListening = controller.__gui.__listening.indexOf(controller) > -1;\n\n controller.remove();\n const newController = add(\n gui,\n controller.object,\n controller.property,\n {\n before: controller.__li.nextElementSibling,\n factoryArgs: [controller.__min, controller.__max, controller.__step]\n });\n\n newController.name(oldName);\n if (wasListening) newController.listen();\n\n return newController;\n }\n\n return returned;\n };\n\n controller.min = common.compose(r, controller.min);\n controller.max = common.compose(r, controller.max);\n } else if (controller instanceof BooleanController) {\n dom.bind(li, 'click', function() {\n dom.fakeEvent(controller.__checkbox, 'click');\n });\n\n dom.bind(controller.__checkbox, 'click', function(e) {\n e.stopPropagation(); // Prevents double-toggle\n });\n } else if (controller instanceof FunctionController) {\n dom.bind(li, 'click', function() {\n dom.fakeEvent(controller.__button, 'click');\n });\n\n dom.bind(li, 'mouseover', function() {\n dom.addClass(controller.__button, 'hover');\n });\n\n dom.bind(li, 'mouseout', function() {\n dom.removeClass(controller.__button, 'hover');\n });\n } else if (controller instanceof ColorController) {\n dom.addClass(li, 'color');\n controller.updateDisplay = common.compose(function(val) {\n li.style.borderLeftColor = controller.__color.toString();\n return val;\n }, controller.updateDisplay);\n\n controller.updateDisplay();\n }\n\n controller.setValue = common.compose(function(val) {\n if (gui.getRoot().__preset_select && controller.isModified()) {\n markPresetModified(gui.getRoot(), true);\n }\n\n return val;\n }, controller.setValue);\n}\n\nfunction recallSavedValue(gui, controller) {\n // Find the topmost GUI, that's where remembered objects live.\n const root = gui.getRoot();\n\n // Does the object we're controlling match anything we've been told to\n // remember?\n const matchedIndex = root.__rememberedObjects.indexOf(controller.object);\n\n // Why yes, it does!\n if (matchedIndex !== -1) {\n // Let me fetch a map of controllers for thcommon.isObject.\n let controllerMap = root.__rememberedObjectIndecesToControllers[matchedIndex];\n\n // Ohp, I believe this is the first controller we've created for this\n // object. Lets make the map fresh.\n if (controllerMap === undefined) {\n controllerMap = {};\n root.__rememberedObjectIndecesToControllers[matchedIndex] =\n controllerMap;\n }\n\n // Keep track of this controller\n controllerMap[controller.property] = controller;\n\n // Okay, now have we saved any values for this controller?\n if (root.load && root.load.remembered) {\n const presetMap = root.load.remembered;\n\n // Which preset are we trying to load?\n let preset;\n\n if (presetMap[gui.preset]) {\n preset = presetMap[gui.preset];\n } else if (presetMap[DEFAULT_DEFAULT_PRESET_NAME]) {\n // Uhh, you can have the default instead?\n preset = presetMap[DEFAULT_DEFAULT_PRESET_NAME];\n } else {\n // Nada.\n return;\n }\n\n // Did the loaded object remember thcommon.isObject? && Did we remember this particular property?\n if (preset[matchedIndex] && preset[matchedIndex][controller.property] !== undefined) {\n // We did remember something for this guy ...\n const value = preset[matchedIndex][controller.property];\n\n // And that's what it is.\n controller.initialValue = value;\n controller.setValue(value);\n }\n }\n }\n}\n\nfunction add(gui, object, property, params) {\n if (object[property] === undefined) {\n throw new Error(`Object \"${object}\" has no property \"${property}\"`);\n }\n\n let controller;\n\n if (params.color) {\n controller = new ColorController(object, property);\n } else {\n const factoryArgs = [object, property].concat(params.factoryArgs);\n controller = ControllerFactory.apply(gui, factoryArgs);\n }\n\n if (params.before instanceof Controller) {\n params.before = params.before.__li;\n }\n\n recallSavedValue(gui, controller);\n\n dom.addClass(controller.domElement, 'c');\n\n const name = document.createElement('span');\n dom.addClass(name, 'property-name');\n name.innerHTML = controller.property;\n\n const container = document.createElement('div');\n container.appendChild(name);\n container.appendChild(controller.domElement);\n\n const li = addRow(gui, container, params.before);\n\n dom.addClass(li, GUI.CLASS_CONTROLLER_ROW);\n if (controller instanceof ColorController) {\n dom.addClass(li, 'color');\n } else {\n dom.addClass(li, typeof controller.getValue());\n }\n\n augmentController(gui, li, controller);\n\n gui.__controllers.push(controller);\n\n return controller;\n}\n\nfunction getLocalStorageHash(gui, key) {\n // TODO how does this deal with multiple GUI's?\n return document.location.href + '.' + key;\n}\n\nfunction addPresetOption(gui, name, setSelected) {\n const opt = document.createElement('option');\n opt.innerHTML = name;\n opt.value = name;\n gui.__preset_select.appendChild(opt);\n if (setSelected) {\n gui.__preset_select.selectedIndex = gui.__preset_select.length - 1;\n }\n}\n\nfunction showHideExplain(gui, explain) {\n explain.style.display = gui.useLocalStorage ? 'block' : 'none';\n}\n\nfunction addSaveMenu(gui) {\n const div = gui.__save_row = document.createElement('li');\n\n dom.addClass(gui.domElement, 'has-save');\n\n gui.__ul.insertBefore(div, gui.__ul.firstChild);\n\n dom.addClass(div, 'save-row');\n\n const gears = document.createElement('span');\n gears.innerHTML = ' ';\n dom.addClass(gears, 'button gears');\n\n // TODO replace with FunctionController\n const button = document.createElement('span');\n button.innerHTML = 'Save';\n dom.addClass(button, 'button');\n dom.addClass(button, 'save');\n\n const button2 = document.createElement('span');\n button2.innerHTML = 'New';\n dom.addClass(button2, 'button');\n dom.addClass(button2, 'save-as');\n\n const button3 = document.createElement('span');\n button3.innerHTML = 'Revert';\n dom.addClass(button3, 'button');\n dom.addClass(button3, 'revert');\n\n const select = gui.__preset_select = document.createElement('select');\n\n if (gui.load && gui.load.remembered) {\n common.each(gui.load.remembered, function(value, key) {\n addPresetOption(gui, key, key === gui.preset);\n });\n } else {\n addPresetOption(gui, DEFAULT_DEFAULT_PRESET_NAME, false);\n }\n\n dom.bind(select, 'change', function() {\n for (let index = 0; index < gui.__preset_select.length; index++) {\n gui.__preset_select[index].innerHTML = gui.__preset_select[index].value;\n }\n\n gui.preset = this.value;\n });\n\n div.appendChild(select);\n div.appendChild(gears);\n div.appendChild(button);\n div.appendChild(button2);\n div.appendChild(button3);\n\n if (SUPPORTS_LOCAL_STORAGE) {\n const explain = document.getElementById('dg-local-explain');\n const localStorageCheckBox = document.getElementById('dg-local-storage');\n const saveLocally = document.getElementById('dg-save-locally');\n\n saveLocally.style.display = 'block';\n\n if (localStorage.getItem(getLocalStorageHash(gui, 'isLocal')) === 'true') {\n localStorageCheckBox.setAttribute('checked', 'checked');\n }\n\n showHideExplain(gui, explain);\n\n // TODO: Use a boolean controller, fool!\n dom.bind(localStorageCheckBox, 'change', function() {\n gui.useLocalStorage = !gui.useLocalStorage;\n showHideExplain(gui, explain);\n });\n }\n\n const newConstructorTextArea = document.getElementById('dg-new-constructor');\n\n dom.bind(newConstructorTextArea, 'keydown', function(e) {\n if (e.metaKey && (e.which === 67 || e.keyCode === 67)) {\n SAVE_DIALOGUE.hide();\n }\n });\n\n dom.bind(gears, 'click', function() {\n newConstructorTextArea.innerHTML = JSON.stringify(gui.getSaveObject(), undefined, 2);\n SAVE_DIALOGUE.show();\n newConstructorTextArea.focus();\n newConstructorTextArea.select();\n });\n\n dom.bind(button, 'click', function() {\n gui.save();\n });\n\n dom.bind(button2, 'click', function() {\n const presetName = prompt('Enter a new preset name.');\n if (presetName) {\n gui.saveAs(presetName);\n }\n });\n\n dom.bind(button3, 'click', function() {\n gui.revert();\n });\n\n // div.appendChild(button2);\n}\n\nfunction addResizeHandle(gui) {\n let pmouseX;\n\n gui.__resize_handle = document.createElement('div');\n\n common.extend(gui.__resize_handle.style, {\n\n width: '6px',\n marginLeft: '-3px',\n height: '200px',\n cursor: 'ew-resize',\n position: 'absolute'\n // border: '1px solid blue'\n\n });\n\n function drag(e) {\n e.preventDefault();\n\n gui.width += pmouseX - e.clientX;\n gui.onResize();\n pmouseX = e.clientX;\n\n return false;\n }\n\n function dragStop() {\n dom.removeClass(gui.__closeButton, GUI.CLASS_DRAG);\n dom.unbind(window, 'mousemove', drag);\n dom.unbind(window, 'mouseup', dragStop);\n }\n\n function dragStart(e) {\n e.preventDefault();\n\n pmouseX = e.clientX;\n\n dom.addClass(gui.__closeButton, GUI.CLASS_DRAG);\n dom.bind(window, 'mousemove', drag);\n dom.bind(window, 'mouseup', dragStop);\n\n return false;\n }\n\n dom.bind(gui.__resize_handle, 'mousedown', dragStart);\n dom.bind(gui.__closeButton, 'mousedown', dragStart);\n\n gui.domElement.insertBefore(gui.__resize_handle, gui.domElement.firstElementChild);\n}\n\nfunction setWidth(gui, w) {\n gui.domElement.style.width = w + 'px';\n // Auto placed save-rows are position fixed, so we have to\n // set the width manually if we want it to bleed to the edge\n if (gui.__save_row && gui.autoPlace) {\n gui.__save_row.style.width = w + 'px';\n }\n if (gui.__closeButton) {\n gui.__closeButton.style.width = w + 'px';\n }\n}\n\nfunction getCurrentPreset(gui, useInitialValues) {\n const toReturn = {};\n\n // For each object I'm remembering\n common.each(gui.__rememberedObjects, function(val, index) {\n const savedValues = {};\n\n // The controllers I've made for thcommon.isObject by property\n const controllerMap =\n gui.__rememberedObjectIndecesToControllers[index];\n\n // Remember each value for each property\n common.each(controllerMap, function(controller, property) {\n savedValues[property] = useInitialValues ? controller.initialValue : controller.getValue();\n });\n\n // Save the values for thcommon.isObject\n toReturn[index] = savedValues;\n });\n\n return toReturn;\n}\n\nfunction setPresetSelectIndex(gui) {\n for (let index = 0; index < gui.__preset_select.length; index++) {\n if (gui.__preset_select[index].value === gui.preset) {\n gui.__preset_select.selectedIndex = index;\n }\n }\n}\n\nfunction updateDisplays(controllerArray) {\n if (controllerArray.length !== 0) {\n requestAnimationFrame.call(window, function() {\n updateDisplays(controllerArray);\n });\n }\n\n common.each(controllerArray, function(c) {\n c.updateDisplay();\n });\n}\n\nexport default GUI;\n\n\n\n// WEBPACK FOOTER //\n// ./dat/gui/GUI.js","/**\n * dat-gui JavaScript Controller Library\n * http://code.google.com/p/dat-gui\n *\n * Copyright 2011 Data Arts Team, Google Creative Lab\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n */\n\nmodule.exports = {\n load: function(url, indoc) {\n const doc = indoc || document;\n const link = doc.createElement('link');\n link.type = 'text/css';\n link.rel = 'stylesheet';\n link.href = url;\n doc.getElementsByTagName('head')[0].appendChild(link);\n },\n\n inject: function(css, indoc) {\n const doc = indoc || document;\n const injected = document.createElement('style');\n injected.type = 'text/css';\n injected.innerHTML = css;\n const head = doc.getElementsByTagName('head')[0];\n try {\n head.appendChild(injected);\n } catch (e) { // Unable to inject CSS, probably because of a Content Security Policy\n }\n }\n};\n\n\n\n// WEBPACK FOOTER //\n// ./dat/utils/css.js","module.exports = \"GUI
's constructor:\\n\\n \\n\\n localStorage
on exit.\\n\\n localStorage
will\\n override those passed to dat.GUI
's constructor. This makes it\\n easier to work incrementally, but localStorage
is fragile,\\n and your friends may not see the same values you do.\\n\\n GUI
's constructor: localStorage
on exit. localStorage
will override those passed to dat.GUI
's constructor. This makes it easier to work incrementally, but localStorage
is fragile, and your friends may not see the same values you do.