diff --git a/addon/codemirror-colorpicker.css b/addon/codemirror-colorpicker.css
index 8b10ff8..27bdddc 100644
--- a/addon/codemirror-colorpicker.css
+++ b/addon/codemirror-colorpicker.css
@@ -171,8 +171,9 @@
position: absolute;
cursor: pointer;
top: 50% !important;
- margin-top: -7px !important;
- left: -3px;
+ left: 0px;
+ -webkit-transform: translateX(-50%) translateY(-50%);
+ transform: translateX(-50%) translateY(-50%);
width: 12px;
height: 12px;
border-radius: 50px; }
@@ -550,13 +551,21 @@
border-radius: 0px; }
.codemirror-colorpicker.sketch > .control .drag-bar, .codemirror-colorpicker.sketch > .control .drag-bar2 {
border-radius: 0px;
- top: 0px !important;
- left: -2px;
- margin-top: 1px !important;
+ top: 50%;
+ left: 0px;
width: 2px;
- height: auto;
+ height: 50%;
+ -webkit-transform: translateX(-50%) translateY(-50%);
+ transform: translateX(-50%) translateY(-50%);
border-radius: 1px;
bottom: 1px !important; }
+ .codemirror-colorpicker.sketch > .control .drag-bar.first, .codemirror-colorpicker.sketch > .control .drag-bar2.first {
+ left: 0px;
+ -webkit-transform: translateX(50%) translateY(-50%) !important;
+ transform: translateX(50%) translateY(-50%) !important; }
+ .codemirror-colorpicker.sketch > .control .drag-bar.last, .codemirror-colorpicker.sketch > .control .drag-bar2.last {
+ -webkit-transform: translateX(-150%) translateY(-50%) !important;
+ transform: translateX(-150%) translateY(-50%) !important; }
.codemirror-colorpicker.sketch > .information .information-change {
display: none; }
.codemirror-colorpicker.sketch > .information.rgb .information-item.rgb {
diff --git a/addon/codemirror-colorpicker.js b/addon/codemirror-colorpicker.js
index ee22e0c..fbba0dc 100644
--- a/addon/codemirror-colorpicker.js
+++ b/addon/codemirror-colorpicker.js
@@ -4997,8 +4997,7 @@ var color = {
*/
contrast: function contrast(c) {
c = this.parse(c);
- var contrast = (Math.round(c.r * 299) + Math.round(c.g * 587) + Math.round(c.b * 114)) / 1000;
- return contrast;
+ return (Math.round(c.r * 299) + Math.round(c.g * 587) + Math.round(c.b * 114)) / 1000;
},
contrastColor: function contrastColor(c) {
return this.contrast(c) >= 128 ? 'black' : 'white';
@@ -5456,6 +5455,8 @@ var Dom = function () {
key: 'removeClass',
value: function removeClass(cls) {
this.el.className = (' ' + this.el.className + ' ').replace(' ' + cls + ' ', ' ').trim();
+
+ return this;
}
}, {
key: 'hasClass',
@@ -5473,6 +5474,8 @@ var Dom = function () {
if (!this.hasClass(cls)) {
this.el.className = this.el.className + ' ' + cls;
}
+
+ return this;
}
}, {
key: 'toggleClass',
@@ -5495,6 +5498,16 @@ var Dom = function () {
return this;
}
+ }, {
+ key: 'find',
+ value: function find(selector) {
+ return this.el.querySelector(selector);
+ }
+ }, {
+ key: 'findAll',
+ value: function findAll(selector) {
+ return this.el.querySelectorAll(selector);
+ }
}, {
key: 'empty',
value: function empty() {
@@ -5728,6 +5741,11 @@ var Dom = function () {
return $element;
}
+ }, {
+ key: 'firstChild',
+ value: function firstChild() {
+ return new Dom(this.el.firstElementChild);
+ }
}]);
return Dom;
}();
@@ -5775,7 +5793,7 @@ var State = function () {
var arr = key.split(DELEGATE_SPLIT);
- var obj = this.masterObj[arr[0]] || this.masterObj;
+ var obj = this.masterObj.refs[arr[0]] || this.masterObj[arr[0]] || this.masterObj;
var method = arr.pop();
if (obj[method]) {
@@ -5817,9 +5835,22 @@ var EventMachin = function () {
classCallCheck(this, EventMachin);
this.state = new State(this);
+ this.refs = {};
}
createClass(EventMachin, [{
+ key: 'template',
+ value: function template(html) {
+ var _this = this;
+
+ this.$el = new Dom("div").html(html).firstChild();
+ var refs = this.$el.findAll("[ref]");
+ [].concat(toConsumableArray(refs)).forEach(function (node) {
+ _this.refs[node.getAttribute("ref")] = new Dom(node);
+ });
+ this.refs.$el = this.$el;
+ }
+ }, {
key: 'initializeEvent',
value: function initializeEvent() {
this.initializeEventMachin();
@@ -5828,6 +5859,7 @@ var EventMachin = function () {
key: 'destroy',
value: function destroy() {
this.destroyEventMachin();
+ // this.refs = {}
}
}, {
key: 'destroyEventMachin',
@@ -5859,7 +5891,7 @@ var EventMachin = function () {
var el = void 0;
if (dom) {
- el = this[dom] || window[dom];
+ el = this.refs[dom] || this[dom] || window[dom];
} else {
el = this.el || this.$el || this.$root;
}
@@ -5873,7 +5905,7 @@ var EventMachin = function () {
}, {
key: 'getDefaultEventObject',
value: function getDefaultEventObject(eventName) {
- var _this = this;
+ var _this2 = this;
var arr = eventName.split('.');
var realEventName = arr.shift();
@@ -5888,7 +5920,7 @@ var EventMachin = function () {
});
var checkMethodList = arr.filter(function (code) {
- return !!_this[code];
+ return !!_this2[code];
});
arr = arr.filter(function (code) {
@@ -5957,7 +5989,7 @@ var EventMachin = function () {
}, {
key: 'checkEventType',
value: function checkEventType(e, eventObject) {
- var _this2 = this;
+ var _this3 = this;
var onlyControl = e.ctrlKey ? eventObject.isControl : true;
var onlyShift = e.shiftKey ? eventObject.isShift : true;
@@ -5973,7 +6005,7 @@ var EventMachin = function () {
if (eventObject.checkMethodList.length) {
// 체크 메소드들은 모든 메소드를 다 적용해야한다.
isAllCheck = eventObject.checkMethodList.every(function (method) {
- return _this2[method].call(_this2, e);
+ return _this3[method].call(_this3, e);
});
}
@@ -5982,13 +6014,13 @@ var EventMachin = function () {
}, {
key: 'makeCallback',
value: function makeCallback(eventObject, callback) {
- var _this3 = this;
+ var _this4 = this;
if (eventObject.delegate) {
return function (e) {
- if (_this3.checkEventType(e, eventObject)) {
- var delegateTarget = _this3.matchPath(e.target || e.srcElement, eventObject.delegate);
+ if (_this4.checkEventType(e, eventObject)) {
+ var delegateTarget = _this4.matchPath(e.target || e.srcElement, eventObject.delegate);
if (delegateTarget) {
// delegate target 이 있는 경우만 callback 실행
@@ -6000,7 +6032,7 @@ var EventMachin = function () {
};
} else {
return function (e) {
- if (_this3.checkEventType(e, eventObject)) {
+ if (_this4.checkEventType(e, eventObject)) {
return callback(e);
}
};
@@ -6016,10 +6048,10 @@ var EventMachin = function () {
}, {
key: 'removeEventAll',
value: function removeEventAll() {
- var _this4 = this;
+ var _this5 = this;
this.getBindings().forEach(function (obj) {
- _this4.removeEvent(obj);
+ _this5.removeEvent(obj);
});
this.initBindings();
}
@@ -6036,346 +6068,712 @@ var EventMachin = function () {
return EventMachin;
}();
-var ColorControl = function (_EventMachin) {
- inherits(ColorControl, _EventMachin);
+var colorSetsList = [{
+ name: "Material",
+ colors: ['#F44336', '#E91E63', '#9C27B0', '#673AB7', '#3F51B5', '#2196F3', '#03A9F4', '#00BCD4', '#009688', '#4CAF50', '#8BC34A', '#CDDC39', '#FFEB3B', '#FFC107', '#FF9800', '#FF5722', '#795548', '#9E9E9E', '#607D8B']
+}, {
+ name: "Custom", "edit": true, "colors": []
+}, {
+ name: "Color Scale", "scale": ['red', 'yellow', 'black'], count: 5
+}];
- function ColorControl(colorpicker) {
- classCallCheck(this, ColorControl);
+var ColorSetsList = function () {
+ function ColorSetsList(colorpicker) {
+ classCallCheck(this, ColorSetsList);
- var _this = possibleConstructorReturn(this, (ColorControl.__proto__ || Object.getPrototypeOf(ColorControl)).call(this));
+ this.colorpicker = colorpicker;
- _this.colorpicker = colorpicker;
- _this.initialize();
- return _this;
+ this.setUserList(this.colorpicker.getOption('colorSets'));
}
- createClass(ColorControl, [{
- key: 'initialize',
- value: function initialize() {
- this.$el = new Dom('div', 'control');
- this.$hue = this.$el.createChild('div', 'hue');
- this.$opacity = this.$el.createChild('div', 'opacity');
- this.$controlPattern = this.$el.createChild('div', 'empty');
- this.$controlColor = this.$el.createChild('div', 'color');
-
- this.$hueContainer = this.$hue.createChild('div', 'hue-container');
- this.$drag_bar = this.$hueContainer.createChild('div', 'drag-bar');
- this.drag_bar_pos = {};
-
- this.$opacityContainer = this.$opacity.createChild('div', 'opacity-container');
- this.$opacityColorBar = this.$opacityContainer.createChild('div', 'color-bar');
-
- this.$opacity_drag_bar = this.$opacityContainer.createChild('div', 'drag-bar2');
- this.opacity_drag_bar_pos = {};
- }
- }, {
- key: 'setBackgroundColor',
- value: function setBackgroundColor(color$$1) {
- this.$controlColor.css("background-color", color$$1);
- }
- }, {
- key: 'refresh',
- value: function refresh() {
- this.setColorUI();
+ createClass(ColorSetsList, [{
+ key: 'list',
+ value: function list() {
+ return this.userList || colorSetsList;
}
}, {
- key: 'setColorUI',
- value: function setColorUI() {
+ key: 'setUserList',
+ value: function setUserList(list) {
+ this.userList = list;
- var x = this.state.get('$el.width') * this.colorpicker.currentS,
- y = this.state.get('$el.height') * (1 - this.colorpicker.currentV);
+ this.resetUserList();
- this.$drag_pointer.css({
- left: x + "px",
- top: y + "px"
- });
+ this.setCurrentColorSets();
}
}, {
- key: 'setOpacityColorBar',
- value: function setOpacityColorBar(hueColor) {
- var rgb = color.parse(hueColor);
+ key: 'resetUserList',
+ value: function resetUserList() {
+ var _this = this;
- rgb.a = 0;
- var start = color.format(rgb, 'rgb');
+ if (this.userList && this.userList.length) {
+ this.userList = this.userList.map(function (element, index) {
- rgb.a = 1;
- var end = color.format(rgb, 'rgb');
+ if (typeof element.colors == 'function') {
+ var makeCallback = element.colors;
- this.$opacityColorBar.css('background', 'linear-gradient(to right, ' + start + ', ' + end + ')');
- }
- }, {
- key: 'setOpacity',
- value: function setOpacity(e) {
- var min = this.$opacityContainer.offset().left;
- var max = min + this.state.get('$opacityContainer.width');
- var current = Event.pos(e).clientX;
- var dist;
+ element.colors = makeCallback(_this.colorpicker, _this);
+ element._colors = makeCallback;
+ }
- if (current < min) {
- dist = 0;
- } else if (current > max) {
- dist = 100;
- } else {
- dist = (current - min) / (max - min) * 100;
+ return Object.assign({
+ name: 'color-' + index,
+ colors: []
+ }, element);
+ });
}
-
- var x = this.state.get('$opacityContainer.width') * (dist / 100);
-
- this.$opacity_drag_bar.css({
- left: x - Math.ceil(this.state.get('$opacity_drag_bar.width') / 2) + 'px'
- });
-
- this.opacity_drag_bar_pos = { x: x };
-
- this.colorpicker.setCurrentA(this.caculateOpacity());
- this.colorpicker.currentFormat();
- this.colorpicker.setInputColor();
- }
- }, {
- key: 'setInputColor',
- value: function setInputColor() {
- this.setBackgroundColor(this.colorpicker.getFormattedColor('rgb'));
-
- var rgb = this.colorpicker.convertRGB();
- var colorString = color.format(rgb, 'rgb');
- this.setOpacityColorBar(colorString);
}
}, {
- key: 'setColorUI',
- value: function setColorUI() {
-
- var hueX = this.state.get('$hueContainer.width') * (this.colorpicker.currentH / 360);
-
- this.$drag_bar.css({
- left: hueX - 7.5 + 'px'
- });
-
- this.drag_bar_pos = { x: hueX };
-
- var opacityX = this.state.get('$opacityContainer.width') * (this.colorpicker.currentA || 0);
+ key: 'setCurrentColorSets',
+ value: function setCurrentColorSets(nameOrIndex) {
- this.$opacity_drag_bar.css({
- left: opacityX - 7.5 + 'px'
- });
+ var _list = this.list();
- this.opacity_drag_bar_pos = { x: opacityX };
+ if (typeof nameOrIndex == 'undefined') {
+ this.currentColorSets = _list[0];
+ } else if (typeof nameOrIndex == 'number') {
+ this.currentColorSets = _list[nameOrIndex];
+ } else {
+ this.currentColorSets = _list.filter(function (obj) {
+ return obj.name == nameOrIndex;
+ })[0];
+ }
}
}, {
- key: 'caculateH',
- value: function caculateH() {
-
- var huePos = this.drag_bar_pos || { x: 0 };
-
- var h = huePos.x / this.state.get('$hueContainer.width') * 360;
-
- return { h: h };
+ key: 'getCurrentColorSets',
+ value: function getCurrentColorSets() {
+ return this.currentColorSets;
}
}, {
- key: 'caculateOpacity',
- value: function caculateOpacity() {
- var opacityPos = this.opacity_drag_bar_pos || { x: 0 };
- var a = Math.round(opacityPos.x / this.state.get('$opacityContainer.width') * 100) / 100;
-
- return isNaN(a) ? 1 : a;
+ key: 'addCurrentColor',
+ value: function addCurrentColor(color$$1) {
+ if (Array.isArray(this.currentColorSets.colors)) {
+ this.currentColorSets.colors.push(color$$1);
+ }
}
}, {
- key: 'EventDocumentMouseMove',
- value: function EventDocumentMouseMove(e) {
- if (this.isHueDown) {
- this.setHueColor(e);
+ key: 'removeCurrentColor',
+ value: function removeCurrentColor(index) {
+ if (this.currentColorSets.colors[index]) {
+ this.currentColorSets.colors.splice(index, 1);
}
-
- if (this.isOpacityDown) {
- this.setOpacity(e);
+ }
+ }, {
+ key: 'removeCurrentColorToTheRight',
+ value: function removeCurrentColorToTheRight(index) {
+ if (this.currentColorSets.colors[index]) {
+ this.currentColorSets.colors.splice(index, Number.MAX_VALUE);
}
}
}, {
- key: 'EventDocumentMouseUp',
- value: function EventDocumentMouseUp(e) {
- this.isHueDown = false;
- this.isOpacityDown = false;
+ key: 'clearPalette',
+ value: function clearPalette() {
+ if (this.currentColorSets.colors) {
+ this.currentColorSets.colors = [];
+ }
}
}, {
- key: 'setControlColor',
- value: function setControlColor(color$$1) {
- this.$controlColor.css('background-color', color$$1);
+ key: 'getCurrentColors',
+ value: function getCurrentColors() {
+ return this.getColors(this.currentColorSets);
}
}, {
- key: 'setHueColor',
- value: function setHueColor(e) {
- var min = this.$hueContainer.offset().left;
- var max = min + this.state.get('$hueContainer.width');
- var current = e ? Event.pos(e).clientX : min + (max - min) * (this.colorpicker.currentH / 360);
+ key: 'getColors',
+ value: function getColors(element) {
- var dist;
- if (current < min) {
- dist = 0;
- } else if (current > max) {
- dist = 100;
- } else {
- dist = (current - min) / (max - min) * 100;
+ if (element.scale) {
+ return color.scale(element.scale, element.count);
}
- var x = this.state.get('$hueContainer.width') * (dist / 100);
+ return element.colors || [];
+ }
+ }, {
+ key: 'getColorSetsList',
+ value: function getColorSetsList() {
+ var _this2 = this;
- this.$drag_bar.css({
- left: x - Math.ceil(this.state.get('$drag_bar.width') / 2) + 'px'
+ return this.list().map(function (element) {
+ return {
+ name: element.name,
+ edit: element.edit,
+ colors: _this2.getColors(element)
+ };
});
-
- this.drag_bar_pos = { x: x };
-
- var hueColor = HueColor.checkHueColor(dist / 100);
-
- this.colorpicker.setBackgroundColor(hueColor);
- this.colorpicker.setCurrentH(dist / 100 * 360);
- this.colorpicker.setInputColor();
}
}, {
- key: 'setOnlyHueColor',
- value: function setOnlyHueColor() {
- var min = this.$hueContainer.offset().left;
- var max = min + this.state.get('$hueContainer.width');
- var current = min + (max - min) * (this.colorpicker.currentH / 360);
+ key: 'destroy',
+ value: function destroy() {}
+ }]);
+ return ColorSetsList;
+}();
- var dist;
- if (current < min) {
- dist = 0;
- } else if (current > max) {
- dist = 100;
- } else {
- dist = (current - min) / (max - min) * 100;
- }
+var BaseColorPicker = function (_EventMachin) {
+ inherits(BaseColorPicker, _EventMachin);
- var x = this.state.get('$hueContainer.width') * (dist / 100);
+ function BaseColorPicker(opt) {
+ classCallCheck(this, BaseColorPicker);
- this.$drag_bar.css({
- left: x - Math.ceil(this.state.get('$drag_bar.width') / 2) + 'px'
+ var _this = possibleConstructorReturn(this, (BaseColorPicker.__proto__ || Object.getPrototypeOf(BaseColorPicker)).call(this));
+
+ _this.opt = opt || {};
+ _this.$body = null;
+ _this.$root = null;
+
+ _this.format = 'rgb';
+ _this.currentA = 0;
+ _this.currentH = 0;
+ _this.currentS = 0;
+ _this.currentV = 0;
+
+ _this.colorSetsList = new ColorSetsList(_this);
+ _this.colorpickerCallback = function () {};
+
+ _this.isColorPickerShow = false;
+ _this.isShortCut = false;
+ _this.hideDelay = _this.opt.hideDeplay || 2000;
+ _this.timerCloseColorPicker;
+ _this.autoHide = _this.opt.autoHide || true;
+
+ return _this;
+ }
+
+ createClass(BaseColorPicker, [{
+ key: 'initialize',
+ value: function initialize() {
+
+ this.$body = new Dom(this.getContainer());
+ this.$root = new Dom('div', 'codemirror-colorpicker');
+
+ // append colorpicker to container (ex : body)
+ if (this.opt.position == 'inline') {
+ this.$body.append(this.$root);
+ }
+
+ if (this.opt.type) {
+ // to change css style
+ this.$root.addClass(this.opt.type);
+ }
+
+ this.$arrow = new Dom('div', 'arrow');
+
+ this.$root.append(this.$arrow);
+ }
+ }, {
+ key: 'getOption',
+ value: function getOption(key) {
+ return this.opt[key];
+ }
+ }, {
+ key: 'setOption',
+ value: function setOption(key, value) {
+ this.opt[key] = value;
+ }
+ }, {
+ key: 'isType',
+ value: function isType(key) {
+ return this.getOption('type') == key;
+ }
+ }, {
+ key: 'isPaletteType',
+ value: function isPaletteType() {
+ return this.isType('palette');
+ }
+ }, {
+ key: 'isSketchType',
+ value: function isSketchType() {
+ return this.isType('sketch');
+ }
+ }, {
+ key: 'getContainer',
+ value: function getContainer() {
+ return this.opt.container || document.body;
+ }
+ }, {
+ key: 'getColor',
+ value: function getColor(type) {
+ this.caculateHSV();
+ var rgb = this.convertRGB();
+
+ if (type) {
+ return color.format(rgb, type);
+ }
+
+ return rgb;
+ }
+ }, {
+ key: 'definePositionForArrow',
+ value: function definePositionForArrow(opt, elementScreenLeft, elementScreenTop) {
+ //this.$arrow.css({})
+ }
+ }, {
+ key: 'definePosition',
+ value: function definePosition(opt) {
+
+ var width = this.$root.width();
+ var height = this.$root.height();
+
+ // set left position for color picker
+ var elementScreenLeft = opt.left - this.$body.scrollLeft();
+ if (width + elementScreenLeft > window.innerWidth) {
+ elementScreenLeft -= width + elementScreenLeft - window.innerWidth;
+ }
+ if (elementScreenLeft < 0) {
+ elementScreenLeft = 0;
+ }
+
+ // set top position for color picker
+ var elementScreenTop = opt.top - this.$body.scrollTop();
+ if (height + elementScreenTop > window.innerHeight) {
+ elementScreenTop -= height + elementScreenTop - window.innerHeight;
+ }
+ if (elementScreenTop < 0) {
+ elementScreenTop = 0;
+ }
+
+ // set position
+ this.$root.css({
+ left: elementScreenLeft + 'px',
+ top: elementScreenTop + 'px'
+ });
+ }
+ }, {
+ key: 'getInitalizePosition',
+ value: function getInitalizePosition() {
+ if (this.opt.position == 'inline') {
+ return {
+ position: 'relative',
+ left: 'auto',
+ top: 'auto',
+ display: 'inline-block'
+ };
+ } else {
+ return {
+ position: 'fixed', // color picker has fixed position
+ left: '-10000px',
+ top: '-10000px'
+ };
+ }
+ }
+ }, {
+ key: 'show',
+ value: function show(opt, color$$1, callback) {
+ this.destroy();
+ this.initializeEvent();
+ this.$root.appendTo(this.$body);
+
+ this.$root.css(this.getInitalizePosition()).show();
+
+ this.definePosition(opt);
+
+ this.isColorPickerShow = true;
+
+ this.isShortCut = opt.isShortCut || false;
+
+ this.initColor(color$$1);
+
+ // define colorpicker callback
+ this.colorpickerCallback = callback;
+
+ // define hide delay
+ this.hideDelay = opt.hideDelay || 2000;
+ if (this.hideDelay > 0) {
+ this.setHideDelay(this.hideDelay);
+ }
+ }
+ }, {
+ key: 'setHideDelay',
+ value: function setHideDelay(delayTime) {
+ var _this2 = this;
+
+ delayTime = delayTime || 0;
+
+ this.$root.off('mouseenter');
+ this.$root.off('mouseleave');
+
+ this.$root.on('mouseenter', function () {
+ clearTimeout(_this2.timerCloseColorPicker);
});
- this.drag_bar_pos = { x: x };
+ this.$root.on('mouseleave', function () {
+ clearTimeout(_this2.timerCloseColorPicker);
+ _this2.timerCloseColorPicker = setTimeout(_this2.hide.bind(_this2), delayTime);
+ });
- var hueColor = HueColor.checkHueColor(dist / 100);
- this.colorpicker.setBackgroundColor(hueColor);
- this.colorpicker.setCurrentH(dist / 100 * 360);
+ clearTimeout(this.timerCloseColorPicker);
+ this.timerCloseColorPicker = setTimeout(this.hide.bind(this), delayTime);
}
}, {
- key: 'mousedown $drag_bar',
- value: function mousedown$drag_bar(e) {
- e.preventDefault();
- this.isHueDown = true;
+ key: 'hide',
+ value: function hide() {
+ if (this.isColorPickerShow) {
+ this.destroy();
+ this.$root.hide();
+ this.$root.remove(); // not empty
+ this.isColorPickerShow = false;
+ }
}
}, {
- key: 'mousedown $opacity_drag_bar',
- value: function mousedown$opacity_drag_bar(e) {
- e.preventDefault();
- this.isOpacityDown = true;
+ key: 'convertRGB',
+ value: function convertRGB() {
+ return color.HSVtoRGB(this.currentH, this.currentS, this.currentV);
}
}, {
- key: 'mousedown $hueContainer',
- value: function mousedown$hueContainer(e) {
- this.isHueDown = true;
- this.setHueColor(e);
+ key: 'convertHEX',
+ value: function convertHEX() {
+ return color.format(this.convertRGB(), 'hex');
}
}, {
- key: 'mousedown $opacityContainer',
- value: function mousedown$opacityContainer(e) {
- this.isOpacityDown = true;
- this.setOpacity(e);
+ key: 'convertHSL',
+ value: function convertHSL() {
+ return color.HSVtoHSL(this.currentH, this.currentS, this.currentV);
+ }
+ }, {
+ key: 'getFormattedColor',
+ value: function getFormattedColor(format) {
+ format = format || 'hex';
+
+ if (format == 'rgb') {
+ var rgb = this.convertRGB();
+ rgb.a = this.currentA;
+ return color.format(rgb, 'rgb');
+ } else if (format == 'hsl') {
+ var hsl = this.convertHSL();
+ hsl.a = this.currentA;
+ return color.format(hsl, 'hsl');
+ } else {
+ var rgb = this.convertRGB();
+ return color.format(rgb, 'hex');
+ }
+ }
+ }, {
+ key: 'callbackColorValue',
+ value: function callbackColorValue(color$$1) {
+
+ if (!isNaN(this.currentA)) {
+ if (typeof this.opt.onChange == 'function') {
+ this.opt.onChange.call(this, color$$1);
+ }
+
+ if (typeof this.colorpickerCallback == 'function') {
+ this.colorpickerCallback(color$$1);
+ }
+ }
+ }
+ }, {
+ key: 'setCurrentHSV',
+ value: function setCurrentHSV(h, s, v, a) {
+ this.currentA = a;
+ this.currentH = h;
+ this.currentS = s;
+ this.currentV = v;
+ }
+ }, {
+ key: 'setCurrentH',
+ value: function setCurrentH(h) {
+ this.currentH = h;
+ }
+ }, {
+ key: 'setCurrentA',
+ value: function setCurrentA(a) {
+ this.currentA = a;
+ }
+ }, {
+ key: 'getHSV',
+ value: function getHSV(colorObj) {
+ if (colorObj.type == 'hsl') {
+ return color.HSLtoHSV(colorObj);
+ } else {
+ return color.RGBtoHSV(colorObj);
+ }
+ }
+ }, {
+ key: 'initColor',
+ value: function initColor(newColor, format) {
+ var c = newColor || "#FF0000",
+ colorObj = color.parse(c);
+ format = format || colorObj.type;
+
+ var hsv = this.getHSV(colorObj);
+ this.setCurrentHSV(hsv.h, hsv.s, hsv.v, colorObj.a);
+ }
+ }, {
+ key: 'checkColorPickerClass',
+ value: function checkColorPickerClass(el) {
+ var hasColorView = new Dom(el).closest('codemirror-colorview');
+ var hasColorPicker = new Dom(el).closest('codemirror-colorpicker');
+ var hasCodeMirror = new Dom(el).closest('CodeMirror');
+ var IsInHtml = el.nodeName == 'HTML';
+
+ return !!(hasColorPicker || hasColorView || hasCodeMirror);
+ }
+ }, {
+ key: 'checkInHtml',
+ value: function checkInHtml(el) {
+ var IsInHtml = el.nodeName == 'HTML';
+
+ return IsInHtml;
+ }
+ }, {
+ key: 'initializeEvent',
+ value: function initializeEvent() {
+
+ this.initializeEventMachin();
+ }
+ }, {
+ key: 'setColorSets',
+ value: function setColorSets(list) {
+ this.colorSetsList.setUserList(list);
+ }
+ }, {
+ key: 'destroy',
+ value: function destroy() {
+ get(BaseColorPicker.prototype.__proto__ || Object.getPrototypeOf(BaseColorPicker.prototype), 'destroy', this).call(this);
+
+ // remove color picker callback
+ this.colorpickerCallback = undefined;
}
}]);
- return ColorControl;
+ return BaseColorPicker;
}(EventMachin);
-var ColorInformation = function (_EventMachin) {
- inherits(ColorInformation, _EventMachin);
+var ColorControl = function (_EventMachin) {
+ inherits(ColorControl, _EventMachin);
- function ColorInformation(colorpicker) {
- classCallCheck(this, ColorInformation);
+ function ColorControl(colorpicker) {
+ classCallCheck(this, ColorControl);
- var _this = possibleConstructorReturn(this, (ColorInformation.__proto__ || Object.getPrototypeOf(ColorInformation)).call(this));
+ var _this = possibleConstructorReturn(this, (ColorControl.__proto__ || Object.getPrototypeOf(ColorControl)).call(this));
_this.colorpicker = colorpicker;
_this.initialize();
-
return _this;
}
- createClass(ColorInformation, [{
+ createClass(ColorControl, [{
key: 'initialize',
value: function initialize() {
- this.$el = new Dom('div', 'information hex');
+ this.template('\n
\n ');
- this.$informationChange = this.$el.createChild('div', 'information-change');
+ this.drag_bar_pos = {};
+ this.opacity_drag_bar_pos = {};
+ }
+ }, {
+ key: 'setBackgroundColor',
+ value: function setBackgroundColor(color$$1) {
+ this.refs.$controlColor.css("background-color", color$$1);
+ }
+ }, {
+ key: 'refresh',
+ value: function refresh() {
+ this.setColorUI();
+ }
+ }, {
+ key: 'setOpacityColorBar',
+ value: function setOpacityColorBar(hueColor) {
+ var rgb = color.parse(hueColor);
- this.$formatChangeButton = this.$informationChange.createChild('button', 'format-change-button arrow-button', { type: 'button' });
+ rgb.a = 0;
+ var start = color.format(rgb, 'rgb');
- this.$el.append(this.makeInputFieldHex());
- this.$el.append(this.makeInputFieldRgb());
- this.$el.append(this.makeInputFieldHsl());
+ rgb.a = 1;
+ var end = color.format(rgb, 'rgb');
- this.format = 'hex';
+ this.refs.$opacityColorBar.css('background', 'linear-gradient(to right, ' + start + ', ' + end + ')');
}
}, {
- key: 'makeInputFieldHex',
- value: function makeInputFieldHex() {
- var item = new Dom('div', 'information-item hex');
- var field = item.createChild('div', 'input-field hex');
+ key: 'setOpacity',
+ value: function setOpacity(e) {
+ var min = this.refs.$opacityContainer.offset().left;
+ var max = min + this.state.get('$opacityContainer.width');
+ var current = Event.pos(e).clientX;
+ var dist;
- this.$hexCode = field.createChild('input', 'input', { type: 'text' });
+ var dist;
+ if (current < min) {
+ dist = 0;
+ this.refs.$opacity_drag_bar.addClass('first').removeClass('last');
+ } else if (current > max) {
+ dist = 100;
+ this.refs.$opacity_drag_bar.addClass('last').removeClass('first');
+ } else {
+ dist = (current - min) / (max - min) * 100;
+ this.refs.$opacity_drag_bar.removeClass('first').removeClass('last');
+ }
- field.createChild('div', 'title').html('HEX');
+ var x = this.state.get('$opacityContainer.width') * (dist / 100);
+
+ this.refs.$opacity_drag_bar.css({
+ // left: (x -Math.ceil(this.state.get('$opacity_drag_bar.width')/2)) + 'px'
+ left: x + 'px'
+ });
- return item;
+ this.opacity_drag_bar_pos = { x: x };
+
+ this.colorpicker.setCurrentA(this.caculateOpacity());
+ this.colorpicker.currentFormat();
+ this.colorpicker.setInputColor();
+ }
+ }, {
+ key: 'setInputColor',
+ value: function setInputColor() {
+ this.setBackgroundColor(this.colorpicker.getFormattedColor('rgb'));
+
+ var rgb = this.colorpicker.convertRGB();
+ var colorString = color.format(rgb, 'rgb');
+ this.setOpacityColorBar(colorString);
+ }
+ }, {
+ key: 'setColorUI',
+ value: function setColorUI() {
+
+ var hueX = this.state.get('$hueContainer.width') * (this.colorpicker.currentH / 360);
+
+ this.refs.$drag_bar.css({
+ // left : (hueX - 7.5) + 'px'
+ left: hueX + 'px'
+ });
+
+ this.drag_bar_pos = { x: hueX };
+
+ var opacityX = this.state.get('$opacityContainer.width') * (this.colorpicker.currentA || 0);
+
+ this.refs.$opacity_drag_bar.css({
+ // left : (opacityX - 7.5) + 'px'
+ left: opacityX + 'px'
+ });
+
+ this.opacity_drag_bar_pos = { x: opacityX };
+ }
+ }, {
+ key: 'caculateH',
+ value: function caculateH() {
+
+ var huePos = this.drag_bar_pos || { x: 0 };
+
+ var h = huePos.x / this.state.get('$hueContainer.width') * 360;
+
+ return { h: h };
}
}, {
- key: 'makeInputFieldRgb',
- value: function makeInputFieldRgb() {
- var item = new Dom('div', 'information-item rgb');
+ key: 'caculateOpacity',
+ value: function caculateOpacity() {
+ var opacityPos = this.opacity_drag_bar_pos || { x: 0 };
+ var a = Math.round(opacityPos.x / this.state.get('$opacityContainer.width') * 100) / 100;
- var field = item.createChild('div', 'input-field rgb-r');
- this.$rgb_r = field.createChild('input', 'input', { type: 'number', step: 1, min: 0, max: 255 });
- field.createChild('div', 'title').html('R');
+ return isNaN(a) ? 1 : a;
+ }
+ }, {
+ key: 'EventDocumentMouseMove',
+ value: function EventDocumentMouseMove(e) {
+ if (this.isHueDown) {
+ this.setHueColor(e);
+ }
- field = item.createChild('div', 'input-field rgb-g');
- this.$rgb_g = field.createChild('input', 'input', { type: 'number', step: 1, min: 0, max: 255 });
- field.createChild('div', 'title').html('G');
+ if (this.isOpacityDown) {
+ this.setOpacity(e);
+ }
+ }
+ }, {
+ key: 'EventDocumentMouseUp',
+ value: function EventDocumentMouseUp(e) {
+ this.isHueDown = false;
+ this.isOpacityDown = false;
+ }
+ }, {
+ key: 'setControlColor',
+ value: function setControlColor(color$$1) {
+ this.refs.$controlColor.css('background-color', color$$1);
+ }
+ }, {
+ key: 'setHueColor',
+ value: function setHueColor(e, isOnlyHue) {
+ var min = this.refs.$hueContainer.offset().left;
+ var max = min + this.state.get('$hueContainer.width');
+ var current = e ? Event.pos(e).clientX : min + (max - min) * (this.colorpicker.currentH / 360);
+
+ var dist;
+ if (current < min) {
+ dist = 0;
+ this.refs.$drag_bar.addClass('first').removeClass('last');
+ } else if (current > max) {
+ dist = 100;
+ this.refs.$drag_bar.addClass('last').removeClass('first');
+ } else {
+ dist = (current - min) / (max - min) * 100;
+ this.refs.$drag_bar.removeClass('first').removeClass('last');
+ }
+
+ var x = this.state.get('$hueContainer.width') * (dist / 100);
+
+ this.refs.$drag_bar.css({
+ // left: (x -Math.ceil(this.state.get('$drag_bar.width')/2)) + 'px'
+ left: x + 'px'
+ });
+
+ this.drag_bar_pos = { x: x };
+
+ var hueColor = HueColor.checkHueColor(dist / 100);
+
+ this.colorpicker.setBackgroundColor(hueColor);
+ this.colorpicker.setCurrentH(dist / 100 * 360);
+
+ if (!isOnlyHue) {
+ this.colorpicker.setInputColor();
+ }
+ }
+ }, {
+ key: 'setOnlyHueColor',
+ value: function setOnlyHueColor() {
+ this.setHueColor(null, true);
+ }
+ }, {
+ key: 'mousedown $drag_bar',
+ value: function mousedown$drag_bar(e) {
+ e.preventDefault();
+ this.isHueDown = true;
+ }
+ }, {
+ key: 'mousedown $opacity_drag_bar',
+ value: function mousedown$opacity_drag_bar(e) {
+ e.preventDefault();
+ this.isOpacityDown = true;
+ }
+ }, {
+ key: 'mousedown $hueContainer',
+ value: function mousedown$hueContainer(e) {
+ this.isHueDown = true;
+ this.setHueColor(e);
+ }
+ }, {
+ key: 'mousedown $opacityContainer',
+ value: function mousedown$opacityContainer(e) {
+ this.isOpacityDown = true;
+ this.setOpacity(e);
+ }
+ }]);
+ return ColorControl;
+}(EventMachin);
- field = item.createChild('div', 'input-field rgb-b');
- this.$rgb_b = field.createChild('input', 'input', { type: 'number', step: 1, min: 0, max: 255 });
- field.createChild('div', 'title').html('B');
+var ColorInformation = function (_EventMachin) {
+ inherits(ColorInformation, _EventMachin);
- // rgba
- field = item.createChild('div', 'input-field rgb-a');
- this.$rgb_a = field.createChild('input', 'input', { type: 'number', step: 0.01, min: 0, max: 1 });
- field.createChild('div', 'title').html('A');
+ function ColorInformation(colorpicker) {
+ classCallCheck(this, ColorInformation);
- return item;
- }
- }, {
- key: 'makeInputFieldHsl',
- value: function makeInputFieldHsl() {
- var item = new Dom('div', 'information-item hsl');
+ var _this = possibleConstructorReturn(this, (ColorInformation.__proto__ || Object.getPrototypeOf(ColorInformation)).call(this));
- var field = item.createChild('div', 'input-field hsl-h');
- this.$hsl_h = field.createChild('input', 'input', { type: 'number', step: 1, min: 0, max: 360 });
- field.createChild('div', 'title').html('H');
+ _this.colorpicker = colorpicker;
+ _this.initialize();
- field = item.createChild('div', 'input-field hsl-s');
- this.$hsl_s = field.createChild('input', 'input', { type: 'number', step: 1, min: 0, max: 100 });
- field.createChild('div', 'postfix').html('%');
- field.createChild('div', 'title').html('S');
+ return _this;
+ }
- field = item.createChild('div', 'input-field hsl-l');
- this.$hsl_l = field.createChild('input', 'input', { type: 'number', step: 1, min: 0, max: 100 });
- field.createChild('div', 'postfix').html('%');
- field.createChild('div', 'title').html('L');
+ createClass(ColorInformation, [{
+ key: 'initialize',
+ value: function initialize() {
- // rgba
- field = item.createChild('div', 'input-field hsl-a');
- this.$hsl_a = field.createChild('input', 'input', { type: 'number', step: 0.01, min: 0, max: 1 });
- field.createChild('div', 'title').html('A');
+ this.template('\n \n ');
- return item;
+ this.format = 'hex';
}
}, {
key: 'currentFormat',
@@ -6434,46 +6832,46 @@ var ColorInformation = function (_EventMachin) {
}, {
key: 'setRGBInput',
value: function setRGBInput(r, g, b) {
- this.$rgb_r.val(r);
- this.$rgb_g.val(g);
- this.$rgb_b.val(b);
- this.$rgb_a.val(this.colorpicker.currentA);
+ this.refs.$rgb_r.val(r);
+ this.refs.$rgb_g.val(g);
+ this.refs.$rgb_b.val(b);
+ this.refs.$rgb_a.val(this.colorpicker.currentA);
}
}, {
key: 'setHSLInput',
value: function setHSLInput(h, s, l) {
- this.$hsl_h.val(h);
- this.$hsl_s.val(s);
- this.$hsl_l.val(l);
- this.$hsl_a.val(this.colorpicker.currentA);
+ this.refs.$hsl_h.val(h);
+ this.refs.$hsl_s.val(s);
+ this.refs.$hsl_l.val(l);
+ this.refs.$hsl_a.val(this.colorpicker.currentA);
}
}, {
key: 'getHexFormat',
value: function getHexFormat() {
return color.format({
- r: this.$rgb_r.int(),
- g: this.$rgb_g.int(),
- b: this.$rgb_b.int()
+ r: this.refs.$rgb_r.int(),
+ g: this.refs.$rgb_g.int(),
+ b: this.refs.$rgb_b.int()
}, 'hex', this.colorpicker.opt.color);
}
}, {
key: 'getRgbFormat',
value: function getRgbFormat() {
return color.format({
- r: this.$rgb_r.int(),
- g: this.$rgb_g.int(),
- b: this.$rgb_b.int(),
- a: this.$rgb_a.float()
+ r: this.refs.$rgb_r.int(),
+ g: this.refs.$rgb_g.int(),
+ b: this.refs.$rgb_b.int(),
+ a: this.refs.$rgb_a.float()
}, 'rgb', this.colorpicker.opt.color);
}
}, {
key: 'getHslFormat',
value: function getHslFormat() {
return color.format({
- h: this.$hsl_h.val(),
- s: this.$hsl_s.val(),
- l: this.$hsl_l.val(),
- a: this.$hsl_a.float()
+ h: this.refs.$hsl_h.val(),
+ s: this.refs.$hsl_s.val(),
+ l: this.refs.$hsl_l.val(),
+ a: this.refs.$hsl_a.float()
}, 'hsl', this.colorpicker.opt.color);
}
}, {
@@ -6498,7 +6896,7 @@ var ColorInformation = function (_EventMachin) {
format = format || this.getFormat();
if (format == 'hex') {
- return this.$hexCode.val();
+ return this.refs.$hexCode.val();
} else if (format == 'rgb') {
return this.getRgbFormat(fixed);
} else if (format == 'hsl') {
@@ -6517,13 +6915,13 @@ var ColorInformation = function (_EventMachin) {
var rgb = null;
if (format == 'hex') {
- this.$hexCode.val(this.convertHEX());
+ this.refs.$hexCode.val(this.convertHEX());
var rgb = this.convertRGB();
this.setRGBInput(rgb.r, rgb.g, rgb.b, rgb.a);
} else if (format == 'rgb') {
var rgb = this.convertRGB();
this.setRGBInput(rgb.r, rgb.g, rgb.b, rgb.a);
- this.$hexCode.val(this.convertHEX());
+ this.refs.$hexCode.val(this.convertHEX());
} else if (format == 'hsl') {
var hsl = this.convertHSL();
this.setHSLInput(hsl.h, hsl.s, hsl.l, hsl.a);
@@ -6539,15 +6937,6 @@ var ColorInformation = function (_EventMachin) {
value: function checkNotNumberKey(e) {
return !Event.checkNumberKey(e);
}
-
- //'keydown.checkNotNumberKey $rgb_r' (e) { e.preventDefault(); }
- //'keydown.checkNotNumberKey $rgb_g' (e) { e.preventDefault(); }
- //'keydown.checkNotNumberKey $rgb_b' (e) { e.preventDefault(); }
-
- //'keydown.checkNumberKey $rgb_r' (e) { this.setRGBtoHexColor(e); }
- //'keydown.checkNumberKey $rgb_g' (e) { this.setRGBtoHexColor(e); }
- //'keydown.checkNumberKey $rgb_b' (e) { this.setRGBtoHexColor(e); }
-
}, {
key: 'changeRgbColor',
value: function changeRgbColor() {
@@ -6608,7 +6997,7 @@ var ColorInformation = function (_EventMachin) {
}, {
key: 'keyup $hexCode',
value: function keyup$hexCode(e) {
- var code = this.$hexCode.val();
+ var code = this.refs.$hexCode.val();
if (code.charAt(0) == '#' && code.length == 7) {
this.colorpicker.changeInformationColor(code);
@@ -6643,15 +7032,13 @@ var ColorPallet = function (_EventMachin) {
createClass(ColorPallet, [{
key: 'initialize',
value: function initialize() {
- this.$el = new Dom('div', 'color');
- this.$saturation = this.$el.createChild('div', 'saturation');
- this.$value = this.$saturation.createChild('div', 'value');
- this.$drag_pointer = this.$value.createChild('div', 'drag-pointer');
+
+ this.template('\n \n ');
}
}, {
key: 'setBackgroundColor',
- value: function setBackgroundColor(color$$1) {
- this.$el.css("background-color", color$$1);
+ value: function setBackgroundColor(color) {
+ this.$el.css("background-color", color);
}
}, {
key: 'refresh',
@@ -6677,7 +7064,7 @@ var ColorPallet = function (_EventMachin) {
var x = this.state.get('$el.width') * this.colorpicker.currentS,
y = this.state.get('$el.height') * (1 - this.colorpicker.currentV);
- this.$drag_pointer.css({
+ this.refs.$drag_pointer.css({
left: x - 5 + "px",
top: y - 5 + "px"
});
@@ -6699,7 +7086,7 @@ var ColorPallet = function (_EventMachin) {
if (y < 0) y = 0;else if (y > h) y = h;
- this.$drag_pointer.css({
+ this.refs.$drag_pointer.css({
left: x - 5 + 'px',
top: y - 5 + 'px'
});
@@ -6755,41 +7142,32 @@ var ColorSetsChooser = function (_EventMachin) {
createClass(ColorSetsChooser, [{
key: 'initialize',
value: function initialize() {
- // make colorset-chooser
- this.$el = new Dom('div', 'color-chooser');
-
- var $container = this.$el.createChild('div', 'color-chooser-container');
-
- var $header = $container.createChild('div', 'colorsets-item colorsets-item-header');
- $header.createChild('h1', 'title').html('Color Paletts');
-
- this.$toggleButton = $header.createChild('span', 'items').html('×');
-
- this.$colorsetsList = $container.createChild('div', 'colorsets-list');
+ this.template('\n \n ');
this.refresh();
}
}, {
key: 'refresh',
value: function refresh() {
- this.$colorsetsList.html(this.makeColorSetsList());
+ this.refs.$colorsetsList.html(this.makeColorSetsList());
}
}, {
key: 'makeColorItemList',
value: function makeColorItemList(colors) {
var maxCount = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 5;
+
var $list = new Dom('div');
for (var i = 0; i < maxCount; i++) {
- var color$$1 = colors[i] || 'rgba(255, 255, 255, 1)';
+ var color = colors[i] || 'rgba(255, 255, 255, 1)';
var $item = $list.createChild('div', 'color-item', {
- title: color$$1
+ title: color
});
$item.createChild('div', 'color-view', null, {
- 'background-color': color$$1
+ 'background-color': color
});
}
@@ -6861,144 +7239,6 @@ var ColorSetsChooser = function (_EventMachin) {
return ColorSetsChooser;
}(EventMachin);
-var colorSetsList = [{
- name: "Material",
- colors: ['#F44336', '#E91E63', '#9C27B0', '#673AB7', '#3F51B5', '#2196F3', '#03A9F4', '#00BCD4', '#009688', '#4CAF50', '#8BC34A', '#CDDC39', '#FFEB3B', '#FFC107', '#FF9800', '#FF5722', '#795548', '#9E9E9E', '#607D8B']
-}, {
- name: "Custom", "edit": true, "colors": []
-}, {
- name: "Color Scale", "scale": ['red', 'yellow', 'black'], count: 5
-}];
-
-var ColorSetsList = function () {
- function ColorSetsList(colorpicker) {
- classCallCheck(this, ColorSetsList);
-
- this.colorpicker = colorpicker;
-
- this.setUserList(this.colorpicker.getOption('colorSets'));
- }
-
- createClass(ColorSetsList, [{
- key: 'list',
- value: function list() {
- return this.userList || colorSetsList;
- }
- }, {
- key: 'setUserList',
- value: function setUserList(list) {
- this.userList = list;
-
- this.resetUserList();
-
- this.setCurrentColorSets();
- }
- }, {
- key: 'resetUserList',
- value: function resetUserList() {
- var _this = this;
-
- if (this.userList && this.userList.length) {
- this.userList = this.userList.map(function (element, index) {
-
- if (typeof element.colors == 'function') {
- var makeCallback = element.colors;
-
- element.colors = makeCallback(_this.colorpicker, _this);
- element._colors = makeCallback;
- }
-
- return Object.assign({
- name: 'color-' + index,
- colors: []
- }, element);
- });
- }
- }
- }, {
- key: 'setCurrentColorSets',
- value: function setCurrentColorSets(nameOrIndex) {
-
- var _list = this.list();
-
- if (typeof nameOrIndex == 'undefined') {
- this.currentColorSets = _list[0];
- } else if (typeof nameOrIndex == 'number') {
- this.currentColorSets = _list[nameOrIndex];
- } else {
- this.currentColorSets = _list.filter(function (obj) {
- return obj.name == nameOrIndex;
- })[0];
- }
- }
- }, {
- key: 'getCurrentColorSets',
- value: function getCurrentColorSets() {
- return this.currentColorSets;
- }
- }, {
- key: 'addCurrentColor',
- value: function addCurrentColor(color$$1) {
- if (Array.isArray(this.currentColorSets.colors)) {
- this.currentColorSets.colors.push(color$$1);
- }
- }
- }, {
- key: 'removeCurrentColor',
- value: function removeCurrentColor(index) {
- if (this.currentColorSets.colors[index]) {
- this.currentColorSets.colors.splice(index, 1);
- }
- }
- }, {
- key: 'removeCurrentColorToTheRight',
- value: function removeCurrentColorToTheRight(index) {
- if (this.currentColorSets.colors[index]) {
- this.currentColorSets.colors.splice(index, Number.MAX_VALUE);
- }
- }
- }, {
- key: 'clearPalette',
- value: function clearPalette() {
- if (this.currentColorSets.colors) {
- this.currentColorSets.colors = [];
- }
- }
- }, {
- key: 'getCurrentColors',
- value: function getCurrentColors() {
- return this.getColors(this.currentColorSets);
- }
- }, {
- key: 'getColors',
- value: function getColors(element) {
-
- if (element.scale) {
- return color.scale(element.scale, element.count);
- }
-
- return element.colors || [];
- }
- }, {
- key: 'getColorSetsList',
- value: function getColorSetsList() {
- var _this2 = this;
-
- return this.list().map(function (element) {
- return {
- name: element.name,
- edit: element.edit,
- colors: _this2.getColors(element)
- };
- });
- }
- }, {
- key: 'destroy',
- value: function destroy() {}
- }]);
- return ColorSetsList;
-}();
-
var CurrentColorSets = function (_EventMachin) {
inherits(CurrentColorSets, _EventMachin);
@@ -7023,16 +7263,16 @@ var CurrentColorSets = function (_EventMachin) {
var colors = this.colorSetsList.getCurrentColors();
for (var i = 0, len = colors.length; i < len; i++) {
- var color$$1 = colors[i];
+ var color = colors[i];
var item = list.createChild('div', 'color-item', {
- 'title': color$$1,
+ 'title': color,
'data-index': i,
- 'data-color': color$$1
+ 'data-color': color
});
item.createChild('div', 'empty');
item.createChild('div', 'color-view', null, {
- 'background-color': color$$1
+ 'background-color': color
});
}
@@ -7045,24 +7285,15 @@ var CurrentColorSets = function (_EventMachin) {
}, {
key: 'initialize',
value: function initialize() {
- // make colorsets view
- this.$el = new Dom('div', 'colorsets');
-
- var $colorSetsMenu = this.$el.createChild('div', 'menu', {
- title: 'Open Color Pallets'
- });
- this.$colorSetsColorList = this.$el.createChild('div', 'color-list');
- this.$colorSetsChooseButton = $colorSetsMenu.createChild('button', 'color-sets-choose-btn arrow-button', {
- type: 'button'
- });
+ this.template('\n \n ');
this.refresh();
}
}, {
key: 'refresh',
value: function refresh() {
- this.$colorSetsColorList.html(this.makeCurrentColorSets());
+ this.refs.$colorSetsColorList.html(this.makeCurrentColorSets());
}
}, {
key: 'refreshAll',
@@ -7072,8 +7303,8 @@ var CurrentColorSets = function (_EventMachin) {
}
}, {
key: 'addColor',
- value: function addColor(color$$1) {
- this.colorSetsList.addCurrentColor(color$$1);
+ value: function addColor(color) {
+ this.colorSetsList.addCurrentColor(color);
this.refreshAll();
}
}, {
@@ -7156,20 +7387,8 @@ var CurrentColorSetsContextMenu = function (_EventMachin) {
createClass(CurrentColorSetsContextMenu, [{
key: 'initialize',
value: function initialize() {
- // make colorsets view
- this.$el = new Dom('ul', 'colorsets-contextmenu');
- this.$el.createChild('li', 'menu-item small-hide', {
- 'data-type': 'remove-color'
- }).html('Remove color');
-
- this.$el.createChild('li', 'menu-item small-hide', {
- 'data-type': 'remove-all-to-the-right'
- }).html('Remove all to the right');
-
- this.$el.createChild('li', 'menu-item', {
- 'data-type': 'clear-palette'
- }).html('Clear palette');
+ this.template('\n \n ');
}
}, {
key: 'show',
@@ -7221,32 +7440,13 @@ var CurrentColorSetsContextMenu = function (_EventMachin) {
return CurrentColorSetsContextMenu;
}(EventMachin);
-var ColorPicker = function (_EventMachin) {
- inherits(ColorPicker, _EventMachin);
+var ColorPicker$1 = function (_BaseColorPicker) {
+ inherits(ColorPicker, _BaseColorPicker);
function ColorPicker(opt) {
classCallCheck(this, ColorPicker);
- var _this = possibleConstructorReturn(this, (ColorPicker.__proto__ || Object.getPrototypeOf(ColorPicker)).call(this));
-
- _this.opt = opt || {};
- _this.$body = null;
- _this.$root = null;
-
- _this.format = 'rgb';
- _this.currentA = 0;
- _this.currentH = 0;
- _this.currentS = 0;
- _this.currentV = 0;
-
- _this.colorSetsList = new ColorSetsList(_this);
- _this.colorpickerCallback = function () {};
-
- _this.isColorPickerShow = false;
- _this.isShortCut = false;
- _this.hideDelay = _this.opt.hideDeplay || 2000;
- _this.timerCloseColorPicker;
- _this.autoHide = _this.opt.autoHide || true;
+ var _this = possibleConstructorReturn(this, (ColorPicker.__proto__ || Object.getPrototypeOf(ColorPicker)).call(this, opt));
_this.control = new ColorControl(_this);
_this.palette = new ColorPallet(_this);
@@ -7260,49 +7460,10 @@ var ColorPicker = function (_EventMachin) {
}
createClass(ColorPicker, [{
- key: 'getOption',
- value: function getOption(key) {
- return this.opt[key];
- }
- }, {
- key: 'isType',
- value: function isType(key) {
- return this.getOption('type') == key;
- }
- }, {
- key: 'isPaletteType',
- value: function isPaletteType() {
- return this.isType('palette');
- }
- }, {
- key: 'isSketchType',
- value: function isSketchType() {
- return this.isType('sketch');
- }
- }, {
- key: 'getContainer',
- value: function getContainer() {
- return this.opt.container || document.body;
- }
- }, {
key: 'initialize',
value: function initialize() {
- this.$body = new Dom(this.getContainer());
- this.$root = new Dom('div', 'codemirror-colorpicker');
-
- // append colorpicker to container (ex : body)
- if (this.opt.position == 'inline') {
- this.$body.append(this.$root);
- }
-
- if (this.opt.type) {
- // to change css style
- this.$root.addClass(this.opt.type);
- }
-
- this.$arrow = new Dom('div', 'arrow');
+ get(ColorPicker.prototype.__proto__ || Object.getPrototypeOf(ColorPicker.prototype), 'initialize', this).call(this);
- this.$root.append(this.$arrow);
this.$root.append(this.palette.$el);
this.$root.append(this.control.$el);
this.$root.append(this.information.$el);
@@ -7636,23 +7797,6 @@ var ColorPicker = function (_EventMachin) {
value: function setHueColor() {
this.control.setOnlyHueColor();
}
- }, {
- key: 'checkColorPickerClass',
- value: function checkColorPickerClass(el) {
- var hasColorView = new Dom(el).closest('codemirror-colorview');
- var hasColorPicker = new Dom(el).closest('codemirror-colorpicker');
- var hasCodeMirror = new Dom(el).closest('CodeMirror');
- var IsInHtml = el.nodeName == 'HTML';
-
- return !!(hasColorPicker || hasColorView || hasCodeMirror);
- }
- }, {
- key: 'checkInHtml',
- value: function checkInHtml(el) {
- var IsInHtml = el.nodeName == 'HTML';
-
- return IsInHtml;
- }
// Event Bindings
@@ -7731,13 +7875,24 @@ var ColorPicker = function (_EventMachin) {
this.colorSetsList.destroy();
this.currentColorSets.destroy();
this.contextMenu.destroy();
-
- // remove color picker callback
- this.colorpickerCallback = undefined;
}
}]);
return ColorPicker;
-}(EventMachin);
+}(BaseColorPicker);
+
+var ColorPicker = {
+ create: function create(opts) {
+ switch (opts.type) {
+ case 'sketch':
+ case 'palette':
+ default:
+ return new ColorPicker$1(opts);
+ }
+ },
+
+ ColorPicker: ColorPicker$1,
+ ChromeDevToolColorPicker: ColorPicker$1
+};
var colorpicker_class = 'codemirror-colorview';
var colorpicker_background_class = 'codemirror-colorview-background';
@@ -7830,7 +7985,7 @@ var ColorView = function () {
if (this.opt.colorpicker) {
this.colorpicker = this.opt.colorpicker(this.opt);
} else {
- this.colorpicker = new ColorPicker(this.opt);
+ this.colorpicker = ColorPicker.create(this.opt);
}
this.init_event();
@@ -8163,16 +8318,16 @@ if (CodeMirror) {
});
}
-var index = {
+var index = _extends({
Color: color,
- ColorNames: ColorNames,
- ColorPicker: ColorPicker,
+ ColorNames: ColorNames
+}, ColorPicker, {
ImageFilter: ImageFilter,
GL: GL,
HueColor: HueColor,
Canvas: Canvas,
ImageLoader: ImageLoader
-};
+});
return index;
diff --git a/dist/codemirror-colorpicker.css b/dist/codemirror-colorpicker.css
index 8b10ff8..27bdddc 100644
--- a/dist/codemirror-colorpicker.css
+++ b/dist/codemirror-colorpicker.css
@@ -171,8 +171,9 @@
position: absolute;
cursor: pointer;
top: 50% !important;
- margin-top: -7px !important;
- left: -3px;
+ left: 0px;
+ -webkit-transform: translateX(-50%) translateY(-50%);
+ transform: translateX(-50%) translateY(-50%);
width: 12px;
height: 12px;
border-radius: 50px; }
@@ -550,13 +551,21 @@
border-radius: 0px; }
.codemirror-colorpicker.sketch > .control .drag-bar, .codemirror-colorpicker.sketch > .control .drag-bar2 {
border-radius: 0px;
- top: 0px !important;
- left: -2px;
- margin-top: 1px !important;
+ top: 50%;
+ left: 0px;
width: 2px;
- height: auto;
+ height: 50%;
+ -webkit-transform: translateX(-50%) translateY(-50%);
+ transform: translateX(-50%) translateY(-50%);
border-radius: 1px;
bottom: 1px !important; }
+ .codemirror-colorpicker.sketch > .control .drag-bar.first, .codemirror-colorpicker.sketch > .control .drag-bar2.first {
+ left: 0px;
+ -webkit-transform: translateX(50%) translateY(-50%) !important;
+ transform: translateX(50%) translateY(-50%) !important; }
+ .codemirror-colorpicker.sketch > .control .drag-bar.last, .codemirror-colorpicker.sketch > .control .drag-bar2.last {
+ -webkit-transform: translateX(-150%) translateY(-50%) !important;
+ transform: translateX(-150%) translateY(-50%) !important; }
.codemirror-colorpicker.sketch > .information .information-change {
display: none; }
.codemirror-colorpicker.sketch > .information.rgb .information-item.rgb {
diff --git a/dist/codemirror-colorpicker.js b/dist/codemirror-colorpicker.js
index f93f96e..712c1a5 100644
--- a/dist/codemirror-colorpicker.js
+++ b/dist/codemirror-colorpicker.js
@@ -5097,8 +5097,7 @@ var color = {
*/
contrast: function contrast(c) {
c = this.parse(c);
- var contrast = (Math.round(c.r * 299) + Math.round(c.g * 587) + Math.round(c.b * 114)) / 1000;
- return contrast;
+ return (Math.round(c.r * 299) + Math.round(c.g * 587) + Math.round(c.b * 114)) / 1000;
},
contrastColor: function contrastColor(c) {
return this.contrast(c) >= 128 ? 'black' : 'white';
@@ -5556,6 +5555,8 @@ var Dom = function () {
key: 'removeClass',
value: function removeClass(cls) {
this.el.className = (' ' + this.el.className + ' ').replace(' ' + cls + ' ', ' ').trim();
+
+ return this;
}
}, {
key: 'hasClass',
@@ -5573,6 +5574,8 @@ var Dom = function () {
if (!this.hasClass(cls)) {
this.el.className = this.el.className + ' ' + cls;
}
+
+ return this;
}
}, {
key: 'toggleClass',
@@ -5595,6 +5598,16 @@ var Dom = function () {
return this;
}
+ }, {
+ key: 'find',
+ value: function find(selector) {
+ return this.el.querySelector(selector);
+ }
+ }, {
+ key: 'findAll',
+ value: function findAll(selector) {
+ return this.el.querySelectorAll(selector);
+ }
}, {
key: 'empty',
value: function empty() {
@@ -5828,6 +5841,11 @@ var Dom = function () {
return $element;
}
+ }, {
+ key: 'firstChild',
+ value: function firstChild() {
+ return new Dom(this.el.firstElementChild);
+ }
}]);
return Dom;
}();
@@ -5875,7 +5893,7 @@ var State = function () {
var arr = key.split(DELEGATE_SPLIT);
- var obj = this.masterObj[arr[0]] || this.masterObj;
+ var obj = this.masterObj.refs[arr[0]] || this.masterObj[arr[0]] || this.masterObj;
var method = arr.pop();
if (obj[method]) {
@@ -5917,9 +5935,22 @@ var EventMachin = function () {
classCallCheck(this, EventMachin);
this.state = new State(this);
+ this.refs = {};
}
createClass(EventMachin, [{
+ key: 'template',
+ value: function template(html) {
+ var _this = this;
+
+ this.$el = new Dom("div").html(html).firstChild();
+ var refs = this.$el.findAll("[ref]");
+ [].concat(toConsumableArray(refs)).forEach(function (node) {
+ _this.refs[node.getAttribute("ref")] = new Dom(node);
+ });
+ this.refs.$el = this.$el;
+ }
+ }, {
key: 'initializeEvent',
value: function initializeEvent() {
this.initializeEventMachin();
@@ -5928,6 +5959,7 @@ var EventMachin = function () {
key: 'destroy',
value: function destroy() {
this.destroyEventMachin();
+ // this.refs = {}
}
}, {
key: 'destroyEventMachin',
@@ -5959,7 +5991,7 @@ var EventMachin = function () {
var el = void 0;
if (dom) {
- el = this[dom] || window[dom];
+ el = this.refs[dom] || this[dom] || window[dom];
} else {
el = this.el || this.$el || this.$root;
}
@@ -5973,7 +6005,7 @@ var EventMachin = function () {
}, {
key: 'getDefaultEventObject',
value: function getDefaultEventObject(eventName) {
- var _this = this;
+ var _this2 = this;
var arr = eventName.split('.');
var realEventName = arr.shift();
@@ -5988,7 +6020,7 @@ var EventMachin = function () {
});
var checkMethodList = arr.filter(function (code) {
- return !!_this[code];
+ return !!_this2[code];
});
arr = arr.filter(function (code) {
@@ -6057,7 +6089,7 @@ var EventMachin = function () {
}, {
key: 'checkEventType',
value: function checkEventType(e, eventObject) {
- var _this2 = this;
+ var _this3 = this;
var onlyControl = e.ctrlKey ? eventObject.isControl : true;
var onlyShift = e.shiftKey ? eventObject.isShift : true;
@@ -6073,7 +6105,7 @@ var EventMachin = function () {
if (eventObject.checkMethodList.length) {
// 체크 메소드들은 모든 메소드를 다 적용해야한다.
isAllCheck = eventObject.checkMethodList.every(function (method) {
- return _this2[method].call(_this2, e);
+ return _this3[method].call(_this3, e);
});
}
@@ -6082,13 +6114,13 @@ var EventMachin = function () {
}, {
key: 'makeCallback',
value: function makeCallback(eventObject, callback) {
- var _this3 = this;
+ var _this4 = this;
if (eventObject.delegate) {
return function (e) {
- if (_this3.checkEventType(e, eventObject)) {
- var delegateTarget = _this3.matchPath(e.target || e.srcElement, eventObject.delegate);
+ if (_this4.checkEventType(e, eventObject)) {
+ var delegateTarget = _this4.matchPath(e.target || e.srcElement, eventObject.delegate);
if (delegateTarget) {
// delegate target 이 있는 경우만 callback 실행
@@ -6100,7 +6132,7 @@ var EventMachin = function () {
};
} else {
return function (e) {
- if (_this3.checkEventType(e, eventObject)) {
+ if (_this4.checkEventType(e, eventObject)) {
return callback(e);
}
};
@@ -6116,10 +6148,10 @@ var EventMachin = function () {
}, {
key: 'removeEventAll',
value: function removeEventAll() {
- var _this4 = this;
+ var _this5 = this;
this.getBindings().forEach(function (obj) {
- _this4.removeEvent(obj);
+ _this5.removeEvent(obj);
});
this.initBindings();
}
@@ -6136,346 +6168,712 @@ var EventMachin = function () {
return EventMachin;
}();
-var ColorControl = function (_EventMachin) {
- inherits(ColorControl, _EventMachin);
+var colorSetsList = [{
+ name: "Material",
+ colors: ['#F44336', '#E91E63', '#9C27B0', '#673AB7', '#3F51B5', '#2196F3', '#03A9F4', '#00BCD4', '#009688', '#4CAF50', '#8BC34A', '#CDDC39', '#FFEB3B', '#FFC107', '#FF9800', '#FF5722', '#795548', '#9E9E9E', '#607D8B']
+}, {
+ name: "Custom", "edit": true, "colors": []
+}, {
+ name: "Color Scale", "scale": ['red', 'yellow', 'black'], count: 5
+}];
- function ColorControl(colorpicker) {
- classCallCheck(this, ColorControl);
+var ColorSetsList = function () {
+ function ColorSetsList(colorpicker) {
+ classCallCheck(this, ColorSetsList);
- var _this = possibleConstructorReturn(this, (ColorControl.__proto__ || Object.getPrototypeOf(ColorControl)).call(this));
+ this.colorpicker = colorpicker;
- _this.colorpicker = colorpicker;
- _this.initialize();
- return _this;
+ this.setUserList(this.colorpicker.getOption('colorSets'));
}
- createClass(ColorControl, [{
- key: 'initialize',
- value: function initialize() {
- this.$el = new Dom('div', 'control');
- this.$hue = this.$el.createChild('div', 'hue');
- this.$opacity = this.$el.createChild('div', 'opacity');
- this.$controlPattern = this.$el.createChild('div', 'empty');
- this.$controlColor = this.$el.createChild('div', 'color');
-
- this.$hueContainer = this.$hue.createChild('div', 'hue-container');
- this.$drag_bar = this.$hueContainer.createChild('div', 'drag-bar');
- this.drag_bar_pos = {};
-
- this.$opacityContainer = this.$opacity.createChild('div', 'opacity-container');
- this.$opacityColorBar = this.$opacityContainer.createChild('div', 'color-bar');
-
- this.$opacity_drag_bar = this.$opacityContainer.createChild('div', 'drag-bar2');
- this.opacity_drag_bar_pos = {};
- }
- }, {
- key: 'setBackgroundColor',
- value: function setBackgroundColor(color$$1) {
- this.$controlColor.css("background-color", color$$1);
- }
- }, {
- key: 'refresh',
- value: function refresh() {
- this.setColorUI();
+ createClass(ColorSetsList, [{
+ key: 'list',
+ value: function list() {
+ return this.userList || colorSetsList;
}
}, {
- key: 'setColorUI',
- value: function setColorUI() {
+ key: 'setUserList',
+ value: function setUserList(list) {
+ this.userList = list;
- var x = this.state.get('$el.width') * this.colorpicker.currentS,
- y = this.state.get('$el.height') * (1 - this.colorpicker.currentV);
+ this.resetUserList();
- this.$drag_pointer.css({
- left: x + "px",
- top: y + "px"
- });
+ this.setCurrentColorSets();
}
}, {
- key: 'setOpacityColorBar',
- value: function setOpacityColorBar(hueColor) {
- var rgb = color.parse(hueColor);
+ key: 'resetUserList',
+ value: function resetUserList() {
+ var _this = this;
- rgb.a = 0;
- var start = color.format(rgb, 'rgb');
+ if (this.userList && this.userList.length) {
+ this.userList = this.userList.map(function (element, index) {
- rgb.a = 1;
- var end = color.format(rgb, 'rgb');
+ if (typeof element.colors == 'function') {
+ var makeCallback = element.colors;
- this.$opacityColorBar.css('background', 'linear-gradient(to right, ' + start + ', ' + end + ')');
- }
- }, {
- key: 'setOpacity',
- value: function setOpacity(e) {
- var min = this.$opacityContainer.offset().left;
- var max = min + this.state.get('$opacityContainer.width');
- var current = Event.pos(e).clientX;
- var dist;
+ element.colors = makeCallback(_this.colorpicker, _this);
+ element._colors = makeCallback;
+ }
- if (current < min) {
- dist = 0;
- } else if (current > max) {
- dist = 100;
- } else {
- dist = (current - min) / (max - min) * 100;
+ return Object.assign({
+ name: 'color-' + index,
+ colors: []
+ }, element);
+ });
}
-
- var x = this.state.get('$opacityContainer.width') * (dist / 100);
-
- this.$opacity_drag_bar.css({
- left: x - Math.ceil(this.state.get('$opacity_drag_bar.width') / 2) + 'px'
- });
-
- this.opacity_drag_bar_pos = { x: x };
-
- this.colorpicker.setCurrentA(this.caculateOpacity());
- this.colorpicker.currentFormat();
- this.colorpicker.setInputColor();
- }
- }, {
- key: 'setInputColor',
- value: function setInputColor() {
- this.setBackgroundColor(this.colorpicker.getFormattedColor('rgb'));
-
- var rgb = this.colorpicker.convertRGB();
- var colorString = color.format(rgb, 'rgb');
- this.setOpacityColorBar(colorString);
}
}, {
- key: 'setColorUI',
- value: function setColorUI() {
-
- var hueX = this.state.get('$hueContainer.width') * (this.colorpicker.currentH / 360);
-
- this.$drag_bar.css({
- left: hueX - 7.5 + 'px'
- });
-
- this.drag_bar_pos = { x: hueX };
-
- var opacityX = this.state.get('$opacityContainer.width') * (this.colorpicker.currentA || 0);
+ key: 'setCurrentColorSets',
+ value: function setCurrentColorSets(nameOrIndex) {
- this.$opacity_drag_bar.css({
- left: opacityX - 7.5 + 'px'
- });
+ var _list = this.list();
- this.opacity_drag_bar_pos = { x: opacityX };
+ if (typeof nameOrIndex == 'undefined') {
+ this.currentColorSets = _list[0];
+ } else if (typeof nameOrIndex == 'number') {
+ this.currentColorSets = _list[nameOrIndex];
+ } else {
+ this.currentColorSets = _list.filter(function (obj) {
+ return obj.name == nameOrIndex;
+ })[0];
+ }
}
}, {
- key: 'caculateH',
- value: function caculateH() {
-
- var huePos = this.drag_bar_pos || { x: 0 };
-
- var h = huePos.x / this.state.get('$hueContainer.width') * 360;
-
- return { h: h };
+ key: 'getCurrentColorSets',
+ value: function getCurrentColorSets() {
+ return this.currentColorSets;
}
}, {
- key: 'caculateOpacity',
- value: function caculateOpacity() {
- var opacityPos = this.opacity_drag_bar_pos || { x: 0 };
- var a = Math.round(opacityPos.x / this.state.get('$opacityContainer.width') * 100) / 100;
-
- return isNaN(a) ? 1 : a;
+ key: 'addCurrentColor',
+ value: function addCurrentColor(color$$1) {
+ if (Array.isArray(this.currentColorSets.colors)) {
+ this.currentColorSets.colors.push(color$$1);
+ }
}
}, {
- key: 'EventDocumentMouseMove',
- value: function EventDocumentMouseMove(e) {
- if (this.isHueDown) {
- this.setHueColor(e);
+ key: 'removeCurrentColor',
+ value: function removeCurrentColor(index) {
+ if (this.currentColorSets.colors[index]) {
+ this.currentColorSets.colors.splice(index, 1);
}
-
- if (this.isOpacityDown) {
- this.setOpacity(e);
+ }
+ }, {
+ key: 'removeCurrentColorToTheRight',
+ value: function removeCurrentColorToTheRight(index) {
+ if (this.currentColorSets.colors[index]) {
+ this.currentColorSets.colors.splice(index, Number.MAX_VALUE);
}
}
}, {
- key: 'EventDocumentMouseUp',
- value: function EventDocumentMouseUp(e) {
- this.isHueDown = false;
- this.isOpacityDown = false;
+ key: 'clearPalette',
+ value: function clearPalette() {
+ if (this.currentColorSets.colors) {
+ this.currentColorSets.colors = [];
+ }
}
}, {
- key: 'setControlColor',
- value: function setControlColor(color$$1) {
- this.$controlColor.css('background-color', color$$1);
+ key: 'getCurrentColors',
+ value: function getCurrentColors() {
+ return this.getColors(this.currentColorSets);
}
}, {
- key: 'setHueColor',
- value: function setHueColor(e) {
- var min = this.$hueContainer.offset().left;
- var max = min + this.state.get('$hueContainer.width');
- var current = e ? Event.pos(e).clientX : min + (max - min) * (this.colorpicker.currentH / 360);
+ key: 'getColors',
+ value: function getColors(element) {
- var dist;
- if (current < min) {
- dist = 0;
- } else if (current > max) {
- dist = 100;
- } else {
- dist = (current - min) / (max - min) * 100;
+ if (element.scale) {
+ return color.scale(element.scale, element.count);
}
- var x = this.state.get('$hueContainer.width') * (dist / 100);
+ return element.colors || [];
+ }
+ }, {
+ key: 'getColorSetsList',
+ value: function getColorSetsList() {
+ var _this2 = this;
- this.$drag_bar.css({
- left: x - Math.ceil(this.state.get('$drag_bar.width') / 2) + 'px'
+ return this.list().map(function (element) {
+ return {
+ name: element.name,
+ edit: element.edit,
+ colors: _this2.getColors(element)
+ };
});
-
- this.drag_bar_pos = { x: x };
-
- var hueColor = HueColor.checkHueColor(dist / 100);
-
- this.colorpicker.setBackgroundColor(hueColor);
- this.colorpicker.setCurrentH(dist / 100 * 360);
- this.colorpicker.setInputColor();
}
}, {
- key: 'setOnlyHueColor',
- value: function setOnlyHueColor() {
- var min = this.$hueContainer.offset().left;
- var max = min + this.state.get('$hueContainer.width');
- var current = min + (max - min) * (this.colorpicker.currentH / 360);
+ key: 'destroy',
+ value: function destroy() {}
+ }]);
+ return ColorSetsList;
+}();
- var dist;
- if (current < min) {
- dist = 0;
- } else if (current > max) {
- dist = 100;
- } else {
- dist = (current - min) / (max - min) * 100;
- }
+var BaseColorPicker = function (_EventMachin) {
+ inherits(BaseColorPicker, _EventMachin);
- var x = this.state.get('$hueContainer.width') * (dist / 100);
+ function BaseColorPicker(opt) {
+ classCallCheck(this, BaseColorPicker);
- this.$drag_bar.css({
- left: x - Math.ceil(this.state.get('$drag_bar.width') / 2) + 'px'
+ var _this = possibleConstructorReturn(this, (BaseColorPicker.__proto__ || Object.getPrototypeOf(BaseColorPicker)).call(this));
+
+ _this.opt = opt || {};
+ _this.$body = null;
+ _this.$root = null;
+
+ _this.format = 'rgb';
+ _this.currentA = 0;
+ _this.currentH = 0;
+ _this.currentS = 0;
+ _this.currentV = 0;
+
+ _this.colorSetsList = new ColorSetsList(_this);
+ _this.colorpickerCallback = function () {};
+
+ _this.isColorPickerShow = false;
+ _this.isShortCut = false;
+ _this.hideDelay = _this.opt.hideDeplay || 2000;
+ _this.timerCloseColorPicker;
+ _this.autoHide = _this.opt.autoHide || true;
+
+ return _this;
+ }
+
+ createClass(BaseColorPicker, [{
+ key: 'initialize',
+ value: function initialize() {
+
+ this.$body = new Dom(this.getContainer());
+ this.$root = new Dom('div', 'codemirror-colorpicker');
+
+ // append colorpicker to container (ex : body)
+ if (this.opt.position == 'inline') {
+ this.$body.append(this.$root);
+ }
+
+ if (this.opt.type) {
+ // to change css style
+ this.$root.addClass(this.opt.type);
+ }
+
+ this.$arrow = new Dom('div', 'arrow');
+
+ this.$root.append(this.$arrow);
+ }
+ }, {
+ key: 'getOption',
+ value: function getOption(key) {
+ return this.opt[key];
+ }
+ }, {
+ key: 'setOption',
+ value: function setOption(key, value) {
+ this.opt[key] = value;
+ }
+ }, {
+ key: 'isType',
+ value: function isType(key) {
+ return this.getOption('type') == key;
+ }
+ }, {
+ key: 'isPaletteType',
+ value: function isPaletteType() {
+ return this.isType('palette');
+ }
+ }, {
+ key: 'isSketchType',
+ value: function isSketchType() {
+ return this.isType('sketch');
+ }
+ }, {
+ key: 'getContainer',
+ value: function getContainer() {
+ return this.opt.container || document.body;
+ }
+ }, {
+ key: 'getColor',
+ value: function getColor(type) {
+ this.caculateHSV();
+ var rgb = this.convertRGB();
+
+ if (type) {
+ return color.format(rgb, type);
+ }
+
+ return rgb;
+ }
+ }, {
+ key: 'definePositionForArrow',
+ value: function definePositionForArrow(opt, elementScreenLeft, elementScreenTop) {
+ //this.$arrow.css({})
+ }
+ }, {
+ key: 'definePosition',
+ value: function definePosition(opt) {
+
+ var width = this.$root.width();
+ var height = this.$root.height();
+
+ // set left position for color picker
+ var elementScreenLeft = opt.left - this.$body.scrollLeft();
+ if (width + elementScreenLeft > window.innerWidth) {
+ elementScreenLeft -= width + elementScreenLeft - window.innerWidth;
+ }
+ if (elementScreenLeft < 0) {
+ elementScreenLeft = 0;
+ }
+
+ // set top position for color picker
+ var elementScreenTop = opt.top - this.$body.scrollTop();
+ if (height + elementScreenTop > window.innerHeight) {
+ elementScreenTop -= height + elementScreenTop - window.innerHeight;
+ }
+ if (elementScreenTop < 0) {
+ elementScreenTop = 0;
+ }
+
+ // set position
+ this.$root.css({
+ left: elementScreenLeft + 'px',
+ top: elementScreenTop + 'px'
+ });
+ }
+ }, {
+ key: 'getInitalizePosition',
+ value: function getInitalizePosition() {
+ if (this.opt.position == 'inline') {
+ return {
+ position: 'relative',
+ left: 'auto',
+ top: 'auto',
+ display: 'inline-block'
+ };
+ } else {
+ return {
+ position: 'fixed', // color picker has fixed position
+ left: '-10000px',
+ top: '-10000px'
+ };
+ }
+ }
+ }, {
+ key: 'show',
+ value: function show(opt, color$$1, callback) {
+ this.destroy();
+ this.initializeEvent();
+ this.$root.appendTo(this.$body);
+
+ this.$root.css(this.getInitalizePosition()).show();
+
+ this.definePosition(opt);
+
+ this.isColorPickerShow = true;
+
+ this.isShortCut = opt.isShortCut || false;
+
+ this.initColor(color$$1);
+
+ // define colorpicker callback
+ this.colorpickerCallback = callback;
+
+ // define hide delay
+ this.hideDelay = opt.hideDelay || 2000;
+ if (this.hideDelay > 0) {
+ this.setHideDelay(this.hideDelay);
+ }
+ }
+ }, {
+ key: 'setHideDelay',
+ value: function setHideDelay(delayTime) {
+ var _this2 = this;
+
+ delayTime = delayTime || 0;
+
+ this.$root.off('mouseenter');
+ this.$root.off('mouseleave');
+
+ this.$root.on('mouseenter', function () {
+ clearTimeout(_this2.timerCloseColorPicker);
});
- this.drag_bar_pos = { x: x };
+ this.$root.on('mouseleave', function () {
+ clearTimeout(_this2.timerCloseColorPicker);
+ _this2.timerCloseColorPicker = setTimeout(_this2.hide.bind(_this2), delayTime);
+ });
- var hueColor = HueColor.checkHueColor(dist / 100);
- this.colorpicker.setBackgroundColor(hueColor);
- this.colorpicker.setCurrentH(dist / 100 * 360);
+ clearTimeout(this.timerCloseColorPicker);
+ this.timerCloseColorPicker = setTimeout(this.hide.bind(this), delayTime);
}
}, {
- key: 'mousedown $drag_bar',
- value: function mousedown$drag_bar(e) {
- e.preventDefault();
- this.isHueDown = true;
+ key: 'hide',
+ value: function hide() {
+ if (this.isColorPickerShow) {
+ this.destroy();
+ this.$root.hide();
+ this.$root.remove(); // not empty
+ this.isColorPickerShow = false;
+ }
}
}, {
- key: 'mousedown $opacity_drag_bar',
- value: function mousedown$opacity_drag_bar(e) {
- e.preventDefault();
- this.isOpacityDown = true;
+ key: 'convertRGB',
+ value: function convertRGB() {
+ return color.HSVtoRGB(this.currentH, this.currentS, this.currentV);
}
}, {
- key: 'mousedown $hueContainer',
- value: function mousedown$hueContainer(e) {
- this.isHueDown = true;
- this.setHueColor(e);
+ key: 'convertHEX',
+ value: function convertHEX() {
+ return color.format(this.convertRGB(), 'hex');
}
}, {
- key: 'mousedown $opacityContainer',
- value: function mousedown$opacityContainer(e) {
- this.isOpacityDown = true;
- this.setOpacity(e);
+ key: 'convertHSL',
+ value: function convertHSL() {
+ return color.HSVtoHSL(this.currentH, this.currentS, this.currentV);
+ }
+ }, {
+ key: 'getFormattedColor',
+ value: function getFormattedColor(format) {
+ format = format || 'hex';
+
+ if (format == 'rgb') {
+ var rgb = this.convertRGB();
+ rgb.a = this.currentA;
+ return color.format(rgb, 'rgb');
+ } else if (format == 'hsl') {
+ var hsl = this.convertHSL();
+ hsl.a = this.currentA;
+ return color.format(hsl, 'hsl');
+ } else {
+ var rgb = this.convertRGB();
+ return color.format(rgb, 'hex');
+ }
+ }
+ }, {
+ key: 'callbackColorValue',
+ value: function callbackColorValue(color$$1) {
+
+ if (!isNaN(this.currentA)) {
+ if (typeof this.opt.onChange == 'function') {
+ this.opt.onChange.call(this, color$$1);
+ }
+
+ if (typeof this.colorpickerCallback == 'function') {
+ this.colorpickerCallback(color$$1);
+ }
+ }
+ }
+ }, {
+ key: 'setCurrentHSV',
+ value: function setCurrentHSV(h, s, v, a) {
+ this.currentA = a;
+ this.currentH = h;
+ this.currentS = s;
+ this.currentV = v;
+ }
+ }, {
+ key: 'setCurrentH',
+ value: function setCurrentH(h) {
+ this.currentH = h;
+ }
+ }, {
+ key: 'setCurrentA',
+ value: function setCurrentA(a) {
+ this.currentA = a;
+ }
+ }, {
+ key: 'getHSV',
+ value: function getHSV(colorObj) {
+ if (colorObj.type == 'hsl') {
+ return color.HSLtoHSV(colorObj);
+ } else {
+ return color.RGBtoHSV(colorObj);
+ }
+ }
+ }, {
+ key: 'initColor',
+ value: function initColor(newColor, format) {
+ var c = newColor || "#FF0000",
+ colorObj = color.parse(c);
+ format = format || colorObj.type;
+
+ var hsv = this.getHSV(colorObj);
+ this.setCurrentHSV(hsv.h, hsv.s, hsv.v, colorObj.a);
+ }
+ }, {
+ key: 'checkColorPickerClass',
+ value: function checkColorPickerClass(el) {
+ var hasColorView = new Dom(el).closest('codemirror-colorview');
+ var hasColorPicker = new Dom(el).closest('codemirror-colorpicker');
+ var hasCodeMirror = new Dom(el).closest('CodeMirror');
+ var IsInHtml = el.nodeName == 'HTML';
+
+ return !!(hasColorPicker || hasColorView || hasCodeMirror);
+ }
+ }, {
+ key: 'checkInHtml',
+ value: function checkInHtml(el) {
+ var IsInHtml = el.nodeName == 'HTML';
+
+ return IsInHtml;
+ }
+ }, {
+ key: 'initializeEvent',
+ value: function initializeEvent() {
+
+ this.initializeEventMachin();
+ }
+ }, {
+ key: 'setColorSets',
+ value: function setColorSets(list) {
+ this.colorSetsList.setUserList(list);
+ }
+ }, {
+ key: 'destroy',
+ value: function destroy() {
+ get(BaseColorPicker.prototype.__proto__ || Object.getPrototypeOf(BaseColorPicker.prototype), 'destroy', this).call(this);
+
+ // remove color picker callback
+ this.colorpickerCallback = undefined;
}
}]);
- return ColorControl;
+ return BaseColorPicker;
}(EventMachin);
-var ColorInformation = function (_EventMachin) {
- inherits(ColorInformation, _EventMachin);
+var ColorControl = function (_EventMachin) {
+ inherits(ColorControl, _EventMachin);
- function ColorInformation(colorpicker) {
- classCallCheck(this, ColorInformation);
+ function ColorControl(colorpicker) {
+ classCallCheck(this, ColorControl);
- var _this = possibleConstructorReturn(this, (ColorInformation.__proto__ || Object.getPrototypeOf(ColorInformation)).call(this));
+ var _this = possibleConstructorReturn(this, (ColorControl.__proto__ || Object.getPrototypeOf(ColorControl)).call(this));
_this.colorpicker = colorpicker;
_this.initialize();
-
return _this;
}
- createClass(ColorInformation, [{
+ createClass(ColorControl, [{
key: 'initialize',
value: function initialize() {
- this.$el = new Dom('div', 'information hex');
+ this.template('\n \n ');
- this.$informationChange = this.$el.createChild('div', 'information-change');
+ this.drag_bar_pos = {};
+ this.opacity_drag_bar_pos = {};
+ }
+ }, {
+ key: 'setBackgroundColor',
+ value: function setBackgroundColor(color$$1) {
+ this.refs.$controlColor.css("background-color", color$$1);
+ }
+ }, {
+ key: 'refresh',
+ value: function refresh() {
+ this.setColorUI();
+ }
+ }, {
+ key: 'setOpacityColorBar',
+ value: function setOpacityColorBar(hueColor) {
+ var rgb = color.parse(hueColor);
- this.$formatChangeButton = this.$informationChange.createChild('button', 'format-change-button arrow-button', { type: 'button' });
+ rgb.a = 0;
+ var start = color.format(rgb, 'rgb');
- this.$el.append(this.makeInputFieldHex());
- this.$el.append(this.makeInputFieldRgb());
- this.$el.append(this.makeInputFieldHsl());
+ rgb.a = 1;
+ var end = color.format(rgb, 'rgb');
- this.format = 'hex';
+ this.refs.$opacityColorBar.css('background', 'linear-gradient(to right, ' + start + ', ' + end + ')');
}
}, {
- key: 'makeInputFieldHex',
- value: function makeInputFieldHex() {
- var item = new Dom('div', 'information-item hex');
- var field = item.createChild('div', 'input-field hex');
+ key: 'setOpacity',
+ value: function setOpacity(e) {
+ var min = this.refs.$opacityContainer.offset().left;
+ var max = min + this.state.get('$opacityContainer.width');
+ var current = Event.pos(e).clientX;
+ var dist;
- this.$hexCode = field.createChild('input', 'input', { type: 'text' });
+ var dist;
+ if (current < min) {
+ dist = 0;
+ this.refs.$opacity_drag_bar.addClass('first').removeClass('last');
+ } else if (current > max) {
+ dist = 100;
+ this.refs.$opacity_drag_bar.addClass('last').removeClass('first');
+ } else {
+ dist = (current - min) / (max - min) * 100;
+ this.refs.$opacity_drag_bar.removeClass('first').removeClass('last');
+ }
- field.createChild('div', 'title').html('HEX');
+ var x = this.state.get('$opacityContainer.width') * (dist / 100);
+
+ this.refs.$opacity_drag_bar.css({
+ // left: (x -Math.ceil(this.state.get('$opacity_drag_bar.width')/2)) + 'px'
+ left: x + 'px'
+ });
- return item;
+ this.opacity_drag_bar_pos = { x: x };
+
+ this.colorpicker.setCurrentA(this.caculateOpacity());
+ this.colorpicker.currentFormat();
+ this.colorpicker.setInputColor();
+ }
+ }, {
+ key: 'setInputColor',
+ value: function setInputColor() {
+ this.setBackgroundColor(this.colorpicker.getFormattedColor('rgb'));
+
+ var rgb = this.colorpicker.convertRGB();
+ var colorString = color.format(rgb, 'rgb');
+ this.setOpacityColorBar(colorString);
+ }
+ }, {
+ key: 'setColorUI',
+ value: function setColorUI() {
+
+ var hueX = this.state.get('$hueContainer.width') * (this.colorpicker.currentH / 360);
+
+ this.refs.$drag_bar.css({
+ // left : (hueX - 7.5) + 'px'
+ left: hueX + 'px'
+ });
+
+ this.drag_bar_pos = { x: hueX };
+
+ var opacityX = this.state.get('$opacityContainer.width') * (this.colorpicker.currentA || 0);
+
+ this.refs.$opacity_drag_bar.css({
+ // left : (opacityX - 7.5) + 'px'
+ left: opacityX + 'px'
+ });
+
+ this.opacity_drag_bar_pos = { x: opacityX };
+ }
+ }, {
+ key: 'caculateH',
+ value: function caculateH() {
+
+ var huePos = this.drag_bar_pos || { x: 0 };
+
+ var h = huePos.x / this.state.get('$hueContainer.width') * 360;
+
+ return { h: h };
}
}, {
- key: 'makeInputFieldRgb',
- value: function makeInputFieldRgb() {
- var item = new Dom('div', 'information-item rgb');
+ key: 'caculateOpacity',
+ value: function caculateOpacity() {
+ var opacityPos = this.opacity_drag_bar_pos || { x: 0 };
+ var a = Math.round(opacityPos.x / this.state.get('$opacityContainer.width') * 100) / 100;
- var field = item.createChild('div', 'input-field rgb-r');
- this.$rgb_r = field.createChild('input', 'input', { type: 'number', step: 1, min: 0, max: 255 });
- field.createChild('div', 'title').html('R');
+ return isNaN(a) ? 1 : a;
+ }
+ }, {
+ key: 'EventDocumentMouseMove',
+ value: function EventDocumentMouseMove(e) {
+ if (this.isHueDown) {
+ this.setHueColor(e);
+ }
- field = item.createChild('div', 'input-field rgb-g');
- this.$rgb_g = field.createChild('input', 'input', { type: 'number', step: 1, min: 0, max: 255 });
- field.createChild('div', 'title').html('G');
+ if (this.isOpacityDown) {
+ this.setOpacity(e);
+ }
+ }
+ }, {
+ key: 'EventDocumentMouseUp',
+ value: function EventDocumentMouseUp(e) {
+ this.isHueDown = false;
+ this.isOpacityDown = false;
+ }
+ }, {
+ key: 'setControlColor',
+ value: function setControlColor(color$$1) {
+ this.refs.$controlColor.css('background-color', color$$1);
+ }
+ }, {
+ key: 'setHueColor',
+ value: function setHueColor(e, isOnlyHue) {
+ var min = this.refs.$hueContainer.offset().left;
+ var max = min + this.state.get('$hueContainer.width');
+ var current = e ? Event.pos(e).clientX : min + (max - min) * (this.colorpicker.currentH / 360);
+
+ var dist;
+ if (current < min) {
+ dist = 0;
+ this.refs.$drag_bar.addClass('first').removeClass('last');
+ } else if (current > max) {
+ dist = 100;
+ this.refs.$drag_bar.addClass('last').removeClass('first');
+ } else {
+ dist = (current - min) / (max - min) * 100;
+ this.refs.$drag_bar.removeClass('first').removeClass('last');
+ }
+
+ var x = this.state.get('$hueContainer.width') * (dist / 100);
+
+ this.refs.$drag_bar.css({
+ // left: (x -Math.ceil(this.state.get('$drag_bar.width')/2)) + 'px'
+ left: x + 'px'
+ });
+
+ this.drag_bar_pos = { x: x };
+
+ var hueColor = HueColor.checkHueColor(dist / 100);
+
+ this.colorpicker.setBackgroundColor(hueColor);
+ this.colorpicker.setCurrentH(dist / 100 * 360);
+
+ if (!isOnlyHue) {
+ this.colorpicker.setInputColor();
+ }
+ }
+ }, {
+ key: 'setOnlyHueColor',
+ value: function setOnlyHueColor() {
+ this.setHueColor(null, true);
+ }
+ }, {
+ key: 'mousedown $drag_bar',
+ value: function mousedown$drag_bar(e) {
+ e.preventDefault();
+ this.isHueDown = true;
+ }
+ }, {
+ key: 'mousedown $opacity_drag_bar',
+ value: function mousedown$opacity_drag_bar(e) {
+ e.preventDefault();
+ this.isOpacityDown = true;
+ }
+ }, {
+ key: 'mousedown $hueContainer',
+ value: function mousedown$hueContainer(e) {
+ this.isHueDown = true;
+ this.setHueColor(e);
+ }
+ }, {
+ key: 'mousedown $opacityContainer',
+ value: function mousedown$opacityContainer(e) {
+ this.isOpacityDown = true;
+ this.setOpacity(e);
+ }
+ }]);
+ return ColorControl;
+}(EventMachin);
- field = item.createChild('div', 'input-field rgb-b');
- this.$rgb_b = field.createChild('input', 'input', { type: 'number', step: 1, min: 0, max: 255 });
- field.createChild('div', 'title').html('B');
+var ColorInformation = function (_EventMachin) {
+ inherits(ColorInformation, _EventMachin);
- // rgba
- field = item.createChild('div', 'input-field rgb-a');
- this.$rgb_a = field.createChild('input', 'input', { type: 'number', step: 0.01, min: 0, max: 1 });
- field.createChild('div', 'title').html('A');
+ function ColorInformation(colorpicker) {
+ classCallCheck(this, ColorInformation);
- return item;
- }
- }, {
- key: 'makeInputFieldHsl',
- value: function makeInputFieldHsl() {
- var item = new Dom('div', 'information-item hsl');
+ var _this = possibleConstructorReturn(this, (ColorInformation.__proto__ || Object.getPrototypeOf(ColorInformation)).call(this));
- var field = item.createChild('div', 'input-field hsl-h');
- this.$hsl_h = field.createChild('input', 'input', { type: 'number', step: 1, min: 0, max: 360 });
- field.createChild('div', 'title').html('H');
+ _this.colorpicker = colorpicker;
+ _this.initialize();
- field = item.createChild('div', 'input-field hsl-s');
- this.$hsl_s = field.createChild('input', 'input', { type: 'number', step: 1, min: 0, max: 100 });
- field.createChild('div', 'postfix').html('%');
- field.createChild('div', 'title').html('S');
+ return _this;
+ }
- field = item.createChild('div', 'input-field hsl-l');
- this.$hsl_l = field.createChild('input', 'input', { type: 'number', step: 1, min: 0, max: 100 });
- field.createChild('div', 'postfix').html('%');
- field.createChild('div', 'title').html('L');
+ createClass(ColorInformation, [{
+ key: 'initialize',
+ value: function initialize() {
- // rgba
- field = item.createChild('div', 'input-field hsl-a');
- this.$hsl_a = field.createChild('input', 'input', { type: 'number', step: 0.01, min: 0, max: 1 });
- field.createChild('div', 'title').html('A');
+ this.template('\n \n ');
- return item;
+ this.format = 'hex';
}
}, {
key: 'currentFormat',
@@ -6534,46 +6932,46 @@ var ColorInformation = function (_EventMachin) {
}, {
key: 'setRGBInput',
value: function setRGBInput(r, g, b) {
- this.$rgb_r.val(r);
- this.$rgb_g.val(g);
- this.$rgb_b.val(b);
- this.$rgb_a.val(this.colorpicker.currentA);
+ this.refs.$rgb_r.val(r);
+ this.refs.$rgb_g.val(g);
+ this.refs.$rgb_b.val(b);
+ this.refs.$rgb_a.val(this.colorpicker.currentA);
}
}, {
key: 'setHSLInput',
value: function setHSLInput(h, s, l) {
- this.$hsl_h.val(h);
- this.$hsl_s.val(s);
- this.$hsl_l.val(l);
- this.$hsl_a.val(this.colorpicker.currentA);
+ this.refs.$hsl_h.val(h);
+ this.refs.$hsl_s.val(s);
+ this.refs.$hsl_l.val(l);
+ this.refs.$hsl_a.val(this.colorpicker.currentA);
}
}, {
key: 'getHexFormat',
value: function getHexFormat() {
return color.format({
- r: this.$rgb_r.int(),
- g: this.$rgb_g.int(),
- b: this.$rgb_b.int()
+ r: this.refs.$rgb_r.int(),
+ g: this.refs.$rgb_g.int(),
+ b: this.refs.$rgb_b.int()
}, 'hex', this.colorpicker.opt.color);
}
}, {
key: 'getRgbFormat',
value: function getRgbFormat() {
return color.format({
- r: this.$rgb_r.int(),
- g: this.$rgb_g.int(),
- b: this.$rgb_b.int(),
- a: this.$rgb_a.float()
+ r: this.refs.$rgb_r.int(),
+ g: this.refs.$rgb_g.int(),
+ b: this.refs.$rgb_b.int(),
+ a: this.refs.$rgb_a.float()
}, 'rgb', this.colorpicker.opt.color);
}
}, {
key: 'getHslFormat',
value: function getHslFormat() {
return color.format({
- h: this.$hsl_h.val(),
- s: this.$hsl_s.val(),
- l: this.$hsl_l.val(),
- a: this.$hsl_a.float()
+ h: this.refs.$hsl_h.val(),
+ s: this.refs.$hsl_s.val(),
+ l: this.refs.$hsl_l.val(),
+ a: this.refs.$hsl_a.float()
}, 'hsl', this.colorpicker.opt.color);
}
}, {
@@ -6598,7 +6996,7 @@ var ColorInformation = function (_EventMachin) {
format = format || this.getFormat();
if (format == 'hex') {
- return this.$hexCode.val();
+ return this.refs.$hexCode.val();
} else if (format == 'rgb') {
return this.getRgbFormat(fixed);
} else if (format == 'hsl') {
@@ -6617,13 +7015,13 @@ var ColorInformation = function (_EventMachin) {
var rgb = null;
if (format == 'hex') {
- this.$hexCode.val(this.convertHEX());
+ this.refs.$hexCode.val(this.convertHEX());
var rgb = this.convertRGB();
this.setRGBInput(rgb.r, rgb.g, rgb.b, rgb.a);
} else if (format == 'rgb') {
var rgb = this.convertRGB();
this.setRGBInput(rgb.r, rgb.g, rgb.b, rgb.a);
- this.$hexCode.val(this.convertHEX());
+ this.refs.$hexCode.val(this.convertHEX());
} else if (format == 'hsl') {
var hsl = this.convertHSL();
this.setHSLInput(hsl.h, hsl.s, hsl.l, hsl.a);
@@ -6639,15 +7037,6 @@ var ColorInformation = function (_EventMachin) {
value: function checkNotNumberKey(e) {
return !Event.checkNumberKey(e);
}
-
- //'keydown.checkNotNumberKey $rgb_r' (e) { e.preventDefault(); }
- //'keydown.checkNotNumberKey $rgb_g' (e) { e.preventDefault(); }
- //'keydown.checkNotNumberKey $rgb_b' (e) { e.preventDefault(); }
-
- //'keydown.checkNumberKey $rgb_r' (e) { this.setRGBtoHexColor(e); }
- //'keydown.checkNumberKey $rgb_g' (e) { this.setRGBtoHexColor(e); }
- //'keydown.checkNumberKey $rgb_b' (e) { this.setRGBtoHexColor(e); }
-
}, {
key: 'changeRgbColor',
value: function changeRgbColor() {
@@ -6708,7 +7097,7 @@ var ColorInformation = function (_EventMachin) {
}, {
key: 'keyup $hexCode',
value: function keyup$hexCode(e) {
- var code = this.$hexCode.val();
+ var code = this.refs.$hexCode.val();
if (code.charAt(0) == '#' && code.length == 7) {
this.colorpicker.changeInformationColor(code);
@@ -6743,15 +7132,13 @@ var ColorPallet = function (_EventMachin) {
createClass(ColorPallet, [{
key: 'initialize',
value: function initialize() {
- this.$el = new Dom('div', 'color');
- this.$saturation = this.$el.createChild('div', 'saturation');
- this.$value = this.$saturation.createChild('div', 'value');
- this.$drag_pointer = this.$value.createChild('div', 'drag-pointer');
+
+ this.template('\n \n ');
}
}, {
key: 'setBackgroundColor',
- value: function setBackgroundColor(color$$1) {
- this.$el.css("background-color", color$$1);
+ value: function setBackgroundColor(color) {
+ this.$el.css("background-color", color);
}
}, {
key: 'refresh',
@@ -6777,7 +7164,7 @@ var ColorPallet = function (_EventMachin) {
var x = this.state.get('$el.width') * this.colorpicker.currentS,
y = this.state.get('$el.height') * (1 - this.colorpicker.currentV);
- this.$drag_pointer.css({
+ this.refs.$drag_pointer.css({
left: x - 5 + "px",
top: y - 5 + "px"
});
@@ -6799,7 +7186,7 @@ var ColorPallet = function (_EventMachin) {
if (y < 0) y = 0;else if (y > h) y = h;
- this.$drag_pointer.css({
+ this.refs.$drag_pointer.css({
left: x - 5 + 'px',
top: y - 5 + 'px'
});
@@ -6855,41 +7242,32 @@ var ColorSetsChooser = function (_EventMachin) {
createClass(ColorSetsChooser, [{
key: 'initialize',
value: function initialize() {
- // make colorset-chooser
- this.$el = new Dom('div', 'color-chooser');
-
- var $container = this.$el.createChild('div', 'color-chooser-container');
-
- var $header = $container.createChild('div', 'colorsets-item colorsets-item-header');
- $header.createChild('h1', 'title').html('Color Paletts');
-
- this.$toggleButton = $header.createChild('span', 'items').html('×');
-
- this.$colorsetsList = $container.createChild('div', 'colorsets-list');
+ this.template('\n \n ');
this.refresh();
}
}, {
key: 'refresh',
value: function refresh() {
- this.$colorsetsList.html(this.makeColorSetsList());
+ this.refs.$colorsetsList.html(this.makeColorSetsList());
}
}, {
key: 'makeColorItemList',
value: function makeColorItemList(colors) {
var maxCount = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 5;
+
var $list = new Dom('div');
for (var i = 0; i < maxCount; i++) {
- var color$$1 = colors[i] || 'rgba(255, 255, 255, 1)';
+ var color = colors[i] || 'rgba(255, 255, 255, 1)';
var $item = $list.createChild('div', 'color-item', {
- title: color$$1
+ title: color
});
$item.createChild('div', 'color-view', null, {
- 'background-color': color$$1
+ 'background-color': color
});
}
@@ -6961,144 +7339,6 @@ var ColorSetsChooser = function (_EventMachin) {
return ColorSetsChooser;
}(EventMachin);
-var colorSetsList = [{
- name: "Material",
- colors: ['#F44336', '#E91E63', '#9C27B0', '#673AB7', '#3F51B5', '#2196F3', '#03A9F4', '#00BCD4', '#009688', '#4CAF50', '#8BC34A', '#CDDC39', '#FFEB3B', '#FFC107', '#FF9800', '#FF5722', '#795548', '#9E9E9E', '#607D8B']
-}, {
- name: "Custom", "edit": true, "colors": []
-}, {
- name: "Color Scale", "scale": ['red', 'yellow', 'black'], count: 5
-}];
-
-var ColorSetsList = function () {
- function ColorSetsList(colorpicker) {
- classCallCheck(this, ColorSetsList);
-
- this.colorpicker = colorpicker;
-
- this.setUserList(this.colorpicker.getOption('colorSets'));
- }
-
- createClass(ColorSetsList, [{
- key: 'list',
- value: function list() {
- return this.userList || colorSetsList;
- }
- }, {
- key: 'setUserList',
- value: function setUserList(list) {
- this.userList = list;
-
- this.resetUserList();
-
- this.setCurrentColorSets();
- }
- }, {
- key: 'resetUserList',
- value: function resetUserList() {
- var _this = this;
-
- if (this.userList && this.userList.length) {
- this.userList = this.userList.map(function (element, index) {
-
- if (typeof element.colors == 'function') {
- var makeCallback = element.colors;
-
- element.colors = makeCallback(_this.colorpicker, _this);
- element._colors = makeCallback;
- }
-
- return Object.assign({
- name: 'color-' + index,
- colors: []
- }, element);
- });
- }
- }
- }, {
- key: 'setCurrentColorSets',
- value: function setCurrentColorSets(nameOrIndex) {
-
- var _list = this.list();
-
- if (typeof nameOrIndex == 'undefined') {
- this.currentColorSets = _list[0];
- } else if (typeof nameOrIndex == 'number') {
- this.currentColorSets = _list[nameOrIndex];
- } else {
- this.currentColorSets = _list.filter(function (obj) {
- return obj.name == nameOrIndex;
- })[0];
- }
- }
- }, {
- key: 'getCurrentColorSets',
- value: function getCurrentColorSets() {
- return this.currentColorSets;
- }
- }, {
- key: 'addCurrentColor',
- value: function addCurrentColor(color$$1) {
- if (Array.isArray(this.currentColorSets.colors)) {
- this.currentColorSets.colors.push(color$$1);
- }
- }
- }, {
- key: 'removeCurrentColor',
- value: function removeCurrentColor(index) {
- if (this.currentColorSets.colors[index]) {
- this.currentColorSets.colors.splice(index, 1);
- }
- }
- }, {
- key: 'removeCurrentColorToTheRight',
- value: function removeCurrentColorToTheRight(index) {
- if (this.currentColorSets.colors[index]) {
- this.currentColorSets.colors.splice(index, Number.MAX_VALUE);
- }
- }
- }, {
- key: 'clearPalette',
- value: function clearPalette() {
- if (this.currentColorSets.colors) {
- this.currentColorSets.colors = [];
- }
- }
- }, {
- key: 'getCurrentColors',
- value: function getCurrentColors() {
- return this.getColors(this.currentColorSets);
- }
- }, {
- key: 'getColors',
- value: function getColors(element) {
-
- if (element.scale) {
- return color.scale(element.scale, element.count);
- }
-
- return element.colors || [];
- }
- }, {
- key: 'getColorSetsList',
- value: function getColorSetsList() {
- var _this2 = this;
-
- return this.list().map(function (element) {
- return {
- name: element.name,
- edit: element.edit,
- colors: _this2.getColors(element)
- };
- });
- }
- }, {
- key: 'destroy',
- value: function destroy() {}
- }]);
- return ColorSetsList;
-}();
-
var CurrentColorSets = function (_EventMachin) {
inherits(CurrentColorSets, _EventMachin);
@@ -7123,16 +7363,16 @@ var CurrentColorSets = function (_EventMachin) {
var colors = this.colorSetsList.getCurrentColors();
for (var i = 0, len = colors.length; i < len; i++) {
- var color$$1 = colors[i];
+ var color = colors[i];
var item = list.createChild('div', 'color-item', {
- 'title': color$$1,
+ 'title': color,
'data-index': i,
- 'data-color': color$$1
+ 'data-color': color
});
item.createChild('div', 'empty');
item.createChild('div', 'color-view', null, {
- 'background-color': color$$1
+ 'background-color': color
});
}
@@ -7145,24 +7385,15 @@ var CurrentColorSets = function (_EventMachin) {
}, {
key: 'initialize',
value: function initialize() {
- // make colorsets view
- this.$el = new Dom('div', 'colorsets');
-
- var $colorSetsMenu = this.$el.createChild('div', 'menu', {
- title: 'Open Color Pallets'
- });
- this.$colorSetsColorList = this.$el.createChild('div', 'color-list');
- this.$colorSetsChooseButton = $colorSetsMenu.createChild('button', 'color-sets-choose-btn arrow-button', {
- type: 'button'
- });
+ this.template('\n \n ');
this.refresh();
}
}, {
key: 'refresh',
value: function refresh() {
- this.$colorSetsColorList.html(this.makeCurrentColorSets());
+ this.refs.$colorSetsColorList.html(this.makeCurrentColorSets());
}
}, {
key: 'refreshAll',
@@ -7172,8 +7403,8 @@ var CurrentColorSets = function (_EventMachin) {
}
}, {
key: 'addColor',
- value: function addColor(color$$1) {
- this.colorSetsList.addCurrentColor(color$$1);
+ value: function addColor(color) {
+ this.colorSetsList.addCurrentColor(color);
this.refreshAll();
}
}, {
@@ -7256,20 +7487,8 @@ var CurrentColorSetsContextMenu = function (_EventMachin) {
createClass(CurrentColorSetsContextMenu, [{
key: 'initialize',
value: function initialize() {
- // make colorsets view
- this.$el = new Dom('ul', 'colorsets-contextmenu');
- this.$el.createChild('li', 'menu-item small-hide', {
- 'data-type': 'remove-color'
- }).html('Remove color');
-
- this.$el.createChild('li', 'menu-item small-hide', {
- 'data-type': 'remove-all-to-the-right'
- }).html('Remove all to the right');
-
- this.$el.createChild('li', 'menu-item', {
- 'data-type': 'clear-palette'
- }).html('Clear palette');
+ this.template('\n \n ');
}
}, {
key: 'show',
@@ -7321,32 +7540,13 @@ var CurrentColorSetsContextMenu = function (_EventMachin) {
return CurrentColorSetsContextMenu;
}(EventMachin);
-var ColorPicker = function (_EventMachin) {
- inherits(ColorPicker, _EventMachin);
+var ColorPicker$1 = function (_BaseColorPicker) {
+ inherits(ColorPicker, _BaseColorPicker);
function ColorPicker(opt) {
classCallCheck(this, ColorPicker);
- var _this = possibleConstructorReturn(this, (ColorPicker.__proto__ || Object.getPrototypeOf(ColorPicker)).call(this));
-
- _this.opt = opt || {};
- _this.$body = null;
- _this.$root = null;
-
- _this.format = 'rgb';
- _this.currentA = 0;
- _this.currentH = 0;
- _this.currentS = 0;
- _this.currentV = 0;
-
- _this.colorSetsList = new ColorSetsList(_this);
- _this.colorpickerCallback = function () {};
-
- _this.isColorPickerShow = false;
- _this.isShortCut = false;
- _this.hideDelay = _this.opt.hideDeplay || 2000;
- _this.timerCloseColorPicker;
- _this.autoHide = _this.opt.autoHide || true;
+ var _this = possibleConstructorReturn(this, (ColorPicker.__proto__ || Object.getPrototypeOf(ColorPicker)).call(this, opt));
_this.control = new ColorControl(_this);
_this.palette = new ColorPallet(_this);
@@ -7360,49 +7560,10 @@ var ColorPicker = function (_EventMachin) {
}
createClass(ColorPicker, [{
- key: 'getOption',
- value: function getOption(key) {
- return this.opt[key];
- }
- }, {
- key: 'isType',
- value: function isType(key) {
- return this.getOption('type') == key;
- }
- }, {
- key: 'isPaletteType',
- value: function isPaletteType() {
- return this.isType('palette');
- }
- }, {
- key: 'isSketchType',
- value: function isSketchType() {
- return this.isType('sketch');
- }
- }, {
- key: 'getContainer',
- value: function getContainer() {
- return this.opt.container || document.body;
- }
- }, {
key: 'initialize',
value: function initialize() {
- this.$body = new Dom(this.getContainer());
- this.$root = new Dom('div', 'codemirror-colorpicker');
-
- // append colorpicker to container (ex : body)
- if (this.opt.position == 'inline') {
- this.$body.append(this.$root);
- }
-
- if (this.opt.type) {
- // to change css style
- this.$root.addClass(this.opt.type);
- }
-
- this.$arrow = new Dom('div', 'arrow');
+ get(ColorPicker.prototype.__proto__ || Object.getPrototypeOf(ColorPicker.prototype), 'initialize', this).call(this);
- this.$root.append(this.$arrow);
this.$root.append(this.palette.$el);
this.$root.append(this.control.$el);
this.$root.append(this.information.$el);
@@ -7736,23 +7897,6 @@ var ColorPicker = function (_EventMachin) {
value: function setHueColor() {
this.control.setOnlyHueColor();
}
- }, {
- key: 'checkColorPickerClass',
- value: function checkColorPickerClass(el) {
- var hasColorView = new Dom(el).closest('codemirror-colorview');
- var hasColorPicker = new Dom(el).closest('codemirror-colorpicker');
- var hasCodeMirror = new Dom(el).closest('CodeMirror');
- var IsInHtml = el.nodeName == 'HTML';
-
- return !!(hasColorPicker || hasColorView || hasCodeMirror);
- }
- }, {
- key: 'checkInHtml',
- value: function checkInHtml(el) {
- var IsInHtml = el.nodeName == 'HTML';
-
- return IsInHtml;
- }
// Event Bindings
@@ -7831,13 +7975,24 @@ var ColorPicker = function (_EventMachin) {
this.colorSetsList.destroy();
this.currentColorSets.destroy();
this.contextMenu.destroy();
-
- // remove color picker callback
- this.colorpickerCallback = undefined;
}
}]);
return ColorPicker;
-}(EventMachin);
+}(BaseColorPicker);
+
+var ColorPicker = {
+ create: function create(opts) {
+ switch (opts.type) {
+ case 'sketch':
+ case 'palette':
+ default:
+ return new ColorPicker$1(opts);
+ }
+ },
+
+ ColorPicker: ColorPicker$1,
+ ChromeDevToolColorPicker: ColorPicker$1
+};
var colorpicker_class = 'codemirror-colorview';
var colorpicker_background_class = 'codemirror-colorview-background';
@@ -7930,7 +8085,7 @@ var ColorView = function () {
if (this.opt.colorpicker) {
this.colorpicker = this.opt.colorpicker(this.opt);
} else {
- this.colorpicker = new ColorPicker(this.opt);
+ this.colorpicker = ColorPicker.create(this.opt);
}
this.init_event();
@@ -8263,16 +8418,16 @@ if (CodeMirror) {
});
}
-var index = {
+var index = _extends({
Color: color,
- ColorNames: ColorNames,
- ColorPicker: ColorPicker,
+ ColorNames: ColorNames
+}, ColorPicker, {
ImageFilter: ImageFilter,
GL: GL,
HueColor: HueColor,
Canvas: Canvas,
ImageLoader: ImageLoader
-};
+});
return index;
diff --git a/dist/codemirror-colorpicker.min.js b/dist/codemirror-colorpicker.min.js
index ac470f2..b21bf90 100644
--- a/dist/codemirror-colorpicker.min.js
+++ b/dist/codemirror-colorpicker.min.js
@@ -1 +1 @@
-var CodeMirrorColorPicker=function(t){"use strict";t=t&&t.hasOwnProperty("default")?t.default:t;var e={aliceblue:"rgb(240, 248, 255)",antiquewhite:"rgb(250, 235, 215)",aqua:"rgb(0, 255, 255)",aquamarine:"rgb(127, 255, 212)",azure:"rgb(240, 255, 255)",beige:"rgb(245, 245, 220)",bisque:"rgb(255, 228, 196)",black:"rgb(0, 0, 0)",blanchedalmond:"rgb(255, 235, 205)",blue:"rgb(0, 0, 255)",blueviolet:"rgb(138, 43, 226)",brown:"rgb(165, 42, 42)",burlywood:"rgb(222, 184, 135)",cadetblue:"rgb(95, 158, 160)",chartreuse:"rgb(127, 255, 0)",chocolate:"rgb(210, 105, 30)",coral:"rgb(255, 127, 80)",cornflowerblue:"rgb(100, 149, 237)",cornsilk:"rgb(255, 248, 220)",crimson:"rgb(237, 20, 61)",cyan:"rgb(0, 255, 255)",darkblue:"rgb(0, 0, 139)",darkcyan:"rgb(0, 139, 139)",darkgoldenrod:"rgb(184, 134, 11)",darkgray:"rgb(169, 169, 169)",darkgrey:"rgb(169, 169, 169)",darkgreen:"rgb(0, 100, 0)",darkkhaki:"rgb(189, 183, 107)",darkmagenta:"rgb(139, 0, 139)",darkolivegreen:"rgb(85, 107, 47)",darkorange:"rgb(255, 140, 0)",darkorchid:"rgb(153, 50, 204)",darkred:"rgb(139, 0, 0)",darksalmon:"rgb(233, 150, 122)",darkseagreen:"rgb(143, 188, 143)",darkslateblue:"rgb(72, 61, 139)",darkslategray:"rgb(47, 79, 79)",darkslategrey:"rgb(47, 79, 79)",darkturquoise:"rgb(0, 206, 209)",darkviolet:"rgb(148, 0, 211)",deeppink:"rgb(255, 20, 147)",deepskyblue:"rgb(0, 191, 255)",dimgray:"rgb(105, 105, 105)",dimgrey:"rgb(105, 105, 105)",dodgerblue:"rgb(30, 144, 255)",firebrick:"rgb(178, 34, 34)",floralwhite:"rgb(255, 250, 240)",forestgreen:"rgb(34, 139, 34)",fuchsia:"rgb(255, 0, 255)",gainsboro:"rgb(220, 220, 220)",ghostwhite:"rgb(248, 248, 255)",gold:"rgb(255, 215, 0)",goldenrod:"rgb(218, 165, 32)",gray:"rgb(128, 128, 128)",grey:"rgb(128, 128, 128)",green:"rgb(0, 128, 0)",greenyellow:"rgb(173, 255, 47)",honeydew:"rgb(240, 255, 240)",hotpink:"rgb(255, 105, 180)",indianred:"rgb(205, 92, 92)",indigo:"rgb(75, 0, 130)",ivory:"rgb(255, 255, 240)",khaki:"rgb(240, 230, 140)",lavender:"rgb(230, 230, 250)",lavenderblush:"rgb(255, 240, 245)",lawngreen:"rgb(124, 252, 0)",lemonchiffon:"rgb(255, 250, 205)",lightblue:"rgb(173, 216, 230)",lightcoral:"rgb(240, 128, 128)",lightcyan:"rgb(224, 255, 255)",lightgoldenrodyellow:"rgb(250, 250, 210)",lightgreen:"rgb(144, 238, 144)",lightgray:"rgb(211, 211, 211)",lightgrey:"rgb(211, 211, 211)",lightpink:"rgb(255, 182, 193)",lightsalmon:"rgb(255, 160, 122)",lightseagreen:"rgb(32, 178, 170)",lightskyblue:"rgb(135, 206, 250)",lightslategray:"rgb(119, 136, 153)",lightslategrey:"rgb(119, 136, 153)",lightsteelblue:"rgb(176, 196, 222)",lightyellow:"rgb(255, 255, 224)",lime:"rgb(0, 255, 0)",limegreen:"rgb(50, 205, 50)",linen:"rgb(250, 240, 230)",magenta:"rgb(255, 0, 255)",maroon:"rgb(128, 0, 0)",mediumaquamarine:"rgb(102, 205, 170)",mediumblue:"rgb(0, 0, 205)",mediumorchid:"rgb(186, 85, 211)",mediumpurple:"rgb(147, 112, 219)",mediumseagreen:"rgb(60, 179, 113)",mediumslateblue:"rgb(123, 104, 238)",mediumspringgreen:"rgb(0, 250, 154)",mediumturquoise:"rgb(72, 209, 204)",mediumvioletred:"rgb(199, 21, 133)",midnightblue:"rgb(25, 25, 112)",mintcream:"rgb(245, 255, 250)",mistyrose:"rgb(255, 228, 225)",moccasin:"rgb(255, 228, 181)",navajowhite:"rgb(255, 222, 173)",navy:"rgb(0, 0, 128)",oldlace:"rgb(253, 245, 230)",olive:"rgb(128, 128, 0)",olivedrab:"rgb(107, 142, 35)",orange:"rgb(255, 165, 0)",orangered:"rgb(255, 69, 0)",orchid:"rgb(218, 112, 214)",palegoldenrod:"rgb(238, 232, 170)",palegreen:"rgb(152, 251, 152)",paleturquoise:"rgb(175, 238, 238)",palevioletred:"rgb(219, 112, 147)",papayawhip:"rgb(255, 239, 213)",peachpuff:"rgb(255, 218, 185)",peru:"rgb(205, 133, 63)",pink:"rgb(255, 192, 203)",plum:"rgb(221, 160, 221)",powderblue:"rgb(176, 224, 230)",purple:"rgb(128, 0, 128)",rebeccapurple:"rgb(102, 51, 153)",red:"rgb(255, 0, 0)",rosybrown:"rgb(188, 143, 143)",royalblue:"rgb(65, 105, 225)",saddlebrown:"rgb(139, 69, 19)",salmon:"rgb(250, 128, 114)",sandybrown:"rgb(244, 164, 96)",seagreen:"rgb(46, 139, 87)",seashell:"rgb(255, 245, 238)",sienna:"rgb(160, 82, 45)",silver:"rgb(192, 192, 192)",skyblue:"rgb(135, 206, 235)",slateblue:"rgb(106, 90, 205)",slategray:"rgb(112, 128, 144)",slategrey:"rgb(112, 128, 144)",snow:"rgb(255, 250, 250)",springgreen:"rgb(0, 255, 127)",steelblue:"rgb(70, 130, 180)",tan:"rgb(210, 180, 140)",teal:"rgb(0, 128, 128)",thistle:"rgb(216, 191, 216)",tomato:"rgb(255, 99, 71)",turquoise:"rgb(64, 224, 208)",violet:"rgb(238, 130, 238)",wheat:"rgb(245, 222, 179)",white:"rgb(255, 255, 255)",whitesmoke:"rgb(245, 245, 245)",yellow:"rgb(255, 255, 0)",yellowgreen:"rgb(154, 205, 50)",transparent:"rgba(0, 0, 0, 0)"};var r={isColorName:function(t){return!!e[t]},getColorByName:function(t){return e[t]}};function n(t,e){if(t.length!==e.length)return!1;for(var r=0,n=t.length;r0)c=l(u);else c=e[Math.floor(a()*e.length)];o=!n(c,h),i[s]=c}return o}function h(t,e,r){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:10,a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"linear";t=t,e=e||Math.max(2,Math.ceil(Math.sqrt(t.length/2)));var l=r||"euclidean";"string"==typeof l&&(l=i[l]);for(var h=0,c=function(){return(h=(9301*h+49297)%233280)/233280},f=function(t,e){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"linear";return o[r](t.length,e).map(function(e){return t[e]})}(t,e,a),g=!0,v=0;g;){if(g=u(e,t,s(e,t,f,l),f,!1,c),++v%n==0)break}return f}var c={create:function(t,e){var r=document.createElement("canvas");return r.width=t||0,r.height=e||0,r},drawPixels:function(t){var e=this.create(t.width,t.height),r=e.getContext("2d"),n=r.getImageData(0,0,e.width,e.height);return n.data.set(t.pixels),r.putImageData(n,0,0),e},createHistogram:function(t,e,r,n){var i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{black:!0,red:!1,green:!1,blue:!1},o=this.create(t,e),a=o.getContext("2d");a.clearRect(0,0,t,e),a.fillStyle="white",a.fillRect(0,0,t,e),a.globalAlpha=.7;var l={black:!1};i.black?l.black=!1:l.black=!0,i.red?l.red=!1:l.red=!0,i.green?l.green=!1:l.green=!0,i.blue?l.blue=!1:l.blue=!0,Object.keys(r).forEach(function(n){if(!l[n]){var i=r[n],o=Math.max.apply(Math,i),s=t/i.length;a.fillStyle=n,i.forEach(function(t,r){var n=e*(t/o),i=r*s;a.fillRect(i,e-n,s,n)})}}),"function"==typeof n&&n(o)},getHistogram:function(t){for(var e,r,n=new Array(256),i=new Array(256),o=new Array(256),a=new Array(256),l=0;l<256;l++)n[l]=0,i[l]=0,o[l]=0,a[l]=0;return r=function(t,e){var r=Math.round(Yt.brightness(t[e],t[e+1],t[e+2]));n[r]++,i[t[e]]++,o[t[e+1]]++,a[t[e+2]]++},function(t,e){for(var r=0;r1&&void 0!==arguments[1]?arguments[1]:{};g(this,t),this.isLoaded=!1,this.imageUrl=e,this.opt=r,this.initialize()}return v(t,[{key:"initialize",value:function(){this.canvas=this.createCanvas(),this.context=this.canvas.getContext("2d")}},{key:"createCanvas",value:function(){return document.createElement("canvas")}},{key:"load",value:function(t){this.loadImage(t)}},{key:"loadImage",value:function(t){var e=this,r=this.context;this.newImage=new Image;var n=this.newImage;n.onload=function(){var i=n.height/n.width;e.opt.canvasWidth&&e.opt.canvasHeight?(e.canvas.width=e.opt.canvasWidth,e.canvas.height=e.opt.canvasHeight):(e.canvas.width=e.opt.maxWidth?e.opt.maxWidth:n.width,e.canvas.height=e.canvas.width*i),r.drawImage(n,0,0,n.width,n.height,0,0,e.canvas.width,e.canvas.height),e.isLoaded=!0,t&&t()},this.getImageUrl(function(t){n.src=t})}},{key:"load",value:function(t){var e=this;this.newImage=new Image;var r=this.newImage;r.onload=function(){e.isLoaded=!0,t&&t()},this.getImageUrl(function(t){r.src=t})}},{key:"getImageUrl",value:function(t){if("string"==typeof this.imageUrl)return t(this.imageUrl);if(this.imageUrl instanceof Blob){var e=new FileReader;e.onload=function(e){t(e.target.result)},e.readAsDataURL(this.imageUrl)}}},{key:"getRGBA",value:function(t,e,r,n){return[t,e,r,n]}},{key:"toArray",value:function(t,e){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},n=this.context.getImageData(0,0,this.canvas.width,this.canvas.height),i=n.width,o=n.height,a=new Uint8ClampedArray(n.data);t||(t=function(t,e){e(t)}),t({pixels:a,width:i,height:o},function(t){var n=c.drawPixels(t);"canvas"==r.returnTo?e(n):e(n.toDataURL(r.outputFormat||"image/png"))},r)}},{key:"toHistogram",value:function(t){var e=this.context.getImageData(0,0,this.canvas.width,this.canvas.height),r=e.width,n=e.height,i={pixels:new Uint8ClampedArray(e.data),width:r,height:n};return c.getHistogram(i)}},{key:"toRGB",value:function(){for(var t=this.context.getImageData(0,0,this.canvas.width,this.canvas.height).data,e=[],r=0,n=t.length;r0&&void 0!==arguments[0]?arguments[0]:1,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1;return[t=t||0===t?t:1,0,0,0,e=e||0===e?e:1,0,0,0,1]},scaleX:function(t){return this.scale(t)},scaleY:function(t){return this.scale(1,t)},translate:function(t,e){return[1,0,t,0,1,e,0,0,1]},rotate:function(t){var e=this.radian(t);return[Math.cos(e),-Math.sin(e),0,Math.sin(e),Math.cos(e),0,0,0,1]},rotate90:function(){return[0,-1,0,1,0,0,0,0,1]},rotate180:function(){return[-1,0,0,0,-1,0,0,0,1]},rotate270:function(){return[0,1,0,-1,0,0,0,0,1]},radian:function(t){return t*Math.PI/180},skew:function(t,e){var r=this.radian(t),n=this.radian(e);return[1,Math.tan(r),0,Math.tan(n),1,0,0,0,1]},skewX:function(t){var e=this.radian(t);return[1,Math.tan(e),0,0,1,0,0,0,1]},skewY:function(t){var e=this.radian(t);return[1,0,0,Math.tan(e),1,0,0,0,1]},shear1:function(t){return[1,-Math.tan(this.radian(t)/2),0,0,1,0,0,0,1]},shear2:function(t){return[1,0,0,Math.sin(this.radian(t)),1,0,0,0,1]}},w={CONSTANT:x,radian:function(t){return x.radian(t)},multiply:function(t,e){return[t[0]*e[0]+t[1]*e[1]+t[2]*e[2],t[3]*e[0]+t[4]*e[1]+t[5]*e[2],t[6]*e[0]+t[7]*e[1]+t[8]*e[2]]},identity:function(t){return this.multiply(x.identity(),t)},translate:function(t,e,r){return this.multiply(x.translate(t,e),r)},rotate:function(t,e){return this.multiply(x.rotate(t),e)},shear1:function(t,e){return this.multiply(x.shear1(t),e)},shear2:function(t,e){return this.multiply(x.shear2(t),e)},rotateShear:function(t,e){var r=e;return r=this.shear1(t,r),r=this.shear2(t,r),r=this.shear1(t,r)}};function _(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"center",r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"center";return function(n,i){var o=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},a=Q(n.pixels.length,n.width,n.height),l=n.width,s=n.height;"center"==e&&(e=Math.floor(l/2)),"center"==r&&(r=Math.floor(s/2));var u=w.CONSTANT.translate(-e,-r),h=w.CONSTANT.translate(e,r),c=w.CONSTANT.shear1(t),f=w.CONSTANT.shear2(t);st(function(t,e,r,i){var o=w.multiply(u,[r,i,1]);o=w.multiply(c,o).map(Math.round),o=w.multiply(f,o).map(Math.round),o=w.multiply(c,o).map(Math.round),o=w.multiply(h,o);var a=k(o,2),g=a[0],v=a[1];g<0||(v<0||g>l-1||v>s-1||ct(t,v*l+g<<2,n.pixels,e))})(a,function(){i(a)},o)}}function S(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:200,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:100,r=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],n=rt(t),i=(e=rt(e))/100,o=r;return ot(function(){var t=i*Math.ceil(.2126*$r+.7152*$g+.0722*$b)>=n?255:0;if(o)0==t&&($r=0,$g=0,$b=0);else{var e=Math.round(t);$r=e,$g=e,$b=e}},{$C:i,$scale:n,$hasColor:o})}function E(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100;return ft(Y([1,2,1,2,4,2,1,2,1],1/16*((t=rt(t))/100)))}function M(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100;return ft(Y([1,4,6,4,1,4,16,24,16,4,6,24,36,24,6,4,16,24,16,4,1,4,6,4,1],1/256*((t=rt(t))/100)))}function A(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1;return t=rt(t),ft([5,5,5,-3,0,-3,-3,-3,-3])}function R(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1;return t=rt(t),ft([5,-3,-3,5,0,-3,5,-3,-3])}function T(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100;return ft(Y([-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,24,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1],(t=rt(t))/100))}function B(){return ft(Y([1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1],1/9))}function I(){return ft(Y([1,0,0,0,0,0,0,0,1,0,1,0,0,0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,0,0,1,0,1,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,1,0,1,0,0,0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,0,0,1,0,1,0,0,0,0,0,0,0,1],1/9))}function F(){return ft(Y([1,0,0,0,1,0,0,0,1,0,1,0,0,1,0,0,1,0,0,0,1,0,1,0,1,0,0,0,0,0,1,1,1,0,0,0,1,1,1,1,1,1,1,1,1,0,0,0,1,1,1,0,0,0,0,0,1,0,1,0,1,0,0,0,1,0,0,1,0,0,1,0,1,0,0,0,1,0,0,0,1],1/9))}function H(){return ft([-1,-2,-1,0,0,0,1,2,1])}function L(){return ft([-1,0,1,-2,0,2,-1,0,1])}var O=[512,512,456,512,328,456,335,512,405,328,271,456,388,335,292,512,454,405,364,328,298,271,496,456,420,388,360,335,312,292,273,512,482,454,428,405,383,364,345,328,312,298,284,271,259,496,475,456,437,420,404,388,374,360,347,335,323,312,302,292,282,273,265,512,497,482,468,454,441,428,417,405,394,383,373,364,354,345,337,328,320,312,305,298,291,284,278,271,265,259,507,496,485,475,465,456,446,437,428,420,412,404,396,388,381,374,367,360,354,347,341,335,329,323,318,312,307,302,297,292,287,282,278,273,269,265,261,512,505,497,489,482,475,468,461,454,447,441,435,428,422,417,411,405,399,394,389,383,378,373,368,364,359,354,350,345,341,337,332,328,324,320,316,312,309,305,301,298,294,291,287,284,281,278,274,271,268,265,262,259,257,507,501,496,491,485,480,475,470,465,460,456,451,446,442,437,433,428,424,420,416,412,408,404,400,396,392,388,385,381,377,374,370,367,363,360,357,354,350,347,344,341,338,335,332,329,326,323,320,318,315,312,310,307,304,302,299,297,294,292,289,287,285,282,280,278,275,273,271,269,267,265,263,261,259],P=[9,11,12,13,13,14,14,15,15,15,15,16,16,16,16,17,17,17,17,17,17,17,18,18,18,18,18,18,18,18,18,19,19,19,19,19,19,19,19,19,19,19,19,19,19,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24];function G(){this.r=0,this.g=0,this.b=0,this.a=0,this.next=null}function D(t,e,r){return r?function(t,e,r,n){if(isNaN(n)||n<1)return t;n|=0;var i,o,a,l,s,u,h,c,f,g,v,d,p,m,b,y,k,C,$,x,w,_,S,E,M=t.pixels,A=t.width,R=t.height,T=n+n+1,B=A-1,I=R-1,F=n+1,H=F*(F+1)/2,L=new G,D=L;for(a=1;a>V,0!=S?(S=255/S,M[u]=(c*z>>V)*S,M[u+1]=(f*z>>V)*S,M[u+2]=(g*z>>V)*S):M[u]=M[u+1]=M[u+2]=0,c-=d,f-=p,g-=m,v-=b,d-=U.r,p-=U.g,m-=U.b,b-=U.a,l=h+((l=i+n+1)>V,S>0?(S=255/S,M[l]=(c*z>>V)*S,M[l+1]=(f*z>>V)*S,M[l+2]=(g*z>>V)*S):M[l]=M[l+1]=M[l+2]=0,c-=d,f-=p,g-=m,v-=b,d-=U.r,p-=U.g,m-=U.b,b-=U.a,l=i+((l=o+F)0&&void 0!==arguments[0]?arguments[0]:10,e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];return t=rt(t),function(r,n){n(D(r,t,e))}}function U(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:256;return ft(Y([1,4,6,4,1,4,16,24,16,4,6,24,-476,24,6,4,16,24,16,4,1,4,6,4,1],-1/(t=rt(t))))}var j,z=p({},{crop:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,r=arguments[2],n=arguments[3],i=Q(r*n*4,r,n);return function(o,a){for(var l=e,s=0;l0&&void 0!==arguments[0]?arguments[0]:0;return t=rt(t),t%=360,function(e,r){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};if(0==t)return e;if(90==t||270==t)var i=Q(e.pixels.length,e.height,e.width);else{if(180!=t)return _(t)(e,r,n);i=Q(e.pixels.length,e.width,e.height)}st(function(r,n,o,a){if(90==t)var l=o*i.width+(i.width-1-a)<<2;else 270==t?l=(i.height-1-o)*i.width+a<<2:180==t&&(l=(i.height-1-a)*i.width+(i.width-1-o)<<2);ct(i.pixels,l,e.pixels,n)})(e,function(){r(i)},n)}},rotateDegree:_,histogram:function(){for(var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"gray",e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[],r=[],n=0;n2&&void 0!==arguments[2]?arguments[2]:100,n=Yt.parse(t),i=Yt.parse(e),o=r;return ot(function(){var t=$r+$g+$b<=o?n:i;$r=t.r,$g=t.g,$b=t.b},{$threshold:o},{$darkColor:n,$lightColor:i})},brightness:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1;t=rt(t);var e=Math.floor(t/100*255);return ot(function(){$r+=e,$g+=e,$b+=e},{$C:e})},brownie:function(){var t=[.5997023498159715,.34553243048391263,-.2708298674538042,0,-.037703249837783157,.8609577587992641,.15059552388459913,0,.24113635128153335,-.07441037908422492,.44972182064877153,0,0,0,0,1];return ot(function(){$r=t[0]*$r+t[1]*$g+t[2]*$b+t[3]*$a,$g=t[4]*$r+t[5]*$g+t[6]*$b+t[7]*$a,$b=t[8]*$r+t[9]*$g+t[10]*$b+t[11]*$a,$a=t[12]*$r+t[13]*$g+t[14]*$b+t[15]*$a},{$matrix:t})},clip:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0;t=rt(t);var e=2.55*Math.abs(t);return ot(function(){$r=$r>255-e?255:0,$g=$g>255-e?255:0,$b=$b>255-e?255:0},{$C:e})},contrast:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0;t=rt(t);var e=Math.max((128+t)/128,0);return ot(function(){$r*=e,$g*=e,$b*=e},{$C:e})},gamma:function(){var t=rt(arguments.length>0&&void 0!==arguments[0]?arguments[0]:1);return ot(function(){$r=255*Math.pow($r/255,t),$g=255*Math.pow($g/255,t),$b=255*Math.pow($b/255,t)},{$C:t})},gradient:function(){var t=[].concat(Array.prototype.slice.call(arguments));1===t.length&&"string"==typeof t[0]&&(t=Yt.convertMatchesArray(t[0]));var e=(t=t.map(function(t){return Yt.matches(t).length?{type:"param",value:t}:{type:"scale",value:t}})).filter(function(t){return"scale"==t.type})[0];e=e?+e.value:256,t=t.filter(function(t){return"param"==t.type}).map(function(t){return t.value}).join(",");var r=Yt.gradient(t,e).map(function(t){var e=Yt.parse(t);return{r:e.r,g:e.g,b:e.b,a:e.a}});return ot(function(){var t=dt(Math.ceil(.2126*$r+.7152*$g+.0722*$b)),n=dt(Math.floor(t*(e/256))),i=r[n];$r=i.r,$g=i.g,$b=i.b,$a=dt(Math.floor(256*i.a))},{},{$colors:r,$scale:e})},grayscale:function(t){var e=(t=rt(t))/100;e>1&&(e=1);var r=[.2126+.7874*(1-e),.7152-.7152*(1-e),.0722-.0722*(1-e),0,.2126-.2126*(1-e),.7152+.2848*(1-e),.0722-.0722*(1-e),0,.2126-.2126*(1-e),.7152-.7152*(1-e),.0722+.9278*(1-e),0,0,0,0,1];return ot(function(){$r=r[0]*$r+r[1]*$g+r[2]*$b+r[3]*$a,$g=r[4]*$r+r[5]*$g+r[6]*$b+r[7]*$a,$b=r[8]*$r+r[9]*$g+r[10]*$b+r[11]*$a,$a=r[12]*$r+r[13]*$g+r[14]*$b+r[15]*$a},{$matrix:r})},hue:function(){return ot(function(){var t=Color.RGBtoHSV($r,$g,$b),e=t.h;e+=Math.abs($amount),e%=360,t.h=e;var r=Color.HSVtoRGB(t);$r=r.r,$g=r.g,$b=r.b},{$C:rt(arguments.length>0&&void 0!==arguments[0]?arguments[0]:360)})},invert:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100,e=(t=rt(t))/100;return ot(function(){$r=(255-$r)*e,$g=(255-$g)*e,$b=(255-$b)*e},{$C:e})},kodachrome:function(){var t=[1.1285582396593525,-.3967382283601348,-.03992559172921793,0,-.16404339962244616,1.0835251566291304,-.05498805115633132,0,-.16786010706155763,-.5603416277695248,1.6014850761964943,0,0,0,0,1];return ot(function(){$r=t[0]*$r+t[1]*$g+t[2]*$b+t[3]*$a,$g=t[4]*$r+t[5]*$g+t[6]*$b+t[7]*$a,$b=t[8]*$r+t[9]*$g+t[10]*$b+t[11]*$a,$a=t[12]*$r+t[13]*$g+t[14]*$b+t[15]*$a},{$matrix:t})},matrix:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:0,o=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,a=arguments.length>6&&void 0!==arguments[6]?arguments[6]:0,l=arguments.length>7&&void 0!==arguments[7]?arguments[7]:0,s=arguments.length>8&&void 0!==arguments[8]?arguments[8]:0,u=arguments.length>9&&void 0!==arguments[9]?arguments[9]:0,h=arguments.length>10&&void 0!==arguments[10]?arguments[10]:0,c=arguments.length>11&&void 0!==arguments[11]?arguments[11]:0,f=arguments.length>12&&void 0!==arguments[12]?arguments[12]:0,g=arguments.length>13&&void 0!==arguments[13]?arguments[13]:0,v=arguments.length>14&&void 0!==arguments[14]?arguments[14]:0,d=arguments.length>15&&void 0!==arguments[15]?arguments[15]:0,p=[t,e,r,n,i,o,a,l,s,u,h,c,f,g,v,d];return ot(function(){$r=p[0]*$r+p[1]*a+p[2]*e+p[3]*t,a=p[4]*$r+p[5]*a+p[6]*e+p[7]*t,e=p[8]*$r+p[9]*a+p[10]*e+p[11]*t,t=p[12]*$r+p[13]*a+p[14]*e+p[15]*t},{$matrix:p})},noise:function(){var t=rt(arguments.length>0&&void 0!==arguments[0]?arguments[0]:1);return ot(function(){var e=5*Math.abs(t),r=-e,n=e,i=Math.round(r+Math.random()*(n-r));$r+=i,$g+=i,$b+=i},{$C:t})},opacity:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100,e=(t=rt(t))/100;return ot(function(){$a*=e},{$C:e})},polaroid:function(){var t=[1.438,-.062,-.062,0,-.122,1.378,-.122,0,-.016,-.016,1.483,0,0,0,0,1];return ot(function(){$r=t[0]*$r+t[1]*$g+t[2]*$b+t[3]*$a,$g=t[4]*$r+t[5]*$g+t[6]*$b+t[7]*$a,$b=t[8]*$r+t[9]*$g+t[10]*$b+t[11]*$a,$a=t[12]*$r+t[13]*$g+t[14]*$b+t[15]*$a},{$matrix:t})},saturation:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100,e=(t=rt(t))/100,r=1-Math.abs(e),n=[r,0,0,0,0,r,0,0,0,0,r,0,0,0,0,r];return ot(function(){$r=n[0]*$r+n[1]*$g+n[2]*$b+n[3]*$a,$g=n[4]*$r+n[5]*$g+n[6]*$b+n[7]*$a,$b=n[8]*$r+n[9]*$g+n[10]*$b+n[11]*$a,$a=n[12]*$r+n[13]*$g+n[14]*$b+n[15]*$a},{$matrix:n})},sepia:function(){var t=rt(arguments.length>0&&void 0!==arguments[0]?arguments[0]:1);t>1&&(t=1);var e=[.393+.607*(1-t),.769-.769*(1-t),.189-.189*(1-t),0,.349-.349*(1-t),.686+.314*(1-t),.168-.168*(1-t),0,.272-.272*(1-t),.534-.534*(1-t),.131+.869*(1-t),0,0,0,0,1];return ot(function(){$r=e[0]*$r+e[1]*$g+e[2]*$b+e[3]*$a,$g=e[4]*$r+e[5]*$g+e[6]*$b+e[7]*$a,$b=e[8]*$r+e[9]*$g+e[10]*$b+e[11]*$a,$a=e[12]*$r+e[13]*$g+e[14]*$b+e[15]*$a},{$matrix:e})},shade:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1,n=rt(t),i=rt(e),o=rt(r);return ot(function(){$r*=n,$g*=i,$b*=o},{$redValue:n,$greenValue:i,$blueValue:o})},shift:function(){var t=[1.438,-.062,-.062,0,-.122,1.378,-.122,0,-.016,-.016,1.483,0,0,0,0,1];return ot(function(){$r=t[0]*$r+t[1]*$g+t[2]*$b+t[3]*$a,$g=t[4]*$r+t[5]*$g+t[6]*$b+t[7]*$a,$b=t[8]*$r+t[9]*$g+t[10]*$b+t[11]*$a,$a=t[12]*$r+t[13]*$g+t[14]*$b+t[15]*$a},{$matrix:t})},solarize:function(t,e,r){var n=rt(t),i=rt(e),o=rt(r);return ot(function(){$r=$r0&&void 0!==arguments[0]?arguments[0]:200,arguments.length>1&&void 0!==arguments[1]?arguments[1]:100,!1)},"threshold-color":S,tint:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1,n=parseParamNumber(t),i=parseParamNumber(e),o=parseParamNumber(r);return ot(function(){$r+=(255-$r)*n,$g+=(255-$g)*i,$b+=(255-$b)*o},{$redTint:n,$greenTint:i,$blueTint:o})}},{blur:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:3;return ft(ut(t=rt(t)))},emboss:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:4;return ft([-2*(t=rt(t)),-t,0,-t,1,t,0,t,2*t])},gaussianBlur:E,"gaussian-blur":E,gaussianBlur5x:M,"gaussian-blur-5x":M,grayscale2:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100;return ft(Y([.3,.3,.3,0,0,.59,.59,.59,0,0,.11,.11,.11,0,0,0,0,0,0,0,0,0,0,0,0],(t=rt(t))/100))},normal:function(){return ft([0,0,0,0,1,0,0,0,0])},kirschHorizontal:A,"kirsch-horizontal":A,kirschVertical:R,"kirsch-vertical":R,laplacian:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100;return ft(Y([-1,-1,-1,-1,8,-1,-1,-1,-1],(t=rt(t))/100))},laplacian5x:T,"laplacian-5x":T,motionBlur:B,"motion-blur":B,motionBlur2:I,"motion-blur-2":I,motionBlur3:F,"motion-blur-3":F,negative:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100;return ft(Y([-1,0,0,0,0,0,-1,0,0,0,0,0,-1,0,0,0,0,0,1,0,1,1,1,1,1],(t=rt(t))/100))},sepia2:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100;return ft(Y([.393,.349,.272,0,0,.769,.686,.534,0,0,.189,.168,.131,0,0,0,0,0,0,0,0,0,0,0,0],(t=rt(t))/100))},sharpen:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100;return ft(Y([0,-1,0,-1,5,-1,0,-1,0],(t=rt(t))/100))},sobelHorizontal:H,"sobel-horizontal":H,sobelVertical:L,"sobel-vertical":L,stackBlur:N,"stack-blur":N,transparency:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100;return ft(Y([1,0,0,0,0,0,1,0,0,0,0,0,1,0,0,0,0,0,.3,0,0,0,0,0,1],(t=rt(t))/100))},unsharpMasking:U,"unsharp-masking":U},{kirsch:function(){return pt("kirsch-horizontal kirsch-vertical")},sobel:function(){return pt("sobel-horizontal sobel-vertical")},vintage:function(){return pt("brightness(15) saturation(-20) gamma(1.8)")}}),V=0,X=(d(j={partial:kt,multi:bt,merge:yt,weight:Y,repeat:q,colorMatrix:function(t,e,r){var n=t[e],i=t[e+1],o=t[e+2],a=t[e+3];ht(t,e,r[0]*n+r[1]*i+r[2]*o+r[3]*a,r[4]*n+r[5]*i+r[6]*o+r[7]*a,r[8]*n+r[9]*i+r[10]*o+r[11]*a,r[12]*n+r[13]*i+r[14]*o+r[15]*a)},each:Z,eachXY:J,createRandomCount:function(){return[9,16,25,36,49,64,81,100].sort(function(t,e){return.5-Math.random()})[0]},createRandRange:function(t,e,r){for(var n=[],i=1;i<=r;i++){var o=Math.random()*(e-t)+t,a=Math.floor(10*Math.random())%2==0?-1:1;n.push(a*o)}n.sort();var l=Math.floor(r>>1),s=n[l];return n[l]=n[0],n[0]=s,n},createBitmap:Q,createBlurMatrix:ut,pack:function(t){return function(e,r){Z(e.pixels.length,function(r,n){t(e.pixels,r,n,e.pixels[r],e.pixels[r+1],e.pixels[r+2],e.pixels[r+3])},function(){r(e)})}},packXY:st,pixel:ot,getBitmap:tt,putBitmap:et,radian:function(t){return w.CONSTANT.radian(t)},convolution:ft,parseParamNumber:rt,filter:pt,clamp:dt,fillColor:ht,fillPixelColor:ct},"multi",bt),d(j,"merge",yt),d(j,"matches",gt),d(j,"parseFilter",vt),d(j,"partial",kt),j),W=X;function Y(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1;return t.map(function(t){return t*e})}function q(t,e){for(var r=new Array(e),n=0;n1&&void 0!==arguments[1]?arguments[1]:0,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1,n=arguments[3],i=arguments[4],o=arguments.length>5&&void 0!==arguments[5]?arguments[5]:1e4,a=arguments.length>6&&void 0!==arguments[6]?arguments[6]:"full",l=arguments.length>7&&void 0!==arguments[7]?arguments[7]:50,s=e,u=function(t){setTimeout(t,0)};function h(){for(var e=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:50,e=[].concat(C(Array(t))).map(function(t){return"cri = ri + i * s; if (cri >= mx) return {currentRunIndex: cri, i: null}; c(cri); i++;"}).join("\n");return new Function("ri","i","s","mx","c","\n let cri = ri;\n \n "+e+"\n \n return {currentRunIndex: cri, i: i} \n ")}(l),a=s,c={},f=0;f=t)return void i();u?u(h):h()}(a)}"requestAnimationFrame"==a&&(u=requestAnimationFrame,o=1e3),"full"==a&&(u=null,o=t),h()}function Z(t,e,r){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};K(t,0,4,function(t){e(t,t>>2)},function(){r()},n.functionDumpCount,n.frameTimer,n.loopCount)}function J(t,e,r,n){var i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{};K(t,0,4,function(t){var n=t>>2;r(t,n%e,Math.floor(n/e))},function(){n()},i.functionDumpCount,i.frameTimer,i.loopCount)}function Q(t,e,r){return{pixels:new Uint8ClampedArray(t),width:e,height:r}}function tt(t,e){return c.getBitmap(t,e)}function et(t,e,r){return c.putBitmap(t,e,r)}function rt(t){return"string"==typeof t&&(t=(t=t.replace(/deg/,"")).replace(/px/,"")),+t}var nt=/(([\w_\-]+)(\(([^\)]*)\))?)+/gi;function it(t){var e,r,n,i,o,a=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},l=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};return e={},r=[{callback:t,context:a,rootContext:l}].map(function(t){var r=[];Object.keys(t.context).forEach(function(t,e){r[t]="n$"+V+++t+"$"}),Object.keys(t.rootContext).forEach(function(n,i){r[n]="r$"+V+++n+"$",e[r[n]]=t.rootContext[n]});var n=Object.keys(t.context).filter(function(e){return"number"!=typeof t.context[e]&&"string"!=typeof t.context[e]&&(!Array.isArray(t.context[e])||"number"!=typeof t.context[e][0]&&"string"!=typeof t.context[e][0])}).map(function(e,n){return[r[e],JSON.stringify(t.context[e])].join(" = ")}),i=t.callback.toString().split("{");return i.shift(),(i=(i=i.join("{")).split("}")).pop(),i=i.join("}"),Object.keys(r).forEach(function(e){var n=r[e];"number"==typeof t.context[e]||"string"==typeof t.context[e]?i=i.replace(new RegExp("\\"+e,"g"),t.context[e]):!Array.isArray(t.context[e])||"number"!=typeof t.context[e][0]&&"string"!=typeof t.context[e][0]?i=i.replace(new RegExp("\\"+e,"g"),n):t.context[e].forEach(function(t,r){i=i.replace(new RegExp("\\"+e+"\\["+r+"\\]","g"),t)})}),{preCallbackString:i,preContext:n}}),n=r.map(function(t,e){return t.preContext.length?"const "+t.preContext+";":""}).join("\n\n"),i=r.map(function(t){return t.preCallbackString}).join("\n\n"),(o=new Function("$pixels","$pixelIndex","$clamp","$Color"," \n let $r = $pixels[$pixelIndex], $g = $pixels[$pixelIndex+1], $b = $pixels[$pixelIndex+2], $a = $pixels[$pixelIndex+3];\n\n "+n+"\n\n "+i+"\n \n $pixels[$pixelIndex] = $r\n $pixels[$pixelIndex+1] = $g \n $pixels[$pixelIndex+2] = $b \n $pixels[$pixelIndex+3] = $a \n ")).$preCallbackString=i,o.$preContext=n,o.rootContextObject=e,o}function ot(t){var e=it(t,arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},arguments.length>2&&void 0!==arguments[2]?arguments[2]:{}),r=function(t,e){};return r.userFunction=e,r}var at=[0,1,2,3];function lt(t,e,r){at.forEach(function(n){var i=t[e+n];t[e+n]=t[r+n],t[r+n]=i})}function st(t){return function(e,r){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};J(e.pixels.length,e.width,function(r,n,i){t(e.pixels,r,n,i)},function(){r(e)},n)}}function ut(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:3,e=Math.pow(t,2);return q(1/e,e)}function ht(t,e,r,n,i,o){if(3==arguments.length){var a=arguments[2];r=a.r,n=a.g,i=a.b,o=a.a}"number"==typeof r&&(t[e]=r),"number"==typeof n&&(t[e+1]=n),"number"==typeof i&&(t[e+2]=i),"number"==typeof o&&(t[e+3]=o)}function ct(t,e,r,n){ht(t,e,r[n],r[n+1],r[n+2],r[n+3])}function ft(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],r=function(t){var e,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:255;return e=t.map(function(t,e){return[]}),t.forEach(function(t,i){if(0!=t){var o=e[i];for(i=r;i<=n;i++)o[i]=t*i}}),e}(t);return function(n,i){var o=Math.round(Math.sqrt(t.length)),a=function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,r=t.width+e,n=t.height+e;return{pixels:new Uint8ClampedArray(r*n*4),width:r,height:n}}(n,2*o);!function(t,e,r,n){for(var i=e.pixels.length/4,o=0,a=0,l=0,s=0,u=0,h=0,c=0;ct.width||a>t.height||(u=s*e.width+l<<2,h=a*t.width+o<<2,t.pixels[h]=e.pixels[u],t.pixels[h+1]=e.pixels[u+1],t.pixels[h+2]=e.pixels[u+2],t.pixels[h+3]=e.pixels[u+3])}(a,n,o,o);for(var l=Q(a.pixels.length,a.width,a.height),s=Q(n.pixels.length,n.width,n.height),u=function(t,e,r,n,i){var o=Math.round(Math.sqrt(t.length)),a=Math.floor(o/2),l=i?1:0,s="let r = 0, g = 0, b = 0, a = 0, scy = 0, scx =0, si = 0; ",u=[],h=[],c=[],f=[];t.forEach(function(t,e){var n=Math.floor(e/o)-a,i=e%o-a;0!=t&&(u.push("$t["+e+"][$sp[(($sy + ("+n+")) * "+r+" + ($sx + ("+i+"))) * 4]]"),h.push("$t["+e+"][$sp[(($sy + ("+n+")) * "+r+" + ($sx + ("+i+"))) * 4 + 1]]"),c.push("$t["+e+"][$sp[(($sy + ("+n+")) * "+r+" + ($sx + ("+i+"))) * 4 + 2]]"),f.push("$t["+e+"][$sp[(($sy + ("+n+")) * "+r+" + ($sx + ("+i+"))) * 4 + 3]]"))}),s+="r = "+u.join(" + ")+"; g = "+h.join(" + ")+"; b = "+c.join(" + ")+"; a = "+f.join(" + ")+";",s+="$dp[$di] = r; $dp[$di+1] = g;$dp[$di+2] = b;$dp[$di+3] = a + ("+l+")*(255-a); ";var g=new Function("$dp","$sp","$di","$sx","$sy","$t",s);return function(t,r,n,i,o){g(t,r,n,i,o,e)}}(t,r,a.width,a.height,e),h=n.pixels.length/4,c=0;c>2,o=0,a=0,l=0,s=0,u=0,h=0,c=0;ct.width||a>t.height||(u=a*t.width+o<<2,h=s*e.width+l<<2,e.pixels[h]=t.pixels[u],e.pixels[h+1]=t.pixels[u+1],e.pixels[h+2]=t.pixels[u+2],e.pixels[h+3]=t.pixels[u+3])}(l,s,o,o),i(s)}}function gt(t){var e=Yt.convertMatches(t),r=e.str.match(nt),n=[];if(!r)return n;var i={next:0};return n=(n=r.map(function(t){return{filter:t,origin:Yt.reverseMatches(t,e.matches)}})).map(function(e){var r=t.indexOf(e.origin,i.next);return e.startIndex=r,e.endIndex=r+e.origin.length,e.arr=vt(e.origin),i.next=e.endIndex,e}).filter(function(t){return!!t.arr.length})}function vt(t){var e=Yt.convertMatches(t),r=e.str.match(nt);if(!r[0])return[];var n=r[0].split("("),i=n.shift(),o=[];return n.length&&(o=n.shift().split(")")[0].split(",").map(function(t){return Yt.reverseMatches(t,e.matches)})),[i].concat(C(o)).map(Yt.trim)}function dt(t){return Math.min(255,t)}function pt(t){return yt(gt(t).map(function(t){return t.arr}))}function mt(){for(var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[],e=[],r=[],n=0,i=t.length;n2&&void 0!==arguments[2]?arguments[2]:{},o=t,a=0;function l(){e[a].call(null,o,function(t){o=t,function(){if(++a>=n)return void r(o);l()}()},i)}l()}}function yt(t){return bt.apply(void 0,C(t))}function kt(t){for(var e=null,r=arguments.length,n=Array(r>1?r-1:0),i=1;i2&&void 0!==arguments[2]?arguments[2]:{};e(tt(r,t),function(e){n(et(r,e,t))},i)}}function Ct(t){return"string"==typeof t&&(t=(t=t.replace(/deg/,"")).replace(/px/,"")),+t}function $t(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1;return t.map(function(t){return t*e})}var xt=0;function wt(t){return[].concat(Array.prototype.slice.call(arguments))}function _t(t){return{type:"convolution",length:t.length,content:t}}function St(t,e){return{type:"shader",index:xt,options:e,content:(r=t,n=xt++,"\n if (u_filterIndex == "+n+".0) {\n "+r+"\n }\n ")};var r,n}function Et(t){return"\n \n if (u_kernelSelect == "+t+".0) {\n vec4 colorSum = "+(e=t,r=Math.sqrt(e),n=Math.floor(r/2),[].concat(C(Array(e))).map(function(t,i){var o=Math.floor(i/r)-n;return"texture(u_image, v_texCoord + onePixel * vec2("+(i%r-n)+", "+o+")) * u_kernel"+e+"["+i+"]"}).join(" + \n"))+"; \n\n outColor = vec4((colorSum / u_kernel"+t+"Weight).rgb, 1);\n \n }\n ";var e,r,n}function Mt(t){return"vec4("+(t=[t.r/255,t.g/255,t.b/255,t.a||0].map(At))+")"}function At(t){return t==Math.floor(t)?t+".0":t}function Rt(){return _t($t([1,2,1,2,4,2,1,2,1],Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:1)*(1/16)))}function Tt(){return _t([1,4,6,4,1,4,16,24,16,4,6,24,36,24,6,4,16,24,16,4,1,4,6,4,1])}function Bt(){return _t([5,5,5,-3,0,-3,-3,-3,-3])}function It(){return _t([5,-3,-3,5,0,-3,5,-3,-3])}function Ft(){return _t([-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,24,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1])}function Ht(){return _t([1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1])}function Lt(){return _t([1,0,0,0,0,0,0,0,1,0,1,0,0,0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,0,0,1,0,1,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,1,0,1,0,0,0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,0,0,1,0,1,0,0,0,0,0,0,0,1])}function Ot(){return _t([1,0,0,0,1,0,0,0,1,0,1,0,0,1,0,0,1,0,0,0,1,0,1,0,1,0,0,0,0,0,1,1,1,0,0,0,1,1,1,1,1,1,1,1,1,0,0,0,1,1,1,0,0,0,0,0,1,0,1,0,1,0,0,0,1,0,0,1,0,0,1,0,1,0,0,0,1,0,0,0,1])}function Pt(){return _t([-1,-2,-1,0,0,0,1,2,1])}function Gt(){return _t([-1,0,1,-2,0,2,-1,0,1])}function Dt(){return _t($t([1,4,6,4,1,4,16,24,16,4,6,24,-476,24,6,4,16,24,16,4,1,4,6,4,1],-1/256))}function Nt(){var t=[arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,arguments.length>4&&void 0!==arguments[4]?arguments[4]:0,arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,arguments.length>6&&void 0!==arguments[6]?arguments[6]:0,arguments.length>7&&void 0!==arguments[7]?arguments[7]:0,arguments.length>8&&void 0!==arguments[8]?arguments[8]:0,arguments.length>9&&void 0!==arguments[9]?arguments[9]:0,arguments.length>10&&void 0!==arguments[10]?arguments[10]:0,arguments.length>11&&void 0!==arguments[11]?arguments[11]:0,arguments.length>12&&void 0!==arguments[12]?arguments[12]:0,arguments.length>13&&void 0!==arguments[13]?arguments[13]:0,arguments.length>14&&void 0!==arguments[14]?arguments[14]:0,arguments.length>15&&void 0!==arguments[15]?arguments[15]:0].map(At);return St("\n\n outColor = vec4(\n "+t[0]+" * pixelColor.r + "+t[1]+" * pixelColor.g + "+t[2]+" * pixelColor.b + "+t[3]+" * pixelColor.a,\n "+t[4]+" * pixelColor.r + "+t[5]+" * pixelColor.g + "+t[6]+" * pixelColor.b + "+t[7]+" * pixelColor.a,\n "+t[8]+" * pixelColor.r + "+t[9]+" * pixelColor.g + "+t[10]+" * pixelColor.b + "+t[11]+" * pixelColor.a,\n "+t[12]+" * pixelColor.r + "+t[13]+" * pixelColor.g + "+t[14]+" * pixelColor.b + "+t[15]+" * pixelColor.a\n ); \n ")}function Ut(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1;return St("\n float c = ( (pixelColor.r * 0.2126 + pixelColor.g * 0.7152 + pixelColor.b * 0.0722) ) >= "+(t=At(Ct(t)))+" ? 1.0 : 0.0;\n\n outColor = vec4(c, c, c, pixelColor.a);\n ")}var jt=p({},{blur:function(){return _t([1,1,1,1,1,1,1,1,1])},normal:function(){return _t([0,0,0,0,1,0,0,0,0])},emboss:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:4;return _t([-2*(t=Ct(t)),-t,0,-t,1,t,0,t,2*t])},gaussianBlur:Rt,"gaussian-blur":Rt,gaussianBlur5x:Tt,"gaussian-blur-5x":Tt,grayscale2:function(){return _t([.3,.3,.3,0,0,.59,.59,.59,0,0,.11,.11,.11,0,0,0,0,0,0,0,0,0,0,0,0])},kirschHorizontal:Bt,"kirsch-horizontal":Bt,kirschVertical:It,"kirsch-vertical":It,laplacian:function(){return _t([-1,-1,-1,-1,8,-1,-1,-1,-1])},laplacian5x:Ft,"laplacian-5x":Ft,motionBlur:Ht,"motion-blur":Ht,motionBlur2:Lt,"motion-blur-2":Lt,motionBlur3:Ot,"motion-blur-3":Ot,negative:function(){return _t([-1,0,0,0,0,0,-1,0,0,0,0,0,-1,0,0,0,0,0,1,0,1,1,1,1,1])},sepia2:function(){return _t([.393,.349,.272,0,0,.769,.686,.534,0,0,.189,.168,.131,0,0,0,0,0,0,0,0,0,0,0,0])},sharpen:function(){return _t([0,-1,0,-1,5,-1,0,-1,0])},sobelHorizontal:Pt,"sobel-horizontal":Pt,sobelVertical:Gt,"sobel-vertical":Gt,transparency:function(){return _t([1,0,0,0,0,0,1,0,0,0,0,0,1,0,0,0,0,0,.3,0,0,0,0,0,1])},unsharpMasking:Dt,"unsharp-masking":Dt},{bitonal:function(t,e){var r=At(arguments.length>2&&void 0!==arguments[2]?arguments[2]:.5),n=Mt(Yt.parse(t));return St("\n if ((pixelColor.r + pixelColor.g + pixelColor.b) > "+r+") {\n outColor = vec4("+Mt(Yt.parse(e))+".rgb, pixelColor.a);\n } else {\n outColor = vec4("+n+".rgb, pixelColor.a);\n }\n ")},brightness:function(){return St("\n outColor = pixelColor + ("+At(Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:1))+");\n ")},brownie:function(){return Nt(.5997023498159715,.34553243048391263,-.2708298674538042,0,-.037703249837783157,.8609577587992641,.15059552388459913,0,.24113635128153335,-.07441037908422492,.44972182064877153,0,0,0,0,1)},clip:function(){var t=At(Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:0));return St("\n outColor = vec4(\n (pixelColor.r > 1.0 - "+t+") ? 1.0 : 0.0,\n (pixelColor.g > 1.0 - "+t+") ? 1.0 : 0.0,\n (pixelColor.b > 1.0 - "+t+") ? 1.0 : 0.0,\n pixelColor.a \n );\n ")},chaos:function(){return St("\n vec2 st = pixelColor.st;\n st *= "+At(Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:10))+";\n \n vec2 ipos = floor(st); // get the integer coords\n\n vec3 color = vec3(random( ipos ));\n\n outColor = vec4(color, pixelColor.a);\n ")},contrast:function(){return St("\n outColor = pixelColor * "+At(Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:1))+";\n ")},gamma:function(){var t=At(Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:1));return St("\n outColor = vec4(pow(pixelColor.r, "+t+"), pow(pixelColor.g, "+t+"), pow(pixelColor.b, "+t+"), pixelColor.a );\n ")},gradient:function(){var t=[].concat(Array.prototype.slice.call(arguments));1===t.length&&"string"==typeof t[0]&&(t=Yt.convertMatchesArray(t[0])),t=t.map(function(t){return t}).join(", ");var e=Yt.parseGradient(t);e[0][1]=0,e[e.length-1][1]=1;for(var r=[],n=0,i=(e=e.map(function(t){var e=Yt.parse(t[0]);return[{r:e.r,g:e.g,b:e.b,a:e.a},t[1]]})).length;n0&&void 0!==arguments[0]?arguments[0]:1);return t>1&&(t=1),Nt(.2126+.7874*(1-t),.7152-.7152*(1-t),.0722-.0722*(1-t),0,.2126-.2126*(1-t),.7152+.2848*(1-t),.0722-.0722*(1-t),0,.2126-.2126*(1-t),.7152-.7152*(1-t),.0722+.9278*(1-t),0,0,0,0,1)},hue:function(){return St("\n vec3 hsv = rgb2hsv(pixelColor.rgb);\n hsv.x += "+At(Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:1))+";\n outColor = vec4(hsv2rgb(hsv).rgb, pixelColor.a);\n ")},invert:function(){var t=At(Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:1));return St("\n outColor = vec4(\n (1.0 - pixelColor.r) * "+t+",\n (1.0 - pixelColor.g) * "+t+",\n (1.0 - pixelColor.b) * "+t+",\n pixelColor.a\n );\n ")},kodachrome:function(){return Nt(1.1285582396593525,-.3967382283601348,-.03992559172921793,0,-.16404339962244616,1.0835251566291304,-.05498805115633132,0,-.16786010706155763,-.5603416277695248,1.6014850761964943,0,0,0,0,1)},matrix:Nt,noise:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1,e=Math.abs(Ct(t)),r=At(-e);return St("\n float rnd = "+r+" + random( pixelColor.st ) * ("+At(e)+" - "+r+");\n\n outColor = vec4(pixelColor.rgb + rnd, 1.0);\n ")},opacity:function(){return St("\n outColor = vec4(pixelColor.rgb, pixelColor.a * "+At(Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:1))+");\n ")},polaroid:function(){return Nt(1.438,-.062,-.062,0,-.122,1.378,-.122,0,-.016,-.016,1.483,0,0,0,0,1)},saturation:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,e=1-Math.abs(Ct(t));return Nt(e,0,0,0,0,e,0,0,0,0,e,0,0,0,0,e)},sepia:function(){var t=Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:1);return t>1&&(t=1),Nt(.393+.607*(1-t),.769-.769*(1-t),.189-.189*(1-t),0,.349-.349*(1-t),.686+.314*(1-t),.168-.168*(1-t),0,.272-.272*(1-t),.534-.534*(1-t),.131+.869*(1-t),0,0,0,0,1)},shade:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1;return St("\n outColor = vec4(\n pixelColor.r * "+At(Ct(t)/255)+",\n pixelColor.g * "+At(Ct(e)/255)+",\n pixelColor.b * "+At(Ct(r)/255)+",\n pixelColor.a\n );\n ")},shift:function(){return Nt(1.438,-.062,-.062,0,-.122,1.378,-.122,0,-.016,-.016,1.483,0,0,0,0,1)},solarize:function(t,e,r){return St("\n outColor = vec4(\n (pixelColor.r < "+At(Ct(t))+") ? 1.0 - pixelColor.r: pixelColor.r,\n (pixelColor.g < "+At(Ct(e))+") ? 1.0 - pixelColor.g: pixelColor.g,\n (pixelColor.b < "+At(Ct(r))+") ? 1.0 - pixelColor.b: pixelColor.b,\n pixelColor.a\n );\n ")},technicolor:function(){return Nt(1.9125277891456083,-.8545344976951645,-.09155508482755585,0,-.3087833385928097,1.7658908555458428,-.10601743074722245,0,-.231103377548616,-.7501899197440212,1.847597816108189,0,0,0,0,1)},threshold:function(){return Ut(arguments.length>0&&void 0!==arguments[0]?arguments[0]:200,arguments.length>1&&void 0!==arguments[1]?arguments[1]:100,!1)},"threshold-color":Ut,tint:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0;return St("\n outColor = vec4(\n pixelColor.r += (1 - pixelColor.r) * "+Ct(t)+",\n pixelColor.g += (1 - pixelColor.g) * "+Ct(e)+",\n pixelColor.b += (1 - pixelColor.b) * "+Ct(r)+",\n pixelColor.a\n );\n ")}},{kirsch:function(){return wt("kirsch-horizontal kirsch-vertical")},sobel:function(){return wt("sobel-horizontal sobel-vertical")},vintage:function(){return wt("brightness(0.15) saturation(-0.2) gamma(1.8)")}}),zt=0,Vt={GLCanvas:function(){function t(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{width:"400px",height:"300px"};g(this,t),this.img=e.img,this.width=parseFloat(this.img.width||e.width||"400px"),this.height=parseFloat(this.img.height||e.height||"300px"),this.init()}return v(t,[{key:"resize",value:function(){this.canvas.width=this.width,this.canvas.height=this.height,this.canvas.style.width=this.width+"px",this.canvas.style.height=this.height+"px",this.viewport()}},{key:"clear",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,i=this.gl;i.clearColor(t,e,r,n),i.clear(i.COLOR_BUFFER_BIT|i.DEPTH_BUFFER_BIT)}},{key:"viewport",value:function(t,e,r,n){var i=this.gl;i.viewport(t||0,e||0,r||i.canvas.width,n||i.canvas.height)}},{key:"initCanvas",value:function(t,e){if(this.canvas=document.createElement("canvas"),this.gl=this.canvas.getContext("webgl2"),!this.gl)throw new Error("you need webgl2 support");this.program=this.createProgram(t,e),this.resize(),this.initBuffer()}},{key:"draw",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"TRIANGLES",e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:6,n=this.gl;n.drawArrays(n[t],e,r)}},{key:"triangles",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:6;this.draw("TRIANGLES",t,e)}},{key:"uniform2f",value:function(){for(var t,e=arguments.length,r=Array(e),n=0;n2&&void 0!==arguments[2]?arguments[2]:"STATIC_DRAW",n=this.gl;this.buffers[t]||(this.buffers[t]=n.createBuffer()),n.bindBuffer(n.ARRAY_BUFFER,this.buffers[t]),e&&n.bufferData(n.ARRAY_BUFFER,new Float32Array(e),n[r])}},{key:"enable",value:function(t){this.gl.enableVertexAttribArray(this.locations[t])}},{key:"location",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"attribute";"attribute"===e?this.locations[t]=this.gl.getAttribLocation(this.program,t):"uniform"===e&&(this.locations[t]=this.gl.getUniformLocation(this.program,t))}},{key:"a",value:function(t){return this.location(t)}},{key:"u",value:function(t){return this.location(t,"uniform")}},{key:"pointer",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"FLOAT",r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:2,n=arguments.length>3&&void 0!==arguments[3]&&arguments[3],i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:0,o=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,a=this.gl;a.vertexAttribPointer(this.locations[t],r,a[e],n,i,o)}},{key:"bufferData",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[],e=this.gl;e.bufferData(e.ARRAY_BUFFER,new Float32Array(t),e.STATIC_DRAW)}},{key:"isPowerOf2",value:function(t){return 0==(t&t-1)}},{key:"bindTexture",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:void 0,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"RGBA",i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"RGBA",o=arguments.length>5&&void 0!==arguments[5]?arguments[5]:"UNSIGNED_BYTE",a=this.gl;1!=arguments.length?(this.textures[t]||(this.textures[t]=a.createTexture()),this.textureIndex[t]=zt++,a.bindTexture(a.TEXTURE_2D,this.textures[t]),this.setTextureParameter(),a.texImage2D(a.TEXTURE_2D,r,a[n],a[i],a[o],e.newImage||e)):a.bindTexture(a.TEXTURE_2D,this.textures[t])}},{key:"bindColorTexture",value:function(t,e){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:256,n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:1,i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:0,o=arguments.length>5&&void 0!==arguments[5]?arguments[5]:"RGBA",a=arguments.length>6&&void 0!==arguments[6]?arguments[6]:"RGBA",l=arguments.length>7&&void 0!==arguments[7]?arguments[7]:"UNSIGNED_BYTE",s=this.gl;this.textures[t]||(this.textures[t]=s.createTexture()),this.textureIndex[t]=zt++,s.bindTexture(s.TEXTURE_2D,this.textures[t]),this.setTextureParameter(),s.texImage2D(s.TEXTURE_2D,i,s[o],r,n,0,s[a],s[l],new Uint8Array(e))}},{key:"bindEmptyTexture",value:function(t,e,r){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"RGBA",o=arguments.length>5&&void 0!==arguments[5]?arguments[5]:"RGBA",a=arguments.length>6&&void 0!==arguments[6]?arguments[6]:"UNSIGNED_BYTE",l=this.gl;this.textures[t]||(this.textures[t]=l.createTexture()),this.textureIndex[t]=zt++,l.bindTexture(l.TEXTURE_2D,this.textures[t]),this.setTextureParameter();l.texImage2D(l.TEXTURE_2D,n,l[i],e,r,0,l[o],l[a],null)}},{key:"setTextureParameter",value:function(){var t=this.gl;t.texParameteri(t.TEXTURE_2D,t.TEXTURE_WRAP_S,t.CLAMP_TO_EDGE),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_WRAP_T,t.CLAMP_TO_EDGE),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_MIN_FILTER,t.NEAREST),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_MAG_FILTER,t.NEAREST)}},{key:"bindFrameBufferWithTexture",value:function(t,e,r,n){this.bindEmptyTexture(e,r,n),this.bindFrameBuffer(t,e)}},{key:"enumToString",value:function(t){var e=this.gl;if(0===t)return"NONE";for(var r in e)if(e[r]===t)return r;return"0x"+t.toString(16)}},{key:"bindFrameBuffer",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null,r=this.gl;if(1!==arguments.length){this.framebuffers[t]||(this.framebuffers[t]=r.createFramebuffer()),r.bindFramebuffer(r.FRAMEBUFFER,this.framebuffers[t]);var n=r.COLOR_ATTACHMENT0;r.framebufferTexture2D(r.FRAMEBUFFER,n,r.TEXTURE_2D,this.textures[e],0);r.checkFramebufferStatus(r.FRAMEBUFFER);r.FRAMEBUFFER_COMPLETE}else r.bindFramebuffer(r.FRAMEBUFFER,null==t?null:this.framebuffers[t])}},{key:"bindVA",value:function(){var t=this.gl;this.vao||(this.vao=t.createVertexArray()),t.bindVertexArray(this.vao)}},{key:"bindAttr",value:function(t,e){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"STATIC_DRAW",n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:2;this.bindBuffer(t,e,r),this.enable(t),this.pointer(t,"FLOAT",n)}},{key:"initBuffer",value:function(){var t=this.canvas,e=t.width,r=t.height;this.a("a_position"),this.a("a_texCoord"),this.u("u_resolution"),this.u("u_image"),this.u("u_flipY"),this.u("u_kernelSelect"),this.u("u_filterIndex"),this.u("u_kernel9[0]"),this.u("u_kernel9Weight"),this.u("u_kernel25[0]"),this.u("u_kernel25Weight"),this.u("u_kernel49[0]"),this.u("u_kernel49Weight"),this.u("u_kernel81[0]"),this.u("u_kernel81Weight"),this.bindVA(),this.bindAttr("a_position",[0,0,e,0,0,r,0,r,e,0,e,r],"STATIC_DRAW",2),this.bindAttr("a_texCoord",[0,0,1,0,0,1,0,1,1,0,1,1],"STATIC_DRAW",2),this.bindTexture("u_image",this.img),this.bindFrameBufferWithTexture("frame_buffer_0","img_texture_0",e,r),this.bindFrameBufferWithTexture("frame_buffer_1","img_texture_1",e,r)}},{key:"activeTexture",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,e=this.gl;e.activeTexture(e.TEXTURE0+t)}},{key:"drawFilter",value:function(){var t=this,e=this.gl;this.resize(),this.clear(),this.useProgram(),this.bindVA(),this.activeTexture(0),this.bindTexture("u_image"),this.uniform1i("u_image",0),this.uniform1f("u_flipY",1);var r=e.canvas,n=r.width,i=r.height;this.eachFilter(function(e,r){t.bindFrameBuffer("frame_buffer_"+r%2),t.uniform2f("u_resolution",n,i),t.viewport(0,0,n,i),t.effectFilter(e),t.bindTexture("img_texture_"+r%2)}),this.uniform1f("u_flipY",-1),this.bindFrameBuffer(null),this.uniform2f("u_resolution",n,i),this.viewport(0,0,n,i),this.clear(),this.effectFilter("normal")}},{key:"effectFilter",value:function(t){"string"==typeof t&&(t=(jt[t]||jt.normal).call(jt)),"convolution"==t.type?(this.uniform1f("u_kernelSelect",t.length),this.uniform1f("u_filterIndex",-1),this.uniform1fv("u_kernel"+t.length+"[0]",t.content),this.uniform1f("u_kernel"+t.length+"Weight",this.computeKernelWeight(t.content))):(this.uniform1f("u_kernelSelect",-1),this.uniform1f("u_filterIndex",t.index)),this.triangles(0,6)}},{key:"computeKernelWeight",value:function(t){var e=t.reduce(function(t,e){return t+e});return e<=0?1:e}},{key:"createProgram",value:function(t,e){var r=this.gl,n=r.createProgram();if(this.vertexShader=this.createVertexShader(t),this.fragmentShader=this.createFragmentShader(e),r.attachShader(n,this.vertexShader),r.attachShader(n,this.fragmentShader),r.linkProgram(n),r.getProgramParameter(n,r.LINK_STATUS))return n;console.error(r.getProgramInfoLog(n)),r.deleteProgram(n)}},{key:"createShader",value:function(t,e){var r=this.gl,n=r.createShader(t);if(r.shaderSource(n,e),r.compileShader(n),r.getShaderParameter(n,r.COMPILE_STATUS))return n;console.error(r.getShaderInfoLog(n)),r.deleteShader(n)}},{key:"createVertexShader",value:function(t){var e=this.gl;return this.createShader(e.VERTEX_SHADER,t)}},{key:"createFragmentShader",value:function(t){var e=this.gl;return this.createShader(e.FRAGMENT_SHADER,t)}},{key:"eachFilter",value:function(t){this.filterList.forEach(t)}},{key:"init",value:function(){this.locations={},this.buffers={},this.framebuffers={},this.textures={},this.textureIndex={},this.hasTexParameter={}}},{key:"destroy",value:function(){var t=this.gl;this.init(),t.deleteProgram(this.program)}},{key:"filter",value:function(t,e){var r,n,i;this.filterList=t,this.initCanvas("#version 300 es \n\n in vec2 a_position;\n in vec2 a_texCoord; \n\n uniform vec2 u_resolution;\n uniform float u_flipY;\n\n out vec2 v_texCoord; \n\n void main() {\n vec2 zeroToOne = a_position / u_resolution;\n\n vec2 zeroToTwo = zeroToOne * 2.0;\n\n vec2 clipSpace = zeroToTwo - 1.0;\n\n gl_Position = vec4(clipSpace * vec2(1, u_flipY), 0, 1);\n\n v_texCoord = a_texCoord;\n\n }\n ",(r=this.filterList,n=r.filter(function(t){return"shader"==t.type}).map(function(t){return t.content}).join("\n\n"),i={9:!0},r.filter(function(t){return"convolution"==t.type}).forEach(function(t){i[t.length]=!0}),"#version 300 es\n\n precision highp int;\n precision mediump float;\n \n uniform sampler2D u_image;\n\n // 3 is 3x3 matrix kernel \n uniform float u_kernelSelect;\n uniform float u_filterIndex;\n\n uniform float u_kernel9[9];\n uniform float u_kernel9Weight;\n uniform float u_kernel25[25];\n uniform float u_kernel25Weight;\n uniform float u_kernel49[49];\n uniform float u_kernel49Weight;\n uniform float u_kernel81[81];\n uniform float u_kernel81Weight; \n\n in vec2 v_texCoord;\n \n out vec4 outColor;\n\n float random (vec2 st) {\n return fract(sin(dot(st.xy, vec2(12.9898,78.233)))* 43758.5453123);\n } \n\n // \n vec3 rgb2hsv(vec3 c)\n {\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\n vec4 p = c.g < c.b ? vec4(c.bg, K.wz) : vec4(c.gb, K.xy);\n vec4 q = c.r < p.x ? vec4(p.xyw, c.r) : vec4(c.r, p.yzx);\n\n float d = q.x - min(q.w, q.y);\n float e = 1.0e-10;\n return vec3(abs(q.z + (q.w - q.y) / (6.0 * d + e)), d / (q.x + e), q.x);\n }\n\n vec3 hsv2rgb(vec3 c)\n {\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n }\n \n void main() {\n vec4 pixelColor = texture(u_image, v_texCoord);\n vec2 onePixel = vec2(1) / vec2(textureSize(u_image, 0)); \n\n "+n+"\n\n "+Object.keys(i).map(function(t){return Et(+t)}).join("\n")+"\n\n }")),this.drawFilter(),"function"==typeof e&&e(this)}}]),t}()};var Xt=p({},Vt,{filter:function(t,e,r,n){var i=new Vt.GLCanvas({width:n.width||t.width,height:n.height||t.height,img:t});i.filter(function t(e){var r=[];"string"==typeof e?r=gt(e):Array.isArray(e)&&(r=e);var n=[];r.forEach(function(e){var r=e.arr[0];if(jt[r]){var i=function(t){var e=t.arr[0],r=jt[e],n=t.arr;return n.shift(),r.apply(this,n)}(e);"convolution"==i.type||"shader"==i.type?n.push(i):i.forEach(function(e){n=n.concat(t(e))})}});return n}(e),function(){"function"==typeof r&&r(i)})}}),Wt=/(#(?:[\da-f]{3}){1,2}|rgb\((?:\s*\d{1,3},\s*){2}\d{1,3}\s*\)|rgba\((?:\s*\d{1,3},\s*){3}\d*\.?\d+\s*\)|hsl\(\s*\d{1,3}(?:,\s*\d{1,3}%){2}\s*\)|hsla\(\s*\d{1,3}(?:,\s*\d{1,3}%){2},\s*\d*\.?\d+\s*\)|([\w_\-]+))/gi,Yt={matches:function(t){var e=t.match(Wt),n=[];if(!e)return n;for(var i=0,o=e.length;i-1||e[i].indexOf("rgb")>-1||e[i].indexOf("hsl")>-1)n.push({color:e[i]});else{var a=r.getColorByName(e[i]);a&&n.push({color:e[i],nameColor:a})}var l={next:0};return n.forEach(function(e){var r=t.indexOf(e.color,l.next);e.startIndex=r,e.endIndex=r+e.color.length,l.next=e.endIndex}),n},convertMatches:function(t){var e=this.matches(t);return e.forEach(function(e,r){t=t.replace(e.color,"@"+r)}),{str:t,matches:e}},convertMatchesArray:function(t){var e=this,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:",",n=this.convertMatches(t);return n.str.split(r).map(function(t,r){return t=e.trim(t),n.matches[r]&&(t=t.replace("@"+r,n.matches[r].color)),t})},reverseMatches:function(t,e){return e.forEach(function(e,r){t=t.replace("@"+r,e.color)}),t},trim:function(t){return t.replace(/^\s+|\s+$/g,"")},round:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1;return Math.round(t*e)/e},format:function(t,e){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"rgba(0, 0, 0, 0)";return Array.isArray(t)&&(t={r:t[0],g:t[1],b:t[2],a:t[3]}),"hex"==e?this.hex(t):"rgb"==e?this.rgb(t,r):"hsl"==e?this.hsl(t):t},hex:function(t){Array.isArray(t)&&(t={r:t[0],g:t[1],b:t[2],a:t[3]});var e=t.r.toString(16);t.r<16&&(e="0"+e);var r=t.g.toString(16);t.g<16&&(r="0"+r);var n=t.b.toString(16);return t.b<16&&(n="0"+n),"#"+e+r+n},rgb:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"rgba(0, 0, 0, 0)";if(Array.isArray(t)&&(t={r:t[0],g:t[1],b:t[2],a:t[3]}),void 0!==t)return 1==t.a||void 0===t.a?isNaN(t.r)?e:"rgb("+t.r+","+t.g+","+t.b+")":"rgba("+t.r+","+t.g+","+t.b+","+t.a+")"},hsl:function(t){return Array.isArray(t)&&(t={r:t[0],g:t[1],b:t[2],a:t[3]}),1==t.a||void 0===t.a?"hsl("+t.h+","+t.s+"%,"+t.l+"%)":"hsla("+t.h+","+t.s+"%,"+t.l+"%,"+t.a+")"},parse:function(t){if("string"==typeof t){if(r.isColorName(t)&&(t=r.getColorByName(t)),t.indexOf("rgb(")>-1){for(var e=0,n=(o=t.replace("rgb(","").replace(")","").split(",")).length;e-1){for(e=0,n=(o=t.replace("rgba(","").replace(")","").split(",")).length;e-1){for(e=0,n=(o=t.replace("hsl(","").replace(")","").split(",")).length;e-1){for(e=0,n=(o=t.replace("hsla(","").replace(")","").split(",")).length;e>16,g:(65280&t)>>8,b:(255&t)>>0,a:1};return i=Object.assign(i,this.RGBtoHSL(i))}if(0<=t&&t<=4294967295){i={type:"hex",r:(4278190080&t)>>24,g:(16711680&t)>>16,b:(65280&t)>>8,a:(255&t)/255};return i=Object.assign(i,this.RGBtoHSL(i))}}return t},HSVtoRGB:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.h,e=n.s,r=n.v}var i=t,o=r;360==i&&(i=0);var a=e*o,l=a*(1-Math.abs(i/60%2-1)),s=o-a,u=[];return 0<=i&&i<60?u=[a,l,0]:60<=i&&i<120?u=[l,a,0]:120<=i&&i<180?u=[0,a,l]:180<=i&&i<240?u=[0,l,a]:240<=i&&i<300?u=[l,0,a]:300<=i&&i<360&&(u=[a,0,l]),{r:this.round(255*(u[0]+s)),g:this.round(255*(u[1]+s)),b:this.round(255*(u[2]+s))}},RGBtoHSV:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.r,e=n.g,r=n.b}var i=t/255,o=e/255,a=r/255,l=Math.max(i,o,a),s=l-Math.min(i,o,a),u=0;0==s?u=0:l==i?u=(o-a)/s%6*60:l==o?u=60*((a-i)/s+2):l==a&&(u=60*((i-o)/s+4)),u<0&&(u=360+u);return{h:u,s:0==l?0:s/l,v:l}},HSVtoHSL:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.h,e=n.s,r=n.v}var i=this.HSVtoRGB(t,e,r);return this.RGBtoHSL(i.r,i.g,i.b)},RGBtoCMYK:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.r,e=n.g,r=n.b}var i=t/255,o=e/255,a=r/255,l=1-Math.max(i,o,a);return{c:(1-i-l)/(1-l),m:(1-o-l)/(1-l),y:(1-a-l)/(1-l),k:l}},CMYKtoRGB:function(t,e,r,n){if(1==arguments.length){var i=arguments[0];t=i.c,e=i.m,r=i.y,n=i.k}return{r:255*(1-t)*(1-n),g:255*(1-e)*(1-n),b:255*(1-r)*(1-n)}},RGBtoHSL:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.r,e=n.g,r=n.b}t/=255,e/=255,r/=255;var i,o,a=Math.max(t,e,r),l=Math.min(t,e,r),s=(a+l)/2;if(a==l)i=o=0;else{var u=a-l;switch(o=s>.5?u/(2-a-l):u/(a+l),a){case t:i=(e-r)/u+(e1&&(r-=1),r<1/6?t+6*(e-t)*r:r<.5?e:r<2/3?t+(e-t)*(2/3-r)*6:t},HSLtoHSV:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.h,e=n.s,n.v}var i=this.HSLtoRGB(t,e,r);return this.RGBtoHSV(i.r,i.g,i.b)},HSLtoRGB:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.h,e=n.s,r=n.l}var i,o,a;if(t/=360,r/=100,0==(e/=100))i=o=a=r;else{var l=r<.5?r*(1+e):r+e-r*e,s=2*r-l;i=this.HUEtoRGB(s,l,t+1/3),o=this.HUEtoRGB(s,l,t),a=this.HUEtoRGB(s,l,t-1/3)}return{r:this.round(255*i),g:this.round(255*o),b:this.round(255*a)}},c:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.r,e=n.g,r=n.b}return this.gray((t+e+r)/3>90?0:255)},gray:function(t){return{r:t,g:t,b:t}},RGBtoSimpleGray:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.r,e=n.g,r=n.b}return this.gray(Math.ceil((t+e+r)/3))},RGBtoGray:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.r,e=n.g,r=n.b}return this.gray(this.RGBtoYCrCb(t,e,r).y)},brightness:function(t,e,r){return Math.ceil(.2126*t+.7152*e+.0722*r)},RGBtoYCrCb:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.r,e=n.g,r=n.b}var i=this.brightness(t,e,r);return{y:i,cr:.713*(t-i),cb:.564*(r-i)}},YCrCbtoRGB:function(t,e,r,n){if(1==arguments.length){var i=arguments[0];t=i.y,e=i.cr,r=i.cb;n=(n=i.bit)||0}var o=t+1.402*(e-n),a=t-.344*(r-n)-.714*(e-n),l=t+1.772*(r-n);return{r:Math.ceil(o),g:Math.ceil(a),b:Math.ceil(l)}},ReverseRGB:function(t){return t>.0031308?1.055*Math.pow(t,1/2.4)-.055:12.92*t},XYZtoRGB:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.x,e=n.y,r=n.z}var i=t/100,o=e/100,a=r/100,l=3.2406*i+-1.5372*o+-.4986*a,s=-.9689*i+1.8758*o+.0415*a,u=.0557*i+-.204*o+1.057*a;return l=this.ReverseRGB(l),s=this.ReverseRGB(s),u=this.ReverseRGB(u),{r:this.round(255*l),g:this.round(255*s),b:this.round(255*u)}},PivotRGB:function(t){return 100*(t>.04045?Math.pow((t+.055)/1.055,2.4):t/12.92)},RGBtoXYZ:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.r,e=n.g,r=n.b}var i=t/255,o=e/255,a=r/255;return{x:.4124*(i=this.PivotRGB(i))+.3576*(o=this.PivotRGB(o))+.1805*(a=this.PivotRGB(a)),y:.2126*i+.7152*o+.0722*a,z:.0193*i+.1192*o+.9505*a}},ReverseXyz:function(t){return Math.pow(t,3)>.008856?Math.pow(t,3):(t-16/116)/7.787},LABtoXYZ:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.l,e=n.a,r=n.b}var i=(t+16)/116,o=e/500+i,a=i-r/200;return i=this.ReverseXyz(i),{x:95.047*(o=this.ReverseXyz(o)),y:100*i,z:108.883*(a=this.ReverseXyz(a))}},PivotXyz:function(t){return t>.008856?Math.pow(t,1/3):(7.787*t+16)/116},XYZtoLAB:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.x,e=n.y,r=n.z}var i=t/95.047,o=e/100,a=r/108.883;return i=this.PivotXyz(i),{l:116*(o=this.PivotXyz(o))-16,a:500*(i-o),b:200*(o-(a=this.PivotXyz(a)))}},RGBtoLAB:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.r,e=n.g,r=n.b}return this.XYZtoLAB(this.RGBtoXYZ(t,e,r))},LABtoRGB:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.l,e=n.a,r=n.b}return this.XYZtoRGB(this.LABtoXYZ(t,e,r))},blend:function(t,e){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:.5,n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"hex",i=this.parse(t),o=this.parse(e);return this.interpolateRGB(i,o,r,n)},mix:function(t,e){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:.5,n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"hex";return this.blend(t,e,r,n)},contrast:function(t){t=this.parse(t);var e=(Math.round(299*t.r)+Math.round(587*t.g)+Math.round(114*t.b))/1e3;return e},contrastColor:function(t){return this.contrast(t)>=128?"black":"white"},interpolateRGB:function(t,e){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:.5,n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"hex",i={r:this.round(t.r+(e.r-t.r)*r),g:this.round(t.g+(e.g-t.g)*r),b:this.round(t.b+(e.b-t.b)*r),a:this.round(t.a+(e.a-t.a)*r,100)};return this.format(i,i.a<1?"rgb":n)},scale:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:5;if(!t)return[];"string"==typeof t&&(t=this.convertMatchesArray(t));for(var r=(t=t||[]).length,n=[],i=0;i0){var n=(1-t.filter(function(t){return"*"!=t[1]&&1!=t[1]}).map(function(t){return t[1]}).reduce(function(t,e){return t+e},0))/r;t.forEach(function(e,r){"*"==e[1]&&r>0&&(t.length-1==r||(e[1]=n))})}return t},gradient:function(t){for(var e=[],r=(arguments.length>1&&void 0!==arguments[1]?arguments[1]:10)-((t=this.parseGradient(t)).length-1),n=r,i=1,o=t.length;i1&&void 0!==arguments[1]?arguments[1]:"h",r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:9,n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"rgb",i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:0,o=arguments.length>5&&void 0!==arguments[5]?arguments[5]:1,a=arguments.length>6&&void 0!==arguments[6]?arguments[6]:100,l=this.parse(t),s=this.RGBtoHSV(l),u=(o-i)*a/r,h=[],c=1;c<=r;c++)s[e]=Math.abs((a-u*c)/a),h.push(this.format(this.HSVtoRGB(s),n));return h},scaleH:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:9,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"rgb",n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:360;return this.scaleHSV(t,"h",e,r,n,i,1)},scaleS:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:9,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"rgb",n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:1;return this.scaleHSV(t,"s",e,r,n,i,100)},scaleV:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:9,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"rgb",n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:1;return this.scaleHSV(t,"v",e,r,n,i,100)},palette:function(t){var e=this,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:6,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"hex";return t.length>r&&(t=h(t,r)),t.map(function(t){return e.format(t,n)})},ImageToRGB:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},r=arguments[2];if(r){if(r){var n;(n=new $(t,e)).loadImage(function(){"function"==typeof r&&r(n.toRGB())})}}else(n=new $(t)).loadImage(function(){"function"==typeof e&&e(n.toRGB())})},ImageToCanvas:function(t,e,r){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{frameTimer:"full"};this.ImageToURL(t,e,r,Object.assign({returnTo:"canvas"},n))},ImageToURL:function(t,e,r){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{frameTimer:"full"},i=new $(t);i.loadImage(function(){i.toArray(e,function(t){"function"==typeof r&&r(t)},n)})},GLToCanvas:function(t,e,r){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{},i=new $(t);i.load(function(){Xt.filter(i.newImage,e,function(t){"function"==typeof r&&r(t)},n)})},histogram:function(t,e){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},n=new $(t);n.loadImage(function(){"function"==typeof e&&e(n.toHistogram(r))})},histogramToPoints:function(t){for(var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:.2,r=[],n=0;n2&&void 0!==arguments[2]?arguments[2]:{width:200,height:100},n=new $(t);n.loadImage(function(){c.createHistogram(r.width||200,r.height||100,n.toHistogram(r),function(t){"function"==typeof e&&e(t.toDataURL("image/png"))},r)})}};Yt.scale.parula=function(t){return Yt.scale(["#352a87","#0f5cdd","#00b5a6","#ffc337","#fdff00"],t)},Yt.scale.jet=function(t){return Yt.scale(["#00008f","#0020ff","#00ffff","#51ff77","#fdff00","#ff0000","#800000"],t)},Yt.scale.hsv=function(t){return Yt.scale(["#ff0000","#ffff00","#00ff00","#00ffff","#0000ff","#ff00ff","#ff0000"],t)},Yt.scale.hot=function(t){return Yt.scale(["#0b0000","#ff0000","#ffff00","#ffffff"],t)},Yt.scale.pink=function(t){return Yt.scale(["#1e0000","#bd7b7b","#e7e5b2","#ffffff"],t)},Yt.scale.bone=function(t){return Yt.scale(["#000000","#4a4a68","#a6c6c6","#ffffff"],t)},Yt.scale.copper=function(t){return Yt.scale(["#000000","#3d2618","#9d623e","#ffa167","#ffc77f"],t)};var qt=[{rgb:"#ff0000",start:0},{rgb:"#ffff00",start:.17},{rgb:"#00ff00",start:.33},{rgb:"#00ffff",start:.5},{rgb:"#0000ff",start:.67},{rgb:"#ff00ff",start:.83},{rgb:"#ff0000",start:1}];!function(){for(var t=0,e=qt.length;t=t){e=qt[n-1],r=qt[n];break}return e&&r?Yt.interpolateRGB(e,r,(t-e.start)/(r.start-e.start)):qt[0].rgb}},Zt=p({},z,X),Jt=0,Qt=[],te=function(){function t(e,r,n){if(g(this,t),"string"!=typeof e)this.el=e;else{var i=document.createElement(e);for(var o in this.uniqId=Jt++,r&&(i.className=r),n=n||{})i.setAttribute(o,n[o]);this.el=i}}return v(t,[{key:"attr",value:function(t,e){return 1==arguments.length?this.el.getAttribute(t):(this.el.setAttribute(t,e),this)}},{key:"closest",value:function(e){for(var r=this,n=!1;!(n=r.hasClass(e));){if(!r.el.parentNode)return null;r=new t(r.el.parentNode)}return n?r:null}},{key:"removeClass",value:function(t){this.el.className=(" "+this.el.className+" ").replace(" "+t+" "," ").trim()}},{key:"hasClass",value:function(t){return!!this.el.className&&(" "+this.el.className+" ").indexOf(" "+t+" ")>-1}},{key:"addClass",value:function(t){this.hasClass(t)||(this.el.className=this.el.className+" "+t)}},{key:"toggleClass",value:function(t){this.hasClass(t)?this.removeClass(t):this.addClass(t)}},{key:"html",value:function(t){return"string"==typeof t?this.el.innerHTML=t:this.empty().append(t),this}},{key:"empty",value:function(){return this.html("")}},{key:"append",value:function(t){return"string"==typeof t?this.el.appendChild(document.createTextNode(t)):this.el.appendChild(t.el||t),this}},{key:"appendTo",value:function(t){return(t.el?t.el:t).appendChild(this.el),this}},{key:"remove",value:function(){return this.el.parentNode&&this.el.parentNode.removeChild(this.el),this}},{key:"text",value:function(){return this.el.textContent}},{key:"css",value:function(t,e){var r=this;if(2==arguments.length)this.el.style[t]=e;else if(1==arguments.length){if("string"==typeof t)return getComputedStyle(this.el)[t];var n=t||{};Object.keys(n).forEach(function(t){r.el.style[t]=n[t]})}return this}},{key:"cssFloat",value:function(t){return parseFloat(this.css(t))}},{key:"cssInt",value:function(t){return parseInt(this.css(t))}},{key:"offset",value:function(){var t=this.el.getBoundingClientRect();return{top:t.top+document.documentElement.scrollTop,left:t.left+document.documentElement.scrollLeft}}},{key:"position",value:function(){return this.el.style.top?{top:parseFloat(this.css("top")),left:parseFloat(this.css("left"))}:this.el.getBoundingClientRect()}},{key:"width",value:function(){return this.el.offsetWidth}},{key:"contentWidth",value:function(){return this.width()-this.cssFloat("padding-left")-this.cssFloat("padding-right")}},{key:"height",value:function(){return this.el.offsetHeight}},{key:"contentHeight",value:function(){return this.height()-this.cssFloat("padding-top")-this.cssFloat("padding-bottom")}},{key:"dataKey",value:function(t){return this.uniqId+"."+t}},{key:"data",value:function(t,e){if(2!=arguments.length){if(1==arguments.length)return Qt[this.dataKey(t)];var r=Object.keys(Qt),n=this.uniqId+".";return r.filter(function(t){return 0==t.indexOf(n)}).map(function(t){return Qt[t]})}return Qt[this.dataKey(t)]=e,this}},{key:"val",value:function(t){return 0==arguments.length?this.el.value:(1==arguments.length&&(this.el.value=t),this)}},{key:"int",value:function(){return parseInt(this.val(),10)}},{key:"float",value:function(){return parseFloat(this.val())}},{key:"show",value:function(){return this.css("display","block")}},{key:"hide",value:function(){return this.css("display","none")}},{key:"toggle",value:function(){return"none"==this.css("display")?this.show():this.hide()}},{key:"scrollTop",value:function(){return this.el===document.body?document.documentElement.scrollTop:this.el.scrollTop}},{key:"scrollLeft",value:function(){return this.el===document.body?document.documentElement.scrollLeft:this.el.scrollLeft}},{key:"on",value:function(t,e,r,n){return this.el.addEventListener(t,e,r,n),this}},{key:"off",value:function(t,e){return this.el.removeEventListener(t,e),this}},{key:"getElement",value:function(){return this.el}},{key:"createChild",value:function(e){var r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"",n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},i=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{},o=new t(e,r,n);return o.css(i),this.append(o),o}}]),t}(),ee={addEvent:function(t,e,r){t.addEventListener(e,r)},removeEvent:function(t,e,r){t.removeEventListener(e,r)},pos:function(t){return t.touches&&t.touches[0]?t.touches[0]:t}},re=function(){function t(e){var r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};g(this,t),this.masterObj=e,this.settingObj=r}return v(t,[{key:"set",value:function(t,e){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:void 0;this.settingObj[t]=e||r}},{key:"init",value:function(t){if(!this.has(t)){var e=t.split("."),r=this.masterObj[e[0]]||this.masterObj,n=e.pop();if(r[n]){for(var i=arguments.length,o=Array(i>1?i-1:0),a=1;a1&&void 0!==arguments[1]?arguments[1]:"";return this.init(t,e),this.settingObj[t]||e}},{key:"has",value:function(t){return!!this.settingObj[t]}}]),t}(),ne=/^(click|mouse(down|up|move|enter|leave)|key(down|up|press)|contextmenu|change|input)/gi,ie=["Control","Shift","Alt","Meta"],oe=function(){function t(){g(this,t),this.state=new re(this)}return v(t,[{key:"initializeEvent",value:function(){this.initializeEventMachin()}},{key:"destroy",value:function(){this.destroyEventMachin()}},{key:"destroyEventMachin",value:function(){this.removeEventAll()}},{key:"initializeEventMachin",value:function(){this.filterProps(ne).forEach(this.parseEvent.bind(this))}},{key:"filterProps",value:function(t){return Object.getOwnPropertyNames(this.__proto__).filter(function(e){return e.match(t)})}},{key:"parseEvent",value:function(t){var e=t.split(" ");this.bindingEvent(e,this[t].bind(this))}},{key:"getDefaultDomElement",value:function(t){var e=void 0;return(e=t?this[t]||window[t]:this.el||this.$el||this.$root)instanceof te?e.getElement():e}},{key:"getDefaultEventObject",value:function(t){var e=this,r=t.split("."),n=r.shift(),i=r.includes("Control"),o=r.includes("Shift"),a=r.includes("Alt"),l=r.includes("Meta"),s=(r=r.filter(function(t){return!1===ie.includes(t)})).filter(function(t){return!!e[t]});return{eventName:n,isControl:i,isShift:o,isAlt:a,isMeta:l,codes:r=r.filter(function(t){return!1===s.includes(t)}).map(function(t){return t.toLowerCase()}),checkMethodList:s}}},{key:"bindingEvent",value:function(t,e){var r,n=(r=t,Array.isArray(r)?r:Array.from(r)),i=n[0],o=n[1],a=n.slice(2);o=this.getDefaultDomElement(o);var l=this.getDefaultEventObject(i);l.dom=o,l.delegate=a.join(" "),this.addEvent(l,e)}},{key:"matchPath",value:function(t,e){return t?t.matches(e)?t:this.matchPath(t.parentElement,e):null}},{key:"getBindings",value:function(){return this._bindings||this.initBindings(),this._bindings}},{key:"addBinding",value:function(t){this.getBindings().push(t)}},{key:"initBindings",value:function(){this._bindings=[]}},{key:"checkEventType",value:function(t,e){var r=this,n=!t.ctrlKey||e.isControl,i=!t.shiftKey||e.isShift,o=!t.altKey||e.isAlt,a=!t.metaKey||e.isMeta,l=!0;e.codes.length&&(l=e.codes.includes(t.code.toLowerCase())||e.codes.includes(t.key.toLowerCase()));var s=!0;return e.checkMethodList.length&&(s=e.checkMethodList.every(function(e){return r[e].call(r,t)})),n&&o&&i&&a&&l&&s}},{key:"makeCallback",value:function(t,e){var r=this;return t.delegate?function(n){if(r.checkEventType(n,t)){var i=r.matchPath(n.target||n.srcElement,t.delegate);if(i)return n.delegateTarget=i,n.$delegateTarget=new te(i),e(n)}}:function(n){if(r.checkEventType(n,t))return e(n)}}},{key:"addEvent",value:function(t,e){t.callback=this.makeCallback(t,e),this.addBinding(t),ee.addEvent(t.dom,t.eventName,t.callback)}},{key:"removeEventAll",value:function(){var t=this;this.getBindings().forEach(function(e){t.removeEvent(e)}),this.initBindings()}},{key:"removeEvent",value:function(t){var e=t.eventName,r=t.dom,n=t.callback;ee.removeEvent(r,e,n)}}]),t}(),ae=function(t){function e(t){g(this,e);var r=y(this,(e.__proto__||Object.getPrototypeOf(e)).call(this));return r.colorpicker=t,r.initialize(),r}return b(e,oe),v(e,[{key:"initialize",value:function(){this.$el=new te("div","control"),this.$hue=this.$el.createChild("div","hue"),this.$opacity=this.$el.createChild("div","opacity"),this.$controlPattern=this.$el.createChild("div","empty"),this.$controlColor=this.$el.createChild("div","color"),this.$hueContainer=this.$hue.createChild("div","hue-container"),this.$drag_bar=this.$hueContainer.createChild("div","drag-bar"),this.drag_bar_pos={},this.$opacityContainer=this.$opacity.createChild("div","opacity-container"),this.$opacityColorBar=this.$opacityContainer.createChild("div","color-bar"),this.$opacity_drag_bar=this.$opacityContainer.createChild("div","drag-bar2"),this.opacity_drag_bar_pos={}}},{key:"setBackgroundColor",value:function(t){this.$controlColor.css("background-color",t)}},{key:"refresh",value:function(){this.setColorUI()}},{key:"setColorUI",value:function(){var t=this.state.get("$el.width")*this.colorpicker.currentS,e=this.state.get("$el.height")*(1-this.colorpicker.currentV);this.$drag_pointer.css({left:t+"px",top:e+"px"})}},{key:"setOpacityColorBar",value:function(t){var e=Yt.parse(t);e.a=0;var r=Yt.format(e,"rgb");e.a=1;var n=Yt.format(e,"rgb");this.$opacityColorBar.css("background","linear-gradient(to right, "+r+", "+n+")")}},{key:"setOpacity",value:function(t){var e,r=this.$opacityContainer.offset().left,n=r+this.state.get("$opacityContainer.width"),i=ee.pos(t).clientX;e=in?100:(i-r)/(n-r)*100;var o=this.state.get("$opacityContainer.width")*(e/100);this.$opacity_drag_bar.css({left:o-Math.ceil(this.state.get("$opacity_drag_bar.width")/2)+"px"}),this.opacity_drag_bar_pos={x:o},this.colorpicker.setCurrentA(this.caculateOpacity()),this.colorpicker.currentFormat(),this.colorpicker.setInputColor()}},{key:"setInputColor",value:function(){this.setBackgroundColor(this.colorpicker.getFormattedColor("rgb"));var t=this.colorpicker.convertRGB(),e=Yt.format(t,"rgb");this.setOpacityColorBar(e)}},{key:"setColorUI",value:function(){var t=this.state.get("$hueContainer.width")*(this.colorpicker.currentH/360);this.$drag_bar.css({left:t-7.5+"px"}),this.drag_bar_pos={x:t};var e=this.state.get("$opacityContainer.width")*(this.colorpicker.currentA||0);this.$opacity_drag_bar.css({left:e-7.5+"px"}),this.opacity_drag_bar_pos={x:e}}},{key:"caculateH",value:function(){return{h:(this.drag_bar_pos||{x:0}).x/this.state.get("$hueContainer.width")*360}}},{key:"caculateOpacity",value:function(){var t=this.opacity_drag_bar_pos||{x:0},e=Math.round(t.x/this.state.get("$opacityContainer.width")*100)/100;return isNaN(e)?1:e}},{key:"EventDocumentMouseMove",value:function(t){this.isHueDown&&this.setHueColor(t),this.isOpacityDown&&this.setOpacity(t)}},{key:"EventDocumentMouseUp",value:function(t){this.isHueDown=!1,this.isOpacityDown=!1}},{key:"setControlColor",value:function(t){this.$controlColor.css("background-color",t)}},{key:"setHueColor",value:function(t){var e,r=this.$hueContainer.offset().left,n=r+this.state.get("$hueContainer.width"),i=t?ee.pos(t).clientX:r+(n-r)*(this.colorpicker.currentH/360);e=in?100:(i-r)/(n-r)*100;var o=this.state.get("$hueContainer.width")*(e/100);this.$drag_bar.css({left:o-Math.ceil(this.state.get("$drag_bar.width")/2)+"px"}),this.drag_bar_pos={x:o};var a=Kt.checkHueColor(e/100);this.colorpicker.setBackgroundColor(a),this.colorpicker.setCurrentH(e/100*360),this.colorpicker.setInputColor()}},{key:"setOnlyHueColor",value:function(){var t,e=this.$hueContainer.offset().left,r=e+this.state.get("$hueContainer.width"),n=e+(r-e)*(this.colorpicker.currentH/360);t=nr?100:(n-e)/(r-e)*100;var i=this.state.get("$hueContainer.width")*(t/100);this.$drag_bar.css({left:i-Math.ceil(this.state.get("$drag_bar.width")/2)+"px"}),this.drag_bar_pos={x:i};var o=Kt.checkHueColor(t/100);this.colorpicker.setBackgroundColor(o),this.colorpicker.setCurrentH(t/100*360)}},{key:"mousedown $drag_bar",value:function(t){t.preventDefault(),this.isHueDown=!0}},{key:"mousedown $opacity_drag_bar",value:function(t){t.preventDefault(),this.isOpacityDown=!0}},{key:"mousedown $hueContainer",value:function(t){this.isHueDown=!0,this.setHueColor(t)}},{key:"mousedown $opacityContainer",value:function(t){this.isOpacityDown=!0,this.setOpacity(t)}}]),e}(),le=function(t){function e(t){g(this,e);var r=y(this,(e.__proto__||Object.getPrototypeOf(e)).call(this));return r.colorpicker=t,r.initialize(),r}return b(e,oe),v(e,[{key:"initialize",value:function(){this.$el=new te("div","information hex"),this.$informationChange=this.$el.createChild("div","information-change"),this.$formatChangeButton=this.$informationChange.createChild("button","format-change-button arrow-button",{type:"button"}),this.$el.append(this.makeInputFieldHex()),this.$el.append(this.makeInputFieldRgb()),this.$el.append(this.makeInputFieldHsl()),this.format="hex"}},{key:"makeInputFieldHex",value:function(){var t=new te("div","information-item hex"),e=t.createChild("div","input-field hex");return this.$hexCode=e.createChild("input","input",{type:"text"}),e.createChild("div","title").html("HEX"),t}},{key:"makeInputFieldRgb",value:function(){var t=new te("div","information-item rgb"),e=t.createChild("div","input-field rgb-r");return this.$rgb_r=e.createChild("input","input",{type:"number",step:1,min:0,max:255}),e.createChild("div","title").html("R"),e=t.createChild("div","input-field rgb-g"),this.$rgb_g=e.createChild("input","input",{type:"number",step:1,min:0,max:255}),e.createChild("div","title").html("G"),e=t.createChild("div","input-field rgb-b"),this.$rgb_b=e.createChild("input","input",{type:"number",step:1,min:0,max:255}),e.createChild("div","title").html("B"),e=t.createChild("div","input-field rgb-a"),this.$rgb_a=e.createChild("input","input",{type:"number",step:.01,min:0,max:1}),e.createChild("div","title").html("A"),t}},{key:"makeInputFieldHsl",value:function(){var t=new te("div","information-item hsl"),e=t.createChild("div","input-field hsl-h");return this.$hsl_h=e.createChild("input","input",{type:"number",step:1,min:0,max:360}),e.createChild("div","title").html("H"),e=t.createChild("div","input-field hsl-s"),this.$hsl_s=e.createChild("input","input",{type:"number",step:1,min:0,max:100}),e.createChild("div","postfix").html("%"),e.createChild("div","title").html("S"),e=t.createChild("div","input-field hsl-l"),this.$hsl_l=e.createChild("input","input",{type:"number",step:1,min:0,max:100}),e.createChild("div","postfix").html("%"),e.createChild("div","title").html("L"),e=t.createChild("div","input-field hsl-a"),this.$hsl_a=e.createChild("input","input",{type:"number",step:.01,min:0,max:1}),e.createChild("div","title").html("A"),t}},{key:"currentFormat",value:function(){var t=this.format||"hex";if(this.colorpicker.currentA<1&&"hex"==t){this.$el.removeClass(t),this.$el.addClass("rgb"),this.format="rgb",this.colorpicker.setInputColor()}}},{key:"setCurrentFormat",value:function(t){this.format=t,this.initFormat()}},{key:"initFormat",value:function(){var t=this.format||"hex";this.$el.removeClass("hex"),this.$el.removeClass("rgb"),this.$el.removeClass("hsl"),this.$el.addClass(t)}},{key:"nextFormat",value:function(){var t=this.format||"hex",e="hex";"hex"==t?e="rgb":"rgb"==t?e="hsl":"hsl"==t&&(e=1==this.colorpicker.currentA?"hex":"rgb"),this.$el.removeClass(t),this.$el.addClass(e),this.format=e,this.setInputColor(),this.colorpicker.changeInputColorAfterNextFormat()}},{key:"setRGBInput",value:function(t,e,r){this.$rgb_r.val(t),this.$rgb_g.val(e),this.$rgb_b.val(r),this.$rgb_a.val(this.colorpicker.currentA)}},{key:"setHSLInput",value:function(t,e,r){this.$hsl_h.val(t),this.$hsl_s.val(e),this.$hsl_l.val(r),this.$hsl_a.val(this.colorpicker.currentA)}},{key:"getHexFormat",value:function(){return Yt.format({r:this.$rgb_r.int(),g:this.$rgb_g.int(),b:this.$rgb_b.int()},"hex",this.colorpicker.opt.color)}},{key:"getRgbFormat",value:function(){return Yt.format({r:this.$rgb_r.int(),g:this.$rgb_g.int(),b:this.$rgb_b.int(),a:this.$rgb_a.float()},"rgb",this.colorpicker.opt.color)}},{key:"getHslFormat",value:function(){return Yt.format({h:this.$hsl_h.val(),s:this.$hsl_s.val(),l:this.$hsl_l.val(),a:this.$hsl_a.float()},"hsl",this.colorpicker.opt.color)}},{key:"convertRGB",value:function(){return this.colorpicker.convertRGB()}},{key:"convertHEX",value:function(){return this.colorpicker.convertHEX()}},{key:"convertHSL",value:function(){return this.colorpicker.convertHSL()}},{key:"getFormattedColor",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]&&arguments[1];return"hex"==(t=t||this.getFormat())?this.$hexCode.val():"rgb"==t?this.getRgbFormat(e):"hsl"==t?this.getHslFormat(e):void 0}},{key:"getFormat",value:function(){return this.format||"hex"}},{key:"setInputColor",value:function(){var t=this.getFormat(),e=null;if("hex"==t){this.$hexCode.val(this.convertHEX());e=this.convertRGB();this.setRGBInput(e.r,e.g,e.b,e.a)}else if("rgb"==t){e=this.convertRGB();this.setRGBInput(e.r,e.g,e.b,e.a),this.$hexCode.val(this.convertHEX())}else if("hsl"==t){var r=this.convertHSL();this.setHSLInput(r.h,r.s,r.l,r.a)}}},{key:"checkNumberKey",value:function(t){return ee.checkNumberKey(t)}},{key:"checkNotNumberKey",value:function(t){return!ee.checkNumberKey(t)}},{key:"changeRgbColor",value:function(){this.colorpicker.changeInformationColor(this.getRgbFormat())}},{key:"changeHslColor",value:function(){this.colorpicker.changeInformationColor(this.getHslFormat())}},{key:"change $rgb_r",value:function(t){this.changeRgbColor()}},{key:"change $rgb_g",value:function(t){this.changeRgbColor()}},{key:"change $rgb_b",value:function(t){this.changeRgbColor()}},{key:"change $rgb_a",value:function(t){this.changeRgbColor()}},{key:"change $hsl_h",value:function(t){this.changeHslColor()}},{key:"change $hsl_s",value:function(t){this.changeHslColor()}},{key:"change $hsl_l",value:function(t){this.changeHslColor()}},{key:"change $hsl_a",value:function(t){this.changeHslColor()}},{key:"keydown $hexCode",value:function(t){if(t.which<65||t.which>70)return this.checkNumberKey(t)}},{key:"keyup $hexCode",value:function(t){var e=this.$hexCode.val();"#"==e.charAt(0)&&7==e.length&&(this.colorpicker.changeInformationColor(e),this.setInputColor())}},{key:"click $formatChangeButton",value:function(t){this.nextFormat()}},{key:"refresh",value:function(){}}]),e}(),se=function(t){function e(t){g(this,e);var r=y(this,(e.__proto__||Object.getPrototypeOf(e)).call(this));return r.colorpicker=t,r.initialize(),r}return b(e,oe),v(e,[{key:"initialize",value:function(){this.$el=new te("div","color"),this.$saturation=this.$el.createChild("div","saturation"),this.$value=this.$saturation.createChild("div","value"),this.$drag_pointer=this.$value.createChild("div","drag-pointer")}},{key:"setBackgroundColor",value:function(t){this.$el.css("background-color",t)}},{key:"refresh",value:function(){this.setColorUI()}},{key:"caculateSV",value:function(){var t=this.drag_pointer_pos||{x:0,y:0},e=this.state.get("$el.width"),r=this.state.get("$el.height");return{s:t.x/e,v:(r-t.y)/r,width:e,height:r}}},{key:"setColorUI",value:function(){var t=this.state.get("$el.width")*this.colorpicker.currentS,e=this.state.get("$el.height")*(1-this.colorpicker.currentV);this.$drag_pointer.css({left:t-5+"px",top:e-5+"px"}),this.drag_pointer_pos={x:t,y:e}}},{key:"setMainColor",value:function(t){t.preventDefault();var e=this.$el.position(),r=this.state.get("$el.contentWidth"),n=this.state.get("$el.contentHeight"),i=t.clientX-e.left,o=t.clientY-e.top;i<0?i=0:i>r&&(i=r),o<0?o=0:o>n&&(o=n),this.$drag_pointer.css({left:i-5+"px",top:o-5+"px"}),this.drag_pointer_pos={x:i,y:o},this.colorpicker.caculateHSV(),this.colorpicker.setInputColor()}},{key:"EventDocumentMouseUp",value:function(t){this.isDown=!1}},{key:"EventDocumentMouseMove",value:function(t){this.isDown&&this.setMainColor(t)}},{key:"mousedown",value:function(t){this.isDown=!0,this.setMainColor(t)}},{key:"mouseup",value:function(t){this.isDown=!1}}]),e}(),ue="data-colorsets-index",he=function(t){function e(t){g(this,e);var r=y(this,(e.__proto__||Object.getPrototypeOf(e)).call(this));return r.colorpicker=t,r.initialize(),r}return b(e,oe),v(e,[{key:"initialize",value:function(){this.$el=new te("div","color-chooser");var t=this.$el.createChild("div","color-chooser-container"),e=t.createChild("div","colorsets-item colorsets-item-header");e.createChild("h1","title").html("Color Paletts"),this.$toggleButton=e.createChild("span","items").html("×"),this.$colorsetsList=t.createChild("div","colorsets-list"),this.refresh()}},{key:"refresh",value:function(){this.$colorsetsList.html(this.makeColorSetsList())}},{key:"makeColorItemList",value:function(t){for(var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:5,r=new te("div"),n=0;n1&&void 0!==arguments[1]&&arguments[1];if("object"==(void 0===t?"undefined":f(t))){if(!t.r||!t.g||!t.b)return;e?this.callbackColorValue(Yt.format(t,"hex")):this.initColor(Yt.format(t,"hex"))}else"string"==typeof t&&(e?this.callbackColorValue(t):this.initColor(t))}},{key:"getColor",value:function(t){this.caculateHSV();var e=this.convertRGB();return t?Yt.format(e,t):e}},{key:"definePositionForArrow",value:function(t,e,r){}},{key:"definePosition",value:function(t){var e=this.$root.width(),r=this.$root.height(),n=t.left-this.$body.scrollLeft();e+n>window.innerWidth&&(n-=e+n-window.innerWidth),n<0&&(n=0);var i=t.top-this.$body.scrollTop();r+i>window.innerHeight&&(i-=r+i-window.innerHeight),i<0&&(i=0),this.$root.css({left:n+"px",top:i+"px"})}},{key:"getInitalizePosition",value:function(){return"inline"==this.opt.position?{position:"relative",left:"auto",top:"auto",display:"inline-block"}:{position:"fixed",left:"-10000px",top:"-10000px"}}},{key:"show",value:function(t,e,r){this.destroy(),this.initializeEvent(),this.$root.appendTo(this.$body),this.$root.css(this.getInitalizePosition()).show(),this.definePosition(t),this.isColorPickerShow=!0,this.isShortCut=t.isShortCut||!1,this.initColor(e),this.colorpickerCallback=r,this.hideDelay=t.hideDelay||2e3,this.hideDelay>0&&this.setHideDelay(this.hideDelay)}},{key:"setHideDelay",value:function(t){var e=this;t=t||0,this.$root.off("mouseenter"),this.$root.off("mouseleave"),this.$root.on("mouseenter",function(){clearTimeout(e.timerCloseColorPicker)}),this.$root.on("mouseleave",function(){clearTimeout(e.timerCloseColorPicker),e.timerCloseColorPicker=setTimeout(e.hide.bind(e),t)}),clearTimeout(this.timerCloseColorPicker),this.timerCloseColorPicker=setTimeout(this.hide.bind(this),t)}},{key:"hide",value:function(){this.isColorPickerShow&&(this.destroy(),this.$root.hide(),this.$root.remove(),this.isColorPickerShow=!1)}},{key:"convertRGB",value:function(){return Yt.HSVtoRGB(this.currentH,this.currentS,this.currentV)}},{key:"convertHEX",value:function(){return Yt.format(this.convertRGB(),"hex")}},{key:"convertHSL",value:function(){return Yt.HSVtoHSL(this.currentH,this.currentS,this.currentV)}},{key:"getCurrentColor",value:function(){return this.information.getFormattedColor()}},{key:"getFormattedColor",value:function(t){if("rgb"==(t=t||"hex"))return(r=this.convertRGB()).a=this.currentA,Yt.format(r,"rgb");if("hsl"==t){var e=this.convertHSL();return e.a=this.currentA,Yt.format(e,"hsl")}var r=this.convertRGB();return Yt.format(r,"hex")}},{key:"setInputColor",value:function(t){this.information.setInputColor(t),this.control.setInputColor(t),this.callbackColorValue()}},{key:"changeInputColorAfterNextFormat",value:function(){this.control.setInputColor(),this.callbackColorValue()}},{key:"callbackColorValue",value:function(t){t=t||this.getCurrentColor(),isNaN(this.currentA)||("function"==typeof this.opt.onChange&&this.opt.onChange.call(this,t),"function"==typeof this.colorpickerCallback&&this.colorpickerCallback(t))}},{key:"caculateHSV",value:function(){var t=this.palette.caculateSV(),e=this.control.caculateH(),r=t.s,n=t.v,i=e.h;0==t.width&&(i=0,r=0,n=0),this.currentH=i,this.currentS=r,this.currentV=n}},{key:"setColorUI",value:function(){this.control.setColorUI(),this.palette.setColorUI()}},{key:"setCurrentHSV",value:function(t,e,r,n){this.currentA=n,this.currentH=t,this.currentS=e,this.currentV=r}},{key:"setCurrentH",value:function(t){this.currentH=t}},{key:"setCurrentA",value:function(t){this.currentA=t}},{key:"setBackgroundColor",value:function(t){this.palette.setBackgroundColor(t)}},{key:"setCurrentFormat",value:function(t){this.format=t,this.information.setCurrentFormat(t)}},{key:"getHSV",value:function(t){return"hsl"==t.type?Yt.HSLtoHSV(t):Yt.RGBtoHSV(t)}},{key:"initColor",value:function(t,e){var r=t||"#FF0000",n=Yt.parse(r);e=e||n.type,this.setCurrentFormat(e);var i=this.getHSV(n);this.setCurrentHSV(i.h,i.s,i.v,n.a),this.setColorUI(),this.setHueColor(),this.setInputColor()}},{key:"changeInformationColor",value:function(t){var e=t||"#FF0000",r=Yt.parse(e),n=this.getHSV(r);this.setCurrentHSV(n.h,n.s,n.v,r.a),this.setColorUI(),this.setHueColor(),this.control.setInputColor(),this.callbackColorValue()}},{key:"setHueColor",value:function(){this.control.setOnlyHueColor()}},{key:"checkColorPickerClass",value:function(t){var e=new te(t).closest("codemirror-colorview"),r=new te(t).closest("codemirror-colorpicker"),n=new te(t).closest("CodeMirror");t.nodeName;return!!(r||e||n)}},{key:"checkInHtml",value:function(t){return"HTML"==t.nodeName}},{key:"mouseup document",value:function(t){this.palette.EventDocumentMouseUp(t),this.control.EventDocumentMouseUp(t),this.checkInHtml(t.target)||0==this.checkColorPickerClass(t.target)&&this.hide()}},{key:"mousemove document",value:function(t){this.palette.EventDocumentMouseMove(t),this.control.EventDocumentMouseMove(t)}},{key:"initializeEvent",value:function(){this.initializeEventMachin(),this.palette.initializeEvent(),this.control.initializeEvent(),this.information.initializeEvent(),this.currentColorSets.initializeEvent(),this.colorSetsChooser.initializeEvent(),this.contextMenu.initializeEvent()}},{key:"currentFormat",value:function(){this.information.currentFormat()}},{key:"toggleColorChooser",value:function(){this.colorSetsChooser.toggle()}},{key:"refreshColorSetsChooser",value:function(){this.colorSetsChooser.refresh()}},{key:"getColorSetsList",value:function(){return this.colorSetsList.getColorSetsList()}},{key:"setCurrentColorSets",value:function(t){this.colorSetsList.setCurrentColorSets(t),this.currentColorSets.refresh()}},{key:"setColorSets",value:function(t){this.colorSetsList.setUserList(t)}},{key:"destroy",value:function(){m(e.prototype.__proto__||Object.getPrototypeOf(e.prototype),"destroy",this).call(this),this.control.destroy(),this.palette.destroy(),this.information.destroy(),this.colorSetsChooser.destroy(),this.colorSetsList.destroy(),this.currentColorSets.destroy(),this.contextMenu.destroy(),this.colorpickerCallback=void 0}}]),e}(),pe="codemirror-colorview",me="codemirror-colorview-background",be=["comment"];function ye(t,e){"setValue"==e.origin?(t.state.colorpicker.close_color_picker(),t.state.colorpicker.init_color_update(),t.state.colorpicker.style_color_update()):t.state.colorpicker.style_color_update(t.getCursor().line)}function ke(t,e){t.state.colorpicker.isUpdate||(t.state.colorpicker.isUpdate=!0,t.state.colorpicker.close_color_picker(),t.state.colorpicker.init_color_update(),t.state.colorpicker.style_color_update())}function Ce(t,e){ye(t,{origin:"setValue"})}function $e(t,e){t.state.colorpicker.keyup(e)}function xe(t,e){t.state.colorpicker.is_edit_mode()&&t.state.colorpicker.check_mousedown(e)}function we(t,e){ye(t,{origin:"setValue"})}function _e(t){t.state.colorpicker.close_color_picker()}var Se=function(){function t(e,r){g(this,t),r="boolean"==typeof r?{mode:"edit"}:Object.assign({mode:"edit"},r||{}),this.opt=r,this.cm=e,this.markers={},this.excluded_token=this.opt.excluded_token||be,this.opt.colorpicker?this.colorpicker=this.opt.colorpicker(this.opt):this.colorpicker=new de(this.opt),this.init_event()}return v(t,[{key:"init_event",value:function(){var t,e,r,n,i;this.cm.on("mousedown",xe),this.cm.on("keyup",$e),this.cm.on("change",ye),this.cm.on("update",ke),this.cm.on("refresh",Ce),this.onPasteCallback=(t=this.cm,e=we,function(r){e.call(this,t,r)}),this.cm.getWrapperElement().addEventListener("paste",this.onPasteCallback),this.is_edit_mode()&&this.cm.on("scroll",(r=_e,n=50,i=void 0,function(t,e){i&&clearTimeout(i),i=setTimeout(function(){r(t,e)},n||300)}))}},{key:"is_edit_mode",value:function(){return"edit"==this.opt.mode}},{key:"is_view_mode",value:function(){return"view"==this.opt.mode}},{key:"destroy",value:function(){this.cm.off("mousedown",xe),this.cm.off("keyup",$e),this.cm.off("change",ye),this.cm.getWrapperElement().removeEventListener("paste",this.onPasteCallback),this.is_edit_mode()&&this.cm.off("scroll")}},{key:"hasClass",value:function(t,e){return!!t.className&&(" "+t.className+" ").indexOf(" "+e+" ")>-1}},{key:"check_mousedown",value:function(t){this.hasClass(t.target,me)?this.open_color_picker(t.target.parentNode):this.close_color_picker()}},{key:"popup_color_picker",value:function(t){var e=this.cm.getCursor(),r=this,n={lineNo:e.line,ch:e.ch,color:t||"#FFFFFF",isShortCut:!0};Object.keys(this.markers).forEach(function(t){if(("#"+t).indexOf("#"+n.lineNo+":")>-1){var e=r.markers[t];e.ch<=n.ch&&n.ch<=e.ch+e.color.length&&(n.ch=e.ch,n.color=e.color,n.nameColor=e.nameColor)}}),this.open_color_picker(n)}},{key:"open_color_picker",value:function(t){var e=t.lineNo,r=t.ch,n=t.nameColor,i=t.color;if(this.colorpicker){var o=this,a=i,l=this.cm.charCoords({line:e,ch:r});this.colorpicker.show({left:l.left,top:l.bottom,isShortCut:t.isShortCut||!1,hideDelay:o.opt.hideDelay||2e3},n||i,function(t){o.cm.replaceRange(t,{line:e,ch:r},{line:e,ch:r+a.length},"*colorpicker"),a=t})}}},{key:"close_color_picker",value:function(t){this.colorpicker&&this.colorpicker.hide()}},{key:"key",value:function(t,e){return[t,e].join(":")}},{key:"keyup",value:function(t){this.colorpicker&&("Escape"==t.key?this.colorpicker.hide():0==this.colorpicker.isShortCut&&this.colorpicker.hide())}},{key:"init_color_update",value:function(){this.markers={}}},{key:"style_color_update",value:function(t){if(t)this.match(t);else for(var e=this.cm.lineCount(),r=0;r-1)&&(delete this.markers[l],i[o].marker.clear())}}},{key:"match_result",value:function(t){return Yt.matches(t.text)}},{key:"submatch",value:function(t,e){var r=this;this.empty_marker(t,e);var n={next:0};this.match_result(e).forEach(function(i){r.render(n,t,e,i.color,i.nameColor)})}},{key:"match",value:function(t){var e=this.cm.getLineHandle(t),r=this;this.cm.operation(function(){r.submatch(t,e)})}},{key:"make_element",value:function(){var t=document.createElement("div");return t.className=pe,this.is_edit_mode()?t.title="open color picker":t.title="",t.back_element=this.make_background_element(),t.appendChild(t.back_element),t}},{key:"make_background_element",value:function(){var t=document.createElement("div");return t.className=me,t}},{key:"set_state",value:function(t,e,r,n){var i=this.create_marker(t,e);return i.lineNo=t,i.ch=e,i.color=r,i.nameColor=n,i}},{key:"create_marker",value:function(t,e){var r=this.key(t,e);return this.markers[r]||(this.markers[r]=this.make_element()),this.markers[r]}},{key:"has_marker",value:function(t,e){var r=this.key(t,e);return!!this.markers[r]}},{key:"update_element",value:function(t,e){t.back_element.style.backgroundColor=e}},{key:"set_mark",value:function(t,e,r){this.cm.setBookmark({line:t,ch:e},{widget:r,handleMouseEvents:!0})}},{key:"is_excluded_token",value:function(t,e){for(var r=this.cm.getTokenTypeAt({line:t,ch:e}),n=0,i=0,o=this.excluded_token.length;i0}},{key:"render",value:function(t,e,r,n,i){var o=r.text.indexOf(n,t.next);if(!0!==this.is_excluded_token(e,o)){if(t.next=o+n.length,this.has_marker(e,o))return this.update_element(this.create_marker(e,o),i||n),void this.set_state(e,o,n,i);var a=this.create_marker(e,o);this.update_element(a,i||n),this.set_state(e,o,n,i||n),this.set_mark(e,o,a)}}}]),t}();return t&&t.defineOption("colorpicker",!1,function(e,r,n){n&&n!=t.Init&&e.state.colorpicker&&(e.state.colorpicker.destroy(),e.state.colorpicker=null),r&&(e.state.colorpicker=new Se(e,r))}),{Color:Yt,ColorNames:r,ColorPicker:de,ImageFilter:Zt,GL:Xt,HueColor:Kt,Canvas:c,ImageLoader:$}}(CodeMirror);
+var CodeMirrorColorPicker=function(t){"use strict";t=t&&t.hasOwnProperty("default")?t.default:t;var e={aliceblue:"rgb(240, 248, 255)",antiquewhite:"rgb(250, 235, 215)",aqua:"rgb(0, 255, 255)",aquamarine:"rgb(127, 255, 212)",azure:"rgb(240, 255, 255)",beige:"rgb(245, 245, 220)",bisque:"rgb(255, 228, 196)",black:"rgb(0, 0, 0)",blanchedalmond:"rgb(255, 235, 205)",blue:"rgb(0, 0, 255)",blueviolet:"rgb(138, 43, 226)",brown:"rgb(165, 42, 42)",burlywood:"rgb(222, 184, 135)",cadetblue:"rgb(95, 158, 160)",chartreuse:"rgb(127, 255, 0)",chocolate:"rgb(210, 105, 30)",coral:"rgb(255, 127, 80)",cornflowerblue:"rgb(100, 149, 237)",cornsilk:"rgb(255, 248, 220)",crimson:"rgb(237, 20, 61)",cyan:"rgb(0, 255, 255)",darkblue:"rgb(0, 0, 139)",darkcyan:"rgb(0, 139, 139)",darkgoldenrod:"rgb(184, 134, 11)",darkgray:"rgb(169, 169, 169)",darkgrey:"rgb(169, 169, 169)",darkgreen:"rgb(0, 100, 0)",darkkhaki:"rgb(189, 183, 107)",darkmagenta:"rgb(139, 0, 139)",darkolivegreen:"rgb(85, 107, 47)",darkorange:"rgb(255, 140, 0)",darkorchid:"rgb(153, 50, 204)",darkred:"rgb(139, 0, 0)",darksalmon:"rgb(233, 150, 122)",darkseagreen:"rgb(143, 188, 143)",darkslateblue:"rgb(72, 61, 139)",darkslategray:"rgb(47, 79, 79)",darkslategrey:"rgb(47, 79, 79)",darkturquoise:"rgb(0, 206, 209)",darkviolet:"rgb(148, 0, 211)",deeppink:"rgb(255, 20, 147)",deepskyblue:"rgb(0, 191, 255)",dimgray:"rgb(105, 105, 105)",dimgrey:"rgb(105, 105, 105)",dodgerblue:"rgb(30, 144, 255)",firebrick:"rgb(178, 34, 34)",floralwhite:"rgb(255, 250, 240)",forestgreen:"rgb(34, 139, 34)",fuchsia:"rgb(255, 0, 255)",gainsboro:"rgb(220, 220, 220)",ghostwhite:"rgb(248, 248, 255)",gold:"rgb(255, 215, 0)",goldenrod:"rgb(218, 165, 32)",gray:"rgb(128, 128, 128)",grey:"rgb(128, 128, 128)",green:"rgb(0, 128, 0)",greenyellow:"rgb(173, 255, 47)",honeydew:"rgb(240, 255, 240)",hotpink:"rgb(255, 105, 180)",indianred:"rgb(205, 92, 92)",indigo:"rgb(75, 0, 130)",ivory:"rgb(255, 255, 240)",khaki:"rgb(240, 230, 140)",lavender:"rgb(230, 230, 250)",lavenderblush:"rgb(255, 240, 245)",lawngreen:"rgb(124, 252, 0)",lemonchiffon:"rgb(255, 250, 205)",lightblue:"rgb(173, 216, 230)",lightcoral:"rgb(240, 128, 128)",lightcyan:"rgb(224, 255, 255)",lightgoldenrodyellow:"rgb(250, 250, 210)",lightgreen:"rgb(144, 238, 144)",lightgray:"rgb(211, 211, 211)",lightgrey:"rgb(211, 211, 211)",lightpink:"rgb(255, 182, 193)",lightsalmon:"rgb(255, 160, 122)",lightseagreen:"rgb(32, 178, 170)",lightskyblue:"rgb(135, 206, 250)",lightslategray:"rgb(119, 136, 153)",lightslategrey:"rgb(119, 136, 153)",lightsteelblue:"rgb(176, 196, 222)",lightyellow:"rgb(255, 255, 224)",lime:"rgb(0, 255, 0)",limegreen:"rgb(50, 205, 50)",linen:"rgb(250, 240, 230)",magenta:"rgb(255, 0, 255)",maroon:"rgb(128, 0, 0)",mediumaquamarine:"rgb(102, 205, 170)",mediumblue:"rgb(0, 0, 205)",mediumorchid:"rgb(186, 85, 211)",mediumpurple:"rgb(147, 112, 219)",mediumseagreen:"rgb(60, 179, 113)",mediumslateblue:"rgb(123, 104, 238)",mediumspringgreen:"rgb(0, 250, 154)",mediumturquoise:"rgb(72, 209, 204)",mediumvioletred:"rgb(199, 21, 133)",midnightblue:"rgb(25, 25, 112)",mintcream:"rgb(245, 255, 250)",mistyrose:"rgb(255, 228, 225)",moccasin:"rgb(255, 228, 181)",navajowhite:"rgb(255, 222, 173)",navy:"rgb(0, 0, 128)",oldlace:"rgb(253, 245, 230)",olive:"rgb(128, 128, 0)",olivedrab:"rgb(107, 142, 35)",orange:"rgb(255, 165, 0)",orangered:"rgb(255, 69, 0)",orchid:"rgb(218, 112, 214)",palegoldenrod:"rgb(238, 232, 170)",palegreen:"rgb(152, 251, 152)",paleturquoise:"rgb(175, 238, 238)",palevioletred:"rgb(219, 112, 147)",papayawhip:"rgb(255, 239, 213)",peachpuff:"rgb(255, 218, 185)",peru:"rgb(205, 133, 63)",pink:"rgb(255, 192, 203)",plum:"rgb(221, 160, 221)",powderblue:"rgb(176, 224, 230)",purple:"rgb(128, 0, 128)",rebeccapurple:"rgb(102, 51, 153)",red:"rgb(255, 0, 0)",rosybrown:"rgb(188, 143, 143)",royalblue:"rgb(65, 105, 225)",saddlebrown:"rgb(139, 69, 19)",salmon:"rgb(250, 128, 114)",sandybrown:"rgb(244, 164, 96)",seagreen:"rgb(46, 139, 87)",seashell:"rgb(255, 245, 238)",sienna:"rgb(160, 82, 45)",silver:"rgb(192, 192, 192)",skyblue:"rgb(135, 206, 235)",slateblue:"rgb(106, 90, 205)",slategray:"rgb(112, 128, 144)",slategrey:"rgb(112, 128, 144)",snow:"rgb(255, 250, 250)",springgreen:"rgb(0, 255, 127)",steelblue:"rgb(70, 130, 180)",tan:"rgb(210, 180, 140)",teal:"rgb(0, 128, 128)",thistle:"rgb(216, 191, 216)",tomato:"rgb(255, 99, 71)",turquoise:"rgb(64, 224, 208)",violet:"rgb(238, 130, 238)",wheat:"rgb(245, 222, 179)",white:"rgb(255, 255, 255)",whitesmoke:"rgb(245, 245, 245)",yellow:"rgb(255, 255, 0)",yellowgreen:"rgb(154, 205, 50)",transparent:"rgba(0, 0, 0, 0)"};var r={isColorName:function(t){return!!e[t]},getColorByName:function(t){return e[t]}};function n(t,e){if(t.length!==e.length)return!1;for(var r=0,n=t.length;r0)h=l(u);else h=e[Math.floor(a()*e.length)];o=!n(h,c),i[s]=h}return o}function c(t,e,r){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:10,a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"linear";t=t,e=e||Math.max(2,Math.ceil(Math.sqrt(t.length/2)));var l=r||"euclidean";"string"==typeof l&&(l=i[l]);for(var c=0,h=function(){return(c=(9301*c+49297)%233280)/233280},f=function(t,e){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"linear";return o[r](t.length,e).map(function(e){return t[e]})}(t,e,a),v=!0,g=0;v;){if(v=u(e,t,s(e,t,f,l),f,!1,h),++g%n==0)break}return f}var h={create:function(t,e){var r=document.createElement("canvas");return r.width=t||0,r.height=e||0,r},drawPixels:function(t){var e=this.create(t.width,t.height),r=e.getContext("2d"),n=r.getImageData(0,0,e.width,e.height);return n.data.set(t.pixels),r.putImageData(n,0,0),e},createHistogram:function(t,e,r,n){var i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{black:!0,red:!1,green:!1,blue:!1},o=this.create(t,e),a=o.getContext("2d");a.clearRect(0,0,t,e),a.fillStyle="white",a.fillRect(0,0,t,e),a.globalAlpha=.7;var l={black:!1};i.black?l.black=!1:l.black=!0,i.red?l.red=!1:l.red=!0,i.green?l.green=!1:l.green=!0,i.blue?l.blue=!1:l.blue=!0,Object.keys(r).forEach(function(n){if(!l[n]){var i=r[n],o=Math.max.apply(Math,i),s=t/i.length;a.fillStyle=n,i.forEach(function(t,r){var n=e*(t/o),i=r*s;a.fillRect(i,e-n,s,n)})}}),"function"==typeof n&&n(o)},getHistogram:function(t){for(var e,r,n=new Array(256),i=new Array(256),o=new Array(256),a=new Array(256),l=0;l<256;l++)n[l]=0,i[l]=0,o[l]=0,a[l]=0;return r=function(t,e){var r=Math.round(qt.brightness(t[e],t[e+1],t[e+2]));n[r]++,i[t[e]]++,o[t[e+1]]++,a[t[e+2]]++},function(t,e){for(var r=0;r1&&void 0!==arguments[1]?arguments[1]:{};v(this,t),this.isLoaded=!1,this.imageUrl=e,this.opt=r,this.initialize()}return g(t,[{key:"initialize",value:function(){this.canvas=this.createCanvas(),this.context=this.canvas.getContext("2d")}},{key:"createCanvas",value:function(){return document.createElement("canvas")}},{key:"load",value:function(t){this.loadImage(t)}},{key:"loadImage",value:function(t){var e=this,r=this.context;this.newImage=new Image;var n=this.newImage;n.onload=function(){var i=n.height/n.width;e.opt.canvasWidth&&e.opt.canvasHeight?(e.canvas.width=e.opt.canvasWidth,e.canvas.height=e.opt.canvasHeight):(e.canvas.width=e.opt.maxWidth?e.opt.maxWidth:n.width,e.canvas.height=e.canvas.width*i),r.drawImage(n,0,0,n.width,n.height,0,0,e.canvas.width,e.canvas.height),e.isLoaded=!0,t&&t()},this.getImageUrl(function(t){n.src=t})}},{key:"load",value:function(t){var e=this;this.newImage=new Image;var r=this.newImage;r.onload=function(){e.isLoaded=!0,t&&t()},this.getImageUrl(function(t){r.src=t})}},{key:"getImageUrl",value:function(t){if("string"==typeof this.imageUrl)return t(this.imageUrl);if(this.imageUrl instanceof Blob){var e=new FileReader;e.onload=function(e){t(e.target.result)},e.readAsDataURL(this.imageUrl)}}},{key:"getRGBA",value:function(t,e,r,n){return[t,e,r,n]}},{key:"toArray",value:function(t,e){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},n=this.context.getImageData(0,0,this.canvas.width,this.canvas.height),i=n.width,o=n.height,a=new Uint8ClampedArray(n.data);t||(t=function(t,e){e(t)}),t({pixels:a,width:i,height:o},function(t){var n=h.drawPixels(t);"canvas"==r.returnTo?e(n):e(n.toDataURL(r.outputFormat||"image/png"))},r)}},{key:"toHistogram",value:function(t){var e=this.context.getImageData(0,0,this.canvas.width,this.canvas.height),r=e.width,n=e.height,i={pixels:new Uint8ClampedArray(e.data),width:r,height:n};return h.getHistogram(i)}},{key:"toRGB",value:function(){for(var t=this.context.getImageData(0,0,this.canvas.width,this.canvas.height).data,e=[],r=0,n=t.length;r0&&void 0!==arguments[0]?arguments[0]:1,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1;return[t=t||0===t?t:1,0,0,0,e=e||0===e?e:1,0,0,0,1]},scaleX:function(t){return this.scale(t)},scaleY:function(t){return this.scale(1,t)},translate:function(t,e){return[1,0,t,0,1,e,0,0,1]},rotate:function(t){var e=this.radian(t);return[Math.cos(e),-Math.sin(e),0,Math.sin(e),Math.cos(e),0,0,0,1]},rotate90:function(){return[0,-1,0,1,0,0,0,0,1]},rotate180:function(){return[-1,0,0,0,-1,0,0,0,1]},rotate270:function(){return[0,1,0,-1,0,0,0,0,1]},radian:function(t){return t*Math.PI/180},skew:function(t,e){var r=this.radian(t),n=this.radian(e);return[1,Math.tan(r),0,Math.tan(n),1,0,0,0,1]},skewX:function(t){var e=this.radian(t);return[1,Math.tan(e),0,0,1,0,0,0,1]},skewY:function(t){var e=this.radian(t);return[1,0,0,Math.tan(e),1,0,0,0,1]},shear1:function(t){return[1,-Math.tan(this.radian(t)/2),0,0,1,0,0,0,1]},shear2:function(t){return[1,0,0,Math.sin(this.radian(t)),1,0,0,0,1]}},_={CONSTANT:x,radian:function(t){return x.radian(t)},multiply:function(t,e){return[t[0]*e[0]+t[1]*e[1]+t[2]*e[2],t[3]*e[0]+t[4]*e[1]+t[5]*e[2],t[6]*e[0]+t[7]*e[1]+t[8]*e[2]]},identity:function(t){return this.multiply(x.identity(),t)},translate:function(t,e,r){return this.multiply(x.translate(t,e),r)},rotate:function(t,e){return this.multiply(x.rotate(t),e)},shear1:function(t,e){return this.multiply(x.shear1(t),e)},shear2:function(t,e){return this.multiply(x.shear2(t),e)},rotateShear:function(t,e){var r=e;return r=this.shear1(t,r),r=this.shear2(t,r),r=this.shear1(t,r)}};function w(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"center",r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"center";return function(n,i){var o=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},a=Q(n.pixels.length,n.width,n.height),l=n.width,s=n.height;"center"==e&&(e=Math.floor(l/2)),"center"==r&&(r=Math.floor(s/2));var u=_.CONSTANT.translate(-e,-r),c=_.CONSTANT.translate(e,r),h=_.CONSTANT.shear1(t),f=_.CONSTANT.shear2(t);st(function(t,e,r,i){var o=_.multiply(u,[r,i,1]);o=_.multiply(h,o).map(Math.round),o=_.multiply(f,o).map(Math.round),o=_.multiply(h,o).map(Math.round),o=_.multiply(c,o);var a=k(o,2),v=a[0],g=a[1];v<0||(g<0||v>l-1||g>s-1||ht(t,g*l+v<<2,n.pixels,e))})(a,function(){i(a)},o)}}function S(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:200,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:100,r=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],n=rt(t),i=(e=rt(e))/100,o=r;return ot(function(){var t=i*Math.ceil(.2126*$r+.7152*$g+.0722*$b)>=n?255:0;if(o)0==t&&($r=0,$g=0,$b=0);else{var e=Math.round(t);$r=e,$g=e,$b=e}},{$C:i,$scale:n,$hasColor:o})}function E(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100;return ft(q([1,2,1,2,4,2,1,2,1],1/16*((t=rt(t))/100)))}function A(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100;return ft(q([1,4,6,4,1,4,16,24,16,4,6,24,36,24,6,4,16,24,16,4,1,4,6,4,1],1/256*((t=rt(t))/100)))}function R(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1;return t=rt(t),ft([5,5,5,-3,0,-3,-3,-3,-3])}function T(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1;return t=rt(t),ft([5,-3,-3,5,0,-3,5,-3,-3])}function M(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100;return ft(q([-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,24,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1],(t=rt(t))/100))}function B(){return ft(q([1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1],1/9))}function H(){return ft(q([1,0,0,0,0,0,0,0,1,0,1,0,0,0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,0,0,1,0,1,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,1,0,1,0,0,0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,0,0,1,0,1,0,0,0,0,0,0,0,1],1/9))}function I(){return ft(q([1,0,0,0,1,0,0,0,1,0,1,0,0,1,0,0,1,0,0,0,1,0,1,0,1,0,0,0,0,0,1,1,1,0,0,0,1,1,1,1,1,1,1,1,1,0,0,0,1,1,1,0,0,0,0,0,1,0,1,0,1,0,0,0,1,0,0,1,0,0,1,0,1,0,0,0,1,0,0,0,1],1/9))}function F(){return ft([-1,-2,-1,0,0,0,1,2,1])}function O(){return ft([-1,0,1,-2,0,2,-1,0,1])}var L=[512,512,456,512,328,456,335,512,405,328,271,456,388,335,292,512,454,405,364,328,298,271,496,456,420,388,360,335,312,292,273,512,482,454,428,405,383,364,345,328,312,298,284,271,259,496,475,456,437,420,404,388,374,360,347,335,323,312,302,292,282,273,265,512,497,482,468,454,441,428,417,405,394,383,373,364,354,345,337,328,320,312,305,298,291,284,278,271,265,259,507,496,485,475,465,456,446,437,428,420,412,404,396,388,381,374,367,360,354,347,341,335,329,323,318,312,307,302,297,292,287,282,278,273,269,265,261,512,505,497,489,482,475,468,461,454,447,441,435,428,422,417,411,405,399,394,389,383,378,373,368,364,359,354,350,345,341,337,332,328,324,320,316,312,309,305,301,298,294,291,287,284,281,278,274,271,268,265,262,259,257,507,501,496,491,485,480,475,470,465,460,456,451,446,442,437,433,428,424,420,416,412,408,404,400,396,392,388,385,381,377,374,370,367,363,360,357,354,350,347,344,341,338,335,332,329,326,323,320,318,315,312,310,307,304,302,299,297,294,292,289,287,285,282,280,278,275,273,271,269,267,265,263,261,259],P=[9,11,12,13,13,14,14,15,15,15,15,16,16,16,16,17,17,17,17,17,17,17,18,18,18,18,18,18,18,18,18,19,19,19,19,19,19,19,19,19,19,19,19,19,19,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,21,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24,24];function G(){this.r=0,this.g=0,this.b=0,this.a=0,this.next=null}function D(t,e,r){return r?function(t,e,r,n){if(isNaN(n)||n<1)return t;n|=0;var i,o,a,l,s,u,c,h,f,v,g,d,p,m,b,y,k,C,$,x,_,w,S,E,A=t.pixels,R=t.width,T=t.height,M=n+n+1,B=R-1,H=T-1,I=n+1,F=I*(I+1)/2,O=new G,D=O;for(a=1;a>U,0!=S?(S=255/S,A[u]=(h*V>>U)*S,A[u+1]=(f*V>>U)*S,A[u+2]=(v*V>>U)*S):A[u]=A[u+1]=A[u+2]=0,h-=d,f-=p,v-=m,g-=b,d-=j.r,p-=j.g,m-=j.b,b-=j.a,l=c+((l=i+n+1)>U,S>0?(S=255/S,A[l]=(h*V>>U)*S,A[l+1]=(f*V>>U)*S,A[l+2]=(v*V>>U)*S):A[l]=A[l+1]=A[l+2]=0,h-=d,f-=p,v-=m,g-=b,d-=j.r,p-=j.g,m-=j.b,b-=j.a,l=i+((l=o+I)0&&void 0!==arguments[0]?arguments[0]:10,e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];return t=rt(t),function(r,n){n(D(r,t,e))}}function j(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:256;return ft(q([1,4,6,4,1,4,16,24,16,4,6,24,-476,24,6,4,16,24,16,4,1,4,6,4,1],-1/(t=rt(t))))}var z,V=p({},{crop:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,r=arguments[2],n=arguments[3],i=Q(r*n*4,r,n);return function(o,a){for(var l=e,s=0;l0&&void 0!==arguments[0]?arguments[0]:0;return t=rt(t),t%=360,function(e,r){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};if(0==t)return e;if(90==t||270==t)var i=Q(e.pixels.length,e.height,e.width);else{if(180!=t)return w(t)(e,r,n);i=Q(e.pixels.length,e.width,e.height)}st(function(r,n,o,a){if(90==t)var l=o*i.width+(i.width-1-a)<<2;else 270==t?l=(i.height-1-o)*i.width+a<<2:180==t&&(l=(i.height-1-a)*i.width+(i.width-1-o)<<2);ht(i.pixels,l,e.pixels,n)})(e,function(){r(i)},n)}},rotateDegree:w,histogram:function(){for(var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"gray",e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[],r=[],n=0;n2&&void 0!==arguments[2]?arguments[2]:100,n=qt.parse(t),i=qt.parse(e),o=r;return ot(function(){var t=$r+$g+$b<=o?n:i;$r=t.r,$g=t.g,$b=t.b},{$threshold:o},{$darkColor:n,$lightColor:i})},brightness:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1;t=rt(t);var e=Math.floor(t/100*255);return ot(function(){$r+=e,$g+=e,$b+=e},{$C:e})},brownie:function(){var t=[.5997023498159715,.34553243048391263,-.2708298674538042,0,-.037703249837783157,.8609577587992641,.15059552388459913,0,.24113635128153335,-.07441037908422492,.44972182064877153,0,0,0,0,1];return ot(function(){$r=t[0]*$r+t[1]*$g+t[2]*$b+t[3]*$a,$g=t[4]*$r+t[5]*$g+t[6]*$b+t[7]*$a,$b=t[8]*$r+t[9]*$g+t[10]*$b+t[11]*$a,$a=t[12]*$r+t[13]*$g+t[14]*$b+t[15]*$a},{$matrix:t})},clip:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0;t=rt(t);var e=2.55*Math.abs(t);return ot(function(){$r=$r>255-e?255:0,$g=$g>255-e?255:0,$b=$b>255-e?255:0},{$C:e})},contrast:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0;t=rt(t);var e=Math.max((128+t)/128,0);return ot(function(){$r*=e,$g*=e,$b*=e},{$C:e})},gamma:function(){var t=rt(arguments.length>0&&void 0!==arguments[0]?arguments[0]:1);return ot(function(){$r=255*Math.pow($r/255,t),$g=255*Math.pow($g/255,t),$b=255*Math.pow($b/255,t)},{$C:t})},gradient:function(){var t=[].concat(Array.prototype.slice.call(arguments));1===t.length&&"string"==typeof t[0]&&(t=qt.convertMatchesArray(t[0]));var e=(t=t.map(function(t){return qt.matches(t).length?{type:"param",value:t}:{type:"scale",value:t}})).filter(function(t){return"scale"==t.type})[0];e=e?+e.value:256,t=t.filter(function(t){return"param"==t.type}).map(function(t){return t.value}).join(",");var r=qt.gradient(t,e).map(function(t){var e=qt.parse(t);return{r:e.r,g:e.g,b:e.b,a:e.a}});return ot(function(){var t=dt(Math.ceil(.2126*$r+.7152*$g+.0722*$b)),n=dt(Math.floor(t*(e/256))),i=r[n];$r=i.r,$g=i.g,$b=i.b,$a=dt(Math.floor(256*i.a))},{},{$colors:r,$scale:e})},grayscale:function(t){var e=(t=rt(t))/100;e>1&&(e=1);var r=[.2126+.7874*(1-e),.7152-.7152*(1-e),.0722-.0722*(1-e),0,.2126-.2126*(1-e),.7152+.2848*(1-e),.0722-.0722*(1-e),0,.2126-.2126*(1-e),.7152-.7152*(1-e),.0722+.9278*(1-e),0,0,0,0,1];return ot(function(){$r=r[0]*$r+r[1]*$g+r[2]*$b+r[3]*$a,$g=r[4]*$r+r[5]*$g+r[6]*$b+r[7]*$a,$b=r[8]*$r+r[9]*$g+r[10]*$b+r[11]*$a,$a=r[12]*$r+r[13]*$g+r[14]*$b+r[15]*$a},{$matrix:r})},hue:function(){return ot(function(){var t=Color.RGBtoHSV($r,$g,$b),e=t.h;e+=Math.abs($amount),e%=360,t.h=e;var r=Color.HSVtoRGB(t);$r=r.r,$g=r.g,$b=r.b},{$C:rt(arguments.length>0&&void 0!==arguments[0]?arguments[0]:360)})},invert:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100,e=(t=rt(t))/100;return ot(function(){$r=(255-$r)*e,$g=(255-$g)*e,$b=(255-$b)*e},{$C:e})},kodachrome:function(){var t=[1.1285582396593525,-.3967382283601348,-.03992559172921793,0,-.16404339962244616,1.0835251566291304,-.05498805115633132,0,-.16786010706155763,-.5603416277695248,1.6014850761964943,0,0,0,0,1];return ot(function(){$r=t[0]*$r+t[1]*$g+t[2]*$b+t[3]*$a,$g=t[4]*$r+t[5]*$g+t[6]*$b+t[7]*$a,$b=t[8]*$r+t[9]*$g+t[10]*$b+t[11]*$a,$a=t[12]*$r+t[13]*$g+t[14]*$b+t[15]*$a},{$matrix:t})},matrix:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:0,o=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,a=arguments.length>6&&void 0!==arguments[6]?arguments[6]:0,l=arguments.length>7&&void 0!==arguments[7]?arguments[7]:0,s=arguments.length>8&&void 0!==arguments[8]?arguments[8]:0,u=arguments.length>9&&void 0!==arguments[9]?arguments[9]:0,c=arguments.length>10&&void 0!==arguments[10]?arguments[10]:0,h=arguments.length>11&&void 0!==arguments[11]?arguments[11]:0,f=arguments.length>12&&void 0!==arguments[12]?arguments[12]:0,v=arguments.length>13&&void 0!==arguments[13]?arguments[13]:0,g=arguments.length>14&&void 0!==arguments[14]?arguments[14]:0,d=arguments.length>15&&void 0!==arguments[15]?arguments[15]:0,p=[t,e,r,n,i,o,a,l,s,u,c,h,f,v,g,d];return ot(function(){$r=p[0]*$r+p[1]*a+p[2]*e+p[3]*t,a=p[4]*$r+p[5]*a+p[6]*e+p[7]*t,e=p[8]*$r+p[9]*a+p[10]*e+p[11]*t,t=p[12]*$r+p[13]*a+p[14]*e+p[15]*t},{$matrix:p})},noise:function(){var t=rt(arguments.length>0&&void 0!==arguments[0]?arguments[0]:1);return ot(function(){var e=5*Math.abs(t),r=-e,n=e,i=Math.round(r+Math.random()*(n-r));$r+=i,$g+=i,$b+=i},{$C:t})},opacity:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100,e=(t=rt(t))/100;return ot(function(){$a*=e},{$C:e})},polaroid:function(){var t=[1.438,-.062,-.062,0,-.122,1.378,-.122,0,-.016,-.016,1.483,0,0,0,0,1];return ot(function(){$r=t[0]*$r+t[1]*$g+t[2]*$b+t[3]*$a,$g=t[4]*$r+t[5]*$g+t[6]*$b+t[7]*$a,$b=t[8]*$r+t[9]*$g+t[10]*$b+t[11]*$a,$a=t[12]*$r+t[13]*$g+t[14]*$b+t[15]*$a},{$matrix:t})},saturation:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100,e=(t=rt(t))/100,r=1-Math.abs(e),n=[r,0,0,0,0,r,0,0,0,0,r,0,0,0,0,r];return ot(function(){$r=n[0]*$r+n[1]*$g+n[2]*$b+n[3]*$a,$g=n[4]*$r+n[5]*$g+n[6]*$b+n[7]*$a,$b=n[8]*$r+n[9]*$g+n[10]*$b+n[11]*$a,$a=n[12]*$r+n[13]*$g+n[14]*$b+n[15]*$a},{$matrix:n})},sepia:function(){var t=rt(arguments.length>0&&void 0!==arguments[0]?arguments[0]:1);t>1&&(t=1);var e=[.393+.607*(1-t),.769-.769*(1-t),.189-.189*(1-t),0,.349-.349*(1-t),.686+.314*(1-t),.168-.168*(1-t),0,.272-.272*(1-t),.534-.534*(1-t),.131+.869*(1-t),0,0,0,0,1];return ot(function(){$r=e[0]*$r+e[1]*$g+e[2]*$b+e[3]*$a,$g=e[4]*$r+e[5]*$g+e[6]*$b+e[7]*$a,$b=e[8]*$r+e[9]*$g+e[10]*$b+e[11]*$a,$a=e[12]*$r+e[13]*$g+e[14]*$b+e[15]*$a},{$matrix:e})},shade:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1,n=rt(t),i=rt(e),o=rt(r);return ot(function(){$r*=n,$g*=i,$b*=o},{$redValue:n,$greenValue:i,$blueValue:o})},shift:function(){var t=[1.438,-.062,-.062,0,-.122,1.378,-.122,0,-.016,-.016,1.483,0,0,0,0,1];return ot(function(){$r=t[0]*$r+t[1]*$g+t[2]*$b+t[3]*$a,$g=t[4]*$r+t[5]*$g+t[6]*$b+t[7]*$a,$b=t[8]*$r+t[9]*$g+t[10]*$b+t[11]*$a,$a=t[12]*$r+t[13]*$g+t[14]*$b+t[15]*$a},{$matrix:t})},solarize:function(t,e,r){var n=rt(t),i=rt(e),o=rt(r);return ot(function(){$r=$r0&&void 0!==arguments[0]?arguments[0]:200,arguments.length>1&&void 0!==arguments[1]?arguments[1]:100,!1)},"threshold-color":S,tint:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1,n=parseParamNumber(t),i=parseParamNumber(e),o=parseParamNumber(r);return ot(function(){$r+=(255-$r)*n,$g+=(255-$g)*i,$b+=(255-$b)*o},{$redTint:n,$greenTint:i,$blueTint:o})}},{blur:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:3;return ft(ut(t=rt(t)))},emboss:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:4;return ft([-2*(t=rt(t)),-t,0,-t,1,t,0,t,2*t])},gaussianBlur:E,"gaussian-blur":E,gaussianBlur5x:A,"gaussian-blur-5x":A,grayscale2:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100;return ft(q([.3,.3,.3,0,0,.59,.59,.59,0,0,.11,.11,.11,0,0,0,0,0,0,0,0,0,0,0,0],(t=rt(t))/100))},normal:function(){return ft([0,0,0,0,1,0,0,0,0])},kirschHorizontal:R,"kirsch-horizontal":R,kirschVertical:T,"kirsch-vertical":T,laplacian:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100;return ft(q([-1,-1,-1,-1,8,-1,-1,-1,-1],(t=rt(t))/100))},laplacian5x:M,"laplacian-5x":M,motionBlur:B,"motion-blur":B,motionBlur2:H,"motion-blur-2":H,motionBlur3:I,"motion-blur-3":I,negative:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100;return ft(q([-1,0,0,0,0,0,-1,0,0,0,0,0,-1,0,0,0,0,0,1,0,1,1,1,1,1],(t=rt(t))/100))},sepia2:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100;return ft(q([.393,.349,.272,0,0,.769,.686,.534,0,0,.189,.168,.131,0,0,0,0,0,0,0,0,0,0,0,0],(t=rt(t))/100))},sharpen:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100;return ft(q([0,-1,0,-1,5,-1,0,-1,0],(t=rt(t))/100))},sobelHorizontal:F,"sobel-horizontal":F,sobelVertical:O,"sobel-vertical":O,stackBlur:N,"stack-blur":N,transparency:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:100;return ft(q([1,0,0,0,0,0,1,0,0,0,0,0,1,0,0,0,0,0,.3,0,0,0,0,0,1],(t=rt(t))/100))},unsharpMasking:j,"unsharp-masking":j},{kirsch:function(){return pt("kirsch-horizontal kirsch-vertical")},sobel:function(){return pt("sobel-horizontal sobel-vertical")},vintage:function(){return pt("brightness(15) saturation(-20) gamma(1.8)")}}),U=0,X=(d(z={partial:kt,multi:bt,merge:yt,weight:q,repeat:Y,colorMatrix:function(t,e,r){var n=t[e],i=t[e+1],o=t[e+2],a=t[e+3];ct(t,e,r[0]*n+r[1]*i+r[2]*o+r[3]*a,r[4]*n+r[5]*i+r[6]*o+r[7]*a,r[8]*n+r[9]*i+r[10]*o+r[11]*a,r[12]*n+r[13]*i+r[14]*o+r[15]*a)},each:Z,eachXY:J,createRandomCount:function(){return[9,16,25,36,49,64,81,100].sort(function(t,e){return.5-Math.random()})[0]},createRandRange:function(t,e,r){for(var n=[],i=1;i<=r;i++){var o=Math.random()*(e-t)+t,a=Math.floor(10*Math.random())%2==0?-1:1;n.push(a*o)}n.sort();var l=Math.floor(r>>1),s=n[l];return n[l]=n[0],n[0]=s,n},createBitmap:Q,createBlurMatrix:ut,pack:function(t){return function(e,r){Z(e.pixels.length,function(r,n){t(e.pixels,r,n,e.pixels[r],e.pixels[r+1],e.pixels[r+2],e.pixels[r+3])},function(){r(e)})}},packXY:st,pixel:ot,getBitmap:tt,putBitmap:et,radian:function(t){return _.CONSTANT.radian(t)},convolution:ft,parseParamNumber:rt,filter:pt,clamp:dt,fillColor:ct,fillPixelColor:ht},"multi",bt),d(z,"merge",yt),d(z,"matches",vt),d(z,"parseFilter",gt),d(z,"partial",kt),z),W=X;function q(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1;return t.map(function(t){return t*e})}function Y(t,e){for(var r=new Array(e),n=0;n1&&void 0!==arguments[1]?arguments[1]:0,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1,n=arguments[3],i=arguments[4],o=arguments.length>5&&void 0!==arguments[5]?arguments[5]:1e4,a=arguments.length>6&&void 0!==arguments[6]?arguments[6]:"full",l=arguments.length>7&&void 0!==arguments[7]?arguments[7]:50,s=e,u=function(t){setTimeout(t,0)};function c(){for(var e=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:50,e=[].concat(C(Array(t))).map(function(t){return"cri = ri + i * s; if (cri >= mx) return {currentRunIndex: cri, i: null}; c(cri); i++;"}).join("\n");return new Function("ri","i","s","mx","c","\n let cri = ri;\n \n "+e+"\n \n return {currentRunIndex: cri, i: i} \n ")}(l),a=s,h={},f=0;f=t)return void i();u?u(c):c()}(a)}"requestAnimationFrame"==a&&(u=requestAnimationFrame,o=1e3),"full"==a&&(u=null,o=t),c()}function Z(t,e,r){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};K(t,0,4,function(t){e(t,t>>2)},function(){r()},n.functionDumpCount,n.frameTimer,n.loopCount)}function J(t,e,r,n){var i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{};K(t,0,4,function(t){var n=t>>2;r(t,n%e,Math.floor(n/e))},function(){n()},i.functionDumpCount,i.frameTimer,i.loopCount)}function Q(t,e,r){return{pixels:new Uint8ClampedArray(t),width:e,height:r}}function tt(t,e){return h.getBitmap(t,e)}function et(t,e,r){return h.putBitmap(t,e,r)}function rt(t){return"string"==typeof t&&(t=(t=t.replace(/deg/,"")).replace(/px/,"")),+t}var nt=/(([\w_\-]+)(\(([^\)]*)\))?)+/gi;function it(t){var e,r,n,i,o,a=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},l=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};return e={},r=[{callback:t,context:a,rootContext:l}].map(function(t){var r=[];Object.keys(t.context).forEach(function(t,e){r[t]="n$"+U+++t+"$"}),Object.keys(t.rootContext).forEach(function(n,i){r[n]="r$"+U+++n+"$",e[r[n]]=t.rootContext[n]});var n=Object.keys(t.context).filter(function(e){return"number"!=typeof t.context[e]&&"string"!=typeof t.context[e]&&(!Array.isArray(t.context[e])||"number"!=typeof t.context[e][0]&&"string"!=typeof t.context[e][0])}).map(function(e,n){return[r[e],JSON.stringify(t.context[e])].join(" = ")}),i=t.callback.toString().split("{");return i.shift(),(i=(i=i.join("{")).split("}")).pop(),i=i.join("}"),Object.keys(r).forEach(function(e){var n=r[e];"number"==typeof t.context[e]||"string"==typeof t.context[e]?i=i.replace(new RegExp("\\"+e,"g"),t.context[e]):!Array.isArray(t.context[e])||"number"!=typeof t.context[e][0]&&"string"!=typeof t.context[e][0]?i=i.replace(new RegExp("\\"+e,"g"),n):t.context[e].forEach(function(t,r){i=i.replace(new RegExp("\\"+e+"\\["+r+"\\]","g"),t)})}),{preCallbackString:i,preContext:n}}),n=r.map(function(t,e){return t.preContext.length?"const "+t.preContext+";":""}).join("\n\n"),i=r.map(function(t){return t.preCallbackString}).join("\n\n"),(o=new Function("$pixels","$pixelIndex","$clamp","$Color"," \n let $r = $pixels[$pixelIndex], $g = $pixels[$pixelIndex+1], $b = $pixels[$pixelIndex+2], $a = $pixels[$pixelIndex+3];\n\n "+n+"\n\n "+i+"\n \n $pixels[$pixelIndex] = $r\n $pixels[$pixelIndex+1] = $g \n $pixels[$pixelIndex+2] = $b \n $pixels[$pixelIndex+3] = $a \n ")).$preCallbackString=i,o.$preContext=n,o.rootContextObject=e,o}function ot(t){var e=it(t,arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},arguments.length>2&&void 0!==arguments[2]?arguments[2]:{}),r=function(t,e){};return r.userFunction=e,r}var at=[0,1,2,3];function lt(t,e,r){at.forEach(function(n){var i=t[e+n];t[e+n]=t[r+n],t[r+n]=i})}function st(t){return function(e,r){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};J(e.pixels.length,e.width,function(r,n,i){t(e.pixels,r,n,i)},function(){r(e)},n)}}function ut(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:3,e=Math.pow(t,2);return Y(1/e,e)}function ct(t,e,r,n,i,o){if(3==arguments.length){var a=arguments[2];r=a.r,n=a.g,i=a.b,o=a.a}"number"==typeof r&&(t[e]=r),"number"==typeof n&&(t[e+1]=n),"number"==typeof i&&(t[e+2]=i),"number"==typeof o&&(t[e+3]=o)}function ht(t,e,r,n){ct(t,e,r[n],r[n+1],r[n+2],r[n+3])}function ft(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],r=function(t){var e,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:255;return e=t.map(function(t,e){return[]}),t.forEach(function(t,i){if(0!=t){var o=e[i];for(i=r;i<=n;i++)o[i]=t*i}}),e}(t);return function(n,i){var o=Math.round(Math.sqrt(t.length)),a=function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,r=t.width+e,n=t.height+e;return{pixels:new Uint8ClampedArray(r*n*4),width:r,height:n}}(n,2*o);!function(t,e,r,n){for(var i=e.pixels.length/4,o=0,a=0,l=0,s=0,u=0,c=0,h=0;ht.width||a>t.height||(u=s*e.width+l<<2,c=a*t.width+o<<2,t.pixels[c]=e.pixels[u],t.pixels[c+1]=e.pixels[u+1],t.pixels[c+2]=e.pixels[u+2],t.pixels[c+3]=e.pixels[u+3])}(a,n,o,o);for(var l=Q(a.pixels.length,a.width,a.height),s=Q(n.pixels.length,n.width,n.height),u=function(t,e,r,n,i){var o=Math.round(Math.sqrt(t.length)),a=Math.floor(o/2),l=i?1:0,s="let r = 0, g = 0, b = 0, a = 0, scy = 0, scx =0, si = 0; ",u=[],c=[],h=[],f=[];t.forEach(function(t,e){var n=Math.floor(e/o)-a,i=e%o-a;0!=t&&(u.push("$t["+e+"][$sp[(($sy + ("+n+")) * "+r+" + ($sx + ("+i+"))) * 4]]"),c.push("$t["+e+"][$sp[(($sy + ("+n+")) * "+r+" + ($sx + ("+i+"))) * 4 + 1]]"),h.push("$t["+e+"][$sp[(($sy + ("+n+")) * "+r+" + ($sx + ("+i+"))) * 4 + 2]]"),f.push("$t["+e+"][$sp[(($sy + ("+n+")) * "+r+" + ($sx + ("+i+"))) * 4 + 3]]"))}),s+="r = "+u.join(" + ")+"; g = "+c.join(" + ")+"; b = "+h.join(" + ")+"; a = "+f.join(" + ")+";",s+="$dp[$di] = r; $dp[$di+1] = g;$dp[$di+2] = b;$dp[$di+3] = a + ("+l+")*(255-a); ";var v=new Function("$dp","$sp","$di","$sx","$sy","$t",s);return function(t,r,n,i,o){v(t,r,n,i,o,e)}}(t,r,a.width,a.height,e),c=n.pixels.length/4,h=0;h>2,o=0,a=0,l=0,s=0,u=0,c=0,h=0;ht.width||a>t.height||(u=a*t.width+o<<2,c=s*e.width+l<<2,e.pixels[c]=t.pixels[u],e.pixels[c+1]=t.pixels[u+1],e.pixels[c+2]=t.pixels[u+2],e.pixels[c+3]=t.pixels[u+3])}(l,s,o,o),i(s)}}function vt(t){var e=qt.convertMatches(t),r=e.str.match(nt),n=[];if(!r)return n;var i={next:0};return n=(n=r.map(function(t){return{filter:t,origin:qt.reverseMatches(t,e.matches)}})).map(function(e){var r=t.indexOf(e.origin,i.next);return e.startIndex=r,e.endIndex=r+e.origin.length,e.arr=gt(e.origin),i.next=e.endIndex,e}).filter(function(t){return!!t.arr.length})}function gt(t){var e=qt.convertMatches(t),r=e.str.match(nt);if(!r[0])return[];var n=r[0].split("("),i=n.shift(),o=[];return n.length&&(o=n.shift().split(")")[0].split(",").map(function(t){return qt.reverseMatches(t,e.matches)})),[i].concat(C(o)).map(qt.trim)}function dt(t){return Math.min(255,t)}function pt(t){return yt(vt(t).map(function(t){return t.arr}))}function mt(){for(var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[],e=[],r=[],n=0,i=t.length;n2&&void 0!==arguments[2]?arguments[2]:{},o=t,a=0;function l(){e[a].call(null,o,function(t){o=t,function(){if(++a>=n)return void r(o);l()}()},i)}l()}}function yt(t){return bt.apply(void 0,C(t))}function kt(t){for(var e=null,r=arguments.length,n=Array(r>1?r-1:0),i=1;i2&&void 0!==arguments[2]?arguments[2]:{};e(tt(r,t),function(e){n(et(r,e,t))},i)}}function Ct(t){return"string"==typeof t&&(t=(t=t.replace(/deg/,"")).replace(/px/,"")),+t}function $t(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1;return t.map(function(t){return t*e})}var xt=0;function _t(t){return[].concat(Array.prototype.slice.call(arguments))}function wt(t){return{type:"convolution",length:t.length,content:t}}function St(t,e){return{type:"shader",index:xt,options:e,content:(r=t,n=xt++,"\n if (u_filterIndex == "+n+".0) {\n "+r+"\n }\n ")};var r,n}function Et(t){return"\n \n if (u_kernelSelect == "+t+".0) {\n vec4 colorSum = "+(e=t,r=Math.sqrt(e),n=Math.floor(r/2),[].concat(C(Array(e))).map(function(t,i){var o=Math.floor(i/r)-n;return"texture(u_image, v_texCoord + onePixel * vec2("+(i%r-n)+", "+o+")) * u_kernel"+e+"["+i+"]"}).join(" + \n"))+"; \n\n outColor = vec4((colorSum / u_kernel"+t+"Weight).rgb, 1);\n \n }\n ";var e,r,n}function At(t){return"vec4("+(t=[t.r/255,t.g/255,t.b/255,t.a||0].map(Rt))+")"}function Rt(t){return t==Math.floor(t)?t+".0":t}function Tt(){return wt($t([1,2,1,2,4,2,1,2,1],Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:1)*(1/16)))}function Mt(){return wt([1,4,6,4,1,4,16,24,16,4,6,24,36,24,6,4,16,24,16,4,1,4,6,4,1])}function Bt(){return wt([5,5,5,-3,0,-3,-3,-3,-3])}function Ht(){return wt([5,-3,-3,5,0,-3,5,-3,-3])}function It(){return wt([-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,24,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1])}function Ft(){return wt([1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,1])}function Ot(){return wt([1,0,0,0,0,0,0,0,1,0,1,0,0,0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,0,0,1,0,1,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,1,0,1,0,0,0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,0,0,1,0,1,0,0,0,0,0,0,0,1])}function Lt(){return wt([1,0,0,0,1,0,0,0,1,0,1,0,0,1,0,0,1,0,0,0,1,0,1,0,1,0,0,0,0,0,1,1,1,0,0,0,1,1,1,1,1,1,1,1,1,0,0,0,1,1,1,0,0,0,0,0,1,0,1,0,1,0,0,0,1,0,0,1,0,0,1,0,1,0,0,0,1,0,0,0,1])}function Pt(){return wt([-1,-2,-1,0,0,0,1,2,1])}function Gt(){return wt([-1,0,1,-2,0,2,-1,0,1])}function Dt(){return wt($t([1,4,6,4,1,4,16,24,16,4,6,24,-476,24,6,4,16,24,16,4,1,4,6,4,1],-1/256))}function Nt(){var t=[arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,arguments.length>4&&void 0!==arguments[4]?arguments[4]:0,arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,arguments.length>6&&void 0!==arguments[6]?arguments[6]:0,arguments.length>7&&void 0!==arguments[7]?arguments[7]:0,arguments.length>8&&void 0!==arguments[8]?arguments[8]:0,arguments.length>9&&void 0!==arguments[9]?arguments[9]:0,arguments.length>10&&void 0!==arguments[10]?arguments[10]:0,arguments.length>11&&void 0!==arguments[11]?arguments[11]:0,arguments.length>12&&void 0!==arguments[12]?arguments[12]:0,arguments.length>13&&void 0!==arguments[13]?arguments[13]:0,arguments.length>14&&void 0!==arguments[14]?arguments[14]:0,arguments.length>15&&void 0!==arguments[15]?arguments[15]:0].map(Rt);return St("\n\n outColor = vec4(\n "+t[0]+" * pixelColor.r + "+t[1]+" * pixelColor.g + "+t[2]+" * pixelColor.b + "+t[3]+" * pixelColor.a,\n "+t[4]+" * pixelColor.r + "+t[5]+" * pixelColor.g + "+t[6]+" * pixelColor.b + "+t[7]+" * pixelColor.a,\n "+t[8]+" * pixelColor.r + "+t[9]+" * pixelColor.g + "+t[10]+" * pixelColor.b + "+t[11]+" * pixelColor.a,\n "+t[12]+" * pixelColor.r + "+t[13]+" * pixelColor.g + "+t[14]+" * pixelColor.b + "+t[15]+" * pixelColor.a\n ); \n ")}function jt(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1;return St("\n float c = ( (pixelColor.r * 0.2126 + pixelColor.g * 0.7152 + pixelColor.b * 0.0722) ) >= "+(t=Rt(Ct(t)))+" ? 1.0 : 0.0;\n\n outColor = vec4(c, c, c, pixelColor.a);\n ")}var zt=p({},{blur:function(){return wt([1,1,1,1,1,1,1,1,1])},normal:function(){return wt([0,0,0,0,1,0,0,0,0])},emboss:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:4;return wt([-2*(t=Ct(t)),-t,0,-t,1,t,0,t,2*t])},gaussianBlur:Tt,"gaussian-blur":Tt,gaussianBlur5x:Mt,"gaussian-blur-5x":Mt,grayscale2:function(){return wt([.3,.3,.3,0,0,.59,.59,.59,0,0,.11,.11,.11,0,0,0,0,0,0,0,0,0,0,0,0])},kirschHorizontal:Bt,"kirsch-horizontal":Bt,kirschVertical:Ht,"kirsch-vertical":Ht,laplacian:function(){return wt([-1,-1,-1,-1,8,-1,-1,-1,-1])},laplacian5x:It,"laplacian-5x":It,motionBlur:Ft,"motion-blur":Ft,motionBlur2:Ot,"motion-blur-2":Ot,motionBlur3:Lt,"motion-blur-3":Lt,negative:function(){return wt([-1,0,0,0,0,0,-1,0,0,0,0,0,-1,0,0,0,0,0,1,0,1,1,1,1,1])},sepia2:function(){return wt([.393,.349,.272,0,0,.769,.686,.534,0,0,.189,.168,.131,0,0,0,0,0,0,0,0,0,0,0,0])},sharpen:function(){return wt([0,-1,0,-1,5,-1,0,-1,0])},sobelHorizontal:Pt,"sobel-horizontal":Pt,sobelVertical:Gt,"sobel-vertical":Gt,transparency:function(){return wt([1,0,0,0,0,0,1,0,0,0,0,0,1,0,0,0,0,0,.3,0,0,0,0,0,1])},unsharpMasking:Dt,"unsharp-masking":Dt},{bitonal:function(t,e){var r=Rt(arguments.length>2&&void 0!==arguments[2]?arguments[2]:.5),n=At(qt.parse(t));return St("\n if ((pixelColor.r + pixelColor.g + pixelColor.b) > "+r+") {\n outColor = vec4("+At(qt.parse(e))+".rgb, pixelColor.a);\n } else {\n outColor = vec4("+n+".rgb, pixelColor.a);\n }\n ")},brightness:function(){return St("\n outColor = pixelColor + ("+Rt(Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:1))+");\n ")},brownie:function(){return Nt(.5997023498159715,.34553243048391263,-.2708298674538042,0,-.037703249837783157,.8609577587992641,.15059552388459913,0,.24113635128153335,-.07441037908422492,.44972182064877153,0,0,0,0,1)},clip:function(){var t=Rt(Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:0));return St("\n outColor = vec4(\n (pixelColor.r > 1.0 - "+t+") ? 1.0 : 0.0,\n (pixelColor.g > 1.0 - "+t+") ? 1.0 : 0.0,\n (pixelColor.b > 1.0 - "+t+") ? 1.0 : 0.0,\n pixelColor.a \n );\n ")},chaos:function(){return St("\n vec2 st = pixelColor.st;\n st *= "+Rt(Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:10))+";\n \n vec2 ipos = floor(st); // get the integer coords\n\n vec3 color = vec3(random( ipos ));\n\n outColor = vec4(color, pixelColor.a);\n ")},contrast:function(){return St("\n outColor = pixelColor * "+Rt(Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:1))+";\n ")},gamma:function(){var t=Rt(Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:1));return St("\n outColor = vec4(pow(pixelColor.r, "+t+"), pow(pixelColor.g, "+t+"), pow(pixelColor.b, "+t+"), pixelColor.a );\n ")},gradient:function(){var t=[].concat(Array.prototype.slice.call(arguments));1===t.length&&"string"==typeof t[0]&&(t=qt.convertMatchesArray(t[0])),t=t.map(function(t){return t}).join(", ");var e=qt.parseGradient(t);e[0][1]=0,e[e.length-1][1]=1;for(var r=[],n=0,i=(e=e.map(function(t){var e=qt.parse(t[0]);return[{r:e.r,g:e.g,b:e.b,a:e.a},t[1]]})).length;n0&&void 0!==arguments[0]?arguments[0]:1);return t>1&&(t=1),Nt(.2126+.7874*(1-t),.7152-.7152*(1-t),.0722-.0722*(1-t),0,.2126-.2126*(1-t),.7152+.2848*(1-t),.0722-.0722*(1-t),0,.2126-.2126*(1-t),.7152-.7152*(1-t),.0722+.9278*(1-t),0,0,0,0,1)},hue:function(){return St("\n vec3 hsv = rgb2hsv(pixelColor.rgb);\n hsv.x += "+Rt(Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:1))+";\n outColor = vec4(hsv2rgb(hsv).rgb, pixelColor.a);\n ")},invert:function(){var t=Rt(Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:1));return St("\n outColor = vec4(\n (1.0 - pixelColor.r) * "+t+",\n (1.0 - pixelColor.g) * "+t+",\n (1.0 - pixelColor.b) * "+t+",\n pixelColor.a\n );\n ")},kodachrome:function(){return Nt(1.1285582396593525,-.3967382283601348,-.03992559172921793,0,-.16404339962244616,1.0835251566291304,-.05498805115633132,0,-.16786010706155763,-.5603416277695248,1.6014850761964943,0,0,0,0,1)},matrix:Nt,noise:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1,e=Math.abs(Ct(t)),r=Rt(-e);return St("\n float rnd = "+r+" + random( pixelColor.st ) * ("+Rt(e)+" - "+r+");\n\n outColor = vec4(pixelColor.rgb + rnd, 1.0);\n ")},opacity:function(){return St("\n outColor = vec4(pixelColor.rgb, pixelColor.a * "+Rt(Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:1))+");\n ")},polaroid:function(){return Nt(1.438,-.062,-.062,0,-.122,1.378,-.122,0,-.016,-.016,1.483,0,0,0,0,1)},saturation:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,e=1-Math.abs(Ct(t));return Nt(e,0,0,0,0,e,0,0,0,0,e,0,0,0,0,e)},sepia:function(){var t=Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:1);return t>1&&(t=1),Nt(.393+.607*(1-t),.769-.769*(1-t),.189-.189*(1-t),0,.349-.349*(1-t),.686+.314*(1-t),.168-.168*(1-t),0,.272-.272*(1-t),.534-.534*(1-t),.131+.869*(1-t),0,0,0,0,1)},shade:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:1,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1;return St("\n outColor = vec4(\n pixelColor.r * "+Rt(Ct(t)/255)+",\n pixelColor.g * "+Rt(Ct(e)/255)+",\n pixelColor.b * "+Rt(Ct(r)/255)+",\n pixelColor.a\n );\n ")},shift:function(){return Nt(1.438,-.062,-.062,0,-.122,1.378,-.122,0,-.016,-.016,1.483,0,0,0,0,1)},solarize:function(t,e,r){return St("\n outColor = vec4(\n (pixelColor.r < "+Rt(Ct(t))+") ? 1.0 - pixelColor.r: pixelColor.r,\n (pixelColor.g < "+Rt(Ct(e))+") ? 1.0 - pixelColor.g: pixelColor.g,\n (pixelColor.b < "+Rt(Ct(r))+") ? 1.0 - pixelColor.b: pixelColor.b,\n pixelColor.a\n );\n ")},technicolor:function(){return Nt(1.9125277891456083,-.8545344976951645,-.09155508482755585,0,-.3087833385928097,1.7658908555458428,-.10601743074722245,0,-.231103377548616,-.7501899197440212,1.847597816108189,0,0,0,0,1)},threshold:function(){return jt(arguments.length>0&&void 0!==arguments[0]?arguments[0]:200,arguments.length>1&&void 0!==arguments[1]?arguments[1]:100,!1)},"threshold-color":jt,tint:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0;return St("\n outColor = vec4(\n pixelColor.r += (1 - pixelColor.r) * "+Ct(t)+",\n pixelColor.g += (1 - pixelColor.g) * "+Ct(e)+",\n pixelColor.b += (1 - pixelColor.b) * "+Ct(r)+",\n pixelColor.a\n );\n ")}},{kirsch:function(){return _t("kirsch-horizontal kirsch-vertical")},sobel:function(){return _t("sobel-horizontal sobel-vertical")},vintage:function(){return _t("brightness(0.15) saturation(-0.2) gamma(1.8)")}}),Vt=0,Ut={GLCanvas:function(){function t(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{width:"400px",height:"300px"};v(this,t),this.img=e.img,this.width=parseFloat(this.img.width||e.width||"400px"),this.height=parseFloat(this.img.height||e.height||"300px"),this.init()}return g(t,[{key:"resize",value:function(){this.canvas.width=this.width,this.canvas.height=this.height,this.canvas.style.width=this.width+"px",this.canvas.style.height=this.height+"px",this.viewport()}},{key:"clear",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,i=this.gl;i.clearColor(t,e,r,n),i.clear(i.COLOR_BUFFER_BIT|i.DEPTH_BUFFER_BIT)}},{key:"viewport",value:function(t,e,r,n){var i=this.gl;i.viewport(t||0,e||0,r||i.canvas.width,n||i.canvas.height)}},{key:"initCanvas",value:function(t,e){if(this.canvas=document.createElement("canvas"),this.gl=this.canvas.getContext("webgl2"),!this.gl)throw new Error("you need webgl2 support");this.program=this.createProgram(t,e),this.resize(),this.initBuffer()}},{key:"draw",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"TRIANGLES",e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:6,n=this.gl;n.drawArrays(n[t],e,r)}},{key:"triangles",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:6;this.draw("TRIANGLES",t,e)}},{key:"uniform2f",value:function(){for(var t,e=arguments.length,r=Array(e),n=0;n2&&void 0!==arguments[2]?arguments[2]:"STATIC_DRAW",n=this.gl;this.buffers[t]||(this.buffers[t]=n.createBuffer()),n.bindBuffer(n.ARRAY_BUFFER,this.buffers[t]),e&&n.bufferData(n.ARRAY_BUFFER,new Float32Array(e),n[r])}},{key:"enable",value:function(t){this.gl.enableVertexAttribArray(this.locations[t])}},{key:"location",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"attribute";"attribute"===e?this.locations[t]=this.gl.getAttribLocation(this.program,t):"uniform"===e&&(this.locations[t]=this.gl.getUniformLocation(this.program,t))}},{key:"a",value:function(t){return this.location(t)}},{key:"u",value:function(t){return this.location(t,"uniform")}},{key:"pointer",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"FLOAT",r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:2,n=arguments.length>3&&void 0!==arguments[3]&&arguments[3],i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:0,o=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,a=this.gl;a.vertexAttribPointer(this.locations[t],r,a[e],n,i,o)}},{key:"bufferData",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[],e=this.gl;e.bufferData(e.ARRAY_BUFFER,new Float32Array(t),e.STATIC_DRAW)}},{key:"isPowerOf2",value:function(t){return 0==(t&t-1)}},{key:"bindTexture",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:void 0,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"RGBA",i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"RGBA",o=arguments.length>5&&void 0!==arguments[5]?arguments[5]:"UNSIGNED_BYTE",a=this.gl;1!=arguments.length?(this.textures[t]||(this.textures[t]=a.createTexture()),this.textureIndex[t]=Vt++,a.bindTexture(a.TEXTURE_2D,this.textures[t]),this.setTextureParameter(),a.texImage2D(a.TEXTURE_2D,r,a[n],a[i],a[o],e.newImage||e)):a.bindTexture(a.TEXTURE_2D,this.textures[t])}},{key:"bindColorTexture",value:function(t,e){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:256,n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:1,i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:0,o=arguments.length>5&&void 0!==arguments[5]?arguments[5]:"RGBA",a=arguments.length>6&&void 0!==arguments[6]?arguments[6]:"RGBA",l=arguments.length>7&&void 0!==arguments[7]?arguments[7]:"UNSIGNED_BYTE",s=this.gl;this.textures[t]||(this.textures[t]=s.createTexture()),this.textureIndex[t]=Vt++,s.bindTexture(s.TEXTURE_2D,this.textures[t]),this.setTextureParameter(),s.texImage2D(s.TEXTURE_2D,i,s[o],r,n,0,s[a],s[l],new Uint8Array(e))}},{key:"bindEmptyTexture",value:function(t,e,r){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"RGBA",o=arguments.length>5&&void 0!==arguments[5]?arguments[5]:"RGBA",a=arguments.length>6&&void 0!==arguments[6]?arguments[6]:"UNSIGNED_BYTE",l=this.gl;this.textures[t]||(this.textures[t]=l.createTexture()),this.textureIndex[t]=Vt++,l.bindTexture(l.TEXTURE_2D,this.textures[t]),this.setTextureParameter();l.texImage2D(l.TEXTURE_2D,n,l[i],e,r,0,l[o],l[a],null)}},{key:"setTextureParameter",value:function(){var t=this.gl;t.texParameteri(t.TEXTURE_2D,t.TEXTURE_WRAP_S,t.CLAMP_TO_EDGE),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_WRAP_T,t.CLAMP_TO_EDGE),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_MIN_FILTER,t.NEAREST),t.texParameteri(t.TEXTURE_2D,t.TEXTURE_MAG_FILTER,t.NEAREST)}},{key:"bindFrameBufferWithTexture",value:function(t,e,r,n){this.bindEmptyTexture(e,r,n),this.bindFrameBuffer(t,e)}},{key:"enumToString",value:function(t){var e=this.gl;if(0===t)return"NONE";for(var r in e)if(e[r]===t)return r;return"0x"+t.toString(16)}},{key:"bindFrameBuffer",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null,r=this.gl;if(1!==arguments.length){this.framebuffers[t]||(this.framebuffers[t]=r.createFramebuffer()),r.bindFramebuffer(r.FRAMEBUFFER,this.framebuffers[t]);var n=r.COLOR_ATTACHMENT0;r.framebufferTexture2D(r.FRAMEBUFFER,n,r.TEXTURE_2D,this.textures[e],0);r.checkFramebufferStatus(r.FRAMEBUFFER);r.FRAMEBUFFER_COMPLETE}else r.bindFramebuffer(r.FRAMEBUFFER,null==t?null:this.framebuffers[t])}},{key:"bindVA",value:function(){var t=this.gl;this.vao||(this.vao=t.createVertexArray()),t.bindVertexArray(this.vao)}},{key:"bindAttr",value:function(t,e){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"STATIC_DRAW",n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:2;this.bindBuffer(t,e,r),this.enable(t),this.pointer(t,"FLOAT",n)}},{key:"initBuffer",value:function(){var t=this.canvas,e=t.width,r=t.height;this.a("a_position"),this.a("a_texCoord"),this.u("u_resolution"),this.u("u_image"),this.u("u_flipY"),this.u("u_kernelSelect"),this.u("u_filterIndex"),this.u("u_kernel9[0]"),this.u("u_kernel9Weight"),this.u("u_kernel25[0]"),this.u("u_kernel25Weight"),this.u("u_kernel49[0]"),this.u("u_kernel49Weight"),this.u("u_kernel81[0]"),this.u("u_kernel81Weight"),this.bindVA(),this.bindAttr("a_position",[0,0,e,0,0,r,0,r,e,0,e,r],"STATIC_DRAW",2),this.bindAttr("a_texCoord",[0,0,1,0,0,1,0,1,1,0,1,1],"STATIC_DRAW",2),this.bindTexture("u_image",this.img),this.bindFrameBufferWithTexture("frame_buffer_0","img_texture_0",e,r),this.bindFrameBufferWithTexture("frame_buffer_1","img_texture_1",e,r)}},{key:"activeTexture",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,e=this.gl;e.activeTexture(e.TEXTURE0+t)}},{key:"drawFilter",value:function(){var t=this,e=this.gl;this.resize(),this.clear(),this.useProgram(),this.bindVA(),this.activeTexture(0),this.bindTexture("u_image"),this.uniform1i("u_image",0),this.uniform1f("u_flipY",1);var r=e.canvas,n=r.width,i=r.height;this.eachFilter(function(e,r){t.bindFrameBuffer("frame_buffer_"+r%2),t.uniform2f("u_resolution",n,i),t.viewport(0,0,n,i),t.effectFilter(e),t.bindTexture("img_texture_"+r%2)}),this.uniform1f("u_flipY",-1),this.bindFrameBuffer(null),this.uniform2f("u_resolution",n,i),this.viewport(0,0,n,i),this.clear(),this.effectFilter("normal")}},{key:"effectFilter",value:function(t){"string"==typeof t&&(t=(zt[t]||zt.normal).call(zt)),"convolution"==t.type?(this.uniform1f("u_kernelSelect",t.length),this.uniform1f("u_filterIndex",-1),this.uniform1fv("u_kernel"+t.length+"[0]",t.content),this.uniform1f("u_kernel"+t.length+"Weight",this.computeKernelWeight(t.content))):(this.uniform1f("u_kernelSelect",-1),this.uniform1f("u_filterIndex",t.index)),this.triangles(0,6)}},{key:"computeKernelWeight",value:function(t){var e=t.reduce(function(t,e){return t+e});return e<=0?1:e}},{key:"createProgram",value:function(t,e){var r=this.gl,n=r.createProgram();if(this.vertexShader=this.createVertexShader(t),this.fragmentShader=this.createFragmentShader(e),r.attachShader(n,this.vertexShader),r.attachShader(n,this.fragmentShader),r.linkProgram(n),r.getProgramParameter(n,r.LINK_STATUS))return n;console.error(r.getProgramInfoLog(n)),r.deleteProgram(n)}},{key:"createShader",value:function(t,e){var r=this.gl,n=r.createShader(t);if(r.shaderSource(n,e),r.compileShader(n),r.getShaderParameter(n,r.COMPILE_STATUS))return n;console.error(r.getShaderInfoLog(n)),r.deleteShader(n)}},{key:"createVertexShader",value:function(t){var e=this.gl;return this.createShader(e.VERTEX_SHADER,t)}},{key:"createFragmentShader",value:function(t){var e=this.gl;return this.createShader(e.FRAGMENT_SHADER,t)}},{key:"eachFilter",value:function(t){this.filterList.forEach(t)}},{key:"init",value:function(){this.locations={},this.buffers={},this.framebuffers={},this.textures={},this.textureIndex={},this.hasTexParameter={}}},{key:"destroy",value:function(){var t=this.gl;this.init(),t.deleteProgram(this.program)}},{key:"filter",value:function(t,e){var r,n,i;this.filterList=t,this.initCanvas("#version 300 es \n\n in vec2 a_position;\n in vec2 a_texCoord; \n\n uniform vec2 u_resolution;\n uniform float u_flipY;\n\n out vec2 v_texCoord; \n\n void main() {\n vec2 zeroToOne = a_position / u_resolution;\n\n vec2 zeroToTwo = zeroToOne * 2.0;\n\n vec2 clipSpace = zeroToTwo - 1.0;\n\n gl_Position = vec4(clipSpace * vec2(1, u_flipY), 0, 1);\n\n v_texCoord = a_texCoord;\n\n }\n ",(r=this.filterList,n=r.filter(function(t){return"shader"==t.type}).map(function(t){return t.content}).join("\n\n"),i={9:!0},r.filter(function(t){return"convolution"==t.type}).forEach(function(t){i[t.length]=!0}),"#version 300 es\n\n precision highp int;\n precision mediump float;\n \n uniform sampler2D u_image;\n\n // 3 is 3x3 matrix kernel \n uniform float u_kernelSelect;\n uniform float u_filterIndex;\n\n uniform float u_kernel9[9];\n uniform float u_kernel9Weight;\n uniform float u_kernel25[25];\n uniform float u_kernel25Weight;\n uniform float u_kernel49[49];\n uniform float u_kernel49Weight;\n uniform float u_kernel81[81];\n uniform float u_kernel81Weight; \n\n in vec2 v_texCoord;\n \n out vec4 outColor;\n\n float random (vec2 st) {\n return fract(sin(dot(st.xy, vec2(12.9898,78.233)))* 43758.5453123);\n } \n\n // \n vec3 rgb2hsv(vec3 c)\n {\n vec4 K = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);\n vec4 p = c.g < c.b ? vec4(c.bg, K.wz) : vec4(c.gb, K.xy);\n vec4 q = c.r < p.x ? vec4(p.xyw, c.r) : vec4(c.r, p.yzx);\n\n float d = q.x - min(q.w, q.y);\n float e = 1.0e-10;\n return vec3(abs(q.z + (q.w - q.y) / (6.0 * d + e)), d / (q.x + e), q.x);\n }\n\n vec3 hsv2rgb(vec3 c)\n {\n vec4 K = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);\n vec3 p = abs(fract(c.xxx + K.xyz) * 6.0 - K.www);\n return c.z * mix(K.xxx, clamp(p - K.xxx, 0.0, 1.0), c.y);\n }\n \n void main() {\n vec4 pixelColor = texture(u_image, v_texCoord);\n vec2 onePixel = vec2(1) / vec2(textureSize(u_image, 0)); \n\n "+n+"\n\n "+Object.keys(i).map(function(t){return Et(+t)}).join("\n")+"\n\n }")),this.drawFilter(),"function"==typeof e&&e(this)}}]),t}()};var Xt=p({},Ut,{filter:function(t,e,r,n){var i=new Ut.GLCanvas({width:n.width||t.width,height:n.height||t.height,img:t});i.filter(function t(e){var r=[];"string"==typeof e?r=vt(e):Array.isArray(e)&&(r=e);var n=[];r.forEach(function(e){var r=e.arr[0];if(zt[r]){var i=function(t){var e=t.arr[0],r=zt[e],n=t.arr;return n.shift(),r.apply(this,n)}(e);"convolution"==i.type||"shader"==i.type?n.push(i):i.forEach(function(e){n=n.concat(t(e))})}});return n}(e),function(){"function"==typeof r&&r(i)})}}),Wt=/(#(?:[\da-f]{3}){1,2}|rgb\((?:\s*\d{1,3},\s*){2}\d{1,3}\s*\)|rgba\((?:\s*\d{1,3},\s*){3}\d*\.?\d+\s*\)|hsl\(\s*\d{1,3}(?:,\s*\d{1,3}%){2}\s*\)|hsla\(\s*\d{1,3}(?:,\s*\d{1,3}%){2},\s*\d*\.?\d+\s*\)|([\w_\-]+))/gi,qt={matches:function(t){var e=t.match(Wt),n=[];if(!e)return n;for(var i=0,o=e.length;i-1||e[i].indexOf("rgb")>-1||e[i].indexOf("hsl")>-1)n.push({color:e[i]});else{var a=r.getColorByName(e[i]);a&&n.push({color:e[i],nameColor:a})}var l={next:0};return n.forEach(function(e){var r=t.indexOf(e.color,l.next);e.startIndex=r,e.endIndex=r+e.color.length,l.next=e.endIndex}),n},convertMatches:function(t){var e=this.matches(t);return e.forEach(function(e,r){t=t.replace(e.color,"@"+r)}),{str:t,matches:e}},convertMatchesArray:function(t){var e=this,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:",",n=this.convertMatches(t);return n.str.split(r).map(function(t,r){return t=e.trim(t),n.matches[r]&&(t=t.replace("@"+r,n.matches[r].color)),t})},reverseMatches:function(t,e){return e.forEach(function(e,r){t=t.replace("@"+r,e.color)}),t},trim:function(t){return t.replace(/^\s+|\s+$/g,"")},round:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1;return Math.round(t*e)/e},format:function(t,e){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"rgba(0, 0, 0, 0)";return Array.isArray(t)&&(t={r:t[0],g:t[1],b:t[2],a:t[3]}),"hex"==e?this.hex(t):"rgb"==e?this.rgb(t,r):"hsl"==e?this.hsl(t):t},hex:function(t){Array.isArray(t)&&(t={r:t[0],g:t[1],b:t[2],a:t[3]});var e=t.r.toString(16);t.r<16&&(e="0"+e);var r=t.g.toString(16);t.g<16&&(r="0"+r);var n=t.b.toString(16);return t.b<16&&(n="0"+n),"#"+e+r+n},rgb:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"rgba(0, 0, 0, 0)";if(Array.isArray(t)&&(t={r:t[0],g:t[1],b:t[2],a:t[3]}),void 0!==t)return 1==t.a||void 0===t.a?isNaN(t.r)?e:"rgb("+t.r+","+t.g+","+t.b+")":"rgba("+t.r+","+t.g+","+t.b+","+t.a+")"},hsl:function(t){return Array.isArray(t)&&(t={r:t[0],g:t[1],b:t[2],a:t[3]}),1==t.a||void 0===t.a?"hsl("+t.h+","+t.s+"%,"+t.l+"%)":"hsla("+t.h+","+t.s+"%,"+t.l+"%,"+t.a+")"},parse:function(t){if("string"==typeof t){if(r.isColorName(t)&&(t=r.getColorByName(t)),t.indexOf("rgb(")>-1){for(var e=0,n=(o=t.replace("rgb(","").replace(")","").split(",")).length;e-1){for(e=0,n=(o=t.replace("rgba(","").replace(")","").split(",")).length;e-1){for(e=0,n=(o=t.replace("hsl(","").replace(")","").split(",")).length;e-1){for(e=0,n=(o=t.replace("hsla(","").replace(")","").split(",")).length;e>16,g:(65280&t)>>8,b:(255&t)>>0,a:1};return i=Object.assign(i,this.RGBtoHSL(i))}if(0<=t&&t<=4294967295){i={type:"hex",r:(4278190080&t)>>24,g:(16711680&t)>>16,b:(65280&t)>>8,a:(255&t)/255};return i=Object.assign(i,this.RGBtoHSL(i))}}return t},HSVtoRGB:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.h,e=n.s,r=n.v}var i=t,o=r;360==i&&(i=0);var a=e*o,l=a*(1-Math.abs(i/60%2-1)),s=o-a,u=[];return 0<=i&&i<60?u=[a,l,0]:60<=i&&i<120?u=[l,a,0]:120<=i&&i<180?u=[0,a,l]:180<=i&&i<240?u=[0,l,a]:240<=i&&i<300?u=[l,0,a]:300<=i&&i<360&&(u=[a,0,l]),{r:this.round(255*(u[0]+s)),g:this.round(255*(u[1]+s)),b:this.round(255*(u[2]+s))}},RGBtoHSV:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.r,e=n.g,r=n.b}var i=t/255,o=e/255,a=r/255,l=Math.max(i,o,a),s=l-Math.min(i,o,a),u=0;0==s?u=0:l==i?u=(o-a)/s%6*60:l==o?u=60*((a-i)/s+2):l==a&&(u=60*((i-o)/s+4)),u<0&&(u=360+u);return{h:u,s:0==l?0:s/l,v:l}},HSVtoHSL:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.h,e=n.s,r=n.v}var i=this.HSVtoRGB(t,e,r);return this.RGBtoHSL(i.r,i.g,i.b)},RGBtoCMYK:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.r,e=n.g,r=n.b}var i=t/255,o=e/255,a=r/255,l=1-Math.max(i,o,a);return{c:(1-i-l)/(1-l),m:(1-o-l)/(1-l),y:(1-a-l)/(1-l),k:l}},CMYKtoRGB:function(t,e,r,n){if(1==arguments.length){var i=arguments[0];t=i.c,e=i.m,r=i.y,n=i.k}return{r:255*(1-t)*(1-n),g:255*(1-e)*(1-n),b:255*(1-r)*(1-n)}},RGBtoHSL:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.r,e=n.g,r=n.b}t/=255,e/=255,r/=255;var i,o,a=Math.max(t,e,r),l=Math.min(t,e,r),s=(a+l)/2;if(a==l)i=o=0;else{var u=a-l;switch(o=s>.5?u/(2-a-l):u/(a+l),a){case t:i=(e-r)/u+(e1&&(r-=1),r<1/6?t+6*(e-t)*r:r<.5?e:r<2/3?t+(e-t)*(2/3-r)*6:t},HSLtoHSV:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.h,e=n.s,n.v}var i=this.HSLtoRGB(t,e,r);return this.RGBtoHSV(i.r,i.g,i.b)},HSLtoRGB:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.h,e=n.s,r=n.l}var i,o,a;if(t/=360,r/=100,0==(e/=100))i=o=a=r;else{var l=r<.5?r*(1+e):r+e-r*e,s=2*r-l;i=this.HUEtoRGB(s,l,t+1/3),o=this.HUEtoRGB(s,l,t),a=this.HUEtoRGB(s,l,t-1/3)}return{r:this.round(255*i),g:this.round(255*o),b:this.round(255*a)}},c:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.r,e=n.g,r=n.b}return this.gray((t+e+r)/3>90?0:255)},gray:function(t){return{r:t,g:t,b:t}},RGBtoSimpleGray:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.r,e=n.g,r=n.b}return this.gray(Math.ceil((t+e+r)/3))},RGBtoGray:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.r,e=n.g,r=n.b}return this.gray(this.RGBtoYCrCb(t,e,r).y)},brightness:function(t,e,r){return Math.ceil(.2126*t+.7152*e+.0722*r)},RGBtoYCrCb:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.r,e=n.g,r=n.b}var i=this.brightness(t,e,r);return{y:i,cr:.713*(t-i),cb:.564*(r-i)}},YCrCbtoRGB:function(t,e,r,n){if(1==arguments.length){var i=arguments[0];t=i.y,e=i.cr,r=i.cb;n=(n=i.bit)||0}var o=t+1.402*(e-n),a=t-.344*(r-n)-.714*(e-n),l=t+1.772*(r-n);return{r:Math.ceil(o),g:Math.ceil(a),b:Math.ceil(l)}},ReverseRGB:function(t){return t>.0031308?1.055*Math.pow(t,1/2.4)-.055:12.92*t},XYZtoRGB:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.x,e=n.y,r=n.z}var i=t/100,o=e/100,a=r/100,l=3.2406*i+-1.5372*o+-.4986*a,s=-.9689*i+1.8758*o+.0415*a,u=.0557*i+-.204*o+1.057*a;return l=this.ReverseRGB(l),s=this.ReverseRGB(s),u=this.ReverseRGB(u),{r:this.round(255*l),g:this.round(255*s),b:this.round(255*u)}},PivotRGB:function(t){return 100*(t>.04045?Math.pow((t+.055)/1.055,2.4):t/12.92)},RGBtoXYZ:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.r,e=n.g,r=n.b}var i=t/255,o=e/255,a=r/255;return{x:.4124*(i=this.PivotRGB(i))+.3576*(o=this.PivotRGB(o))+.1805*(a=this.PivotRGB(a)),y:.2126*i+.7152*o+.0722*a,z:.0193*i+.1192*o+.9505*a}},ReverseXyz:function(t){return Math.pow(t,3)>.008856?Math.pow(t,3):(t-16/116)/7.787},LABtoXYZ:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.l,e=n.a,r=n.b}var i=(t+16)/116,o=e/500+i,a=i-r/200;return i=this.ReverseXyz(i),{x:95.047*(o=this.ReverseXyz(o)),y:100*i,z:108.883*(a=this.ReverseXyz(a))}},PivotXyz:function(t){return t>.008856?Math.pow(t,1/3):(7.787*t+16)/116},XYZtoLAB:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.x,e=n.y,r=n.z}var i=t/95.047,o=e/100,a=r/108.883;return i=this.PivotXyz(i),{l:116*(o=this.PivotXyz(o))-16,a:500*(i-o),b:200*(o-(a=this.PivotXyz(a)))}},RGBtoLAB:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.r,e=n.g,r=n.b}return this.XYZtoLAB(this.RGBtoXYZ(t,e,r))},LABtoRGB:function(t,e,r){if(1==arguments.length){var n=arguments[0];t=n.l,e=n.a,r=n.b}return this.XYZtoRGB(this.LABtoXYZ(t,e,r))},blend:function(t,e){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:.5,n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"hex",i=this.parse(t),o=this.parse(e);return this.interpolateRGB(i,o,r,n)},mix:function(t,e){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:.5,n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"hex";return this.blend(t,e,r,n)},contrast:function(t){return t=this.parse(t),(Math.round(299*t.r)+Math.round(587*t.g)+Math.round(114*t.b))/1e3},contrastColor:function(t){return this.contrast(t)>=128?"black":"white"},interpolateRGB:function(t,e){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:.5,n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"hex",i={r:this.round(t.r+(e.r-t.r)*r),g:this.round(t.g+(e.g-t.g)*r),b:this.round(t.b+(e.b-t.b)*r),a:this.round(t.a+(e.a-t.a)*r,100)};return this.format(i,i.a<1?"rgb":n)},scale:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:5;if(!t)return[];"string"==typeof t&&(t=this.convertMatchesArray(t));for(var r=(t=t||[]).length,n=[],i=0;i0){var n=(1-t.filter(function(t){return"*"!=t[1]&&1!=t[1]}).map(function(t){return t[1]}).reduce(function(t,e){return t+e},0))/r;t.forEach(function(e,r){"*"==e[1]&&r>0&&(t.length-1==r||(e[1]=n))})}return t},gradient:function(t){for(var e=[],r=(arguments.length>1&&void 0!==arguments[1]?arguments[1]:10)-((t=this.parseGradient(t)).length-1),n=r,i=1,o=t.length;i1&&void 0!==arguments[1]?arguments[1]:"h",r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:9,n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"rgb",i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:0,o=arguments.length>5&&void 0!==arguments[5]?arguments[5]:1,a=arguments.length>6&&void 0!==arguments[6]?arguments[6]:100,l=this.parse(t),s=this.RGBtoHSV(l),u=(o-i)*a/r,c=[],h=1;h<=r;h++)s[e]=Math.abs((a-u*h)/a),c.push(this.format(this.HSVtoRGB(s),n));return c},scaleH:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:9,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"rgb",n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:360;return this.scaleHSV(t,"h",e,r,n,i,1)},scaleS:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:9,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"rgb",n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:1;return this.scaleHSV(t,"s",e,r,n,i,100)},scaleV:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:9,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"rgb",n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,i=arguments.length>4&&void 0!==arguments[4]?arguments[4]:1;return this.scaleHSV(t,"v",e,r,n,i,100)},palette:function(t){var e=this,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:6,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"hex";return t.length>r&&(t=c(t,r)),t.map(function(t){return e.format(t,n)})},ImageToRGB:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},r=arguments[2];if(r){if(r){var n;(n=new $(t,e)).loadImage(function(){"function"==typeof r&&r(n.toRGB())})}}else(n=new $(t)).loadImage(function(){"function"==typeof e&&e(n.toRGB())})},ImageToCanvas:function(t,e,r){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{frameTimer:"full"};this.ImageToURL(t,e,r,Object.assign({returnTo:"canvas"},n))},ImageToURL:function(t,e,r){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{frameTimer:"full"},i=new $(t);i.loadImage(function(){i.toArray(e,function(t){"function"==typeof r&&r(t)},n)})},GLToCanvas:function(t,e,r){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{},i=new $(t);i.load(function(){Xt.filter(i.newImage,e,function(t){"function"==typeof r&&r(t)},n)})},histogram:function(t,e){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},n=new $(t);n.loadImage(function(){"function"==typeof e&&e(n.toHistogram(r))})},histogramToPoints:function(t){for(var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:.2,r=[],n=0;n2&&void 0!==arguments[2]?arguments[2]:{width:200,height:100},n=new $(t);n.loadImage(function(){h.createHistogram(r.width||200,r.height||100,n.toHistogram(r),function(t){"function"==typeof e&&e(t.toDataURL("image/png"))},r)})}};qt.scale.parula=function(t){return qt.scale(["#352a87","#0f5cdd","#00b5a6","#ffc337","#fdff00"],t)},qt.scale.jet=function(t){return qt.scale(["#00008f","#0020ff","#00ffff","#51ff77","#fdff00","#ff0000","#800000"],t)},qt.scale.hsv=function(t){return qt.scale(["#ff0000","#ffff00","#00ff00","#00ffff","#0000ff","#ff00ff","#ff0000"],t)},qt.scale.hot=function(t){return qt.scale(["#0b0000","#ff0000","#ffff00","#ffffff"],t)},qt.scale.pink=function(t){return qt.scale(["#1e0000","#bd7b7b","#e7e5b2","#ffffff"],t)},qt.scale.bone=function(t){return qt.scale(["#000000","#4a4a68","#a6c6c6","#ffffff"],t)},qt.scale.copper=function(t){return qt.scale(["#000000","#3d2618","#9d623e","#ffa167","#ffc77f"],t)};var Yt=[{rgb:"#ff0000",start:0},{rgb:"#ffff00",start:.17},{rgb:"#00ff00",start:.33},{rgb:"#00ffff",start:.5},{rgb:"#0000ff",start:.67},{rgb:"#ff00ff",start:.83},{rgb:"#ff0000",start:1}];!function(){for(var t=0,e=Yt.length;t=t){e=Yt[n-1],r=Yt[n];break}return e&&r?qt.interpolateRGB(e,r,(t-e.start)/(r.start-e.start)):Yt[0].rgb}},Zt=p({},V,X),Jt=0,Qt=[],te=function(){function t(e,r,n){if(v(this,t),"string"!=typeof e)this.el=e;else{var i=document.createElement(e);for(var o in this.uniqId=Jt++,r&&(i.className=r),n=n||{})i.setAttribute(o,n[o]);this.el=i}}return g(t,[{key:"attr",value:function(t,e){return 1==arguments.length?this.el.getAttribute(t):(this.el.setAttribute(t,e),this)}},{key:"closest",value:function(e){for(var r=this,n=!1;!(n=r.hasClass(e));){if(!r.el.parentNode)return null;r=new t(r.el.parentNode)}return n?r:null}},{key:"removeClass",value:function(t){return this.el.className=(" "+this.el.className+" ").replace(" "+t+" "," ").trim(),this}},{key:"hasClass",value:function(t){return!!this.el.className&&(" "+this.el.className+" ").indexOf(" "+t+" ")>-1}},{key:"addClass",value:function(t){return this.hasClass(t)||(this.el.className=this.el.className+" "+t),this}},{key:"toggleClass",value:function(t){this.hasClass(t)?this.removeClass(t):this.addClass(t)}},{key:"html",value:function(t){return"string"==typeof t?this.el.innerHTML=t:this.empty().append(t),this}},{key:"find",value:function(t){return this.el.querySelector(t)}},{key:"findAll",value:function(t){return this.el.querySelectorAll(t)}},{key:"empty",value:function(){return this.html("")}},{key:"append",value:function(t){return"string"==typeof t?this.el.appendChild(document.createTextNode(t)):this.el.appendChild(t.el||t),this}},{key:"appendTo",value:function(t){return(t.el?t.el:t).appendChild(this.el),this}},{key:"remove",value:function(){return this.el.parentNode&&this.el.parentNode.removeChild(this.el),this}},{key:"text",value:function(){return this.el.textContent}},{key:"css",value:function(t,e){var r=this;if(2==arguments.length)this.el.style[t]=e;else if(1==arguments.length){if("string"==typeof t)return getComputedStyle(this.el)[t];var n=t||{};Object.keys(n).forEach(function(t){r.el.style[t]=n[t]})}return this}},{key:"cssFloat",value:function(t){return parseFloat(this.css(t))}},{key:"cssInt",value:function(t){return parseInt(this.css(t))}},{key:"offset",value:function(){var t=this.el.getBoundingClientRect();return{top:t.top+document.documentElement.scrollTop,left:t.left+document.documentElement.scrollLeft}}},{key:"position",value:function(){return this.el.style.top?{top:parseFloat(this.css("top")),left:parseFloat(this.css("left"))}:this.el.getBoundingClientRect()}},{key:"width",value:function(){return this.el.offsetWidth}},{key:"contentWidth",value:function(){return this.width()-this.cssFloat("padding-left")-this.cssFloat("padding-right")}},{key:"height",value:function(){return this.el.offsetHeight}},{key:"contentHeight",value:function(){return this.height()-this.cssFloat("padding-top")-this.cssFloat("padding-bottom")}},{key:"dataKey",value:function(t){return this.uniqId+"."+t}},{key:"data",value:function(t,e){if(2!=arguments.length){if(1==arguments.length)return Qt[this.dataKey(t)];var r=Object.keys(Qt),n=this.uniqId+".";return r.filter(function(t){return 0==t.indexOf(n)}).map(function(t){return Qt[t]})}return Qt[this.dataKey(t)]=e,this}},{key:"val",value:function(t){return 0==arguments.length?this.el.value:(1==arguments.length&&(this.el.value=t),this)}},{key:"int",value:function(){return parseInt(this.val(),10)}},{key:"float",value:function(){return parseFloat(this.val())}},{key:"show",value:function(){return this.css("display","block")}},{key:"hide",value:function(){return this.css("display","none")}},{key:"toggle",value:function(){return"none"==this.css("display")?this.show():this.hide()}},{key:"scrollTop",value:function(){return this.el===document.body?document.documentElement.scrollTop:this.el.scrollTop}},{key:"scrollLeft",value:function(){return this.el===document.body?document.documentElement.scrollLeft:this.el.scrollLeft}},{key:"on",value:function(t,e,r,n){return this.el.addEventListener(t,e,r,n),this}},{key:"off",value:function(t,e){return this.el.removeEventListener(t,e),this}},{key:"getElement",value:function(){return this.el}},{key:"createChild",value:function(e){var r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"",n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},i=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{},o=new t(e,r,n);return o.css(i),this.append(o),o}},{key:"firstChild",value:function(){return new t(this.el.firstElementChild)}}]),t}(),ee={addEvent:function(t,e,r){t.addEventListener(e,r)},removeEvent:function(t,e,r){t.removeEventListener(e,r)},pos:function(t){return t.touches&&t.touches[0]?t.touches[0]:t}},re=function(){function t(e){var r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};v(this,t),this.masterObj=e,this.settingObj=r}return g(t,[{key:"set",value:function(t,e){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:void 0;this.settingObj[t]=e||r}},{key:"init",value:function(t){if(!this.has(t)){var e=t.split("."),r=this.masterObj.refs[e[0]]||this.masterObj[e[0]]||this.masterObj,n=e.pop();if(r[n]){for(var i=arguments.length,o=Array(i>1?i-1:0),a=1;a1&&void 0!==arguments[1]?arguments[1]:"";return this.init(t,e),this.settingObj[t]||e}},{key:"has",value:function(t){return!!this.settingObj[t]}}]),t}(),ne=/^(click|mouse(down|up|move|enter|leave)|key(down|up|press)|contextmenu|change|input)/gi,ie=["Control","Shift","Alt","Meta"],oe=function(){function t(){v(this,t),this.state=new re(this),this.refs={}}return g(t,[{key:"template",value:function(t){var e=this;this.$el=new te("div").html(t).firstChild();var r=this.$el.findAll("[ref]");[].concat(C(r)).forEach(function(t){e.refs[t.getAttribute("ref")]=new te(t)}),this.refs.$el=this.$el}},{key:"initializeEvent",value:function(){this.initializeEventMachin()}},{key:"destroy",value:function(){this.destroyEventMachin()}},{key:"destroyEventMachin",value:function(){this.removeEventAll()}},{key:"initializeEventMachin",value:function(){this.filterProps(ne).forEach(this.parseEvent.bind(this))}},{key:"filterProps",value:function(t){return Object.getOwnPropertyNames(this.__proto__).filter(function(e){return e.match(t)})}},{key:"parseEvent",value:function(t){var e=t.split(" ");this.bindingEvent(e,this[t].bind(this))}},{key:"getDefaultDomElement",value:function(t){var e=void 0;return(e=t?this.refs[t]||this[t]||window[t]:this.el||this.$el||this.$root)instanceof te?e.getElement():e}},{key:"getDefaultEventObject",value:function(t){var e=this,r=t.split("."),n=r.shift(),i=r.includes("Control"),o=r.includes("Shift"),a=r.includes("Alt"),l=r.includes("Meta"),s=(r=r.filter(function(t){return!1===ie.includes(t)})).filter(function(t){return!!e[t]});return{eventName:n,isControl:i,isShift:o,isAlt:a,isMeta:l,codes:r=r.filter(function(t){return!1===s.includes(t)}).map(function(t){return t.toLowerCase()}),checkMethodList:s}}},{key:"bindingEvent",value:function(t,e){var r,n=(r=t,Array.isArray(r)?r:Array.from(r)),i=n[0],o=n[1],a=n.slice(2);o=this.getDefaultDomElement(o);var l=this.getDefaultEventObject(i);l.dom=o,l.delegate=a.join(" "),this.addEvent(l,e)}},{key:"matchPath",value:function(t,e){return t?t.matches(e)?t:this.matchPath(t.parentElement,e):null}},{key:"getBindings",value:function(){return this._bindings||this.initBindings(),this._bindings}},{key:"addBinding",value:function(t){this.getBindings().push(t)}},{key:"initBindings",value:function(){this._bindings=[]}},{key:"checkEventType",value:function(t,e){var r=this,n=!t.ctrlKey||e.isControl,i=!t.shiftKey||e.isShift,o=!t.altKey||e.isAlt,a=!t.metaKey||e.isMeta,l=!0;e.codes.length&&(l=e.codes.includes(t.code.toLowerCase())||e.codes.includes(t.key.toLowerCase()));var s=!0;return e.checkMethodList.length&&(s=e.checkMethodList.every(function(e){return r[e].call(r,t)})),n&&o&&i&&a&&l&&s}},{key:"makeCallback",value:function(t,e){var r=this;return t.delegate?function(n){if(r.checkEventType(n,t)){var i=r.matchPath(n.target||n.srcElement,t.delegate);if(i)return n.delegateTarget=i,n.$delegateTarget=new te(i),e(n)}}:function(n){if(r.checkEventType(n,t))return e(n)}}},{key:"addEvent",value:function(t,e){t.callback=this.makeCallback(t,e),this.addBinding(t),ee.addEvent(t.dom,t.eventName,t.callback)}},{key:"removeEventAll",value:function(){var t=this;this.getBindings().forEach(function(e){t.removeEvent(e)}),this.initBindings()}},{key:"removeEvent",value:function(t){var e=t.eventName,r=t.dom,n=t.callback;ee.removeEvent(r,e,n)}}]),t}(),ae=[{name:"Material",colors:["#F44336","#E91E63","#9C27B0","#673AB7","#3F51B5","#2196F3","#03A9F4","#00BCD4","#009688","#4CAF50","#8BC34A","#CDDC39","#FFEB3B","#FFC107","#FF9800","#FF5722","#795548","#9E9E9E","#607D8B"]},{name:"Custom",edit:!0,colors:[]},{name:"Color Scale",scale:["red","yellow","black"],count:5}],le=function(){function t(e){v(this,t),this.colorpicker=e,this.setUserList(this.colorpicker.getOption("colorSets"))}return g(t,[{key:"list",value:function(){return this.userList||ae}},{key:"setUserList",value:function(t){this.userList=t,this.resetUserList(),this.setCurrentColorSets()}},{key:"resetUserList",value:function(){var t=this;this.userList&&this.userList.length&&(this.userList=this.userList.map(function(e,r){if("function"==typeof e.colors){var n=e.colors;e.colors=n(t.colorpicker,t),e._colors=n}return Object.assign({name:"color-"+r,colors:[]},e)}))}},{key:"setCurrentColorSets",value:function(t){var e=this.list();this.currentColorSets=void 0===t?e[0]:"number"==typeof t?e[t]:e.filter(function(e){return e.name==t})[0]}},{key:"getCurrentColorSets",value:function(){return this.currentColorSets}},{key:"addCurrentColor",value:function(t){Array.isArray(this.currentColorSets.colors)&&this.currentColorSets.colors.push(t)}},{key:"removeCurrentColor",value:function(t){this.currentColorSets.colors[t]&&this.currentColorSets.colors.splice(t,1)}},{key:"removeCurrentColorToTheRight",value:function(t){this.currentColorSets.colors[t]&&this.currentColorSets.colors.splice(t,Number.MAX_VALUE)}},{key:"clearPalette",value:function(){this.currentColorSets.colors&&(this.currentColorSets.colors=[])}},{key:"getCurrentColors",value:function(){return this.getColors(this.currentColorSets)}},{key:"getColors",value:function(t){return t.scale?qt.scale(t.scale,t.count):t.colors||[]}},{key:"getColorSetsList",value:function(){var t=this;return this.list().map(function(e){return{name:e.name,edit:e.edit,colors:t.getColors(e)}})}},{key:"destroy",value:function(){}}]),t}(),se=function(t){function e(t){v(this,e);var r=y(this,(e.__proto__||Object.getPrototypeOf(e)).call(this));return r.opt=t||{},r.$body=null,r.$root=null,r.format="rgb",r.currentA=0,r.currentH=0,r.currentS=0,r.currentV=0,r.colorSetsList=new le(r),r.colorpickerCallback=function(){},r.isColorPickerShow=!1,r.isShortCut=!1,r.hideDelay=r.opt.hideDeplay||2e3,r.timerCloseColorPicker,r.autoHide=r.opt.autoHide||!0,r}return b(e,oe),g(e,[{key:"initialize",value:function(){this.$body=new te(this.getContainer()),this.$root=new te("div","codemirror-colorpicker"),"inline"==this.opt.position&&this.$body.append(this.$root),this.opt.type&&this.$root.addClass(this.opt.type),this.$arrow=new te("div","arrow"),this.$root.append(this.$arrow)}},{key:"getOption",value:function(t){return this.opt[t]}},{key:"setOption",value:function(t,e){this.opt[t]=e}},{key:"isType",value:function(t){return this.getOption("type")==t}},{key:"isPaletteType",value:function(){return this.isType("palette")}},{key:"isSketchType",value:function(){return this.isType("sketch")}},{key:"getContainer",value:function(){return this.opt.container||document.body}},{key:"getColor",value:function(t){this.caculateHSV();var e=this.convertRGB();return t?qt.format(e,t):e}},{key:"definePositionForArrow",value:function(t,e,r){}},{key:"definePosition",value:function(t){var e=this.$root.width(),r=this.$root.height(),n=t.left-this.$body.scrollLeft();e+n>window.innerWidth&&(n-=e+n-window.innerWidth),n<0&&(n=0);var i=t.top-this.$body.scrollTop();r+i>window.innerHeight&&(i-=r+i-window.innerHeight),i<0&&(i=0),this.$root.css({left:n+"px",top:i+"px"})}},{key:"getInitalizePosition",value:function(){return"inline"==this.opt.position?{position:"relative",left:"auto",top:"auto",display:"inline-block"}:{position:"fixed",left:"-10000px",top:"-10000px"}}},{key:"show",value:function(t,e,r){this.destroy(),this.initializeEvent(),this.$root.appendTo(this.$body),this.$root.css(this.getInitalizePosition()).show(),this.definePosition(t),this.isColorPickerShow=!0,this.isShortCut=t.isShortCut||!1,this.initColor(e),this.colorpickerCallback=r,this.hideDelay=t.hideDelay||2e3,this.hideDelay>0&&this.setHideDelay(this.hideDelay)}},{key:"setHideDelay",value:function(t){var e=this;t=t||0,this.$root.off("mouseenter"),this.$root.off("mouseleave"),this.$root.on("mouseenter",function(){clearTimeout(e.timerCloseColorPicker)}),this.$root.on("mouseleave",function(){clearTimeout(e.timerCloseColorPicker),e.timerCloseColorPicker=setTimeout(e.hide.bind(e),t)}),clearTimeout(this.timerCloseColorPicker),this.timerCloseColorPicker=setTimeout(this.hide.bind(this),t)}},{key:"hide",value:function(){this.isColorPickerShow&&(this.destroy(),this.$root.hide(),this.$root.remove(),this.isColorPickerShow=!1)}},{key:"convertRGB",value:function(){return qt.HSVtoRGB(this.currentH,this.currentS,this.currentV)}},{key:"convertHEX",value:function(){return qt.format(this.convertRGB(),"hex")}},{key:"convertHSL",value:function(){return qt.HSVtoHSL(this.currentH,this.currentS,this.currentV)}},{key:"getFormattedColor",value:function(t){if("rgb"==(t=t||"hex"))return(r=this.convertRGB()).a=this.currentA,qt.format(r,"rgb");if("hsl"==t){var e=this.convertHSL();return e.a=this.currentA,qt.format(e,"hsl")}var r=this.convertRGB();return qt.format(r,"hex")}},{key:"callbackColorValue",value:function(t){isNaN(this.currentA)||("function"==typeof this.opt.onChange&&this.opt.onChange.call(this,t),"function"==typeof this.colorpickerCallback&&this.colorpickerCallback(t))}},{key:"setCurrentHSV",value:function(t,e,r,n){this.currentA=n,this.currentH=t,this.currentS=e,this.currentV=r}},{key:"setCurrentH",value:function(t){this.currentH=t}},{key:"setCurrentA",value:function(t){this.currentA=t}},{key:"getHSV",value:function(t){return"hsl"==t.type?qt.HSLtoHSV(t):qt.RGBtoHSV(t)}},{key:"initColor",value:function(t,e){var r=t||"#FF0000",n=qt.parse(r);e=e||n.type;var i=this.getHSV(n);this.setCurrentHSV(i.h,i.s,i.v,n.a)}},{key:"checkColorPickerClass",value:function(t){var e=new te(t).closest("codemirror-colorview"),r=new te(t).closest("codemirror-colorpicker"),n=new te(t).closest("CodeMirror");t.nodeName;return!!(r||e||n)}},{key:"checkInHtml",value:function(t){return"HTML"==t.nodeName}},{key:"initializeEvent",value:function(){this.initializeEventMachin()}},{key:"setColorSets",value:function(t){this.colorSetsList.setUserList(t)}},{key:"destroy",value:function(){m(e.prototype.__proto__||Object.getPrototypeOf(e.prototype),"destroy",this).call(this),this.colorpickerCallback=void 0}}]),e}(),ue=function(t){function e(t){v(this,e);var r=y(this,(e.__proto__||Object.getPrototypeOf(e)).call(this));return r.colorpicker=t,r.initialize(),r}return b(e,oe),g(e,[{key:"initialize",value:function(){this.template('\n \n '),this.drag_bar_pos={},this.opacity_drag_bar_pos={}}},{key:"setBackgroundColor",value:function(t){this.refs.$controlColor.css("background-color",t)}},{key:"refresh",value:function(){this.setColorUI()}},{key:"setOpacityColorBar",value:function(t){var e=qt.parse(t);e.a=0;var r=qt.format(e,"rgb");e.a=1;var n=qt.format(e,"rgb");this.refs.$opacityColorBar.css("background","linear-gradient(to right, "+r+", "+n+")")}},{key:"setOpacity",value:function(t){var e,r=this.refs.$opacityContainer.offset().left,n=r+this.state.get("$opacityContainer.width"),i=ee.pos(t).clientX;in?(e=100,this.refs.$opacity_drag_bar.addClass("last").removeClass("first")):(e=(i-r)/(n-r)*100,this.refs.$opacity_drag_bar.removeClass("first").removeClass("last"));var o=this.state.get("$opacityContainer.width")*(e/100);this.refs.$opacity_drag_bar.css({left:o+"px"}),this.opacity_drag_bar_pos={x:o},this.colorpicker.setCurrentA(this.caculateOpacity()),this.colorpicker.currentFormat(),this.colorpicker.setInputColor()}},{key:"setInputColor",value:function(){this.setBackgroundColor(this.colorpicker.getFormattedColor("rgb"));var t=this.colorpicker.convertRGB(),e=qt.format(t,"rgb");this.setOpacityColorBar(e)}},{key:"setColorUI",value:function(){var t=this.state.get("$hueContainer.width")*(this.colorpicker.currentH/360);this.refs.$drag_bar.css({left:t+"px"}),this.drag_bar_pos={x:t};var e=this.state.get("$opacityContainer.width")*(this.colorpicker.currentA||0);this.refs.$opacity_drag_bar.css({left:e+"px"}),this.opacity_drag_bar_pos={x:e}}},{key:"caculateH",value:function(){return{h:(this.drag_bar_pos||{x:0}).x/this.state.get("$hueContainer.width")*360}}},{key:"caculateOpacity",value:function(){var t=this.opacity_drag_bar_pos||{x:0},e=Math.round(t.x/this.state.get("$opacityContainer.width")*100)/100;return isNaN(e)?1:e}},{key:"EventDocumentMouseMove",value:function(t){this.isHueDown&&this.setHueColor(t),this.isOpacityDown&&this.setOpacity(t)}},{key:"EventDocumentMouseUp",value:function(t){this.isHueDown=!1,this.isOpacityDown=!1}},{key:"setControlColor",value:function(t){this.refs.$controlColor.css("background-color",t)}},{key:"setHueColor",value:function(t,e){var r,n=this.refs.$hueContainer.offset().left,i=n+this.state.get("$hueContainer.width"),o=t?ee.pos(t).clientX:n+(i-n)*(this.colorpicker.currentH/360);oi?(r=100,this.refs.$drag_bar.addClass("last").removeClass("first")):(r=(o-n)/(i-n)*100,this.refs.$drag_bar.removeClass("first").removeClass("last"));var a=this.state.get("$hueContainer.width")*(r/100);this.refs.$drag_bar.css({left:a+"px"}),this.drag_bar_pos={x:a};var l=Kt.checkHueColor(r/100);this.colorpicker.setBackgroundColor(l),this.colorpicker.setCurrentH(r/100*360),e||this.colorpicker.setInputColor()}},{key:"setOnlyHueColor",value:function(){this.setHueColor(null,!0)}},{key:"mousedown $drag_bar",value:function(t){t.preventDefault(),this.isHueDown=!0}},{key:"mousedown $opacity_drag_bar",value:function(t){t.preventDefault(),this.isOpacityDown=!0}},{key:"mousedown $hueContainer",value:function(t){this.isHueDown=!0,this.setHueColor(t)}},{key:"mousedown $opacityContainer",value:function(t){this.isOpacityDown=!0,this.setOpacity(t)}}]),e}(),ce=function(t){function e(t){v(this,e);var r=y(this,(e.__proto__||Object.getPrototypeOf(e)).call(this));return r.colorpicker=t,r.initialize(),r}return b(e,oe),g(e,[{key:"initialize",value:function(){this.template('\n \n '),this.format="hex"}},{key:"currentFormat",value:function(){var t=this.format||"hex";if(this.colorpicker.currentA<1&&"hex"==t){this.$el.removeClass(t),this.$el.addClass("rgb"),this.format="rgb",this.colorpicker.setInputColor()}}},{key:"setCurrentFormat",value:function(t){this.format=t,this.initFormat()}},{key:"initFormat",value:function(){var t=this.format||"hex";this.$el.removeClass("hex"),this.$el.removeClass("rgb"),this.$el.removeClass("hsl"),this.$el.addClass(t)}},{key:"nextFormat",value:function(){var t=this.format||"hex",e="hex";"hex"==t?e="rgb":"rgb"==t?e="hsl":"hsl"==t&&(e=1==this.colorpicker.currentA?"hex":"rgb"),this.$el.removeClass(t),this.$el.addClass(e),this.format=e,this.setInputColor(),this.colorpicker.changeInputColorAfterNextFormat()}},{key:"setRGBInput",value:function(t,e,r){this.refs.$rgb_r.val(t),this.refs.$rgb_g.val(e),this.refs.$rgb_b.val(r),this.refs.$rgb_a.val(this.colorpicker.currentA)}},{key:"setHSLInput",value:function(t,e,r){this.refs.$hsl_h.val(t),this.refs.$hsl_s.val(e),this.refs.$hsl_l.val(r),this.refs.$hsl_a.val(this.colorpicker.currentA)}},{key:"getHexFormat",value:function(){return qt.format({r:this.refs.$rgb_r.int(),g:this.refs.$rgb_g.int(),b:this.refs.$rgb_b.int()},"hex",this.colorpicker.opt.color)}},{key:"getRgbFormat",value:function(){return qt.format({r:this.refs.$rgb_r.int(),g:this.refs.$rgb_g.int(),b:this.refs.$rgb_b.int(),a:this.refs.$rgb_a.float()},"rgb",this.colorpicker.opt.color)}},{key:"getHslFormat",value:function(){return qt.format({h:this.refs.$hsl_h.val(),s:this.refs.$hsl_s.val(),l:this.refs.$hsl_l.val(),a:this.refs.$hsl_a.float()},"hsl",this.colorpicker.opt.color)}},{key:"convertRGB",value:function(){return this.colorpicker.convertRGB()}},{key:"convertHEX",value:function(){return this.colorpicker.convertHEX()}},{key:"convertHSL",value:function(){return this.colorpicker.convertHSL()}},{key:"getFormattedColor",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]&&arguments[1];return"hex"==(t=t||this.getFormat())?this.refs.$hexCode.val():"rgb"==t?this.getRgbFormat(e):"hsl"==t?this.getHslFormat(e):void 0}},{key:"getFormat",value:function(){return this.format||"hex"}},{key:"setInputColor",value:function(){var t=this.getFormat(),e=null;if("hex"==t){this.refs.$hexCode.val(this.convertHEX());e=this.convertRGB();this.setRGBInput(e.r,e.g,e.b,e.a)}else if("rgb"==t){e=this.convertRGB();this.setRGBInput(e.r,e.g,e.b,e.a),this.refs.$hexCode.val(this.convertHEX())}else if("hsl"==t){var r=this.convertHSL();this.setHSLInput(r.h,r.s,r.l,r.a)}}},{key:"checkNumberKey",value:function(t){return ee.checkNumberKey(t)}},{key:"checkNotNumberKey",value:function(t){return!ee.checkNumberKey(t)}},{key:"changeRgbColor",value:function(){this.colorpicker.changeInformationColor(this.getRgbFormat())}},{key:"changeHslColor",value:function(){this.colorpicker.changeInformationColor(this.getHslFormat())}},{key:"change $rgb_r",value:function(t){this.changeRgbColor()}},{key:"change $rgb_g",value:function(t){this.changeRgbColor()}},{key:"change $rgb_b",value:function(t){this.changeRgbColor()}},{key:"change $rgb_a",value:function(t){this.changeRgbColor()}},{key:"change $hsl_h",value:function(t){this.changeHslColor()}},{key:"change $hsl_s",value:function(t){this.changeHslColor()}},{key:"change $hsl_l",value:function(t){this.changeHslColor()}},{key:"change $hsl_a",value:function(t){this.changeHslColor()}},{key:"keydown $hexCode",value:function(t){if(t.which<65||t.which>70)return this.checkNumberKey(t)}},{key:"keyup $hexCode",value:function(t){var e=this.refs.$hexCode.val();"#"==e.charAt(0)&&7==e.length&&(this.colorpicker.changeInformationColor(e),this.setInputColor())}},{key:"click $formatChangeButton",value:function(t){this.nextFormat()}},{key:"refresh",value:function(){}}]),e}(),he=function(t){function e(t){v(this,e);var r=y(this,(e.__proto__||Object.getPrototypeOf(e)).call(this));return r.colorpicker=t,r.initialize(),r}return b(e,oe),g(e,[{key:"initialize",value:function(){this.template('\n \n ')}},{key:"setBackgroundColor",value:function(t){this.$el.css("background-color",t)}},{key:"refresh",value:function(){this.setColorUI()}},{key:"caculateSV",value:function(){var t=this.drag_pointer_pos||{x:0,y:0},e=this.state.get("$el.width"),r=this.state.get("$el.height");return{s:t.x/e,v:(r-t.y)/r,width:e,height:r}}},{key:"setColorUI",value:function(){var t=this.state.get("$el.width")*this.colorpicker.currentS,e=this.state.get("$el.height")*(1-this.colorpicker.currentV);this.refs.$drag_pointer.css({left:t-5+"px",top:e-5+"px"}),this.drag_pointer_pos={x:t,y:e}}},{key:"setMainColor",value:function(t){t.preventDefault();var e=this.$el.position(),r=this.state.get("$el.contentWidth"),n=this.state.get("$el.contentHeight"),i=t.clientX-e.left,o=t.clientY-e.top;i<0?i=0:i>r&&(i=r),o<0?o=0:o>n&&(o=n),this.refs.$drag_pointer.css({left:i-5+"px",top:o-5+"px"}),this.drag_pointer_pos={x:i,y:o},this.colorpicker.caculateHSV(),this.colorpicker.setInputColor()}},{key:"EventDocumentMouseUp",value:function(t){this.isDown=!1}},{key:"EventDocumentMouseMove",value:function(t){this.isDown&&this.setMainColor(t)}},{key:"mousedown",value:function(t){this.isDown=!0,this.setMainColor(t)}},{key:"mouseup",value:function(t){this.isDown=!1}}]),e}(),fe="data-colorsets-index",ve=function(t){function e(t){v(this,e);var r=y(this,(e.__proto__||Object.getPrototypeOf(e)).call(this));return r.colorpicker=t,r.initialize(),r}return b(e,oe),g(e,[{key:"initialize",value:function(){this.template('\n \n '),this.refresh()}},{key:"refresh",value:function(){this.refs.$colorsetsList.html(this.makeColorSetsList())}},{key:"makeColorItemList",value:function(t){for(var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:5,r=new te("div"),n=0;n\n \n \n \n '),this.refresh()}},{key:"refresh",value:function(){this.refs.$colorSetsColorList.html(this.makeCurrentColorSets())}},{key:"refreshAll",value:function(){this.refresh(),this.colorpicker.refreshColorSetsChooser()}},{key:"addColor",value:function(t){this.colorSetsList.addCurrentColor(t),this.refreshAll()}},{key:"removeColor",value:function(t){this.colorSetsList.removeCurrentColor(t),this.refreshAll()}},{key:"removeAllToTheRight",value:function(t){this.colorSetsList.removeCurrentColorToTheRight(t),this.refreshAll()}},{key:"clearPalette",value:function(){this.colorSetsList.clearPalette(),this.refreshAll()}},{key:"click $colorSetsChooseButton",value:function(t){this.colorpicker.toggleColorChooser()}},{key:"contextmenu $colorSetsColorList",value:function(t){if(t.preventDefault(),this.colorSetsList.getCurrentColorSets().edit){var e=new te(t.target).closest("color-item");if(e){var r=parseInt(e.attr("data-index"));this.colorpicker.showContextMenu(t,r)}else this.colorpicker.showContextMenu(t)}}},{key:"click $colorSetsColorList .add-color-item",value:function(t){this.addColor(this.colorpicker.getCurrentColor())}},{key:"click $colorSetsColorList .color-item",value:function(t){var e=!!this.colorpicker.isPaletteType();this.colorpicker.setColor(t.$delegateTarget.attr("data-color"),e)}}]),e}(),de=function(t){function e(t){v(this,e);var r=y(this,(e.__proto__||Object.getPrototypeOf(e)).call(this));return r.colorpicker=t,r.currentColorSets=t.currentColorSets,r.initialize(),r}return b(e,oe),g(e,[{key:"initialize",value:function(){this.template('\n \n ')}},{key:"show",value:function(t,e){var r=ee.pos(t);this.$el.css({top:r.clientY-10+"px",left:r.clientX+"px"}),this.$el.addClass("show"),this.selectedColorIndex=e,void 0===this.selectedColorIndex?this.$el.addClass("small"):this.$el.removeClass("small")}},{key:"hide",value:function(){this.$el.removeClass("show")}},{key:"runCommand",value:function(t){switch(t){case"remove-color":this.currentColorSets.removeColor(this.selectedColorIndex);break;case"remove-all-to-the-right":this.currentColorSets.removeAllToTheRight(this.selectedColorIndex);break;case"clear-palette":this.currentColorSets.clearPalette()}}},{key:"click $el .menu-item",value:function(t){t.preventDefault(),this.runCommand(t.$delegateTarget.attr("data-type")),this.hide()}}]),e}(),pe=function(t){function e(t){v(this,e);var r=y(this,(e.__proto__||Object.getPrototypeOf(e)).call(this,t));return r.control=new ue(r),r.palette=new he(r),r.information=new ce(r),r.colorSetsChooser=new ve(r),r.currentColorSets=new ge(r),r.contextMenu=new de(r,r.currentColorSets),r.initialize(),r}return b(e,se),g(e,[{key:"initialize",value:function(){m(e.prototype.__proto__||Object.getPrototypeOf(e.prototype),"initialize",this).call(this),this.$root.append(this.palette.$el),this.$root.append(this.control.$el),this.$root.append(this.information.$el),this.$root.append(this.currentColorSets.$el),this.$root.append(this.colorSetsChooser.$el),this.$root.append(this.contextMenu.$el),this.$checkColorPickerClass=this.checkColorPickerClass.bind(this),this.initColor(this.opt.color),this.initializeEvent()}},{key:"showContextMenu",value:function(t,e){this.contextMenu.show(t,e)}},{key:"setColor",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]&&arguments[1];if("object"==(void 0===t?"undefined":f(t))){if(!t.r||!t.g||!t.b)return;e?this.callbackColorValue(qt.format(t,"hex")):this.initColor(qt.format(t,"hex"))}else"string"==typeof t&&(e?this.callbackColorValue(t):this.initColor(t))}},{key:"getColor",value:function(t){this.caculateHSV();var e=this.convertRGB();return t?qt.format(e,t):e}},{key:"definePositionForArrow",value:function(t,e,r){}},{key:"definePosition",value:function(t){var e=this.$root.width(),r=this.$root.height(),n=t.left-this.$body.scrollLeft();e+n>window.innerWidth&&(n-=e+n-window.innerWidth),n<0&&(n=0);var i=t.top-this.$body.scrollTop();r+i>window.innerHeight&&(i-=r+i-window.innerHeight),i<0&&(i=0),this.$root.css({left:n+"px",top:i+"px"})}},{key:"getInitalizePosition",value:function(){return"inline"==this.opt.position?{position:"relative",left:"auto",top:"auto",display:"inline-block"}:{position:"fixed",left:"-10000px",top:"-10000px"}}},{key:"show",value:function(t,e,r){this.destroy(),this.initializeEvent(),this.$root.appendTo(this.$body),this.$root.css(this.getInitalizePosition()).show(),this.definePosition(t),this.isColorPickerShow=!0,this.isShortCut=t.isShortCut||!1,this.initColor(e),this.colorpickerCallback=r,this.hideDelay=t.hideDelay||2e3,this.hideDelay>0&&this.setHideDelay(this.hideDelay)}},{key:"setHideDelay",value:function(t){var e=this;t=t||0,this.$root.off("mouseenter"),this.$root.off("mouseleave"),this.$root.on("mouseenter",function(){clearTimeout(e.timerCloseColorPicker)}),this.$root.on("mouseleave",function(){clearTimeout(e.timerCloseColorPicker),e.timerCloseColorPicker=setTimeout(e.hide.bind(e),t)}),clearTimeout(this.timerCloseColorPicker),this.timerCloseColorPicker=setTimeout(this.hide.bind(this),t)}},{key:"hide",value:function(){this.isColorPickerShow&&(this.destroy(),this.$root.hide(),this.$root.remove(),this.isColorPickerShow=!1)}},{key:"convertRGB",value:function(){return qt.HSVtoRGB(this.currentH,this.currentS,this.currentV)}},{key:"convertHEX",value:function(){return qt.format(this.convertRGB(),"hex")}},{key:"convertHSL",value:function(){return qt.HSVtoHSL(this.currentH,this.currentS,this.currentV)}},{key:"getCurrentColor",value:function(){return this.information.getFormattedColor()}},{key:"getFormattedColor",value:function(t){if("rgb"==(t=t||"hex"))return(r=this.convertRGB()).a=this.currentA,qt.format(r,"rgb");if("hsl"==t){var e=this.convertHSL();return e.a=this.currentA,qt.format(e,"hsl")}var r=this.convertRGB();return qt.format(r,"hex")}},{key:"setInputColor",value:function(t){this.information.setInputColor(t),this.control.setInputColor(t),this.callbackColorValue()}},{key:"changeInputColorAfterNextFormat",value:function(){this.control.setInputColor(),this.callbackColorValue()}},{key:"callbackColorValue",value:function(t){t=t||this.getCurrentColor(),isNaN(this.currentA)||("function"==typeof this.opt.onChange&&this.opt.onChange.call(this,t),"function"==typeof this.colorpickerCallback&&this.colorpickerCallback(t))}},{key:"caculateHSV",value:function(){var t=this.palette.caculateSV(),e=this.control.caculateH(),r=t.s,n=t.v,i=e.h;0==t.width&&(i=0,r=0,n=0),this.currentH=i,this.currentS=r,this.currentV=n}},{key:"setColorUI",value:function(){this.control.setColorUI(),this.palette.setColorUI()}},{key:"setCurrentHSV",value:function(t,e,r,n){this.currentA=n,this.currentH=t,this.currentS=e,this.currentV=r}},{key:"setCurrentH",value:function(t){this.currentH=t}},{key:"setCurrentA",value:function(t){this.currentA=t}},{key:"setBackgroundColor",value:function(t){this.palette.setBackgroundColor(t)}},{key:"setCurrentFormat",value:function(t){this.format=t,this.information.setCurrentFormat(t)}},{key:"getHSV",value:function(t){return"hsl"==t.type?qt.HSLtoHSV(t):qt.RGBtoHSV(t)}},{key:"initColor",value:function(t,e){var r=t||"#FF0000",n=qt.parse(r);e=e||n.type,this.setCurrentFormat(e);var i=this.getHSV(n);this.setCurrentHSV(i.h,i.s,i.v,n.a),this.setColorUI(),this.setHueColor(),this.setInputColor()}},{key:"changeInformationColor",value:function(t){var e=t||"#FF0000",r=qt.parse(e),n=this.getHSV(r);this.setCurrentHSV(n.h,n.s,n.v,r.a),this.setColorUI(),this.setHueColor(),this.control.setInputColor(),this.callbackColorValue()}},{key:"setHueColor",value:function(){this.control.setOnlyHueColor()}},{key:"mouseup document",value:function(t){this.palette.EventDocumentMouseUp(t),this.control.EventDocumentMouseUp(t),this.checkInHtml(t.target)||0==this.checkColorPickerClass(t.target)&&this.hide()}},{key:"mousemove document",value:function(t){this.palette.EventDocumentMouseMove(t),this.control.EventDocumentMouseMove(t)}},{key:"initializeEvent",value:function(){this.initializeEventMachin(),this.palette.initializeEvent(),this.control.initializeEvent(),this.information.initializeEvent(),this.currentColorSets.initializeEvent(),this.colorSetsChooser.initializeEvent(),this.contextMenu.initializeEvent()}},{key:"currentFormat",value:function(){this.information.currentFormat()}},{key:"toggleColorChooser",value:function(){this.colorSetsChooser.toggle()}},{key:"refreshColorSetsChooser",value:function(){this.colorSetsChooser.refresh()}},{key:"getColorSetsList",value:function(){return this.colorSetsList.getColorSetsList()}},{key:"setCurrentColorSets",value:function(t){this.colorSetsList.setCurrentColorSets(t),this.currentColorSets.refresh()}},{key:"setColorSets",value:function(t){this.colorSetsList.setUserList(t)}},{key:"destroy",value:function(){m(e.prototype.__proto__||Object.getPrototypeOf(e.prototype),"destroy",this).call(this),this.control.destroy(),this.palette.destroy(),this.information.destroy(),this.colorSetsChooser.destroy(),this.colorSetsList.destroy(),this.currentColorSets.destroy(),this.contextMenu.destroy()}}]),e}(),me={create:function(t){switch(t.type){case"sketch":case"palette":default:return new pe(t)}},ColorPicker:pe,ChromeDevToolColorPicker:pe},be="codemirror-colorview",ye="codemirror-colorview-background",ke=["comment"];function Ce(t,e){"setValue"==e.origin?(t.state.colorpicker.close_color_picker(),t.state.colorpicker.init_color_update(),t.state.colorpicker.style_color_update()):t.state.colorpicker.style_color_update(t.getCursor().line)}function $e(t,e){t.state.colorpicker.isUpdate||(t.state.colorpicker.isUpdate=!0,t.state.colorpicker.close_color_picker(),t.state.colorpicker.init_color_update(),t.state.colorpicker.style_color_update())}function xe(t,e){Ce(t,{origin:"setValue"})}function _e(t,e){t.state.colorpicker.keyup(e)}function we(t,e){t.state.colorpicker.is_edit_mode()&&t.state.colorpicker.check_mousedown(e)}function Se(t,e){Ce(t,{origin:"setValue"})}function Ee(t){t.state.colorpicker.close_color_picker()}var Ae=function(){function t(e,r){v(this,t),r="boolean"==typeof r?{mode:"edit"}:Object.assign({mode:"edit"},r||{}),this.opt=r,this.cm=e,this.markers={},this.excluded_token=this.opt.excluded_token||ke,this.opt.colorpicker?this.colorpicker=this.opt.colorpicker(this.opt):this.colorpicker=me.create(this.opt),this.init_event()}return g(t,[{key:"init_event",value:function(){var t,e,r,n,i;this.cm.on("mousedown",we),this.cm.on("keyup",_e),this.cm.on("change",Ce),this.cm.on("update",$e),this.cm.on("refresh",xe),this.onPasteCallback=(t=this.cm,e=Se,function(r){e.call(this,t,r)}),this.cm.getWrapperElement().addEventListener("paste",this.onPasteCallback),this.is_edit_mode()&&this.cm.on("scroll",(r=Ee,n=50,i=void 0,function(t,e){i&&clearTimeout(i),i=setTimeout(function(){r(t,e)},n||300)}))}},{key:"is_edit_mode",value:function(){return"edit"==this.opt.mode}},{key:"is_view_mode",value:function(){return"view"==this.opt.mode}},{key:"destroy",value:function(){this.cm.off("mousedown",we),this.cm.off("keyup",_e),this.cm.off("change",Ce),this.cm.getWrapperElement().removeEventListener("paste",this.onPasteCallback),this.is_edit_mode()&&this.cm.off("scroll")}},{key:"hasClass",value:function(t,e){return!!t.className&&(" "+t.className+" ").indexOf(" "+e+" ")>-1}},{key:"check_mousedown",value:function(t){this.hasClass(t.target,ye)?this.open_color_picker(t.target.parentNode):this.close_color_picker()}},{key:"popup_color_picker",value:function(t){var e=this.cm.getCursor(),r=this,n={lineNo:e.line,ch:e.ch,color:t||"#FFFFFF",isShortCut:!0};Object.keys(this.markers).forEach(function(t){if(("#"+t).indexOf("#"+n.lineNo+":")>-1){var e=r.markers[t];e.ch<=n.ch&&n.ch<=e.ch+e.color.length&&(n.ch=e.ch,n.color=e.color,n.nameColor=e.nameColor)}}),this.open_color_picker(n)}},{key:"open_color_picker",value:function(t){var e=t.lineNo,r=t.ch,n=t.nameColor,i=t.color;if(this.colorpicker){var o=this,a=i,l=this.cm.charCoords({line:e,ch:r});this.colorpicker.show({left:l.left,top:l.bottom,isShortCut:t.isShortCut||!1,hideDelay:o.opt.hideDelay||2e3},n||i,function(t){o.cm.replaceRange(t,{line:e,ch:r},{line:e,ch:r+a.length},"*colorpicker"),a=t})}}},{key:"close_color_picker",value:function(t){this.colorpicker&&this.colorpicker.hide()}},{key:"key",value:function(t,e){return[t,e].join(":")}},{key:"keyup",value:function(t){this.colorpicker&&("Escape"==t.key?this.colorpicker.hide():0==this.colorpicker.isShortCut&&this.colorpicker.hide())}},{key:"init_color_update",value:function(){this.markers={}}},{key:"style_color_update",value:function(t){if(t)this.match(t);else for(var e=this.cm.lineCount(),r=0;r-1)&&(delete this.markers[l],i[o].marker.clear())}}},{key:"match_result",value:function(t){return qt.matches(t.text)}},{key:"submatch",value:function(t,e){var r=this;this.empty_marker(t,e);var n={next:0};this.match_result(e).forEach(function(i){r.render(n,t,e,i.color,i.nameColor)})}},{key:"match",value:function(t){var e=this.cm.getLineHandle(t),r=this;this.cm.operation(function(){r.submatch(t,e)})}},{key:"make_element",value:function(){var t=document.createElement("div");return t.className=be,this.is_edit_mode()?t.title="open color picker":t.title="",t.back_element=this.make_background_element(),t.appendChild(t.back_element),t}},{key:"make_background_element",value:function(){var t=document.createElement("div");return t.className=ye,t}},{key:"set_state",value:function(t,e,r,n){var i=this.create_marker(t,e);return i.lineNo=t,i.ch=e,i.color=r,i.nameColor=n,i}},{key:"create_marker",value:function(t,e){var r=this.key(t,e);return this.markers[r]||(this.markers[r]=this.make_element()),this.markers[r]}},{key:"has_marker",value:function(t,e){var r=this.key(t,e);return!!this.markers[r]}},{key:"update_element",value:function(t,e){t.back_element.style.backgroundColor=e}},{key:"set_mark",value:function(t,e,r){this.cm.setBookmark({line:t,ch:e},{widget:r,handleMouseEvents:!0})}},{key:"is_excluded_token",value:function(t,e){for(var r=this.cm.getTokenTypeAt({line:t,ch:e}),n=0,i=0,o=this.excluded_token.length;i0}},{key:"render",value:function(t,e,r,n,i){var o=r.text.indexOf(n,t.next);if(!0!==this.is_excluded_token(e,o)){if(t.next=o+n.length,this.has_marker(e,o))return this.update_element(this.create_marker(e,o),i||n),void this.set_state(e,o,n,i);var a=this.create_marker(e,o);this.update_element(a,i||n),this.set_state(e,o,n,i||n),this.set_mark(e,o,a)}}}]),t}();return t&&t.defineOption("colorpicker",!1,function(e,r,n){n&&n!=t.Init&&e.state.colorpicker&&(e.state.colorpicker.destroy(),e.state.colorpicker=null),r&&(e.state.colorpicker=new Ae(e,r))}),p({Color:qt,ColorNames:r},me,{ImageFilter:Zt,GL:Xt,HueColor:Kt,Canvas:h,ImageLoader:$})}(CodeMirror);
diff --git a/package.json b/package.json
index b3e22f4..a3c3080 100644
--- a/package.json
+++ b/package.json
@@ -1,6 +1,6 @@
{
"name": "codemirror-colorpicker",
- "version": "1.9.10",
+ "version": "1.9.11",
"description": "colorpicker for codemirror",
"main": "./dist/codemirror-colorpicker.js",
"scripts": {
diff --git a/src/colorpicker/BaseColorPicker.js b/src/colorpicker/BaseColorPicker.js
new file mode 100644
index 0000000..b69ed4a
--- /dev/null
+++ b/src/colorpicker/BaseColorPicker.js
@@ -0,0 +1,296 @@
+import Color from '../util/Color'
+import Dom from '../util/Dom'
+import EventMachin from '../util/EventMachin'
+import ColorSetsList from './ColorSetsList'
+
+
+export default class BaseColorPicker extends EventMachin {
+ constructor(opt) {
+ super();
+
+ this.opt = opt || {};
+ this.$body = null;
+ this.$root = null;
+
+ this.format = 'rgb';
+ this.currentA = 0;
+ this.currentH = 0;
+ this.currentS = 0;
+ this.currentV = 0;
+
+ this.colorSetsList = new ColorSetsList(this);
+ this.colorpickerCallback = function () { };
+
+ this.isColorPickerShow = false;
+ this.isShortCut = false;
+ this.hideDelay = this.opt.hideDeplay || 2000;
+ this.timerCloseColorPicker;
+ this.autoHide = this.opt.autoHide || true;
+
+ }
+
+ initialize () {
+
+ this.$body = new Dom(this.getContainer());
+ this.$root = new Dom('div', 'codemirror-colorpicker');
+
+ // append colorpicker to container (ex : body)
+ if (this.opt.position == 'inline') {
+ this.$body.append(this.$root);
+ }
+
+ if (this.opt.type) { // to change css style
+ this.$root.addClass(this.opt.type);
+ }
+
+ this.$arrow = new Dom('div', 'arrow');
+
+ this.$root.append(this.$arrow);
+ }
+
+ getOption(key) {
+ return this.opt[key];
+ }
+
+ setOption (key, value) {
+ this.opt[key] = value;
+ }
+
+ isType (key) {
+ return this.getOption('type') == key;
+ }
+
+ isPaletteType() {
+ return this.isType('palette');
+ }
+
+ isSketchType() {
+ return this.isType('sketch');
+ }
+
+ getContainer () {
+ return this.opt.container || document.body;
+ }
+
+ getColor(type) {
+ this.caculateHSV();
+ var rgb = this.convertRGB();
+
+ if (type) {
+ return Color.format(rgb, type);
+ }
+
+ return rgb;
+ }
+
+ definePositionForArrow(opt, elementScreenLeft, elementScreenTop) {
+ //this.$arrow.css({})
+ }
+
+ definePosition(opt) {
+
+ var width = this.$root.width();
+ var height = this.$root.height();
+
+ // set left position for color picker
+ var elementScreenLeft = opt.left - this.$body.scrollLeft();
+ if (width + elementScreenLeft > window.innerWidth) {
+ elementScreenLeft -= (width + elementScreenLeft) - window.innerWidth;
+ }
+ if (elementScreenLeft < 0) { elementScreenLeft = 0; }
+
+ // set top position for color picker
+ var elementScreenTop = opt.top - this.$body.scrollTop();
+ if (height + elementScreenTop > window.innerHeight) {
+ elementScreenTop -= (height + elementScreenTop) - window.innerHeight;
+ }
+ if (elementScreenTop < 0) { elementScreenTop = 0; }
+
+ // set position
+ this.$root.css({
+ left: (elementScreenLeft) + 'px',
+ top: (elementScreenTop) + 'px'
+ });
+ }
+
+ getInitalizePosition() {
+ if (this.opt.position == 'inline') {
+ return {
+ position: 'relative',
+ left: 'auto',
+ top: 'auto',
+ display: 'inline-block'
+ }
+ } else {
+ return {
+ position: 'fixed', // color picker has fixed position
+ left: '-10000px',
+ top: '-10000px'
+ }
+ }
+ }
+
+ show(opt, color, callback) {
+ this.destroy();
+ this.initializeEvent();
+ this.$root.appendTo(this.$body);
+
+ this.$root.css(this.getInitalizePosition()).show();
+
+ this.definePosition(opt);
+
+ this.isColorPickerShow = true;
+
+ this.isShortCut = opt.isShortCut || false;
+
+ this.initColor(color);
+
+ // define colorpicker callback
+ this.colorpickerCallback = callback;
+
+ // define hide delay
+ this.hideDelay = opt.hideDelay || 2000;
+ if (this.hideDelay > 0) {
+ this.setHideDelay(this.hideDelay);
+ }
+
+ }
+
+ setHideDelay(delayTime) {
+ delayTime = delayTime || 0;
+
+ this.$root.off('mouseenter');
+ this.$root.off('mouseleave');
+
+ this.$root.on('mouseenter', () => {
+ clearTimeout(this.timerCloseColorPicker);
+ });
+
+ this.$root.on('mouseleave', () => {
+ clearTimeout(this.timerCloseColorPicker);
+ this.timerCloseColorPicker = setTimeout(this.hide.bind(this), delayTime);
+ });
+
+ clearTimeout(this.timerCloseColorPicker);
+ this.timerCloseColorPicker = setTimeout(this.hide.bind(this), delayTime);
+ }
+
+ hide() {
+ if (this.isColorPickerShow) {
+ this.destroy();
+ this.$root.hide();
+ this.$root.remove(); // not empty
+ this.isColorPickerShow = false;
+ }
+ }
+
+ convertRGB() {
+ return Color.HSVtoRGB(this.currentH, this.currentS, this.currentV);
+ }
+
+ convertHEX() {
+ return Color.format(this.convertRGB(), 'hex');
+ }
+
+ convertHSL() {
+ return Color.HSVtoHSL(this.currentH, this.currentS, this.currentV);
+ }
+
+
+ getFormattedColor(format) {
+ format = format || 'hex';
+
+ if (format == 'rgb') {
+ var rgb = this.convertRGB();
+ rgb.a = this.currentA;
+ return Color.format(rgb, 'rgb');
+ } else if (format == 'hsl') {
+ var hsl = this.convertHSL();
+ hsl.a = this.currentA;
+ return Color.format(hsl, 'hsl');
+ } else {
+ var rgb = this.convertRGB();
+ return Color.format(rgb, 'hex');
+ }
+ }
+
+
+ callbackColorValue(color) {
+
+ if (!isNaN(this.currentA)) {
+ if (typeof this.opt.onChange == 'function') {
+ this.opt.onChange.call(this, color);
+ }
+
+ if (typeof this.colorpickerCallback == 'function') {
+ this.colorpickerCallback(color);
+ }
+
+ }
+ }
+
+ setCurrentHSV(h, s, v, a) {
+ this.currentA = a;
+ this.currentH = h;
+ this.currentS = s ;
+ this.currentV = v;
+ }
+
+ setCurrentH(h) {
+ this.currentH = h;
+ }
+
+ setCurrentA(a) {
+ this.currentA = a;
+ }
+
+
+ getHSV(colorObj) {
+ if (colorObj.type == 'hsl') {
+ return Color.HSLtoHSV(colorObj);
+ } else {
+ return Color.RGBtoHSV(colorObj);
+ }
+
+ }
+
+ initColor(newColor, format) {
+ let c = newColor || "#FF0000", colorObj = Color.parse(c);
+ format = format || colorObj.type;
+
+ let hsv = this.getHSV(colorObj);
+ this.setCurrentHSV(hsv.h, hsv.s, hsv.v, colorObj.a);
+ }
+
+ checkColorPickerClass(el) {
+ var hasColorView = new Dom(el).closest('codemirror-colorview');
+ var hasColorPicker = new Dom(el).closest('codemirror-colorpicker');
+ var hasCodeMirror = new Dom(el).closest('CodeMirror');
+ var IsInHtml = el.nodeName == 'HTML';
+
+ return !!(hasColorPicker || hasColorView || hasCodeMirror);
+ }
+
+ checkInHtml(el) {
+ var IsInHtml = el.nodeName == 'HTML';
+
+ return IsInHtml;
+ }
+
+ initializeEvent() {
+
+ this.initializeEventMachin();
+
+ }
+
+ setColorSets(list) {
+ this.colorSetsList.setUserList(list);
+ }
+
+ destroy() {
+ super.destroy();
+
+ // remove color picker callback
+ this.colorpickerCallback = undefined;
+ }
+}
\ No newline at end of file
diff --git a/src/colorpicker/ColorControl.js b/src/colorpicker/chromedevtool/ColorControl.js
similarity index 57%
rename from src/colorpicker/ColorControl.js
rename to src/colorpicker/chromedevtool/ColorControl.js
index c2398a3..8dc7bd1 100644
--- a/src/colorpicker/ColorControl.js
+++ b/src/colorpicker/chromedevtool/ColorControl.js
@@ -1,10 +1,9 @@
-import Color from '../util/Color'
-import HueColor from '../util/HueColor'
-import Dom from '../util/Dom'
-import Event from '../util/Event'
-import EventMachin from '../util/EventMachin'
-
+import Color from '../../util/Color'
+import HueColor from '../../util/HueColor'
+import Dom from '../../util/Dom'
+import Event from '../../util/Event'
+import EventMachin from '../../util/EventMachin'
export default class ColorControl extends EventMachin {
constructor (colorpicker) {
@@ -14,42 +13,36 @@ export default class ColorControl extends EventMachin {
}
initialize () {
- this.$el = new Dom('div', 'control' );
- this.$hue = this.$el.createChild('div', 'hue' );
- this.$opacity = this.$el.createChild('div', 'opacity' );
- this.$controlPattern = this.$el.createChild('div', 'empty' );
- this.$controlColor = this.$el.createChild('div', 'color' );
-
- this.$hueContainer = this.$hue.createChild('div', 'hue-container' );
- this.$drag_bar = this.$hueContainer.createChild('div', 'drag-bar');
- this.drag_bar_pos = {}
+ this.template(`
+
+ `)
- this.$opacityContainer = this.$opacity.createChild('div', 'opacity-container' );
- this.$opacityColorBar = this.$opacityContainer.createChild('div', 'color-bar' );
-
- this.$opacity_drag_bar = this.$opacityContainer.createChild('div', 'drag-bar2' );
+ this.drag_bar_pos = {}
this.opacity_drag_bar_pos = {}
}
setBackgroundColor (color) {
- this.$controlColor.css("background-color", color);
+ this.refs.$controlColor.css("background-color", color);
}
refresh () {
this.setColorUI();
}
- setColorUI() {
-
- var x = this.state.get('$el.width') * this.colorpicker.currentS,
- y = this.state.get('$el.height') * ( 1 - this.colorpicker.currentV );
-
- this.$drag_pointer.css({
- left : (x) + "px",
- top : (y) + "px"
- });
- }
-
setOpacityColorBar(hueColor) {
var rgb = Color.parse(hueColor);
@@ -60,27 +53,32 @@ export default class ColorControl extends EventMachin {
var end = Color.format(rgb, 'rgb');
var prefix = cssPrefix;
- this.$opacityColorBar.css('background', 'linear-gradient(to right, ' + start + ', ' + end + ')');
+ this.refs.$opacityColorBar.css('background', 'linear-gradient(to right, ' + start + ', ' + end + ')');
}
setOpacity(e) {
- var min = this.$opacityContainer.offset().left;
+ var min = this.refs.$opacityContainer.offset().left;
var max = min + this.state.get('$opacityContainer.width');
var current = Event.pos(e).clientX;
var dist;
+ var dist;
if (current < min) {
dist = 0;
+ this.refs.$opacity_drag_bar.addClass('first').removeClass('last')
} else if (current > max) {
dist = 100;
+ this.refs.$opacity_drag_bar.addClass('last').removeClass('first')
} else {
dist = (current - min) / (max - min) * 100;
- }
+ this.refs.$opacity_drag_bar.removeClass('first').removeClass('last')
+ }
var x = (this.state.get('$opacityContainer.width') * (dist/100));
- this.$opacity_drag_bar.css({
- left: (x -Math.ceil(this.state.get('$opacity_drag_bar.width')/2)) + 'px'
+ this.refs.$opacity_drag_bar.css({
+ // left: (x -Math.ceil(this.state.get('$opacity_drag_bar.width')/2)) + 'px'
+ left: (x) + 'px'
});
this.opacity_drag_bar_pos = { x };
@@ -100,18 +98,20 @@ export default class ColorControl extends EventMachin {
setColorUI() {
- var hueX = this.state.get('$hueContainer.width') * (this.colorpicker.currentH / 360);
-
- this.$drag_bar.css({
- left : (hueX - 7.5) + 'px'
+ var hueX = this.state.get('$hueContainer.width') * (this.colorpicker.currentH / 360);
+
+ this.refs.$drag_bar.css({
+ // left : (hueX - 7.5) + 'px'
+ left : (hueX) + 'px'
});
this.drag_bar_pos = { x : hueX };
var opacityX = this.state.get('$opacityContainer.width') * (this.colorpicker.currentA || 0);
- this.$opacity_drag_bar.css({
- left : (opacityX - 7.5) + 'px'
+ this.refs.$opacity_drag_bar.css({
+ // left : (opacityX - 7.5) + 'px'
+ left : (opacityX) + 'px'
});
this.opacity_drag_bar_pos = { x : opacityX };
@@ -151,28 +151,32 @@ export default class ColorControl extends EventMachin {
}
setControlColor (color) {
- this.$controlColor.css('background-color', color);
+ this.refs.$controlColor.css('background-color', color);
}
- setHueColor(e) {
- var min = this.$hueContainer.offset().left;
+ setHueColor(e, isOnlyHue) {
+ var min = this.refs.$hueContainer.offset().left;
var max = min + this.state.get('$hueContainer.width');
var current = e ? Event.pos(e).clientX : min + (max - min) * (this.colorpicker.currentH / 360);
var dist;
if (current < min) {
dist = 0;
+ this.refs.$drag_bar.addClass('first').removeClass('last')
} else if (current > max) {
dist = 100;
+ this.refs.$drag_bar.addClass('last').removeClass('first')
} else {
dist = (current - min) / (max - min) * 100;
+ this.refs.$drag_bar.removeClass('first').removeClass('last')
}
var x = (this.state.get('$hueContainer.width') * (dist/100));
- this.$drag_bar.css({
- left: (x -Math.ceil(this.state.get('$drag_bar.width')/2)) + 'px'
+ this.refs.$drag_bar.css({
+ // left: (x -Math.ceil(this.state.get('$drag_bar.width')/2)) + 'px'
+ left: (x) + 'px'
});
this.drag_bar_pos = { x };
@@ -181,34 +185,15 @@ export default class ColorControl extends EventMachin {
this.colorpicker.setBackgroundColor(hueColor);
this.colorpicker.setCurrentH((dist/100) * 360);
- this.colorpicker.setInputColor();
+
+ if (!isOnlyHue) {
+ this.colorpicker.setInputColor();
+ }
+
}
setOnlyHueColor() {
- var min = this.$hueContainer.offset().left;
- var max = min + this.state.get('$hueContainer.width');
- var current = min + (max - min) * (this.colorpicker.currentH / 360);
-
- var dist;
- if (current < min) {
- dist = 0;
- } else if (current > max) {
- dist = 100;
- } else {
- dist = (current - min) / (max - min) * 100;
- }
-
- var x = (this.state.get('$hueContainer.width') * (dist/100));
-
- this.$drag_bar.css({
- left: (x -Math.ceil(this.state.get('$drag_bar.width')/2)) + 'px'
- });
-
- this.drag_bar_pos = { x };
-
- var hueColor = HueColor.checkHueColor(dist/100);
- this.colorpicker.setBackgroundColor(hueColor);
- this.colorpicker.setCurrentH((dist/100) * 360);
+ this.setHueColor(null, true)
}
'mousedown $drag_bar' (e) {
diff --git a/src/colorpicker/ColorInformation.js b/src/colorpicker/chromedevtool/ColorInformation.js
similarity index 51%
rename from src/colorpicker/ColorInformation.js
rename to src/colorpicker/chromedevtool/ColorInformation.js
index b7e4f1c..de5d767 100644
--- a/src/colorpicker/ColorInformation.js
+++ b/src/colorpicker/chromedevtool/ColorInformation.js
@@ -1,7 +1,7 @@
-import Color from '../util/Color'
-import Dom from '../util/Dom'
-import Event from '../util/Event'
-import EventMachin from '../util/EventMachin'
+import Color from '../../util/Color'
+import Dom from '../../util/Dom'
+import Event from '../../util/Event'
+import EventMachin from '../../util/EventMachin'
export default class ColorInformation extends EventMachin {
@@ -14,79 +14,62 @@ export default class ColorInformation extends EventMachin {
}
initialize () {
- this.$el = new Dom('div', 'information hex' );
- this.$informationChange = this.$el.createChild('div', 'information-change');
-
- this.$formatChangeButton = this.$informationChange.createChild('button', 'format-change-button arrow-button', { type : 'button'});
-
- this.$el.append(this.makeInputFieldHex());
- this.$el.append(this.makeInputFieldRgb());
- this.$el.append(this.makeInputFieldHsl());
+ this.template(`
+
+ `)
this.format = 'hex';
}
-
- makeInputFieldHex () {
- var item = new Dom('div', 'information-item hex');
- var field = item.createChild('div', 'input-field hex');
-
- this.$hexCode = field.createChild('input', 'input', { type : 'text' });
-
- field.createChild('div', 'title').html('HEX');
-
- return item;
- }
-
- makeInputFieldRgb () {
- var item = new Dom('div', 'information-item rgb');
-
- var field = item.createChild('div', 'input-field rgb-r');
- this.$rgb_r = field.createChild('input', 'input', { type : 'number', step : 1, min : 0, max : 255 });
- field.createChild('div', 'title').html('R');
-
- field = item.createChild('div', 'input-field rgb-g');
- this.$rgb_g = field.createChild('input', 'input', { type : 'number', step : 1, min : 0, max : 255 });
- field.createChild('div', 'title').html('G');
-
- field = item.createChild('div', 'input-field rgb-b');
- this.$rgb_b = field.createChild('input', 'input', { type : 'number', step : 1, min : 0, max : 255 });
- field.createChild('div', 'title').html('B');
-
- // rgba
- field = item.createChild('div', 'input-field rgb-a');
- this.$rgb_a = field.createChild('input', 'input', { type : 'number', step : 0.01, min : 0, max : 1 });
- field.createChild('div', 'title').html('A');
-
- return item;
- }
-
- makeInputFieldHsl () {
- var item = new Dom('div', 'information-item hsl');
-
- var field = item.createChild('div', 'input-field hsl-h');
- this.$hsl_h = field.createChild('input', 'input', { type : 'number', step : 1, min : 0, max : 360 });
- field.createChild('div', 'title').html('H');
-
- field = item.createChild('div', 'input-field hsl-s');
- this.$hsl_s = field.createChild('input', 'input', { type : 'number', step: 1, min: 0, max : 100 });
- field.createChild('div', 'postfix').html('%');
- field.createChild('div', 'title').html('S');
-
- field = item.createChild('div', 'input-field hsl-l');
- this.$hsl_l = field.createChild('input', 'input', { type : 'number', step: 1, min: 0, max : 100 });
- field.createChild('div', 'postfix').html('%');
- field.createChild('div', 'title').html('L');
-
- // rgba
- field = item.createChild('div', 'input-field hsl-a');
- this.$hsl_a = field.createChild('input', 'input', { type : 'number', step : 0.01, min : 0, max : 1 });
- field.createChild('div', 'title').html('A');
-
- return item;
- }
-
currentFormat () {
var current_format = this.format || 'hex';
if (this.colorpicker.currentA < 1 && current_format == 'hex' ) {
@@ -140,42 +123,42 @@ export default class ColorInformation extends EventMachin {
setRGBInput(r, g, b) {
- this.$rgb_r.val(r);
- this.$rgb_g.val(g);
- this.$rgb_b.val(b);
- this.$rgb_a.val(this.colorpicker.currentA);
+ this.refs.$rgb_r.val(r);
+ this.refs.$rgb_g.val(g);
+ this.refs.$rgb_b.val(b);
+ this.refs.$rgb_a.val(this.colorpicker.currentA);
}
setHSLInput(h, s, l) {
- this.$hsl_h.val(h);
- this.$hsl_s.val(s);
- this.$hsl_l.val(l);
- this.$hsl_a.val(this.colorpicker.currentA);
+ this.refs.$hsl_h.val(h);
+ this.refs.$hsl_s.val(s);
+ this.refs.$hsl_l.val(l);
+ this.refs.$hsl_a.val(this.colorpicker.currentA);
}
getHexFormat() {
return Color.format({
- r : this.$rgb_r.int(),
- g : this.$rgb_g.int(),
- b : this.$rgb_b.int()
+ r : this.refs.$rgb_r.int(),
+ g : this.refs.$rgb_g.int(),
+ b : this.refs.$rgb_b.int()
}, 'hex', this.colorpicker.opt.color);
}
getRgbFormat() {
return Color.format({
- r : this.$rgb_r.int(),
- g : this.$rgb_g.int(),
- b : this.$rgb_b.int(),
- a : this.$rgb_a.float()
+ r : this.refs.$rgb_r.int(),
+ g : this.refs.$rgb_g.int(),
+ b : this.refs.$rgb_b.int(),
+ a : this.refs.$rgb_a.float()
}, 'rgb', this.colorpicker.opt.color);
}
getHslFormat() {
return Color.format({
- h : this.$hsl_h.val(),
- s : this.$hsl_s.val(),
- l : this.$hsl_l.val(),
- a : this.$hsl_a.float()
+ h : this.refs.$hsl_h.val(),
+ s : this.refs.$hsl_s.val(),
+ l : this.refs.$hsl_l.val(),
+ a : this.refs.$hsl_a.float()
}, 'hsl', this.colorpicker.opt.color);
}
@@ -195,7 +178,7 @@ export default class ColorInformation extends EventMachin {
getFormattedColor (format, fixed = false) {
format = format || this.getFormat();
if (format == 'hex') {
- return this.$hexCode.val();
+ return this.refs.$hexCode.val();
} else if (format == 'rgb') {
return this.getRgbFormat(fixed);
} else if (format == 'hsl') {
@@ -212,13 +195,13 @@ export default class ColorInformation extends EventMachin {
var rgb = null;
if (format == 'hex') {
- this.$hexCode.val(this.convertHEX());
+ this.refs.$hexCode.val(this.convertHEX());
var rgb = this.convertRGB();
this.setRGBInput(rgb.r, rgb.g, rgb.b, rgb.a);
} else if (format == 'rgb') {
var rgb = this.convertRGB();
this.setRGBInput(rgb.r, rgb.g, rgb.b, rgb.a);
- this.$hexCode.val(this.convertHEX());
+ this.refs.$hexCode.val(this.convertHEX());
} else if (format == 'hsl') {
var hsl = this.convertHSL();
this.setHSLInput(hsl.h, hsl.s, hsl.l, hsl.a);
@@ -234,14 +217,6 @@ export default class ColorInformation extends EventMachin {
return !Event.checkNumberKey(e);
}
- //'keydown.checkNotNumberKey $rgb_r' (e) { e.preventDefault(); }
- //'keydown.checkNotNumberKey $rgb_g' (e) { e.preventDefault(); }
- //'keydown.checkNotNumberKey $rgb_b' (e) { e.preventDefault(); }
-
- //'keydown.checkNumberKey $rgb_r' (e) { this.setRGBtoHexColor(e); }
- //'keydown.checkNumberKey $rgb_g' (e) { this.setRGBtoHexColor(e); }
- //'keydown.checkNumberKey $rgb_b' (e) { this.setRGBtoHexColor(e); }
-
changeRgbColor () {
this.colorpicker.changeInformationColor(this.getRgbFormat());
}
@@ -267,7 +242,7 @@ export default class ColorInformation extends EventMachin {
}
'keyup $hexCode' (e) {
- var code = this.$hexCode.val();
+ var code = this.refs.$hexCode.val();
if(code.charAt(0) == '#' && code.length == 7) {
this.colorpicker.changeInformationColor(code);
diff --git a/src/colorpicker/ColorPalette.js b/src/colorpicker/chromedevtool/ColorPalette.js
similarity index 79%
rename from src/colorpicker/ColorPalette.js
rename to src/colorpicker/chromedevtool/ColorPalette.js
index 2394b2f..48927d3 100644
--- a/src/colorpicker/ColorPalette.js
+++ b/src/colorpicker/chromedevtool/ColorPalette.js
@@ -1,7 +1,6 @@
-import Color from '../util/Color'
-import Dom from '../util/Dom'
-import Event from '../util/Event'
-import EventMachin from '../util/EventMachin'
+
+import Dom from '../../util/Dom'
+import EventMachin from '../../util/EventMachin'
export default class ColorPallet extends EventMachin {
constructor (colorpicker) {
@@ -12,10 +11,16 @@ export default class ColorPallet extends EventMachin {
}
initialize () {
- this.$el = new Dom('div', 'color');
- this.$saturation = this.$el.createChild('div', 'saturation' );
- this.$value = this.$saturation.createChild('div', 'value' );
- this.$drag_pointer = this.$value.createChild('div', 'drag-pointer' );
+
+ this.template(`
+
+ `)
}
setBackgroundColor (color) {
@@ -41,7 +46,7 @@ export default class ColorPallet extends EventMachin {
setColorUI() {
var x = this.state.get('$el.width') * this.colorpicker.currentS, y = this.state.get('$el.height') * ( 1 - this.colorpicker.currentV );
- this.$drag_pointer.css({
+ this.refs.$drag_pointer.css({
left : (x - 5) + "px",
top : (y - 5) + "px"
});
@@ -65,7 +70,7 @@ export default class ColorPallet extends EventMachin {
if (y < 0) y = 0;
else if (y > h) y = h;
- this.$drag_pointer.css({
+ this.refs.$drag_pointer.css({
left: (x - 5) + 'px',
top: (y - 5) + 'px'
});
diff --git a/src/colorpicker/ColorSetsChooser.js b/src/colorpicker/chromedevtool/ColorSetsChooser.js
similarity index 74%
rename from src/colorpicker/ColorSetsChooser.js
rename to src/colorpicker/chromedevtool/ColorSetsChooser.js
index 8fc0325..c103f47 100644
--- a/src/colorpicker/ColorSetsChooser.js
+++ b/src/colorpicker/chromedevtool/ColorSetsChooser.js
@@ -1,7 +1,5 @@
-import Color from '../util/Color'
-import Dom from '../util/Dom'
-import Event from '../util/Event'
-import EventMachin from '../util/EventMachin'
+import Dom from '../../util/Dom'
+import EventMachin from '../../util/EventMachin'
const DATA_COLORSETS_INDEX = 'data-colorsets-index';
@@ -15,27 +13,28 @@ export default class ColorSetsChooser extends EventMachin {
}
initialize () {
- // make colorset-chooser
- this.$el = new Dom('div', 'color-chooser' );
- const $container = this.$el.createChild('div', 'color-chooser-container');
-
- const $header = $container.createChild('div', 'colorsets-item colorsets-item-header');
-
- $header.createChild('h1', 'title').html('Color Paletts')
-
- this.$toggleButton = $header.createChild('span', 'items').html('×');
-
- this.$colorsetsList = $container.createChild('div', 'colorsets-list' );
+ this.template(`
+
+ `)
this.refresh();
}
refresh () {
- this.$colorsetsList.html(this.makeColorSetsList());
+ this.refs.$colorsetsList.html(this.makeColorSetsList());
}
makeColorItemList (colors, maxCount = 5) {
+
var $list = new Dom('div');
for(var i = 0; i < maxCount; i++) {
diff --git a/src/colorpicker/CurrentColorSets.js b/src/colorpicker/chromedevtool/CurrentColorSets.js
similarity index 80%
rename from src/colorpicker/CurrentColorSets.js
rename to src/colorpicker/chromedevtool/CurrentColorSets.js
index fa93957..10557e3 100644
--- a/src/colorpicker/CurrentColorSets.js
+++ b/src/colorpicker/chromedevtool/CurrentColorSets.js
@@ -1,7 +1,5 @@
-import Color from '../util/Color'
-import Dom from '../util/Dom'
-import Event from '../util/Event'
-import EventMachin from '../util/EventMachin'
+import Dom from '../../util/Dom'
+import EventMachin from '../../util/EventMachin'
export default class CurrentColorSets extends EventMachin {
constructor (colorpicker) {
@@ -43,23 +41,21 @@ export default class CurrentColorSets extends EventMachin {
}
initialize () {
- // make colorsets view
- this.$el = new Dom('div', 'colorsets' );
- const $colorSetsMenu = this.$el.createChild('div', 'menu', {
- title: 'Open Color Pallets'
- });
- this.$colorSetsColorList = this.$el.createChild('div', 'color-list' );
-
- this.$colorSetsChooseButton = $colorSetsMenu.createChild('button', 'color-sets-choose-btn arrow-button', {
- type : 'button'
- });
+ this.template(`
+
+ `)
this.refresh();
}
refresh () {
- this.$colorSetsColorList.html(this.makeCurrentColorSets())
+ this.refs.$colorSetsColorList.html(this.makeCurrentColorSets())
}
refreshAll () {
diff --git a/src/colorpicker/CurrentColorSetsContextMenu.js b/src/colorpicker/chromedevtool/CurrentColorSetsContextMenu.js
similarity index 67%
rename from src/colorpicker/CurrentColorSetsContextMenu.js
rename to src/colorpicker/chromedevtool/CurrentColorSetsContextMenu.js
index 7006ff2..9d05da1 100644
--- a/src/colorpicker/CurrentColorSetsContextMenu.js
+++ b/src/colorpicker/chromedevtool/CurrentColorSetsContextMenu.js
@@ -1,7 +1,6 @@
-import Color from '../util/Color'
-import Dom from '../util/Dom'
-import Event from '../util/Event'
-import EventMachin from '../util/EventMachin'
+import Dom from '../../util/Dom'
+import Event from '../../util/Event'
+import EventMachin from '../../util/EventMachin'
export default class CurrentColorSetsContextMenu extends EventMachin {
constructor (colorpicker) {
@@ -14,21 +13,14 @@ export default class CurrentColorSetsContextMenu extends EventMachin {
}
initialize () {
- // make colorsets view
- this.$el = new Dom('ul', 'colorsets-contextmenu' );
-
- this.$el.createChild('li', 'menu-item small-hide', {
- 'data-type' : 'remove-color'
- }).html('Remove color')
-
- this.$el.createChild('li', 'menu-item small-hide', {
- 'data-type' : 'remove-all-to-the-right'
- }).html('Remove all to the right')
-
- this.$el.createChild('li', 'menu-item', {
- 'data-type' : 'clear-palette'
- }).html('Clear palette')
+ this.template(`
+
+ `)
}
show (e, index) {
diff --git a/src/colorpicker/chromedevtool/index.js b/src/colorpicker/chromedevtool/index.js
new file mode 100644
index 0000000..179717f
--- /dev/null
+++ b/src/colorpicker/chromedevtool/index.js
@@ -0,0 +1,408 @@
+import Color from '../../util/Color'
+import Dom from '../../util/Dom'
+
+import BaseColorPicker from '../BaseColorPicker'
+
+import ColorControl from './ColorControl'
+import ColorInformation from './ColorInformation'
+import ColorPalette from './ColorPalette'
+import ColorSetsChooser from './ColorSetsChooser'
+import CurrentColorSets from './CurrentColorSets'
+import CurrentColorSetsContextMenu from './CurrentColorSetsContextMenu'
+
+export default class ColorPicker extends BaseColorPicker {
+ constructor(opt) {
+ super(opt);
+
+ this.control = new ColorControl(this);
+ this.palette = new ColorPalette(this);
+ this.information = new ColorInformation(this);
+ this.colorSetsChooser = new ColorSetsChooser(this);
+ this.currentColorSets = new CurrentColorSets(this);
+ this.contextMenu = new CurrentColorSetsContextMenu(this, this.currentColorSets);
+
+ this.initialize();
+ }
+
+ initialize() {
+ super.initialize()
+
+ this.$root.append(this.palette.$el);
+ this.$root.append(this.control.$el);
+ this.$root.append(this.information.$el);
+ this.$root.append(this.currentColorSets.$el);
+ this.$root.append(this.colorSetsChooser.$el);
+ this.$root.append(this.contextMenu.$el);
+
+ this.$checkColorPickerClass = this.checkColorPickerClass.bind(this);
+
+ this.initColor(this.opt.color);
+
+ // register all events
+ this.initializeEvent();
+ }
+
+ showContextMenu(e, index) {
+ this.contextMenu.show(e, index);
+ }
+
+ setColor(value, isDirect = false) {
+
+ if (typeof (value) == "object") {
+ if (!value.r || !value.g || !value.b)
+ return;
+
+ if (isDirect) {
+ this.callbackColorValue(Color.format(value, "hex"));
+ } else {
+ this.initColor(Color.format(value, "hex"));
+ }
+
+ } else if (typeof (value) == "string") {
+
+ if (isDirect) {
+ this.callbackColorValue(value);
+ } else {
+ this.initColor(value);
+ }
+
+
+
+ }
+ }
+
+ getColor(type) {
+ this.caculateHSV();
+ var rgb = this.convertRGB();
+
+ if (type) {
+ return Color.format(rgb, type);
+ }
+
+ return rgb;
+ }
+
+ definePositionForArrow(opt, elementScreenLeft, elementScreenTop) {
+ //this.$arrow.css({})
+ }
+
+ definePosition(opt) {
+
+ var width = this.$root.width();
+ var height = this.$root.height();
+
+ // set left position for color picker
+ var elementScreenLeft = opt.left - this.$body.scrollLeft();
+ if (width + elementScreenLeft > window.innerWidth) {
+ elementScreenLeft -= (width + elementScreenLeft) - window.innerWidth;
+ }
+ if (elementScreenLeft < 0) { elementScreenLeft = 0; }
+
+ // set top position for color picker
+ var elementScreenTop = opt.top - this.$body.scrollTop();
+ if (height + elementScreenTop > window.innerHeight) {
+ elementScreenTop -= (height + elementScreenTop) - window.innerHeight;
+ }
+ if (elementScreenTop < 0) { elementScreenTop = 0; }
+
+ // set position
+ this.$root.css({
+ left: (elementScreenLeft) + 'px',
+ top: (elementScreenTop) + 'px'
+ });
+ }
+
+ getInitalizePosition() {
+ if (this.opt.position == 'inline') {
+ return {
+ position: 'relative',
+ left: 'auto',
+ top: 'auto',
+ display: 'inline-block'
+ }
+ } else {
+ return {
+ position: 'fixed', // color picker has fixed position
+ left: '-10000px',
+ top: '-10000px'
+ }
+ }
+ }
+
+ show(opt, color, callback) {
+ this.destroy();
+ this.initializeEvent();
+ this.$root.appendTo(this.$body);
+
+ this.$root.css(this.getInitalizePosition()).show();
+
+ this.definePosition(opt);
+
+ this.isColorPickerShow = true;
+
+ this.isShortCut = opt.isShortCut || false;
+
+ this.initColor(color);
+
+ // define colorpicker callback
+ this.colorpickerCallback = callback;
+
+ // define hide delay
+ this.hideDelay = opt.hideDelay || 2000;
+ if (this.hideDelay > 0) {
+ this.setHideDelay(this.hideDelay);
+ }
+
+ }
+
+ setHideDelay(delayTime) {
+ delayTime = delayTime || 0;
+
+ this.$root.off('mouseenter');
+ this.$root.off('mouseleave');
+
+ this.$root.on('mouseenter', () => {
+ clearTimeout(this.timerCloseColorPicker);
+ });
+
+ this.$root.on('mouseleave', () => {
+ clearTimeout(this.timerCloseColorPicker);
+ this.timerCloseColorPicker = setTimeout(this.hide.bind(this), delayTime);
+ });
+
+ clearTimeout(this.timerCloseColorPicker);
+ this.timerCloseColorPicker = setTimeout(this.hide.bind(this), delayTime);
+ }
+
+ hide() {
+ if (this.isColorPickerShow) {
+ this.destroy();
+ this.$root.hide();
+ this.$root.remove(); // not empty
+ this.isColorPickerShow = false;
+ }
+ }
+
+ convertRGB() {
+ return Color.HSVtoRGB(this.currentH, this.currentS, this.currentV);
+ }
+
+ convertHEX() {
+ return Color.format(this.convertRGB(), 'hex');
+ }
+
+ convertHSL() {
+ return Color.HSVtoHSL(this.currentH, this.currentS, this.currentV);
+ }
+
+ getCurrentColor() {
+ return this.information.getFormattedColor();
+ }
+
+ getFormattedColor(format) {
+ format = format || 'hex';
+
+ if (format == 'rgb') {
+ var rgb = this.convertRGB();
+ rgb.a = this.currentA;
+ return Color.format(rgb, 'rgb');
+ } else if (format == 'hsl') {
+ var hsl = this.convertHSL();
+ hsl.a = this.currentA;
+ return Color.format(hsl, 'hsl');
+ } else {
+ var rgb = this.convertRGB();
+ return Color.format(rgb, 'hex');
+ }
+ }
+
+
+
+ setInputColor(isNoInputColor) {
+ this.information.setInputColor(isNoInputColor);
+ this.control.setInputColor(isNoInputColor);
+
+ this.callbackColorValue();
+ }
+
+ changeInputColorAfterNextFormat() {
+ this.control.setInputColor();
+
+ this.callbackColorValue();
+ }
+
+ callbackColorValue(color) {
+
+ color = color || this.getCurrentColor();
+
+
+ if (!isNaN(this.currentA)) {
+ if (typeof this.opt.onChange == 'function') {
+ this.opt.onChange.call(this, color);
+ }
+
+ if (typeof this.colorpickerCallback == 'function') {
+ this.colorpickerCallback(color);
+ }
+
+ }
+ }
+
+ caculateHSV() {
+
+ var obj = this.palette.caculateSV();
+ var control = this.control.caculateH();
+
+ var s = obj.s;
+ var v = obj.v;
+ var h = control.h;
+
+
+ if (obj.width == 0) {
+ h = 0;
+ s = 0;
+ v = 0;
+ }
+
+ this.currentH = h
+ this.currentS = s
+ this.currentV = v
+ }
+
+
+ setColorUI() {
+ this.control.setColorUI()
+ this.palette.setColorUI()
+ }
+
+ setCurrentHSV(h, s, v, a) {
+ this.currentA = a;
+ this.currentH = h;
+ this.currentS = s ;
+ this.currentV = v;
+ }
+
+
+ setCurrentH(h) {
+ this.currentH = h;
+ }
+
+ setCurrentA(a) {
+ this.currentA = a;
+ }
+
+ setBackgroundColor(color) {
+ this.palette.setBackgroundColor(color);
+ }
+
+ setCurrentFormat(format) {
+ this.format = format;
+ this.information.setCurrentFormat(format);
+ }
+
+ getHSV(colorObj) {
+ if (colorObj.type == 'hsl') {
+ return Color.HSLtoHSV(colorObj);
+ } else {
+ return Color.RGBtoHSV(colorObj);
+ }
+
+ }
+
+ initColor(newColor, format) {
+ let c = newColor || "#FF0000", colorObj = Color.parse(c);
+ format = format || colorObj.type;
+
+
+ this.setCurrentFormat(format);
+
+ let hsv = this.getHSV(colorObj);
+ this.setCurrentHSV(hsv.h, hsv.s, hsv.v, colorObj.a);
+ this.setColorUI();
+ this.setHueColor();
+ this.setInputColor();
+ }
+
+ changeInformationColor(newColor) {
+ let c = newColor || "#FF0000", colorObj = Color.parse(c);
+
+ let hsv = this.getHSV(colorObj);
+ this.setCurrentHSV(hsv.h, hsv.s, hsv.v, colorObj.a);
+ this.setColorUI();
+ this.setHueColor();
+ this.control.setInputColor();
+ this.callbackColorValue();
+ }
+
+ setHueColor() {
+ this.control.setOnlyHueColor();
+ }
+
+ // Event Bindings
+ 'mouseup document' (e) {
+ this.palette.EventDocumentMouseUp(e);
+ this.control.EventDocumentMouseUp(e);
+
+ // when color picker clicked in outside
+ if (this.checkInHtml(e.target)) {
+ //this.setHideDelay(hideDelay);
+ } else if (this.checkColorPickerClass(e.target) == false) {
+ this.hide();
+ }
+ }
+
+ 'mousemove document' (e) {
+ this.palette.EventDocumentMouseMove(e);
+ this.control.EventDocumentMouseMove(e);
+ }
+
+ initializeEvent() {
+
+ this.initializeEventMachin();
+
+ this.palette.initializeEvent();
+ this.control.initializeEvent();
+ this.information.initializeEvent()
+ this.currentColorSets.initializeEvent()
+ this.colorSetsChooser.initializeEvent();
+ this.contextMenu.initializeEvent();
+
+ }
+
+ currentFormat() {
+ this.information.currentFormat();
+ }
+
+ toggleColorChooser() {
+ this.colorSetsChooser.toggle();
+ }
+
+ refreshColorSetsChooser() {
+ this.colorSetsChooser.refresh();
+ }
+
+ getColorSetsList() {
+ return this.colorSetsList.getColorSetsList();
+ }
+
+ setCurrentColorSets(nameOrIndex) {
+ this.colorSetsList.setCurrentColorSets(nameOrIndex);
+ this.currentColorSets.refresh();
+ }
+
+ setColorSets(list) {
+ this.colorSetsList.setUserList(list);
+ }
+
+ destroy() {
+ super.destroy();
+
+ this.control.destroy();
+ this.palette.destroy();
+ this.information.destroy();
+ this.colorSetsChooser.destroy();
+ this.colorSetsList.destroy();
+ this.currentColorSets.destroy();
+ this.contextMenu.destroy();
+ }
+}
\ No newline at end of file
diff --git a/src/colorpicker/index.js b/src/colorpicker/index.js
index e791771..15baa0e 100644
--- a/src/colorpicker/index.js
+++ b/src/colorpicker/index.js
@@ -1,480 +1,14 @@
-import Color from '../util/Color'
-import Dom from '../util/Dom'
-import Event from '../util/Event'
-import EventMachin from '../util/EventMachin'
-
-import ColorControl from './ColorControl'
-import ColorInformation from './ColorInformation'
-import ColorPalette from './ColorPalette'
-import ColorSetsChooser from './ColorSetsChooser'
-import ColorSetsList from './ColorSetsList'
-import CurrentColorSets from './CurrentColorSets'
-import CurrentColorSetsContextMenu from './CurrentColorSetsContextMenu'
-
-export default class ColorPicker extends EventMachin {
- constructor(opt) {
- super();
-
- this.opt = opt || {};
- this.$body = null;
- this.$root = null;
-
- this.format = 'rgb';
- this.currentA = 0;
- this.currentH = 0;
- this.currentS = 0;
- this.currentV = 0;
-
- this.colorSetsList = new ColorSetsList(this);
- this.colorpickerCallback = function () { };
-
- this.isColorPickerShow = false;
- this.isShortCut = false;
- this.hideDelay = this.opt.hideDeplay || 2000;
- this.timerCloseColorPicker;
- this.autoHide = this.opt.autoHide || true;
-
- this.control = new ColorControl(this);
- this.palette = new ColorPalette(this);
- this.information = new ColorInformation(this);
- this.colorSetsChooser = new ColorSetsChooser(this);
- this.currentColorSets = new CurrentColorSets(this);
- this.contextMenu = new CurrentColorSetsContextMenu(this, this.currentColorSets);
-
- this.initialize();
- }
-
- getOption(key) {
- return this.opt[key];
- }
-
- isType (key) {
- return this.getOption('type') == key;
- }
-
- isPaletteType() {
- return this.isType('palette');
- }
-
- isSketchType() {
- return this.isType('sketch');
- }
-
- getContainer () {
- return this.opt.container || document.body;
- }
-
- initialize() {
- this.$body = new Dom(this.getContainer());
- this.$root = new Dom('div', 'codemirror-colorpicker');
-
- // append colorpicker to container (ex : body)
- if (this.opt.position == 'inline') {
- this.$body.append(this.$root);
- }
-
- if (this.opt.type) { // to change css style
- this.$root.addClass(this.opt.type);
- }
-
- this.$arrow = new Dom('div', 'arrow');
-
-
- this.$root.append(this.$arrow);
- this.$root.append(this.palette.$el);
- this.$root.append(this.control.$el);
- this.$root.append(this.information.$el);
- this.$root.append(this.currentColorSets.$el);
- this.$root.append(this.colorSetsChooser.$el);
- this.$root.append(this.contextMenu.$el);
-
- this.$checkColorPickerClass = this.checkColorPickerClass.bind(this);
-
- this.initColor(this.opt.color);
-
- // register all events
- this.initializeEvent();
- }
-
- showContextMenu(e, index) {
- this.contextMenu.show(e, index);
- }
-
- setColor(value, isDirect = false) {
-
- if (typeof (value) == "object") {
- if (!value.r || !value.g || !value.b)
- return;
-
- if (isDirect) {
- this.callbackColorValue(Color.format(value, "hex"));
- } else {
- this.initColor(Color.format(value, "hex"));
- }
-
- } else if (typeof (value) == "string") {
-
- if (isDirect) {
- this.callbackColorValue(value);
- } else {
- this.initColor(value);
- }
-
-
-
- }
- }
-
- getColor(type) {
- this.caculateHSV();
- var rgb = this.convertRGB();
-
- if (type) {
- return Color.format(rgb, type);
- }
-
- return rgb;
- }
-
- definePositionForArrow(opt, elementScreenLeft, elementScreenTop) {
- //this.$arrow.css({})
- }
-
- definePosition(opt) {
-
- var width = this.$root.width();
- var height = this.$root.height();
-
- // set left position for color picker
- var elementScreenLeft = opt.left - this.$body.scrollLeft();
- if (width + elementScreenLeft > window.innerWidth) {
- elementScreenLeft -= (width + elementScreenLeft) - window.innerWidth;
- }
- if (elementScreenLeft < 0) { elementScreenLeft = 0; }
-
- // set top position for color picker
- var elementScreenTop = opt.top - this.$body.scrollTop();
- if (height + elementScreenTop > window.innerHeight) {
- elementScreenTop -= (height + elementScreenTop) - window.innerHeight;
- }
- if (elementScreenTop < 0) { elementScreenTop = 0; }
-
- // set position
- this.$root.css({
- left: (elementScreenLeft) + 'px',
- top: (elementScreenTop) + 'px'
- });
- }
-
- getInitalizePosition() {
- if (this.opt.position == 'inline') {
- return {
- position: 'relative',
- left: 'auto',
- top: 'auto',
- display: 'inline-block'
- }
- } else {
- return {
- position: 'fixed', // color picker has fixed position
- left: '-10000px',
- top: '-10000px'
- }
- }
- }
-
- show(opt, color, callback) {
- this.destroy();
- this.initializeEvent();
- this.$root.appendTo(this.$body);
-
- this.$root.css(this.getInitalizePosition()).show();
-
- this.definePosition(opt);
-
- this.isColorPickerShow = true;
-
- this.isShortCut = opt.isShortCut || false;
-
- this.initColor(color);
-
- // define colorpicker callback
- this.colorpickerCallback = callback;
-
- // define hide delay
- this.hideDelay = opt.hideDelay || 2000;
- if (this.hideDelay > 0) {
- this.setHideDelay(this.hideDelay);
- }
-
- }
-
- setHideDelay(delayTime) {
- delayTime = delayTime || 0;
-
- this.$root.off('mouseenter');
- this.$root.off('mouseleave');
-
- this.$root.on('mouseenter', () => {
- clearTimeout(this.timerCloseColorPicker);
- });
-
- this.$root.on('mouseleave', () => {
- clearTimeout(this.timerCloseColorPicker);
- this.timerCloseColorPicker = setTimeout(this.hide.bind(this), delayTime);
- });
-
- clearTimeout(this.timerCloseColorPicker);
- this.timerCloseColorPicker = setTimeout(this.hide.bind(this), delayTime);
- }
-
- hide() {
- if (this.isColorPickerShow) {
- this.destroy();
- this.$root.hide();
- this.$root.remove(); // not empty
- this.isColorPickerShow = false;
- }
- }
-
- convertRGB() {
- return Color.HSVtoRGB(this.currentH, this.currentS, this.currentV);
- }
-
- convertHEX() {
- return Color.format(this.convertRGB(), 'hex');
- }
-
- convertHSL() {
- return Color.HSVtoHSL(this.currentH, this.currentS, this.currentV);
- }
-
- getCurrentColor() {
- return this.information.getFormattedColor();
- }
-
- getFormattedColor(format) {
- format = format || 'hex';
-
- if (format == 'rgb') {
- var rgb = this.convertRGB();
- rgb.a = this.currentA;
- return Color.format(rgb, 'rgb');
- } else if (format == 'hsl') {
- var hsl = this.convertHSL();
- hsl.a = this.currentA;
- return Color.format(hsl, 'hsl');
- } else {
- var rgb = this.convertRGB();
- return Color.format(rgb, 'hex');
- }
- }
-
-
-
- setInputColor(isNoInputColor) {
- this.information.setInputColor(isNoInputColor);
- this.control.setInputColor(isNoInputColor);
-
- this.callbackColorValue();
- }
-
- changeInputColorAfterNextFormat() {
- this.control.setInputColor();
-
- this.callbackColorValue();
- }
-
- callbackColorValue(color) {
-
- color = color || this.getCurrentColor();
-
-
- if (!isNaN(this.currentA)) {
- if (typeof this.opt.onChange == 'function') {
- this.opt.onChange.call(this, color);
- }
-
- if (typeof this.colorpickerCallback == 'function') {
- this.colorpickerCallback(color);
- }
-
- }
- }
-
- caculateHSV() {
-
- var obj = this.palette.caculateSV();
- var control = this.control.caculateH();
-
- var s = obj.s;
- var v = obj.v;
- var h = control.h;
-
-
- if (obj.width == 0) {
- h = 0;
- s = 0;
- v = 0;
- }
-
- this.currentH = h
- this.currentS = s
- this.currentV = v
- }
-
-
- setColorUI() {
- this.control.setColorUI()
- this.palette.setColorUI()
- }
-
- setCurrentHSV(h, s, v, a) {
- this.currentA = a;
- this.currentH = h;
- this.currentS = s ;
- this.currentV = v;
- }
-
-
- setCurrentH(h) {
- this.currentH = h;
- }
-
- setCurrentA(a) {
- this.currentA = a;
- }
-
- setBackgroundColor(color) {
- this.palette.setBackgroundColor(color);
- }
-
- setCurrentFormat(format) {
- this.format = format;
- this.information.setCurrentFormat(format);
- }
-
- getHSV(colorObj) {
- if (colorObj.type == 'hsl') {
- return Color.HSLtoHSV(colorObj);
- } else {
- return Color.RGBtoHSV(colorObj);
- }
-
- }
-
- initColor(newColor, format) {
- let c = newColor || "#FF0000", colorObj = Color.parse(c);
- format = format || colorObj.type;
-
-
- this.setCurrentFormat(format);
-
- let hsv = this.getHSV(colorObj);
- this.setCurrentHSV(hsv.h, hsv.s, hsv.v, colorObj.a);
- this.setColorUI();
- this.setHueColor();
- this.setInputColor();
- }
-
- changeInformationColor(newColor) {
- let c = newColor || "#FF0000", colorObj = Color.parse(c);
-
- let hsv = this.getHSV(colorObj);
- this.setCurrentHSV(hsv.h, hsv.s, hsv.v, colorObj.a);
- this.setColorUI();
- this.setHueColor();
- this.control.setInputColor();
- this.callbackColorValue();
- }
-
- setHueColor() {
- this.control.setOnlyHueColor();
- }
-
- checkColorPickerClass(el) {
- var hasColorView = new Dom(el).closest('codemirror-colorview');
- var hasColorPicker = new Dom(el).closest('codemirror-colorpicker');
- var hasCodeMirror = new Dom(el).closest('CodeMirror');
- var IsInHtml = el.nodeName == 'HTML';
-
- return !!(hasColorPicker || hasColorView || hasCodeMirror);
- }
-
- checkInHtml(el) {
- var IsInHtml = el.nodeName == 'HTML';
-
- return IsInHtml;
- }
-
- // Event Bindings
- 'mouseup document' (e) {
- this.palette.EventDocumentMouseUp(e);
- this.control.EventDocumentMouseUp(e);
-
- // when color picker clicked in outside
- if (this.checkInHtml(e.target)) {
- //this.setHideDelay(hideDelay);
- } else if (this.checkColorPickerClass(e.target) == false) {
- this.hide();
- }
- }
-
- 'mousemove document' (e) {
- this.palette.EventDocumentMouseMove(e);
- this.control.EventDocumentMouseMove(e);
- }
-
- initializeEvent() {
-
- this.initializeEventMachin();
-
- this.palette.initializeEvent();
- this.control.initializeEvent();
- this.information.initializeEvent()
- this.currentColorSets.initializeEvent()
- this.colorSetsChooser.initializeEvent();
- this.contextMenu.initializeEvent();
-
- }
-
- currentFormat() {
- this.information.currentFormat();
- }
-
- toggleColorChooser() {
- this.colorSetsChooser.toggle();
- }
-
- refreshColorSetsChooser() {
- this.colorSetsChooser.refresh();
- }
-
- getColorSetsList() {
- return this.colorSetsList.getColorSetsList();
- }
-
- setCurrentColorSets(nameOrIndex) {
- this.colorSetsList.setCurrentColorSets(nameOrIndex);
- this.currentColorSets.refresh();
- }
-
- setColorSets(list) {
- this.colorSetsList.setUserList(list);
- }
-
- destroy() {
- super.destroy();
-
- this.control.destroy();
- this.palette.destroy();
- this.information.destroy();
- this.colorSetsChooser.destroy();
- this.colorSetsList.destroy();
- this.currentColorSets.destroy();
- this.contextMenu.destroy();
-
- // remove color picker callback
- this.colorpickerCallback = undefined;
- }
-}
\ No newline at end of file
+import ChromeDevToolColorPicker from './chromedevtool/index'
+
+export default {
+ create (opts) {
+ switch(opts.type) {
+ case 'sketch':
+ case 'palette':
+ default:
+ return new ChromeDevToolColorPicker(opts);
+ }
+ },
+ ColorPicker: ChromeDevToolColorPicker,
+ ChromeDevToolColorPicker
+}
\ No newline at end of file
diff --git a/src/colorview/index.js b/src/colorview/index.js
index 0aa2663..bd8f5ab 100644
--- a/src/colorview/index.js
+++ b/src/colorview/index.js
@@ -96,7 +96,7 @@ export default class ColorView {
if (this.opt.colorpicker) {
this.colorpicker = this.opt.colorpicker(this.opt);
} else {
- this.colorpicker = new ColorPicker(this.opt);
+ this.colorpicker = ColorPicker.create(this.opt);
}
this.init_event();
diff --git a/src/index.js b/src/index.js
index 60baa5f..11bc334 100644
--- a/src/index.js
+++ b/src/index.js
@@ -36,7 +36,7 @@ if (CodeMirror) {
export default {
Color,
ColorNames,
- ColorPicker,
+ ...ColorPicker,
ImageFilter,
GL,
HueColor,
diff --git a/src/scss/component/control.scss b/src/scss/component/control.scss
index 76a3155..d3d1590 100644
--- a/src/scss/component/control.scss
+++ b/src/scss/component/control.scss
@@ -55,8 +55,8 @@
position: absolute;
cursor: pointer;
top: 50% !important;
- margin-top: -7px !important;
- left: -3px;
+ left: 0px;
+ transform: translateX(-50%) translateY(-50%);
width: 12px;
height: 12px;
-webkit-border-radius: 50px;
diff --git a/src/scss/index.scss b/src/scss/index.scss
index 90ae891..4181d0e 100644
--- a/src/scss/index.scss
+++ b/src/scss/index.scss
@@ -2,4 +2,4 @@
@import './colorview';
@import './colorpicker';
-
\ No newline at end of file
+
\ No newline at end of file
diff --git a/src/scss/themes/sketch.scss b/src/scss/themes/sketch.scss
index 4ce40c0..b14d544 100644
--- a/src/scss/themes/sketch.scss
+++ b/src/scss/themes/sketch.scss
@@ -47,13 +47,22 @@
.drag-bar, .drag-bar2 {
border-radius: 0px;
- top: 0px !important;
- left: -2px;
- margin-top: 1px !important;
+ top: 50%;
+ left: 0px;
width: 2px;
- height: auto;
+ height: 50%;
+ transform: translateX(-50%) translateY(-50%);
border-radius: 1px;
bottom: 1px !important;
+
+ &.first {
+ left: 0px;
+ transform: translateX(50%) translateY(-50%) !important;
+ }
+
+ &.last {
+ transform: translateX(-150%) translateY(-50%) !important;
+ }
}
}
diff --git a/src/util/Color.js b/src/util/Color.js
index c479979..0f28111 100644
--- a/src/util/Color.js
+++ b/src/util/Color.js
@@ -16,8 +16,6 @@ const color = {
return result;
}
-
- var obj = { next: 0 };
for (var i = 0, len = matches.length; i < len; i++) {
if (matches[i].indexOf('#') > -1 || matches[i].indexOf('rgb') > -1 || matches[i].indexOf('hsl') > -1) {
@@ -686,8 +684,7 @@ const color = {
*/
contrast(c) {
c = this.parse(c);
- const contrast = (Math.round(c.r * 299) + Math.round(c.g * 587) + Math.round(c.b * 114)) / 1000;
- return contrast;
+ return (Math.round(c.r * 299) + Math.round(c.g * 587) + Math.round(c.b * 114)) / 1000;
},
contrastColor (c) {
diff --git a/src/util/Dom.js b/src/util/Dom.js
index b132c74..52f8749 100644
--- a/src/util/Dom.js
+++ b/src/util/Dom.js
@@ -63,6 +63,8 @@ export default class Dom {
removeClass (cls) {
this.el.className = ((` ${this.el.className} `).replace(` ${cls} `, ' ')).trim();
+
+ return this;
}
hasClass (cls) {
@@ -79,6 +81,8 @@ export default class Dom {
if (!this.hasClass(cls)) {
this.el.className = `${this.el.className} ${cls}`;
}
+
+ return this;
}
@@ -100,6 +104,15 @@ export default class Dom {
return this;
}
+
+ find (selector) {
+ return this.el.querySelector(selector)
+ }
+
+ findAll (selector) {
+ return this.el.querySelectorAll(selector)
+ }
+
empty () {
return this.html('');
@@ -302,5 +315,9 @@ export default class Dom {
return $element;
}
+
+ firstChild () {
+ return new Dom(this.el.firstElementChild);
+ }
}
diff --git a/src/util/EventMachin.js b/src/util/EventMachin.js
index a7b8f6b..cf746e5 100644
--- a/src/util/EventMachin.js
+++ b/src/util/EventMachin.js
@@ -10,6 +10,16 @@ export default class EventMachin {
constructor() {
this.state = new State(this);
+ this.refs = {}
+ }
+
+ template (html) {
+ this.$el = new Dom("div").html(html).firstChild()
+ const refs = this.$el.findAll("[ref]");
+ [...refs].forEach(node => {
+ this.refs[node.getAttribute("ref")] = new Dom(node);
+ })
+ this.refs.$el = this.$el
}
initializeEvent () {
@@ -18,6 +28,7 @@ export default class EventMachin {
destroy() {
this.destroyEventMachin();
+ // this.refs = {}
}
destroyEventMachin () {
@@ -44,7 +55,7 @@ export default class EventMachin {
let el;
if (dom) {
- el = this[dom] || window[dom];
+ el = this.refs[dom] || this[dom] || window[dom];
} else {
el = this.el || this.$el || this.$root;
}
diff --git a/src/util/State.js b/src/util/State.js
index af2a660..bb01ed0 100644
--- a/src/util/State.js
+++ b/src/util/State.js
@@ -17,7 +17,7 @@ export default class State {
const arr = key.split(DELEGATE_SPLIT);
- const obj = this.masterObj[arr[0]] || this.masterObj;
+ const obj = this.masterObj.refs[arr[0]] || this.masterObj[arr[0]] || this.masterObj;
const method = arr.pop();
if (obj[method]) {