dat.gui/build/dat.gui.js

4398 lines
123 KiB
JavaScript
Raw Normal View History

2015-08-14 13:24:30 +00:00
(function webpackUniversalModuleDefinition(root, factory) {
if(typeof exports === 'object' && typeof module === 'object')
module.exports = factory();
else if(typeof define === 'function' && define.amd)
define(factory);
else if(typeof exports === 'object')
exports["dat"] = factory();
else
root["dat"] = factory();
})(this, function() {
return /******/ (function(modules) { // webpackBootstrap
/******/ // The module cache
/******/ var installedModules = {};
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/ // Check if module is in cache
/******/ if(installedModules[moduleId])
/******/ return installedModules[moduleId].exports;
/******/ // Create a new module (and put it into the cache)
/******/ var module = installedModules[moduleId] = {
/******/ exports: {},
/******/ id: moduleId,
/******/ loaded: false
/******/ };
/******/ // Execute the module function
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
/******/ // Flag the module as loaded
/******/ module.loaded = true;
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/ // expose the modules object (__webpack_modules__)
/******/ __webpack_require__.m = modules;
/******/ // expose the module cache
/******/ __webpack_require__.c = installedModules;
/******/ // __webpack_public_path__
/******/ __webpack_require__.p = "";
/******/ // Load entry module and return exports
/******/ return __webpack_require__(0);
/******/ })
/************************************************************************/
/******/ ([
/* 0 */
/***/ function(module, exports, __webpack_require__) {
module.exports = __webpack_require__(1);
/***/ },
/* 1 */
/***/ function(module, exports, __webpack_require__) {
module.exports = {
color: {
Color: __webpack_require__(2),
math: __webpack_require__(6),
interpret: __webpack_require__(3)
},
controllers: {
Controller: __webpack_require__(7),
BooleanController: __webpack_require__(8),
OptionController: __webpack_require__(10),
StringController: __webpack_require__(11),
NumberController: __webpack_require__(12),
NumberControllerBox: __webpack_require__(13),
NumberControllerSlider: __webpack_require__(14),
FunctionController: __webpack_require__(20),
ColorController: __webpack_require__(21),
},
dom: {
dom: __webpack_require__(9)
},
gui: {
GUI: __webpack_require__(22)
}
};
/***/ },
/* 2 */
/***/ function(module, exports, __webpack_require__) {
/**
* dat-gui JavaScript Controller Library
* http://code.google.com/p/dat-gui
*
* Copyright 2011 Data Arts Team, Google Creative Lab
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*/
var interpret = __webpack_require__(3),
math = __webpack_require__(6),
toString = __webpack_require__(4),
common = __webpack_require__(5);
var Color = function () {
this.__state = interpret.apply(this, arguments);
if (this.__state === false) {
throw 'Failed to interpret color arguments';
}
this.__state.a = this.__state.a || 1;
};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
Color.COMPONENTS = ['r', 'g', 'b', 'h', 's', 'v', 'hex', 'a'];
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.extend(Color.prototype, {
toString: function () {
return toString(this);
},
toOriginal: function () {
return this.__state.conversion.write(this);
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
defineRGBComponent(Color.prototype, 'r', 2);
defineRGBComponent(Color.prototype, 'g', 1);
defineRGBComponent(Color.prototype, 'b', 0);
defineHSVComponent(Color.prototype, 'h');
defineHSVComponent(Color.prototype, 's');
defineHSVComponent(Color.prototype, 'v');
Object.defineProperty(Color.prototype, 'a', {
get: function () {
return this.__state.a;
},
set: function (v) {
this.__state.a = v;
}
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
Object.defineProperty(Color.prototype, 'hex', {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
get: function () {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (!this.__state.space !== 'HEX') {
this.__state.hex = math.rgb_to_hex(this.r, this.g, this.b);
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return this.__state.hex;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
set: function (v) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.__state.space = 'HEX';
this.__state.hex = v;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function defineRGBComponent(target, component, componentHexIndex) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
Object.defineProperty(target, component, {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
get: function () {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (this.__state.space === 'RGB') {
return this.__state[component];
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
recalculateRGB(this, component, componentHexIndex);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return this.__state[component];
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
set: function (v) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (this.__state.space !== 'RGB') {
recalculateRGB(this, component, componentHexIndex);
this.__state.space = 'RGB';
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.__state[component] = v;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function defineHSVComponent(target, component) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
Object.defineProperty(target, component, {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
get: function () {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (this.__state.space === 'HSV')
return this.__state[component];
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
recalculateHSV(this);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return this.__state[component];
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
set: function (v) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (this.__state.space !== 'HSV') {
recalculateHSV(this);
this.__state.space = 'HSV';
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.__state[component] = v;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function recalculateRGB(color, component, componentHexIndex) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (color.__state.space === 'HEX') {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
color.__state[component] = math.component_from_hex(color.__state.hex, componentHexIndex);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
} else if (color.__state.space === 'HSV') {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.extend(color.__state, math.hsv_to_rgb(color.__state.h, color.__state.s, color.__state.v));
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
} else {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
throw 'Corrupted color state';
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function recalculateHSV(color) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var result = math.rgb_to_hsv(color.r, color.g, color.b);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.extend(color.__state,
{
s: result.s,
v: result.v
}
);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (!common.isNaN(result.h)) {
color.__state.h = result.h;
} else if (common.isUndefined(color.__state.h)) {
color.__state.h = 0;
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
module.exports = Color;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/***/ },
/* 3 */
/***/ function(module, exports, __webpack_require__) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/**
* 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
*/
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var toString = __webpack_require__(4),
common = __webpack_require__(5);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var result, toReturn;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var interpret = function() {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
toReturn = false;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var original = arguments.length > 1 ? common.toArray(arguments) : arguments[0];
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.each(INTERPRETATIONS, function(family) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (family.litmus(original)) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.each(family.conversions, function(conversion, conversionName) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
result = conversion.read(original);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (toReturn === false && result !== false) {
toReturn = result;
result.conversionName = conversionName;
result.conversion = conversion;
return common.BREAK;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return common.BREAK;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return toReturn;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var INTERPRETATIONS = [
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Strings
{
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
litmus: common.isString,
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
conversions: {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
THREE_CHAR_HEX: {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
read: function(original) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var test = original.match(/^#([A-F0-9])([A-F0-9])([A-F0-9])$/i);
if (test === null) return false;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return {
space: 'HEX',
hex: parseInt(
'0x' +
test[1].toString() + test[1].toString() +
test[2].toString() + test[2].toString() +
test[3].toString() + test[3].toString())
};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
write: toString
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
SIX_CHAR_HEX: {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
read: function(original) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var test = original.match(/^#([A-F0-9]{6})$/i);
if (test === null) return false;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return {
space: 'HEX',
hex: parseInt('0x' + test[1].toString())
};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
write: toString
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
CSS_RGB: {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
read: function(original) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var test = original.match(/^rgb\(\s*(.+)\s*,\s*(.+)\s*,\s*(.+)\s*\)/);
if (test === null) return false;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return {
space: 'RGB',
r: parseFloat(test[1]),
g: parseFloat(test[2]),
b: parseFloat(test[3])
};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
write: toString
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
CSS_RGBA: {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
read: function(original) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var test = original.match(/^rgba\(\s*(.+)\s*,\s*(.+)\s*,\s*(.+)\s*\,\s*(.+)\s*\)/);
if (test === null) return false;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return {
space: 'RGB',
r: parseFloat(test[1]),
g: parseFloat(test[2]),
b: parseFloat(test[3]),
a: parseFloat(test[4])
};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
write: toString
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Numbers
{
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
litmus: common.isNumber,
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
conversions: {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
HEX: {
read: function(original) {
return {
space: 'HEX',
hex: original,
conversionName: 'HEX'
}
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
write: function(color) {
return color.hex;
}
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Arrays
{
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
litmus: common.isArray,
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
conversions: {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
RGB_ARRAY: {
read: function(original) {
if (original.length != 3) return false;
return {
space: 'RGB',
r: original[0],
g: original[1],
b: original[2]
};
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
write: function(color) {
return [color.r, color.g, color.b];
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
RGBA_ARRAY: {
read: function(original) {
if (original.length != 4) return false;
return {
space: 'RGB',
r: original[0],
g: original[1],
b: original[2],
a: original[3]
};
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
write: function(color) {
return [color.r, color.g, color.b, color.a];
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
// Objects
{
litmus: common.isObject,
conversions: {
RGBA_OBJ: {
read: function(original) {
if (common.isNumber(original.r) &&
common.isNumber(original.g) &&
common.isNumber(original.b) &&
common.isNumber(original.a)) {
return {
space: 'RGB',
r: original.r,
g: original.g,
b: original.b,
a: original.a
}
}
return false;
},
write: function(color) {
return {
r: color.r,
g: color.g,
b: color.b,
a: color.a
}
}
},
RGB_OBJ: {
read: function(original) {
if (common.isNumber(original.r) &&
common.isNumber(original.g) &&
common.isNumber(original.b)) {
return {
space: 'RGB',
r: original.r,
g: original.g,
b: original.b
}
}
return false;
},
write: function(color) {
return {
r: color.r,
g: color.g,
b: color.b
}
}
},
HSVA_OBJ: {
read: function(original) {
if (common.isNumber(original.h) &&
common.isNumber(original.s) &&
common.isNumber(original.v) &&
common.isNumber(original.a)) {
return {
space: 'HSV',
h: original.h,
s: original.s,
v: original.v,
a: original.a
}
}
return false;
},
write: function(color) {
return {
h: color.h,
s: color.s,
v: color.v,
a: color.a
}
}
},
HSV_OBJ: {
read: function(original) {
if (common.isNumber(original.h) &&
common.isNumber(original.s) &&
common.isNumber(original.v)) {
return {
space: 'HSV',
h: original.h,
s: original.s,
v: original.v
}
}
return false;
},
write: function(color) {
return {
h: color.h,
s: color.s,
v: color.v
}
}
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
];
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
module.exports = interpret;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/***/ },
/* 4 */
/***/ function(module, exports, __webpack_require__) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/**
* 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
*/
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var common = __webpack_require__(5);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
module.exports = function(color) {
if (color.a == 1 || common.isUndefined(color.a)) {
var s = color.hex.toString(16);
while (s.length < 6) {
s = '0' + s;
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return '#' + s;
} else {
return 'rgba(' + Math.round(color.r) + ',' + Math.round(color.g) + ',' + Math.round(color.b) + ',' + color.a + ')';
}
};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/***/ },
/* 5 */
/***/ function(module, exports) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/**
* 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
*/
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var ARR_EACH = Array.prototype.forEach;
var ARR_SLICE = Array.prototype.slice;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/**
* Band-aid methods for things that should be a lot easier in JavaScript.
* Implementation and structure inspired by underscore.js
* http://documentcloud.github.com/underscore/
*/
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var Common = {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
BREAK: {},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
extend: function (target) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.each(ARR_SLICE.call(arguments, 1), function (obj) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
for (var key in obj)
if (!this.isUndefined(obj[key]))
target[key] = obj[key];
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}, this);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return target;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
defaults: function (target) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.each(ARR_SLICE.call(arguments, 1), function (obj) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
for (var key in obj)
if (this.isUndefined(target[key]))
target[key] = obj[key];
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}, this);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return target;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
compose: function () {
var toCall = ARR_SLICE.call(arguments);
return function () {
var args = ARR_SLICE.call(arguments);
for (var i = toCall.length - 1; i >= 0; i--) {
args = [toCall[i].apply(this, args)];
}
return args[0];
}
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
each: function (obj, itr, scope) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (!obj) return;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (ARR_EACH && obj.forEach && obj.forEach === ARR_EACH) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
obj.forEach(itr, scope);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
} else if (obj.length === obj.length + 0) { // Is number but not NaN
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
for (var key = 0, l = obj.length; key < l; key++)
if (key in obj && itr.call(scope, obj[key], key) === this.BREAK)
return;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
} else {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
for (var key in obj)
if (itr.call(scope, obj[key], key) === this.BREAK)
return;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
defer: function (fnc) {
setTimeout(fnc, 0);
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
toArray: function (obj) {
if (obj.toArray) return obj.toArray();
return ARR_SLICE.call(obj);
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
isUndefined: function (obj) {
return obj === undefined;
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
isNull: function (obj) {
return obj === null;
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
isNaN: function (obj) {
return obj !== obj;
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
isArray: Array.isArray || function (obj) {
return obj.constructor === Array;
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
isObject: function (obj) {
return obj === Object(obj);
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
isNumber: function (obj) {
return obj === obj + 0;
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
isString: function (obj) {
return obj === obj + '';
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
isBoolean: function (obj) {
return obj === false || obj === true;
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
isFunction: function (obj) {
return Object.prototype.toString.call(obj) === '[object Function]';
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
};
module.exports = Common;
/***/ },
/* 6 */
/***/ function(module, exports) {
/**
* dat-gui JavaScript Controller Library
* http://code.google.com/p/dat-gui
*
* Copyright 2011 Data Arts Team, Google Creative Lab
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*/
var tmpComponent;
var ColorMath = {
hsv_to_rgb: function(h, s, v) {
var hi = Math.floor(h / 60) % 6;
var f = h / 60 - Math.floor(h / 60);
var p = v * (1.0 - s);
var q = v * (1.0 - (f * s));
var t = v * (1.0 - ((1.0 - f) * s));
var c = [
[v, t, p],
[q, v, p],
[p, v, t],
[p, q, v],
[t, p, v],
[v, p, q]
][hi];
return {
r: c[0] * 255,
g: c[1] * 255,
b: c[2] * 255
};
},
rgb_to_hsv: function(r, g, b) {
var min = Math.min(r, g, b),
max = Math.max(r, g, b),
delta = max - min,
h, s;
if (max != 0) {
s = delta / max;
} else {
return {
h: NaN,
s: 0,
v: 0
};
}
if (r == max) {
h = (g - b) / delta;
} else if (g == max) {
h = 2 + (b - r) / delta;
} else {
h = 4 + (r - g) / delta;
}
h /= 6;
if (h < 0) {
h += 1;
}
return {
h: h * 360,
s: s,
v: max / 255
};
},
rgb_to_hex: function(r, g, b) {
var hex = this.hex_with_component(0, 2, r);
hex = this.hex_with_component(hex, 1, g);
hex = this.hex_with_component(hex, 0, b);
return hex;
},
component_from_hex: function(hex, componentIndex) {
return (hex >> (componentIndex * 8)) & 0xFF;
},
hex_with_component: function(hex, componentIndex, value) {
return value << (tmpComponent = componentIndex * 8) | (hex & ~ (0xFF << tmpComponent));
}
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
module.exports = ColorMath;
/***/ },
/* 7 */
/***/ function(module, exports, __webpack_require__) {
/**
* dat-gui JavaScript Controller Library
* http://code.google.com/p/dat-gui
*
* Copyright 2011 Data Arts Team, Google Creative Lab
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*/
var common = __webpack_require__(5);
/**
* @class An "abstract" class that represents a given property of an object.
*
* @param {Object} object The object to be manipulated
* @param {string} property The name of the property to be manipulated
*
* @member dat.controllers
*/
var Controller = function(object, property) {
this.initialValue = object[property];
/**
* Those who extend this class will put their DOM elements in here.
* @type {DOMElement}
*/
this.domElement = document.createElement('div');
/**
* The object to manipulate
* @type {Object}
*/
this.object = object;
/**
* The name of the property to manipulate
* @type {String}
*/
this.property = property;
/**
* The function to be called on change.
* @type {Function}
* @ignore
*/
this.__onChange = undefined;
/**
* The function to be called on finishing change.
* @type {Function}
* @ignore
*/
this.__onFinishChange = undefined;
};
common.extend(
Controller.prototype,
/** @lends dat.controllers.Controller.prototype */
{
/**
* Specify that a function fire every time someone changes the value with
* this Controller.
*
* @param {Function} fnc This function will be called whenever the value
* is modified via this Controller.
* @returns {dat.controllers.Controller} this
*/
onChange: function(fnc) {
this.__onChange = fnc;
return this;
},
/**
* Specify that a function fire every time someone "finishes" changing
* the value wih this Controller. Useful for values that change
* incrementally like numbers or strings.
*
* @param {Function} fnc This function will be called whenever
* someone "finishes" changing the value via this Controller.
* @returns {dat.controllers.Controller} this
*/
onFinishChange: function(fnc) {
this.__onFinishChange = fnc;
return this;
},
/**
* Change the value of <code>object[property]</code>
*
* @param {Object} newValue The new value of <code>object[property]</code>
*/
setValue: function(newValue) {
this.object[this.property] = newValue;
if (this.__onChange) {
this.__onChange.call(this, newValue);
}
this.updateDisplay();
return this;
},
/**
* Gets the value of <code>object[property]</code>
*
* @returns {Object} The current value of <code>object[property]</code>
*/
getValue: function() {
return this.object[this.property];
},
/**
* Refreshes the visual display of a Controller in order to keep sync
* with the object's current value.
* @returns {dat.controllers.Controller} this
*/
updateDisplay: function() {
return this;
},
/**
* @returns {Boolean} true if the value has deviated from initialValue
*/
isModified: function() {
return this.initialValue !== this.getValue()
}
}
);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
module.exports = Controller;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/***/ },
/* 8 */
/***/ function(module, exports, __webpack_require__) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/**
* 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
*/
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var Controller = __webpack_require__(7),
dom = __webpack_require__(9),
common = __webpack_require__(5);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/**
* @class Provides a checkbox input to alter the boolean property of an object.
* @extends dat.controllers.Controller
*
* @param {Object} object The object to be manipulated
* @param {string} property The name of the property to be manipulated
*
* @member dat.controllers
*/
var BooleanController = function(object, property) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
BooleanController.superclass.call(this, object, property);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var _this = this;
this.__prev = this.getValue();
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.__checkbox = document.createElement('input');
this.__checkbox.setAttribute('type', 'checkbox');
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.bind(this.__checkbox, 'change', onChange, false);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.domElement.appendChild(this.__checkbox);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Match original value
this.updateDisplay();
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function onChange() {
_this.setValue(!_this.__prev);
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
BooleanController.superclass = Controller;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.extend(
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
BooleanController.prototype,
Controller.prototype,
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
{
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
setValue: function(v) {
var toReturn = BooleanController.superclass.prototype.setValue.call(this, v);
if (this.__onFinishChange) {
this.__onFinishChange.call(this, this.getValue());
}
this.__prev = this.getValue();
return toReturn;
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
updateDisplay: function() {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (this.getValue() === true) {
this.__checkbox.setAttribute('checked', 'checked');
this.__checkbox.checked = true;
} else {
this.__checkbox.checked = false;
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return BooleanController.superclass.prototype.updateDisplay.call(this);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
module.exports = BooleanController;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/***/ },
/* 9 */
/***/ function(module, exports, __webpack_require__) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/**
* 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
*/
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var common = __webpack_require__(5);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var EVENT_MAP = {
'HTMLEvents': ['change'],
'MouseEvents': ['click', 'mousemove', 'mousedown', 'mouseup', 'mouseover'],
'KeyboardEvents': ['keydown']
};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var EVENT_MAP_INV = {};
common.each(EVENT_MAP, function (v, k) {
common.each(v, function (e) {
EVENT_MAP_INV[e] = k;
});
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var CSS_VALUE_PIXELS = /(\d+(\.\d+)?)px/;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function cssValueToPixels(val) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (val === '0' || common.isUndefined(val)) return 0;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var match = val.match(CSS_VALUE_PIXELS);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (!common.isNull(match)) {
return parseFloat(match[1]);
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// TODO ...ems? %?
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return 0;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/**
* @namespace
* @member dat.dom
*/
var dom = {
/**
*
* @param elem
* @param selectable
*/
makeSelectable: function (elem, selectable) {
if (elem === undefined || elem.style === undefined) return;
elem.onselectstart = selectable ? function () {
return false;
} : function () {
};
elem.style.MozUserSelect = selectable ? 'auto' : 'none';
elem.style.KhtmlUserSelect = selectable ? 'auto' : 'none';
elem.unselectable = selectable ? 'on' : 'off';
},
/**
*
* @param elem
* @param horizontal
* @param vertical
*/
makeFullscreen: function (elem, horizontal, vertical) {
if (common.isUndefined(horizontal)) horizontal = true;
if (common.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 (elem, eventType, params, aux) {
params = params || {};
var className = EVENT_MAP_INV[eventType];
if (!className) {
throw new Error('Event type ' + eventType + ' not supported.');
}
var evt = document.createEvent(className);
switch (className) {
case 'MouseEvents':
var clientX = params.x || params.clientX || 0;
var clientY = params.y || params.clientY || 0;
evt.initMouseEvent(eventType, params.bubbles || false,
params.cancelable || true, window, params.clickCount || 1,
0, //screen X
0, //screen Y
clientX, //client X
clientY, //client Y
false, false, false, false, 0, null);
break;
case 'KeyboardEvents':
var init = evt.initKeyboardEvent || evt.initKeyEvent; // webkit || moz
common.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;
}
common.defaults(evt, aux);
elem.dispatchEvent(evt);
},
/**
*
* @param elem
* @param event
* @param func
* @param bool
*/
bind: function (elem, event, func, bool) {
bool = bool || false;
if (elem.addEventListener)
elem.addEventListener(event, func, bool);
else if (elem.attachEvent)
elem.attachEvent('on' + event, func);
return dom;
},
/**
*
* @param elem
* @param event
* @param func
* @param bool
*/
unbind: function (elem, event, func, bool) {
bool = bool || false;
if (elem.removeEventListener)
elem.removeEventListener(event, func, bool);
else if (elem.detachEvent)
elem.detachEvent('on' + event, func);
return dom;
},
/**
*
* @param elem
* @param className
*/
addClass: function (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 (elem, className) {
if (className) {
if (elem.className === undefined) {
// elem.className = className;
} else if (elem.className === className) {
elem.removeAttribute('class');
} else {
var classes = elem.className.split(/ +/);
var index = classes.indexOf(className);
if (index != -1) {
classes.splice(index, 1);
elem.className = classes.join(' ');
}
}
} else {
elem.className = undefined;
}
return dom;
},
hasClass: function (elem, className) {
return new RegExp('(?:^|\\s+)' + className + '(?:\\s+|$)').test(elem.className) || false;
},
/**
*
* @param elem
*/
getWidth: function (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 (elem) {
var style = getComputedStyle(elem);
return cssValueToPixels(style['border-top-width']) +
cssValueToPixels(style['border-bottom-width']) +
cssValueToPixels(style['padding-top']) +
cssValueToPixels(style['padding-bottom']) +
cssValueToPixels(style['height']);
},
/**
*
* @param elem
*/
getOffset: function (elem) {
var offset = {left: 0, top: 0};
if (elem.offsetParent) {
do {
offset.left += elem.offsetLeft;
offset.top += elem.offsetTop;
} while (elem = elem.offsetParent);
}
return offset;
},
// http://stackoverflow.com/posts/2684561/revisions
/**
*
* @param elem
*/
isActive: function (elem) {
return elem === document.activeElement && ( elem.type || elem.href );
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
};
module.exports = dom;
/***/ },
/* 10 */
/***/ function(module, exports, __webpack_require__) {
/**
* dat-gui JavaScript Controller Library
* http://code.google.com/p/dat-gui
*
* Copyright 2011 Data Arts Team, Google Creative Lab
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*/
var Controller = __webpack_require__(7),
dom = __webpack_require__(9),
common = __webpack_require__(5);
/**
* @class Provides a select input to alter the property of an object, using a
* list of accepted values.
*
* @extends dat.controllers.Controller
*
* @param {Object} object The object to be manipulated
* @param {string} property The name of the property to be manipulated
* @param {Object|string[]} options A map of labels to acceptable values, or
* a list of acceptable string values.
*
* @member dat.controllers
*/
var OptionController = function(object, property, options) {
OptionController.superclass.call(this, object, property);
var _this = this;
/**
* The drop down menu
* @ignore
*/
this.__select = document.createElement('select');
if (common.isArray(options)) {
var map = {};
common.each(options, function(element) {
map[element] = element;
});
options = map;
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.each(options, function(value, key) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var opt = document.createElement('option');
opt.innerHTML = key;
opt.setAttribute('value', value);
_this.__select.appendChild(opt);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Acknowledge original value
this.updateDisplay();
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.bind(this.__select, 'change', function() {
var desiredValue = this.options[this.selectedIndex].value;
_this.setValue(desiredValue);
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.domElement.appendChild(this.__select);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
OptionController.superclass = Controller;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.extend(
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
OptionController.prototype,
Controller.prototype,
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
{
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
setValue: function(v) {
var toReturn = OptionController.superclass.prototype.setValue.call(this, v);
if (this.__onFinishChange) {
this.__onFinishChange.call(this, this.getValue());
}
return toReturn;
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
updateDisplay: function() {
this.__select.value = this.getValue();
return OptionController.superclass.prototype.updateDisplay.call(this);
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
);
module.exports = OptionController;
/***/ },
/* 11 */
/***/ function(module, exports, __webpack_require__) {
/**
* dat-gui JavaScript Controller Library
* http://code.google.com/p/dat-gui
*
* Copyright 2011 Data Arts Team, Google Creative Lab
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*/
var Controller = __webpack_require__(7),
dom = __webpack_require__(9),
common = __webpack_require__(5);
/**
* @class Provides a text input to alter the string property of an object.
*
* @extends dat.controllers.Controller
*
* @param {Object} object The object to be manipulated
* @param {string} property The name of the property to be manipulated
*
* @member dat.controllers
*/
var StringController = function(object, property) {
StringController.superclass.call(this, object, property);
var _this = this;
this.__input = document.createElement('input');
this.__input.setAttribute('type', 'text');
dom.bind(this.__input, 'keyup', onChange);
dom.bind(this.__input, 'change', onChange);
dom.bind(this.__input, 'blur', onBlur);
dom.bind(this.__input, 'keydown', function(e) {
if (e.keyCode === 13) {
this.blur();
}
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function onChange() {
_this.setValue(_this.__input.value);
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function onBlur() {
if (_this.__onFinishChange) {
_this.__onFinishChange.call(_this, _this.getValue());
}
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.updateDisplay();
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.domElement.appendChild(this.__input);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
StringController.superclass = Controller;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.extend(
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
StringController.prototype,
Controller.prototype,
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
{
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
updateDisplay: function() {
// Stops the caret from moving on account of:
// keyup -> setValue -> updateDisplay
if (!dom.isActive(this.__input)) {
this.__input.value = this.getValue();
}
return StringController.superclass.prototype.updateDisplay.call(this);
}
2013-12-18 23:27:02 +00:00
}
2015-08-14 13:24:30 +00:00
);
module.exports = StringController;
/***/ },
/* 12 */
/***/ function(module, exports, __webpack_require__) {
/**
* dat-gui JavaScript Controller Library
* http://code.google.com/p/dat-gui
*
* Copyright 2011 Data Arts Team, Google Creative Lab
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*/
var Controller = __webpack_require__(7),
common = __webpack_require__(5);
/**
* @class Represents a given property of an object that is a number.
*
* @extends dat.controllers.Controller
*
* @param {Object} object The object to be manipulated
* @param {string} property The name of the property to be manipulated
* @param {Object} [params] Optional parameters
* @param {Number} [params.min] Minimum allowed value
* @param {Number} [params.max] Maximum allowed value
* @param {Number} [params.step] Increment by which to change value
*
* @member dat.controllers
*/
var NumberController = function(object, property, params) {
NumberController.superclass.call(this, object, property);
params = params || {};
this.__min = params.min;
this.__max = params.max;
this.__step = params.step;
if (common.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);
};
NumberController.superclass = Controller;
common.extend(
NumberController.prototype,
Controller.prototype,
/** @lends dat.controllers.NumberController.prototype */
{
setValue: function(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 NumberController.superclass.prototype.setValue.call(this, v);
},
/**
* Specify a minimum value for <code>object[property]</code>.
*
* @param {Number} minValue The minimum value for
* <code>object[property]</code>
* @returns {dat.controllers.NumberController} this
*/
min: function(v) {
this.__min = v;
return this;
},
/**
* Specify a maximum value for <code>object[property]</code>.
*
* @param {Number} maxValue The maximum value for
* <code>object[property]</code>
* @returns {dat.controllers.NumberController} this
*/
max: function(v) {
this.__max = v;
return this;
},
/**
* Specify a step value that dat.controllers.NumberController
* increments by.
*
* @param {Number} stepValue The step value for
* dat.controllers.NumberController
* @default if minimum and maximum specified increment is 1% of the
* difference otherwise stepValue is 1
* @returns {dat.controllers.NumberController} this
*/
step: function(v) {
this.__step = v;
this.__impliedStep = v;
this.__precision = numDecimals(v);
return this;
}
}
);
function numDecimals(x) {
x = x.toString();
if (x.indexOf('.') > -1) {
return x.length - x.indexOf('.') - 1;
} else {
return 0;
}
}
module.exports = NumberController;
/***/ },
/* 13 */
/***/ function(module, exports, __webpack_require__) {
/**
* dat-gui JavaScript Controller Library
* http://code.google.com/p/dat-gui
*
* Copyright 2011 Data Arts Team, Google Creative Lab
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*/
var Controller = __webpack_require__(7),
NumberController = __webpack_require__(12),
dom = __webpack_require__(9),
common = __webpack_require__(5);
/**
* @class Represents a given property of an object that is a number and
* provides an input element with which to manipulate it.
*
* @extends dat.controllers.Controller
* @extends dat.controllers.NumberController
*
* @param {Object} object The object to be manipulated
* @param {string} property The name of the property to be manipulated
* @param {Object} [params] Optional parameters
* @param {Number} [params.min] Minimum allowed value
* @param {Number} [params.max] Maximum allowed value
* @param {Number} [params.step] Increment by which to change value
*
* @member dat.controllers
*/
var NumberControllerBox = function(object, property, params) {
this.__truncationSuspended = false;
NumberControllerBox.superclass.call(this, object, property, params);
var _this = this;
/**
* {Number} Previous mouse y position
* @ignore
*/
var prev_y;
this.__input = document.createElement('input');
this.__input.setAttribute('type', 'text');
// Makes it so manually specified values are not truncated.
dom.bind(this.__input, 'change', onChange);
dom.bind(this.__input, 'blur', onBlur);
dom.bind(this.__input, 'mousedown', onMouseDown);
dom.bind(this.__input, 'keydown', function(e) {
// When pressing entire, you can be as precise as you want.
if (e.keyCode === 13) {
_this.__truncationSuspended = true;
this.blur();
_this.__truncationSuspended = false;
}
});
function onChange() {
var attempted = parseFloat(_this.__input.value);
if (!common.isNaN(attempted)) _this.setValue(attempted);
}
function onBlur() {
onChange();
if (_this.__onFinishChange) {
_this.__onFinishChange.call(_this, _this.getValue());
}
}
function onMouseDown(e) {
dom.bind(window, 'mousemove', onMouseDrag);
dom.bind(window, 'mouseup', onMouseUp);
prev_y = e.clientY;
}
function onMouseDrag(e) {
var diff = prev_y - e.clientY;
_this.setValue(_this.getValue() + diff * _this.__impliedStep);
prev_y = e.clientY;
}
function onMouseUp() {
dom.unbind(window, 'mousemove', onMouseDrag);
dom.unbind(window, 'mouseup', onMouseUp);
}
this.updateDisplay();
this.domElement.appendChild(this.__input);
};
NumberControllerBox.superclass = NumberController;
common.extend(
NumberControllerBox.prototype,
NumberController.prototype,
{
updateDisplay: function() {
this.__input.value = this.__truncationSuspended ? this.getValue() : roundToDecimal(this.getValue(), this.__precision);
return NumberControllerBox.superclass.prototype.updateDisplay.call(this);
}
}
);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function roundToDecimal(value, decimals) {
var tenTo = Math.pow(10, decimals);
return Math.round(value * tenTo) / tenTo;
}
module.exports = NumberControllerBox;
/***/ },
/* 14 */
/***/ function(module, exports, __webpack_require__) {
/**
* dat-gui JavaScript Controller Library
* http://code.google.com/p/dat-gui
*
* Copyright 2011 Data Arts Team, Google Creative Lab
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*/
var NumberController = __webpack_require__(12),
dom = __webpack_require__(9),
css = __webpack_require__(15),
common = __webpack_require__(5),
styleSheet = __webpack_require__(16);
/**
* @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
* <code>&lt;div&gt;</code> tags, <strong>not</strong> the html5
* <code>&lt;slider&gt;</code> element.
*
* @extends dat.controllers.Controller
* @extends dat.controllers.NumberController
*
* @param {Object} object The object to be manipulated
* @param {string} property The name of the property to be manipulated
* @param {Number} minValue Minimum allowed value
* @param {Number} maxValue Maximum allowed value
* @param {Number} stepValue Increment by which to change value
*
* @member dat.controllers
*/
var NumberControllerSlider = function(object, property, min, max, step) {
NumberControllerSlider.superclass.call(this, object, property, { min: min, max: max, step: step });
var _this = this;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.__background = document.createElement('div');
this.__foreground = document.createElement('div');
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.bind(this.__background, 'mousedown', onMouseDown);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.addClass(this.__background, 'slider');
dom.addClass(this.__foreground, 'slider-fg');
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function onMouseDown(e) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.bind(window, 'mousemove', onMouseDrag);
dom.bind(window, 'mouseup', onMouseUp);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
onMouseDrag(e);
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function onMouseDrag(e) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
e.preventDefault();
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var offset = dom.getOffset(_this.__background);
var width = dom.getWidth(_this.__background);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
_this.setValue(
map(e.clientX, offset.left, offset.left + width, _this.__min, _this.__max)
);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return false;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function onMouseUp() {
dom.unbind(window, 'mousemove', onMouseDrag);
dom.unbind(window, 'mouseup', onMouseUp);
if (_this.__onFinishChange) {
_this.__onFinishChange.call(_this, _this.getValue());
}
}
this.updateDisplay();
this.__background.appendChild(this.__foreground);
this.domElement.appendChild(this.__background);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
NumberControllerSlider.superclass = NumberController;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/**
* Injects default stylesheet for slider elements.
*/
NumberControllerSlider.useDefaultStyles = function() {
css.inject(styleSheet);
};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.extend(
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
NumberControllerSlider.prototype,
NumberController.prototype,
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
{
updateDisplay: function() {
var pct = (this.getValue() - this.__min)/(this.__max - this.__min);
this.__foreground.style.width = pct*100+'%';
return NumberControllerSlider.superclass.prototype.updateDisplay.call(this);
}
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
);
function map(v, i1, i2, o1, o2) {
return o1 + (o2 - o1) * ((v - i1) / (i2 - i1));
}
module.exports = NumberControllerSlider;
/***/ },
/* 15 */
/***/ function(module, exports) {
/**
* dat-gui JavaScript Controller Library
* http://code.google.com/p/dat-gui
*
* Copyright 2011 Data Arts Team, Google Creative Lab
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*/
module.exports = {
load: function (url, doc) {
doc = doc || document;
var link = doc.createElement('link');
link.type = 'text/css';
link.rel = 'stylesheet';
link.href = url;
doc.getElementsByTagName('head')[0].appendChild(link);
},
inject: function (css, doc) {
doc = doc || document;
var injected = document.createElement('style');
injected.type = 'text/css';
injected.innerHTML = css;
doc.getElementsByTagName('head')[0].appendChild(injected);
}
};
/***/ },
/* 16 */
/***/ function(module, exports, __webpack_require__) {
// style-loader: Adds some css to the DOM by adding a <style> tag
// load the styles
var content = __webpack_require__(17);
if(typeof content === 'string') content = [[module.id, content, '']];
// add the styles to the DOM
var update = __webpack_require__(19)(content, {});
if(content.locals) module.exports = content.locals;
// Hot Module Replacement
if(false) {
// When the styles change, update the <style> tags
if(!content.locals) {
module.hot.accept("!!./../../../node_modules/css-loader/index.js!./NumberControllerSlider.css", function() {
var newContent = require("!!./../../../node_modules/css-loader/index.js!./NumberControllerSlider.css");
if(typeof newContent === 'string') newContent = [[module.id, newContent, '']];
update(newContent);
});
}
// When the module is disposed, remove the <style> tags
module.hot.dispose(function() { update(); });
}
/***/ },
/* 17 */
/***/ function(module, exports, __webpack_require__) {
exports = module.exports = __webpack_require__(18)();
// imports
// module
exports.push([module.id, "/**\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\n.slider {\n box-shadow: inset 0 2px 4px rgba(0,0,0,0.15);\n height: 1em;\n border-radius: 1em;\n background-color: #eee;\n padding: 0 0.5em;\n overflow: hidden;\n}\n\n.slider-fg {\n padding: 1px 0 2px 0;\n background-color: #aaa;\n height: 1em;\n margin-left: -0.5em;\n padding-right: 0.5em;\n border-radius: 1em 0 0 1em;\n}\n\n.slider-fg:after {\n display: inline-block;\n border-radius: 1em;\n background-color: #fff;\n border: 1px solid #aaa;\n content: '';\n float: right;\n margin-right: -1em;\n margin-top: -1px;\n height: 0.9em;\n width: 0.9em;\n}", ""]);
// exports
/***/ },
/* 18 */
/***/ function(module, exports) {
/*
MIT License http://www.opensource.org/licenses/mit-license.php
Author Tobias Koppers @sokra
*/
// css base code, injected by the css-loader
module.exports = function() {
var list = [];
// return the list of modules as css string
list.toString = function toString() {
var result = [];
for(var i = 0; i < this.length; i++) {
var item = this[i];
if(item[2]) {
result.push("@media " + item[2] + "{" + item[1] + "}");
} else {
result.push(item[1]);
}
}
return result.join("");
};
// import a list of modules into the list
list.i = function(modules, mediaQuery) {
if(typeof modules === "string")
modules = [[null, modules, ""]];
var alreadyImportedModules = {};
for(var i = 0; i < this.length; i++) {
var id = this[i][0];
if(typeof id === "number")
alreadyImportedModules[id] = true;
}
for(i = 0; i < modules.length; i++) {
var item = modules[i];
// skip already imported module
// this implementation is not 100% perfect for weird media query combinations
// when a module is imported multiple times with different media queries.
// I hope this will never occur (Hey this way we have smaller bundles)
if(typeof item[0] !== "number" || !alreadyImportedModules[item[0]]) {
if(mediaQuery && !item[2]) {
item[2] = mediaQuery;
} else if(mediaQuery) {
item[2] = "(" + item[2] + ") and (" + mediaQuery + ")";
}
list.push(item);
}
}
};
return list;
};
/***/ },
/* 19 */
/***/ function(module, exports, __webpack_require__) {
/*
MIT License http://www.opensource.org/licenses/mit-license.php
Author Tobias Koppers @sokra
*/
var stylesInDom = {},
memoize = function(fn) {
var memo;
return function () {
if (typeof memo === "undefined") memo = fn.apply(this, arguments);
return memo;
};
},
isOldIE = memoize(function() {
return /msie [6-9]\b/.test(window.navigator.userAgent.toLowerCase());
}),
getHeadElement = memoize(function () {
return document.head || document.getElementsByTagName("head")[0];
}),
singletonElement = null,
singletonCounter = 0;
module.exports = function(list, options) {
if(false) {
if(typeof document !== "object") throw new Error("The style-loader cannot be used in a non-browser environment");
}
options = options || {};
// Force single-tag solution on IE6-9, which has a hard limit on the # of <style>
// tags it will allow on a page
if (typeof options.singleton === "undefined") options.singleton = isOldIE();
var styles = listToStyles(list);
addStylesToDom(styles, options);
return function update(newList) {
var mayRemove = [];
for(var i = 0; i < styles.length; i++) {
var item = styles[i];
var domStyle = stylesInDom[item.id];
domStyle.refs--;
mayRemove.push(domStyle);
}
if(newList) {
var newStyles = listToStyles(newList);
addStylesToDom(newStyles, options);
}
for(var i = 0; i < mayRemove.length; i++) {
var domStyle = mayRemove[i];
if(domStyle.refs === 0) {
for(var j = 0; j < domStyle.parts.length; j++)
domStyle.parts[j]();
delete stylesInDom[domStyle.id];
}
}
};
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function addStylesToDom(styles, options) {
for(var i = 0; i < styles.length; i++) {
var item = styles[i];
var domStyle = stylesInDom[item.id];
if(domStyle) {
domStyle.refs++;
for(var j = 0; j < domStyle.parts.length; j++) {
domStyle.parts[j](item.parts[j]);
}
for(; j < item.parts.length; j++) {
domStyle.parts.push(addStyle(item.parts[j], options));
}
} else {
var parts = [];
for(var j = 0; j < item.parts.length; j++) {
parts.push(addStyle(item.parts[j], options));
}
stylesInDom[item.id] = {id: item.id, refs: 1, parts: parts};
}
}
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function listToStyles(list) {
var styles = [];
var newStyles = {};
for(var i = 0; i < list.length; i++) {
var item = list[i];
var id = item[0];
var css = item[1];
var media = item[2];
var sourceMap = item[3];
var part = {css: css, media: media, sourceMap: sourceMap};
if(!newStyles[id])
styles.push(newStyles[id] = {id: id, parts: [part]});
else
newStyles[id].parts.push(part);
}
return styles;
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function createStyleElement() {
var styleElement = document.createElement("style");
var head = getHeadElement();
styleElement.type = "text/css";
head.appendChild(styleElement);
return styleElement;
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function createLinkElement() {
var linkElement = document.createElement("link");
var head = getHeadElement();
linkElement.rel = "stylesheet";
head.appendChild(linkElement);
return linkElement;
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function addStyle(obj, options) {
var styleElement, update, remove;
if (options.singleton) {
var styleIndex = singletonCounter++;
styleElement = singletonElement || (singletonElement = createStyleElement());
update = applyToSingletonTag.bind(null, styleElement, styleIndex, false);
remove = applyToSingletonTag.bind(null, styleElement, styleIndex, true);
} else if(obj.sourceMap &&
typeof URL === "function" &&
typeof URL.createObjectURL === "function" &&
typeof URL.revokeObjectURL === "function" &&
typeof Blob === "function" &&
typeof btoa === "function") {
styleElement = createLinkElement();
update = updateLink.bind(null, styleElement);
remove = function() {
styleElement.parentNode.removeChild(styleElement);
if(styleElement.href)
URL.revokeObjectURL(styleElement.href);
};
} else {
styleElement = createStyleElement();
update = applyToTag.bind(null, styleElement);
remove = function() {
styleElement.parentNode.removeChild(styleElement);
};
}
update(obj);
return function updateStyle(newObj) {
if(newObj) {
if(newObj.css === obj.css && newObj.media === obj.media && newObj.sourceMap === obj.sourceMap)
return;
update(obj = newObj);
} else {
remove();
}
};
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var replaceText = (function () {
var textStore = [];
return function (index, replacement) {
textStore[index] = replacement;
return textStore.filter(Boolean).join('\n');
};
})();
function applyToSingletonTag(styleElement, index, remove, obj) {
var css = remove ? "" : obj.css;
if (styleElement.styleSheet) {
styleElement.styleSheet.cssText = replaceText(index, css);
} else {
var cssNode = document.createTextNode(css);
var childNodes = styleElement.childNodes;
if (childNodes[index]) styleElement.removeChild(childNodes[index]);
if (childNodes.length) {
styleElement.insertBefore(cssNode, childNodes[index]);
} else {
styleElement.appendChild(cssNode);
}
}
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function applyToTag(styleElement, obj) {
var css = obj.css;
var media = obj.media;
var sourceMap = obj.sourceMap;
if(media) {
styleElement.setAttribute("media", media)
}
if(styleElement.styleSheet) {
styleElement.styleSheet.cssText = css;
} else {
while(styleElement.firstChild) {
styleElement.removeChild(styleElement.firstChild);
}
styleElement.appendChild(document.createTextNode(css));
}
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function updateLink(linkElement, obj) {
var css = obj.css;
var media = obj.media;
var sourceMap = obj.sourceMap;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if(sourceMap) {
// http://stackoverflow.com/a/26603875
css += "\n/*# sourceMappingURL=data:application/json;base64," + btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))) + " */";
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var blob = new Blob([css], { type: "text/css" });
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var oldSrc = linkElement.href;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
linkElement.href = URL.createObjectURL(blob);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if(oldSrc)
URL.revokeObjectURL(oldSrc);
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/***/ },
/* 20 */
/***/ function(module, exports, __webpack_require__) {
/**
* dat-gui JavaScript Controller Library
* http://code.google.com/p/dat-gui
*
* Copyright 2011 Data Arts Team, Google Creative Lab
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*/
var Controller = __webpack_require__(7),
dom = __webpack_require__(9),
common = __webpack_require__(5);
/**
* @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
*
* @member dat.controllers
*/
var FunctionController = function(object, property, text) {
FunctionController.superclass.call(this, object, property);
var _this = this;
this.__button = document.createElement('div');
this.__button.innerHTML = text === undefined ? 'Fire' : text;
dom.bind(this.__button, 'click', function(e) {
e.preventDefault();
_this.fire();
return false;
});
dom.addClass(this.__button, 'button');
this.domElement.appendChild(this.__button);
};
FunctionController.superclass = Controller;
common.extend(
FunctionController.prototype,
Controller.prototype,
{
fire: function() {
if (this.__onChange) {
this.__onChange.call(this);
}
this.getValue().call(this.object);
if (this.__onFinishChange) {
this.__onFinishChange.call(this, this.getValue());
}
}
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
module.exports = FunctionController;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/***/ },
/* 21 */
/***/ function(module, exports, __webpack_require__) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/**
* 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
*/
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var Controller = __webpack_require__(7),
dom = __webpack_require__(9),
Color = __webpack_require__(2),
interpret = __webpack_require__(3),
common = __webpack_require__(5);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var ColorController = function(object, property) {
ColorController.superclass.call(this, object, property);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.__color = new Color(this.getValue());
this.__temp = new Color(0);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var _this = this;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.domElement = document.createElement('div');
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.makeSelectable(this.domElement, false);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.__selector = document.createElement('div');
this.__selector.className = 'selector';
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.__saturation_field = document.createElement('div');
this.__saturation_field.className = 'saturation-field';
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.__field_knob = document.createElement('div');
this.__field_knob.className = 'field-knob';
this.__field_knob_border = '2px solid ';
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.__hue_knob = document.createElement('div');
this.__hue_knob.className = 'hue-knob';
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.__hue_field = document.createElement('div');
this.__hue_field.className = 'hue-field';
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.__input = document.createElement('input');
this.__input.type = 'text';
this.__input_textShadow = '0 1px 1px ';
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.bind(this.__input, 'keydown', function(e) {
if (e.keyCode === 13) { // on enter
onBlur.call(this);
}
});
dom.bind(this.__input, 'blur', onBlur);
dom.bind(this.__selector, 'mousedown', function(e) {
dom
.addClass(this, 'drag')
.bind(window, 'mouseup', function(e) {
dom.removeClass(_this.__selector, 'drag');
});
});
var value_field = document.createElement('div');
common.extend(this.__selector.style, {
width: '122px',
height: '102px',
padding: '3px',
backgroundColor: '#222',
boxShadow: '0px 1px 3px rgba(0,0,0,0.3)'
});
common.extend(this.__field_knob.style, {
position: 'absolute',
width: '12px',
height: '12px',
border: this.__field_knob_border + (this.__color.v < .5 ? '#fff' : '#000'),
boxShadow: '0px 1px 3px rgba(0,0,0,0.5)',
borderRadius: '12px',
zIndex: 1
});
common.extend(this.__hue_knob.style, {
position: 'absolute',
width: '15px',
height: '2px',
borderRight: '4px solid #fff',
zIndex: 1
});
common.extend(this.__saturation_field.style, {
width: '100px',
height: '100px',
border: '1px solid #555',
marginRight: '3px',
display: 'inline-block',
cursor: 'pointer'
});
common.extend(value_field.style, {
width: '100%',
height: '100%',
background: 'none'
});
linearGradient(value_field, 'top', 'rgba(0,0,0,0)', '#000');
common.extend(this.__hue_field.style, {
width: '15px',
height: '100px',
display: 'inline-block',
border: '1px solid #555',
cursor: 'ns-resize'
});
hueGradient(this.__hue_field);
common.extend(this.__input.style, {
outline: 'none',
// width: '120px',
textAlign: 'center',
// padding: '4px',
// marginBottom: '6px',
color: '#fff',
border: 0,
fontWeight: 'bold',
textShadow: this.__input_textShadow + 'rgba(0,0,0,0.7)'
});
dom.bind(this.__saturation_field, 'mousedown', fieldDown);
dom.bind(this.__field_knob, 'mousedown', fieldDown);
dom.bind(this.__hue_field, 'mousedown', function(e) {
setH(e);
dom.bind(window, 'mousemove', setH);
dom.bind(window, 'mouseup', unbindH);
});
function fieldDown(e) {
setSV(e);
// document.body.style.cursor = 'none';
dom.bind(window, 'mousemove', setSV);
dom.bind(window, 'mouseup', unbindSV);
}
function unbindSV() {
dom.unbind(window, 'mousemove', setSV);
dom.unbind(window, 'mouseup', unbindSV);
// document.body.style.cursor = 'default';
}
function onBlur() {
var i = interpret(this.value);
if (i !== false) {
_this.__color.__state = i;
_this.setValue(_this.__color.toOriginal());
} else {
this.value = _this.__color.toString();
}
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function unbindH() {
dom.unbind(window, 'mousemove', setH);
dom.unbind(window, 'mouseup', unbindH);
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.__saturation_field.appendChild(value_field);
this.__selector.appendChild(this.__field_knob);
this.__selector.appendChild(this.__saturation_field);
this.__selector.appendChild(this.__hue_field);
this.__hue_field.appendChild(this.__hue_knob);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.domElement.appendChild(this.__input);
this.domElement.appendChild(this.__selector);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.updateDisplay();
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function setSV(e) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
e.preventDefault();
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var w = dom.getWidth(_this.__saturation_field);
var o = dom.getOffset(_this.__saturation_field);
var s = (e.clientX - o.left + document.body.scrollLeft) / w;
var v = 1 - (e.clientY - o.top + document.body.scrollTop) / w;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (v > 1) v = 1;
else if (v < 0) v = 0;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (s > 1) s = 1;
else if (s < 0) s = 0;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
_this.__color.v = v;
_this.__color.s = s;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
_this.setValue(_this.__color.toOriginal());
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return false;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function setH(e) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
e.preventDefault();
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var s = dom.getHeight(_this.__hue_field);
var o = dom.getOffset(_this.__hue_field);
var h = 1 - (e.clientY - o.top + document.body.scrollTop) / s;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (h > 1) h = 1;
else if (h < 0) h = 0;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
_this.__color.h = h * 360;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
_this.setValue(_this.__color.toOriginal());
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return false;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
ColorController.superclass = Controller;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.extend(
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
ColorController.prototype,
Controller.prototype,
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
{
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
updateDisplay: function() {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var i = interpret(this.getValue());
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (i !== false) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var mismatch = false;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Check for mismatch on the interpreted value.
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.each(Color.COMPONENTS, function(component) {
if (!common.isUndefined(i[component]) &&
!common.isUndefined(this.__color.__state[component]) &&
i[component] !== this.__color.__state[component]) {
mismatch = true;
return {}; // break
}
}, this);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// If nothing diverges, we keep our previous values
// for statefulness, otherwise we recalculate fresh
if (mismatch) {
common.extend(this.__color.__state, i);
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.extend(this.__temp.__state, this.__color.__state);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.__temp.a = 1;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var flip = (this.__color.v < .5 || this.__color.s > .5) ? 255 : 0;
var _flip = 255 - flip;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.extend(this.__field_knob.style, {
marginLeft: 100 * this.__color.s - 7 + 'px',
marginTop: 100 * (1 - this.__color.v) - 7 + 'px',
backgroundColor: this.__temp.toString(),
border: this.__field_knob_border + 'rgb(' + flip + ',' + flip + ',' + flip +')'
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.__hue_knob.style.marginTop = (1 - this.__color.h / 360) * 100 + 'px'
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.__temp.s = 1;
this.__temp.v = 1;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
linearGradient(this.__saturation_field, 'left', '#fff', this.__temp.toString());
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.extend(this.__input.style, {
backgroundColor: this.__input.value = this.__color.toString(),
color: 'rgb(' + flip + ',' + flip + ',' + flip +')',
textShadow: this.__input_textShadow + 'rgba(' + _flip + ',' + _flip + ',' + _flip +',.7)'
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var vendors = ['-moz-','-o-','-webkit-','-ms-',''];
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function linearGradient(elem, x, a, b) {
elem.style.background = '';
common.each(vendors, function(vendor) {
elem.style.cssText += 'background: ' + vendor + 'linear-gradient('+x+', '+a+' 0%, ' + b + ' 100%); ';
});
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
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%);'
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
module.exports = ColorController;
/***/ },
/* 22 */
/***/ function(module, exports, __webpack_require__) {
/**
* dat-gui JavaScript Controller Library
* http://code.google.com/p/dat-gui
*
* Copyright 2011 Data Arts Team, Google Creative Lab
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*/
var css = __webpack_require__(15),
saveDialogueContents = __webpack_require__(23),
styleSheet = __webpack_require__(24),
controllerFactory = __webpack_require__(26),
Controller = __webpack_require__(7),
BooleanController = __webpack_require__(8),
FunctionController = __webpack_require__(20),
NumberControllerBox = __webpack_require__(13),
NumberControllerSlider = __webpack_require__(14),
OptionController = __webpack_require__(10),
ColorController = __webpack_require__(21),
requestAnimationFrame = __webpack_require__(27),
CenteredDiv = __webpack_require__(28),
dom = __webpack_require__(9),
common = __webpack_require__(5);
css.inject(styleSheet);
/** Outer-most className for GUI's */
var CSS_NAMESPACE = 'dg';
var HIDE_KEY_CODE = 72;
/** 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;
/** Have we yet to create an autoPlace GUI? */
var auto_place_virgin = true;
/** Fixed position div that auto place GUI's go inside */
var auto_place_container;
/** Are we hiding the GUI's ? */
var hide = false;
/** GUI's which should be hidden */
var hideable_guis = [];
/**
* A lightweight controller library for JavaScript. It allows you to easily
* manipulate variables and fire functions on the fly.
* @class
*
* @member dat.gui
*
* @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
*/
var GUI = function(params) {
var _this = this;
/**
* Outermost DOM Element
* @type DOMElement
*/
this.domElement = document.createElement('div');
this.__ul = document.createElement('ul');
this.domElement.appendChild(this.__ul);
dom.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 = [];
params = params || {};
// Default parameters
params = common.defaults(params, {
autoPlace: true,
width: GUI.DEFAULT_WIDTH
});
params = common.defaults(params, {
resizable: params.autoPlace,
hideable: params.autoPlace
});
if (!common.isUndefined(params.load)) {
// Explicit preset
if (params.preset) params.load.preset = params.preset;
} else {
params.load = { preset: DEFAULT_DEFAULT_PRESET_NAME };
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (common.isUndefined(params.parent) && params.hideable) {
hideable_guis.push(this);
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Only root level GUI's are resizable.
params.resizable = common.isUndefined(params.parent) && params.resizable;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (params.autoPlace && common.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 use_local_storage =
SUPPORTS_LOCAL_STORAGE &&
localStorage.getItem(getLocalStorageHash(this, 'isLocal')) === 'true';
var saveToLocalStorage;
Object.defineProperties(this,
/** @lends dat.gui.GUI.prototype */
{
/**
* The parent <code>GUI</code>
* @type dat.gui.GUI
*/
parent: {
get: function() {
return params.parent;
}
},
scrollable: {
get: function() {
return params.scrollable;
}
},
/**
* Handles <code>GUI</code>'s element placement for you
* @type Boolean
*/
autoPlace: {
get: function() {
return params.autoPlace;
}
},
/**
* The identifier for a set of saved values
* @type String
*/
preset: {
get: function() {
if (_this.parent) {
return _this.getRoot().preset;
} else {
return params.load.preset;
}
},
set: function(v) {
if (_this.parent) {
_this.getRoot().preset = v;
} else {
params.load.preset = v;
}
setPresetSelectIndex(this);
_this.revert();
}
},
/**
* The width of <code>GUI</code> element
* @type Number
*/
width: {
get: function() {
return params.width;
},
set: function(v) {
params.width = v;
setWidth(_this, v);
}
},
/**
* The name of <code>GUI</code>. Used for folders. i.e
* a folder's name
* @type String
*/
name: {
get: function() {
return params.name;
},
set: function(v) {
// TODO Check for collisions among sibling folders
params.name = v;
if (title_row_name) {
title_row_name.innerHTML = params.name;
}
}
},
/**
* Whether the <code>GUI</code> is collapsed or not
* @type Boolean
*/
closed: {
get: function() {
return params.closed;
},
set: function(v) {
params.closed = v;
if (params.closed) {
dom.addClass(_this.__ul, GUI.CLASS_CLOSED);
} else {
dom.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() {
return params.load;
}
},
/**
* Determines whether or not to use <a href="https://developer.mozilla.org/en/DOM/Storage#localStorage">localStorage</a> as the means for
* <code>remember</code>ing
* @type Boolean
*/
useLocalStorage: {
get: function() {
return use_local_storage;
},
set: function(bool) {
if (SUPPORTS_LOCAL_STORAGE) {
use_local_storage = bool;
if (bool) {
dom.bind(window, 'unload', saveToLocalStorage);
} else {
dom.unbind(window, 'unload', saveToLocalStorage);
}
localStorage.setItem(getLocalStorageHash(_this, 'isLocal'), bool);
}
}
}
});
// Are we a root level GUI?
if (common.isUndefined(params.parent)) {
params.closed = false;
dom.addClass(this.domElement, GUI.CLASS_MAIN);
dom.makeSelectable(this.domElement, false);
// Are we supposed to be loading locally?
if (SUPPORTS_LOCAL_STORAGE) {
if (use_local_storage) {
_this.useLocalStorage = true;
var saved_gui = localStorage.getItem(getLocalStorageHash(this, 'gui'));
if (saved_gui) {
params.load = JSON.parse(saved_gui);
}
}
}
this.__closeButton = document.createElement('div');
this.__closeButton.innerHTML = GUI.TEXT_CLOSED;
dom.addClass(this.__closeButton, GUI.CLASS_CLOSE_BUTTON);
this.domElement.appendChild(this.__closeButton);
dom.bind(this.__closeButton, 'click', function() {
_this.closed = !_this.closed;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Oh, you're a nested GUI!
} else {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (params.closed === undefined) {
params.closed = true;
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var title_row_name = document.createTextNode(params.name);
dom.addClass(title_row_name, 'controller-name');
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var title_row = addRow(_this, title_row_name);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var on_click_title = function(e) {
e.preventDefault();
_this.closed = !_this.closed;
return false;
};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.addClass(this.__ul, GUI.CLASS_CLOSED);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.addClass(title_row, 'title');
dom.bind(title_row, 'click', on_click_title);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (!params.closed) {
this.closed = false;
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (params.autoPlace) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (common.isUndefined(params.parent)) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (auto_place_virgin) {
auto_place_container = document.createElement('div');
dom.addClass(auto_place_container, CSS_NAMESPACE);
dom.addClass(auto_place_container, GUI.CLASS_AUTO_PLACE_CONTAINER);
document.body.appendChild(auto_place_container);
auto_place_virgin = false;
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Put it in the dom for you.
auto_place_container.appendChild(this.domElement);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Apply the auto styles
dom.addClass(this.domElement, GUI.CLASS_AUTO_PLACE);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Make it not elastic.
if (!this.parent) setWidth(_this, params.width);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.bind(window, 'resize', function() { _this.onResize() });
dom.bind(this.__ul, 'webkitTransitionEnd', function() { _this.onResize(); });
dom.bind(this.__ul, 'transitionend', function() { _this.onResize() });
dom.bind(this.__ul, 'oTransitionEnd', function() { _this.onResize() });
this.onResize();
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (params.resizable) {
addResizeHandle(this);
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
saveToLocalStorage = function () {
if (SUPPORTS_LOCAL_STORAGE && localStorage.getItem(getLocalStorageHash(_this, 'isLocal')) === 'true') {
localStorage.setItem(getLocalStorageHash(_this, 'gui'), JSON.stringify(_this.getSaveObject()));
}
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// expose this method publicly
this.saveToLocalStorageIfPossible = saveToLocalStorage;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var root = _this.getRoot();
function resetWidth() {
var root = _this.getRoot();
root.width += 1;
common.defer(function() {
root.width -= 1;
});
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (!params.parent) {
resetWidth();
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
GUI.toggleHide = function() {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
hide = !hide;
common.each(hideable_guis, function(gui) {
gui.domElement.style.zIndex = hide ? -999 : 999;
gui.domElement.style.opacity = hide ? 0 : 1;
});
};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
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_DRAG = 'drag';
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
GUI.DEFAULT_WIDTH = 245;
GUI.TEXT_CLOSED = 'Close Controls';
GUI.TEXT_OPEN = 'Open Controls';
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.bind(window, 'keydown', function(e) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (document.activeElement.type !== 'text' &&
(e.which === HIDE_KEY_CODE || e.keyCode == HIDE_KEY_CODE)) {
GUI.toggleHide();
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}, false);
common.extend(
GUI.prototype,
/** @lends dat.gui.GUI */
{
/**
* @param object
* @param property
* @returns {dat.controllers.Controller} The new controller that was added.
* @instance
*/
add: function(object, property) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return add(
this,
object,
property,
{
factoryArgs: Array.prototype.slice.call(arguments, 2)
}
);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/**
* @param object
* @param property
* @returns {dat.controllers.ColorController} The new controller that was added.
* @instance
*/
addColor: function(object, property) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return add(
this,
object,
property,
{
color: true
}
);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/**
* @param controller
* @instance
*/
remove: function(controller) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// TODO listening?
this.__ul.removeChild(controller.__li);
this.__controllers.splice(this.__controllers.indexOf(controller), 1);
var _this = this;
common.defer(function() {
_this.onResize();
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
destroy: function() {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (this.autoPlace) {
auto_place_container.removeChild(this.domElement);
}
},
/**
* @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(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 new_gui_params = { 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.
new_gui_params.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
new_gui_params.closed = this.load.folders[name].closed;
// Pass down the loaded data
new_gui_params.load = this.load.folders[name];
}
var gui = new GUI(new_gui_params);
this.__folders[name] = gui;
var li = addRow(this, gui.domElement);
dom.addClass(li, 'folder');
return gui;
},
open: function() {
this.closed = false;
},
close: function() {
this.closed = true;
},
onResize: function() {
var root = this.getRoot();
if (root.scrollable) {
var top = dom.getOffset(root.__ul).top;
var h = 0;
common.each(root.__ul.childNodes, function(node) {
if (! (root.autoPlace && node === root.__save_row))
h += dom.getHeight(node);
});
if (window.innerHeight - top - CLOSE_BUTTON_HEIGHT < h) {
dom.addClass(root.domElement, GUI.CLASS_TOO_TALL);
root.__ul.style.height = window.innerHeight - top - CLOSE_BUTTON_HEIGHT + 'px';
} else {
dom.removeClass(root.domElement, GUI.CLASS_TOO_TALL);
root.__ul.style.height = 'auto';
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (root.__resize_handle) {
common.defer(function() {
root.__resize_handle.style.height = root.__ul.offsetHeight + 'px';
});
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (root.__closeButton) {
root.__closeButton.style.width = root.width + 'px';
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/**
* 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
*/
remember: function() {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (common.isUndefined(SAVE_DIALOGUE)) {
SAVE_DIALOGUE = new CenteredDiv();
SAVE_DIALOGUE.domElement.innerHTML = saveDialogueContents;
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (this.parent) {
throw new Error("You can only call remember on a top level GUI.");
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var _this = this;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.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);
}
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (this.autoPlace) {
// Set save row width
setWidth(this, this.width);
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/**
* @returns {dat.gui.GUI} the topmost parent GUI of a nested GUI.
* @instance
*/
getRoot: function() {
var gui = this;
while (gui.parent) {
gui = gui.parent;
}
return gui;
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/**
* @returns {Object} a JSON object representing the current state of
* this GUI as well as its remembered properties.
* @instance
*/
getSaveObject: function() {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var toReturn = this.load;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
toReturn.closed = this.closed;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Am I remembering any values?
if (this.__rememberedObjects.length > 0) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
toReturn.preset = this.preset;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (!toReturn.remembered) {
toReturn.remembered = {};
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
toReturn.remembered[this.preset] = getCurrentPreset(this);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
toReturn.folders = {};
common.each(this.__folders, function(element, key) {
toReturn.folders[key] = element.getSaveObject();
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return toReturn;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
save: function() {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (!this.load.remembered) {
this.load.remembered = {};
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.load.remembered[this.preset] = getCurrentPreset(this);
markPresetModified(this, false);
this.saveToLocalStorageIfPossible();
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
saveAs: function(presetName) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (!this.load.remembered) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Retain default values upon first save
this.load.remembered = {};
this.load.remembered[DEFAULT_DEFAULT_PRESET_NAME] = getCurrentPreset(this, true);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.load.remembered[presetName] = getCurrentPreset(this);
this.preset = presetName;
addPresetOption(this, presetName, true);
this.saveToLocalStorageIfPossible();
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
revert: function(gui) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.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);
}
}, this);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.each(this.__folders, function(folder) {
folder.revert(folder);
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (!gui) {
markPresetModified(this.getRoot(), false);
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
listen: function(controller) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var init = this.__listening.length == 0;
this.__listening.push(controller);
if (init) updateDisplays(this.__listening);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function add(gui, object, property, params) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (object[property] === undefined) {
throw new Error("Object " + object + " has no property \"" + property + "\"");
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var controller;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (params.color) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
controller = new ColorController(object, property);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
} else {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var factoryArgs = [object,property].concat(params.factoryArgs);
controller = controllerFactory.apply(gui, factoryArgs);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (params.before instanceof Controller) {
params.before = params.before.__li;
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
recallSavedValue(gui, controller);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.addClass(controller.domElement, 'c');
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var name = document.createElement('span');
dom.addClass(name, 'property-name');
name.innerHTML = controller.property;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var container = document.createElement('div');
container.appendChild(name);
container.appendChild(controller.domElement);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var li = addRow(gui, container, params.before);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.addClass(li, GUI.CLASS_CONTROLLER_ROW);
if (controller instanceof ColorController) {
dom.addClass(li, "color");
} else {
dom.addClass(li, typeof controller.getValue());
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
augmentController(gui, li, controller);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
gui.__controllers.push(controller);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return controller;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/**
* Add a row to the end of the GUI or before another row.
*
* @param gui
* @param [dom] If specified, inserts the dom content in the new row
* @param [liBefore] If specified, places the new row before another row
*/
function addRow(gui, dom, liBefore) {
var li = document.createElement('li');
if (dom) li.appendChild(dom);
if (liBefore) {
gui.__ul.insertBefore(li, params.before);
} else {
gui.__ul.appendChild(li);
}
gui.onResize();
return li;
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function augmentController(gui, li, controller) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
controller.__li = li;
controller.__gui = gui;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.extend(controller, {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
options: function(options) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (arguments.length > 1) {
controller.remove();
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return add(
gui,
controller.object,
controller.property,
{
before: controller.__li.nextElementSibling,
factoryArgs: [common.toArray(arguments)]
}
);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (common.isArray(options) || common.isObject(options)) {
controller.remove();
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return add(
gui,
controller.object,
controller.property,
{
before: controller.__li.nextElementSibling,
factoryArgs: [options]
}
);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
name: function(v) {
controller.__li.firstElementChild.firstElementChild.innerHTML = v;
return controller;
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
listen: function() {
controller.__gui.listen(controller);
return controller;
},
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
remove: function() {
controller.__gui.remove(controller);
return controller;
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// All sliders should be accompanied by a box.
if (controller instanceof NumberControllerSlider) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var box = new NumberControllerBox(controller.object, controller.property,
{ min: controller.__min, max: controller.__max, step: controller.__step });
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.each(['updateDisplay', 'onChange', 'onFinishChange'], function(method) {
var pc = controller[method];
var pb = box[method];
controller[method] = box[method] = function() {
var args = Array.prototype.slice.call(arguments);
pc.apply(controller, args);
return pb.apply(box, args);
}
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.addClass(li, 'has-slider');
controller.domElement.insertBefore(box.domElement, controller.domElement.firstElementChild);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
else if (controller instanceof NumberControllerBox) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var r = function(returned) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Have we defined both boundaries?
if (common.isNumber(controller.__min) && common.isNumber(controller.__max)) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Well, then lets just replace this with a slider.
controller.remove();
return add(
gui,
controller.object,
controller.property,
{
before: controller.__li.nextElementSibling,
factoryArgs: [controller.__min, controller.__max, controller.__step]
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return returned;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
controller.min = common.compose(r, controller.min);
controller.max = common.compose(r, controller.max);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
else if (controller instanceof BooleanController) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.bind(li, 'click', function() {
dom.fakeEvent(controller.__checkbox, 'click');
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.bind(controller.__checkbox, 'click', function(e) {
e.stopPropagation(); // Prevents double-toggle
})
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
else if (controller instanceof FunctionController) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.bind(li, 'click', function() {
dom.fakeEvent(controller.__button, 'click');
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.bind(li, 'mouseover', function() {
dom.addClass(controller.__button, 'hover');
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.bind(li, 'mouseout', function() {
dom.removeClass(controller.__button, 'hover');
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
else if (controller instanceof ColorController) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.addClass(li, 'color');
controller.updateDisplay = common.compose(function(r) {
li.style.borderLeftColor = controller.__color.toString();
return r;
}, controller.updateDisplay);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
controller.updateDisplay();
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
controller.setValue = common.compose(function(r) {
if (gui.getRoot().__preset_select && controller.isModified()) {
markPresetModified(gui.getRoot(), true);
}
return r;
}, controller.setValue);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function recallSavedValue(gui, controller) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Find the topmost GUI, that's where remembered objects live.
var root = gui.getRoot();
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Does the object we're controlling match anything we've been told to
// remember?
var matched_index = root.__rememberedObjects.indexOf(controller.object);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Why yes, it does!
if (matched_index != -1) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Let me fetch a map of controllers for thcommon.isObject.
var controller_map =
root.__rememberedObjectIndecesToControllers[matched_index];
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Ohp, I believe this is the first controller we've created for this
// object. Lets make the map fresh.
if (controller_map === undefined) {
controller_map = {};
root.__rememberedObjectIndecesToControllers[matched_index] =
controller_map;
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Keep track of this controller
controller_map[controller.property] = controller;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Okay, now have we saved any values for this controller?
if (root.load && root.load.remembered) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var preset_map = root.load.remembered;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Which preset are we trying to load?
var preset;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (preset_map[gui.preset]) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
preset = preset_map[gui.preset];
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
} else if (preset_map[DEFAULT_DEFAULT_PRESET_NAME]) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Uhh, you can have the default instead?
preset = preset_map[DEFAULT_DEFAULT_PRESET_NAME];
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
} else {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Nada.
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Did the loaded object remember thcommon.isObject?
if (preset[matched_index] &&
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Did we remember this particular property?
preset[matched_index][controller.property] !== undefined) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// We did remember something for this guy ...
var value = preset[matched_index][controller.property];
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// And that's what it is.
controller.initialValue = value;
controller.setValue(value);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function getLocalStorageHash(gui, key) {
// TODO how does this deal with multiple GUI's?
return document.location.href + '.' + key;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function addSaveMenu(gui) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var div = gui.__save_row = document.createElement('li');
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.addClass(gui.domElement, 'has-save');
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
gui.__ul.insertBefore(div, gui.__ul.firstChild);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.addClass(div, 'save-row');
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var gears = document.createElement('span');
gears.innerHTML = '&nbsp;';
dom.addClass(gears, 'button gears');
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// TODO replace with FunctionController
var button = document.createElement('span');
button.innerHTML = 'Save';
dom.addClass(button, 'button');
dom.addClass(button, 'save');
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var button2 = document.createElement('span');
button2.innerHTML = 'New';
dom.addClass(button2, 'button');
dom.addClass(button2, 'save-as');
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var button3 = document.createElement('span');
button3.innerHTML = 'Revert';
dom.addClass(button3, 'button');
dom.addClass(button3, 'revert');
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var select = gui.__preset_select = document.createElement('select');
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (gui.load && gui.load.remembered) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.each(gui.load.remembered, function(value, key) {
addPresetOption(gui, key, key == gui.preset);
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
} else {
addPresetOption(gui, DEFAULT_DEFAULT_PRESET_NAME, false);
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.bind(select, 'change', function() {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
for (var index = 0; index < gui.__preset_select.length; index++) {
gui.__preset_select[index].innerHTML = gui.__preset_select[index].value;
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
gui.preset = this.value;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
div.appendChild(select);
div.appendChild(gears);
div.appendChild(button);
div.appendChild(button2);
div.appendChild(button3);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (SUPPORTS_LOCAL_STORAGE) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var saveLocally = document.getElementById('dg-save-locally');
var explain = document.getElementById('dg-local-explain');
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
saveLocally.style.display = 'block';
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var localStorageCheckBox = document.getElementById('dg-local-storage');
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (localStorage.getItem(getLocalStorageHash(gui, 'isLocal')) === 'true') {
localStorageCheckBox.setAttribute('checked', 'checked');
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function showHideExplain() {
explain.style.display = gui.useLocalStorage ? 'block' : 'none';
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
showHideExplain();
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// TODO: Use a boolean controller, fool!
dom.bind(localStorageCheckBox, 'change', function() {
gui.useLocalStorage = !gui.useLocalStorage;
showHideExplain();
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var newConstructorTextArea = document.getElementById('dg-new-constructor');
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.bind(newConstructorTextArea, 'keydown', function(e) {
if (e.metaKey && (e.which === 67 || e.keyCode == 67)) {
SAVE_DIALOGUE.hide();
}
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.bind(gears, 'click', function() {
newConstructorTextArea.innerHTML = JSON.stringify(gui.getSaveObject(), undefined, 2);
SAVE_DIALOGUE.show();
newConstructorTextArea.focus();
newConstructorTextArea.select();
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.bind(button, 'click', function() {
gui.save();
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.bind(button2, 'click', function() {
var presetName = prompt('Enter a new preset name.');
if (presetName) gui.saveAs(presetName);
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.bind(button3, 'click', function() {
gui.revert();
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// div.appendChild(button2);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function addResizeHandle(gui) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
gui.__resize_handle = document.createElement('div');
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.extend(gui.__resize_handle.style, {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
width: '6px',
marginLeft: '-3px',
height: '200px',
cursor: 'ew-resize',
position: 'absolute'
// border: '1px solid blue'
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var pmouseX;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.bind(gui.__resize_handle, 'mousedown', dragStart);
dom.bind(gui.__closeButton, 'mousedown', dragStart);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
gui.domElement.insertBefore(gui.__resize_handle, gui.domElement.firstElementChild);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function dragStart(e) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
e.preventDefault();
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
pmouseX = e.clientX;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.addClass(gui.__closeButton, GUI.CLASS_DRAG);
dom.bind(window, 'mousemove', drag);
dom.bind(window, 'mouseup', dragStop);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return false;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function drag(e) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
e.preventDefault();
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
gui.width += pmouseX - e.clientX;
gui.onResize();
pmouseX = e.clientX;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return false;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function dragStop() {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.removeClass(gui.__closeButton, GUI.CLASS_DRAG);
dom.unbind(window, 'mousemove', drag);
dom.unbind(window, 'mouseup', dragStop);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
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';
}
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function getCurrentPreset(gui, useInitialValues) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var toReturn = {};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// For each object I'm remembering
common.each(gui.__rememberedObjects, function(val, index) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var saved_values = {};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// The controllers I've made for thcommon.isObject by property
var controller_map =
gui.__rememberedObjectIndecesToControllers[index];
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Remember each value for each property
common.each(controller_map, function(controller, property) {
saved_values[property] = useInitialValues ? controller.initialValue : controller.getValue();
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Save the values for thcommon.isObject
toReturn[index] = saved_values;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return toReturn;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
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;
}
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
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;
}
}
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
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;
}
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function updateDisplays(controllerArray) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (controllerArray.length != 0) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
requestAnimationFrame(function() {
updateDisplays(controllerArray);
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
common.each(controllerArray, function(c) {
c.updateDisplay();
});
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
module.exports = GUI;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/***/ },
/* 23 */
/***/ function(module, exports) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
module.exports = "<div id=\"dg-save\" class=\"dg dialogue\">\n\n Here's the new load parameter for your <code>GUI</code>'s constructor:\n\n <textarea id=\"dg-new-constructor\"></textarea>\n\n <div id=\"dg-save-locally\">\n\n <input id=\"dg-local-storage\" type=\"checkbox\"/> Automatically save\n values to <code>localStorage</code> on exit.\n\n <div id=\"dg-local-explain\">The values saved to <code>localStorage</code> will\n override those passed to <code>dat.GUI</code>'s constructor. This makes it\n easier to work incrementally, but <code>localStorage</code> is fragile,\n and your friends may not see the same values you do.\n \n </div>\n \n </div>\n\n</div>";
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/***/ },
/* 24 */
/***/ function(module, exports, __webpack_require__) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// style-loader: Adds some css to the DOM by adding a <style> tag
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// load the styles
var content = __webpack_require__(25);
if(typeof content === 'string') content = [[module.id, content, '']];
// add the styles to the DOM
var update = __webpack_require__(19)(content, {});
if(content.locals) module.exports = content.locals;
// Hot Module Replacement
if(false) {
// When the styles change, update the <style> tags
if(!content.locals) {
module.hot.accept("!!./../../../node_modules/css-loader/index.js!./style.css", function() {
var newContent = require("!!./../../../node_modules/css-loader/index.js!./style.css");
if(typeof newContent === 'string') newContent = [[module.id, newContent, '']];
update(newContent);
});
}
// When the module is disposed, remove the <style> tags
module.hot.dispose(function() { update(); });
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/***/ },
/* 25 */
/***/ function(module, exports, __webpack_require__) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
exports = module.exports = __webpack_require__(18)();
// imports
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// module
exports.push([module.id, ".dg {\n /** Clear list styles */\n /* Auto-place container */\n /* Auto-placed GUI's */\n /* Line items that don't contain folders. */\n /** Folder names */\n /** Hides closed items */\n /** Controller row */\n /** Name-half (left) */\n /** Controller-half (right) */\n /** Controller placement */\n /** Shorter number boxes when slider is present. */\n /** Ensure the entire boolean and function row shows a hand */ }\n .dg ul {\n list-style: none;\n margin: 0;\n padding: 0;\n width: 100%;\n clear: both; }\n .dg.ac {\n position: fixed;\n top: 0;\n left: 0;\n right: 0;\n height: 0;\n z-index: 0; }\n .dg:not(.ac) .main {\n /** Exclude mains in ac so that we don't hide close button */\n overflow: hidden; }\n .dg.main {\n -webkit-transition: opacity 0.1s linear;\n -o-transition: opacity 0.1s linear;\n -moz-transition: opacity 0.1s linear;\n transition: opacity 0.1s linear; }\n .dg.main.taller-than-window {\n overflow-y: auto; }\n .dg.main.taller-than-window .close-button {\n opacity: 1;\n /* TODO, these are style notes */\n margin-top: -1px;\n border-top: 1px solid #2c2c2c; }\n .dg.main ul.closed .close-button {\n opacity: 1 !important; }\n .dg.main:hover .close-button,\n .dg.main .close-button.drag {\n opacity: 1; }\n .dg.main .close-button {\n /*opacity: 0;*/\n -webkit-transition: opacity 0.1s linear;\n -o-transition: opacity 0.1s linear;\n -moz-transition: opacity 0.1s linear;\n transition: opacity 0.1s linear;\n border: 0;\n position: absolute;\n line-height: 19px;\n height: 20px;\n /* TODO, these are style notes */\n cursor: pointer;\n text-align: center;\n background-color: #000; }\n .dg.main .close-button:hover {\n background-color: #111; }\n .dg.a {\n float: right;\n margin-right: 15px;\n overflow-x: hidden; }\n .dg.a.has-save > ul {\n margin-top: 27px; }\n .dg.a.has-save > ul.closed {\n margin-top: 0; }\n .dg.a .save-row {\n position: fixed;\n top: 0;\n z-index: 1002; }\n .dg li {\n -webkit-transition: height 0.1s ease-out;\n -o-transition: height 0.1s ease-out;\n -moz-transition: height 0.1s ease-out;\n transition: height 0.1s ease-out; }\n .dg li:not(.folder) {\n cursor: auto;\n height: 27px;\n line-height: 27px;\n overflow: hidden;\n padding: 0 4px 0 5px; }\n .dg li.folder {\n padding: 0;\n border-left: 4px solid rgba(0, 0, 0, 0); }\n .dg li.title {\n cursor: pointer;\n margin-left: -4px; }\n .dg .closed li:not(.title),\n .dg .closed ul li,\n .dg .closed ul li > * {\n height: 0;\n overflow: hidden;\n border: 0; }\n .dg .cr {\n clear: both;\n padding-left: 3px;\n height: 27px; }\n .dg .property-name {\n cursor: default;\n float: left;\n clear: left;\n width: 40%;\n overflow: hidden;\n text-overflow: ellipsis; }\n .dg .c {\n float: left;\n width: 60%; }\n .dg .c input[type=text] {\n border: 0;\n margin-top: 4px;\n padding: 3px;\n width: 100%;\n float: right; }\n .dg .has-slider input[type=text] {\n width: 30%;\n /*display: none;*/\n margin-left: 0; }\n .dg .slider {\n float: left;\n width: 66%;\n margin-left: -5px;\n margin-right: 0;\n height: 19px;\n margin-top: 4px; }\n .dg .slider-fg {\n height: 100%; }\n .dg .c input[type=checkbox] {\n margin-top: 9px; }\n .dg .c select {\n margin-top: 5px; }\n .dg .cr.function,\n .dg .cr.function .property-name,\n .dg .cr.function *,\n .dg .cr.boolean,\n .dg .cr.boolean * {\n cursor: pointer; }\n .dg .selector {\n display: none;\n position: absolute;\n margin-left: -9px;\n margin-top: 23px;\n z-index: 10; }\n .dg .c:hover .selector,\n .dg .selector.drag {\n display: block; }\n .dg li.save-row {\n padding: 0; }\n .dg li.save-row .button {\n display: inline-block;\n padding: 0px 6px; }\n .dg.dialogue {\n backg
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// exports
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/***/ },
/* 26 */
/***/ function(module, exports, __webpack_require__) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/**
* 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
*/
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var OptionController = __webpack_require__(10),
NumberControllerBox = __webpack_require__(13),
NumberControllerSlider = __webpack_require__(14),
StringController = __webpack_require__(11),
FunctionController = __webpack_require__(20),
BooleanController = __webpack_require__(8),
common = __webpack_require__(5);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
module.exports = function(object, property) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var initialValue = object[property];
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Providing options?
if (common.isArray(arguments[2]) || common.isObject(arguments[2])) {
return new OptionController(object, property, arguments[2]);
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
// Providing a map?
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (common.isNumber(initialValue)) {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
if (common.isNumber(arguments[2]) && common.isNumber(arguments[3])) {
// Has min and max.
return new NumberControllerSlider(object, property, arguments[2], arguments[3]);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
} else {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
return new NumberControllerBox(object, property, { min: arguments[2], max: arguments[3] });
}
}
if (common.isString(initialValue)) {
return new StringController(object, property);
}
if (common.isFunction(initialValue)) {
return new FunctionController(object, property, '');
}
if (common.isBoolean(initialValue)) {
return new BooleanController(object, property);
}
};
/***/ },
/* 27 */
/***/ function(module, exports) {
/**
* dat-gui JavaScript Controller Library
* http://code.google.com/p/dat-gui
*
* Copyright 2011 Data Arts Team, Google Creative Lab
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*/
module.exports = function () {
return window.requestAnimationFrame ||
window.webkitRequestAnimationFrame ||
window.mozRequestAnimationFrame ||
window.oRequestAnimationFrame ||
window.msRequestAnimationFrame ||
function (callback, element) {
window.setTimeout(callback, 1000 / 60);
};
};
/***/ },
/* 28 */
/***/ function(module, exports, __webpack_require__) {
/**
* dat-gui JavaScript Controller Library
* http://code.google.com/p/dat-gui
*
* Copyright 2011 Data Arts Team, Google Creative Lab
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*/
var dom = __webpack_require__(9),
common = __webpack_require__(5);
var CenteredDiv = function() {
this.backgroundElement = document.createElement('div');
common.extend(this.backgroundElement.style, {
backgroundColor: 'rgba(0,0,0,0.8)',
top: 0,
left: 0,
display: 'none',
zIndex: '1000',
opacity: 0,
WebkitTransition: 'opacity 0.2s linear',
transition: 'opacity 0.2s linear'
});
dom.makeFullscreen(this.backgroundElement);
this.backgroundElement.style.position = 'fixed';
this.domElement = document.createElement('div');
common.extend(this.domElement.style, {
position: 'fixed',
display: 'none',
zIndex: '1001',
opacity: 0,
WebkitTransition: '-webkit-transform 0.2s ease-out, opacity 0.2s linear',
transition: 'transform 0.2s ease-out, opacity 0.2s linear'
});
document.body.appendChild(this.backgroundElement);
document.body.appendChild(this.domElement);
var _this = this;
dom.bind(this.backgroundElement, 'click', function() {
_this.hide();
});
};
CenteredDiv.prototype.show = function() {
var _this = this;
this.backgroundElement.style.display = 'block';
this.domElement.style.display = 'block';
this.domElement.style.opacity = 0;
// this.domElement.style.top = '52%';
this.domElement.style.webkitTransform = 'scale(1.1)';
this.layout();
common.defer(function() {
_this.backgroundElement.style.opacity = 1;
_this.domElement.style.opacity = 1;
_this.domElement.style.webkitTransform = 'scale(1)';
});
};
CenteredDiv.prototype.hide = function() {
var _this = this;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
var hide = function() {
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
_this.domElement.style.display = 'none';
_this.backgroundElement.style.display = 'none';
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.unbind(_this.domElement, 'webkitTransitionEnd', hide);
dom.unbind(_this.domElement, 'transitionend', hide);
dom.unbind(_this.domElement, 'oTransitionEnd', hide);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
dom.bind(this.domElement, 'webkitTransitionEnd', hide);
dom.bind(this.domElement, 'transitionend', hide);
dom.bind(this.domElement, 'oTransitionEnd', hide);
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
this.backgroundElement.style.opacity = 0;
// this.domElement.style.top = '48%';
this.domElement.style.opacity = 0;
this.domElement.style.webkitTransform = 'scale(1.1)';
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
CenteredDiv.prototype.layout = function() {
this.domElement.style.left = window.innerWidth/2 - dom.getWidth(this.domElement) / 2 + 'px';
this.domElement.style.top = window.innerHeight/2 - dom.getHeight(this.domElement) / 2 + 'px';
};
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
function lockScroll(e) {
console.log(e);
}
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
module.exports = CenteredDiv;
2013-12-18 23:27:02 +00:00
2015-08-14 13:24:30 +00:00
/***/ }
/******/ ])
});
;