|
(window["webpackJsonpGUI"] = window["webpackJsonpGUI"] || []).push([["addon-entry-2d-color-picker"],{ |
|
|
|
"./node_modules/css-loader/index.js!./src/addons/addons/2d-color-picker/style.css": |
|
|
|
|
|
|
|
|
|
(function(module, exports, __webpack_require__) { |
|
|
|
exports = module.exports = __webpack_require__( "./node_modules/css-loader/lib/css-base.js")(false); |
|
|
|
|
|
|
|
|
|
exports.push([module.i, ".sa-2dcolor-picker {\n width: 150px;\n height: 150px;\n border-radius: 8px;\n margin: 8px;\n position: relative;\n user-select: none;\n}\n\n.sa-2dcolor-picker-image {\n border-radius: 8px;\n width: 150px;\n height: 150px;\n user-select: none;\n}\n", ""]); |
|
|
|
|
|
|
|
|
|
}), |
|
|
|
"./node_modules/url-loader/dist/cjs.js!./src/addons/addons/2d-color-picker/assets/sv-gr.png": |
|
|
|
|
|
|
|
|
|
(function(module, __webpack_exports__, __webpack_require__) { |
|
|
|
"use strict"; |
|
__webpack_require__.r(__webpack_exports__); |
|
__webpack_exports__["default"] = (""); |
|
|
|
}), |
|
|
|
"./src/addons/addons/2d-color-picker/_runtime_entry.js": |
|
|
|
|
|
|
|
|
|
(function(module, __webpack_exports__, __webpack_require__) { |
|
|
|
"use strict"; |
|
__webpack_require__.r(__webpack_exports__); |
|
__webpack_require__.d(__webpack_exports__, "resources", function() { return resources; }); |
|
var _userscript_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__( "./src/addons/addons/2d-color-picker/userscript.js"); |
|
var _css_loader_style_css__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__( "./node_modules/css-loader/index.js!./src/addons/addons/2d-color-picker/style.css"); |
|
var _css_loader_style_css__WEBPACK_IMPORTED_MODULE_1___default = __webpack_require__.n(_css_loader_style_css__WEBPACK_IMPORTED_MODULE_1__); |
|
var _url_loader_assets_sv_gr_png__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__( "./node_modules/url-loader/dist/cjs.js!./src/addons/addons/2d-color-picker/assets/sv-gr.png"); |
|
|
|
|
|
|
|
|
|
const resources = { |
|
"userscript.js": _userscript_js__WEBPACK_IMPORTED_MODULE_0__["default"], |
|
"style.css": _css_loader_style_css__WEBPACK_IMPORTED_MODULE_1___default.a, |
|
"assets/sv-gr.png": _url_loader_assets_sv_gr_png__WEBPACK_IMPORTED_MODULE_2__["default"] |
|
}; |
|
|
|
}), |
|
|
|
"./src/addons/addons/2d-color-picker/paint-editor.js": |
|
|
|
|
|
|
|
|
|
(function(module, __webpack_exports__, __webpack_require__) { |
|
|
|
"use strict"; |
|
__webpack_require__.r(__webpack_exports__); |
|
var _libraries_common_cs_normalize_color_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__( "./src/addons/libraries/common/cs/normalize-color.js"); |
|
var _libraries_common_cs_rate_limiter_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__( "./src/addons/libraries/common/cs/rate-limiter.js"); |
|
var _libraries_thirdparty_cs_tinycolor_min_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__( "./src/addons/libraries/thirdparty/cs/tinycolor-min.js"); |
|
|
|
|
|
|
|
|
|
|
|
|
|
__webpack_exports__["default"] = (async _ref => { |
|
let { |
|
addon, |
|
console, |
|
msg |
|
} = _ref; |
|
let prevEventHandler; |
|
|
|
const rateLimiter = new _libraries_common_cs_rate_limiter_js__WEBPACK_IMPORTED_MODULE_1__["default"](250); |
|
|
|
|
|
const getColor = element => { |
|
let fillOrStroke; |
|
const state = addon.tab.redux.state; |
|
if (state.scratchPaint.modals.fillColor) { |
|
fillOrStroke = "fill"; |
|
} else if (state.scratchPaint.modals.strokeColor) { |
|
fillOrStroke = "stroke"; |
|
} else { |
|
return; |
|
} |
|
const colorType = state.scratchPaint.fillMode.colorIndex; |
|
const primaryOrSecondary = ["primary", "secondary"][colorType]; |
|
const color = state.scratchPaint.color["".concat(fillOrStroke, "Color")][primaryOrSecondary]; |
|
if (color === null || color === "scratch-paint/style-path/mixed") return; |
|
|
|
|
|
return Object(_libraries_thirdparty_cs_tinycolor_min_js__WEBPACK_IMPORTED_MODULE_2__["default"])(color).toHex8(); |
|
}; |
|
|
|
|
|
const setColor = (hex, element) => { |
|
hex = Object(_libraries_common_cs_normalize_color_js__WEBPACK_IMPORTED_MODULE_0__["normalizeHex"])(hex); |
|
if (!addon.tab.redux.state || !addon.tab.redux.state.scratchPaint) return; |
|
|
|
|
|
const onEyeDropperOpened = _ref2 => { |
|
let { |
|
detail |
|
} = _ref2; |
|
if (detail.action.type !== "scratch-paint/eye-dropper/ACTIVATE_COLOR_PICKER") return; |
|
addon.tab.redux.removeEventListener("statechanged", onEyeDropperOpened); |
|
setTimeout(() => { |
|
const previousTool = addon.tab.redux.state.scratchPaint.color.eyeDropper.previousTool; |
|
if (previousTool) previousTool.activate(); |
|
addon.tab.redux.state.scratchPaint.color.eyeDropper.callback(hex); |
|
addon.tab.redux.dispatch({ |
|
type: "scratch-paint/eye-dropper/DEACTIVATE_COLOR_PICKER" |
|
}); |
|
}, 50); |
|
}; |
|
addon.tab.redux.addEventListener("statechanged", onEyeDropperOpened); |
|
element.children[1].children[0].click(); |
|
}; |
|
|
|
|
|
const convertToGeneralColor = hex => { |
|
let h = Object(_libraries_thirdparty_cs_tinycolor_min_js__WEBPACK_IMPORTED_MODULE_2__["default"])(hex).toHsv(); |
|
h.s = 1; |
|
h.v = 1; |
|
return Object(_libraries_thirdparty_cs_tinycolor_min_js__WEBPACK_IMPORTED_MODULE_2__["default"])(h).toHex(); |
|
}; |
|
|
|
|
|
while (true) { |
|
|
|
const element = await addon.tab.waitForElement('div[class*="color-picker_swatch-row"]', { |
|
markAsSeen: true, |
|
reduxCondition: state => state.scratchGui.editorTab.activeTabIndex === 1 && !state.scratchGui.mode.isPlayerOnly |
|
}); |
|
rateLimiter.abort(false); |
|
if (!("colorIndex" in addon.tab.redux.state.scratchPaint.fillMode)) { |
|
console.error("Detected new paint editor; this will be supported in future versions."); |
|
return; |
|
} |
|
|
|
|
|
function updateColor() { |
|
rateLimiter.limit(() => { |
|
let c = getColor(element); |
|
let chsv = Object(_libraries_thirdparty_cs_tinycolor_min_js__WEBPACK_IMPORTED_MODULE_2__["default"])(c).toHsv(); |
|
updateHandleFinal(chsv.s, chsv.v); |
|
saColorPicker.style.background = "#" + convertToGeneralColor(getColor(element)); |
|
}); |
|
} |
|
|
|
|
|
addon.tab.redux.initialize(); |
|
addon.tab.redux.addEventListener("statechanged", e => e.detail.action.type === "scratch-paint/fill-style/CHANGE_FILL_COLOR" || e.detail.action.type === "scratch-paint/fill-style/CHANGE_FILL_COLOR_2" || e.detail.action.type === "scratch-paint/stroke-style/CHANGE_STROKE_COLOR" || e.detail.action.type === "scratch-paint/stroke-style/CHANGE_STROKE_COLOR_2" ? updateColor() : 0); |
|
if (addon.tab.redux && typeof prevEventHandler === "function") { |
|
addon.tab.redux.removeEventListener("statechanged", prevEventHandler); |
|
prevEventHandler = null; |
|
} |
|
|
|
|
|
if (addon.tab.editorMode !== "editor") continue; |
|
let defaultColor = getColor(element); |
|
|
|
|
|
const saColorPicker = document.createElement("div"); |
|
saColorPicker.className = "sa-2dcolor-picker"; |
|
saColorPicker.style.background = "#" + convertToGeneralColor(defaultColor || "ff0000"); |
|
const saColorPickerImage = Object.assign(document.createElement("img"), { |
|
className: "sa-2dcolor-picker-image", |
|
src: addon.self.getResource("/assets/sv-gr.png") , |
|
draggable: false |
|
}); |
|
const saColorPickerHandle = Object.assign(document.createElement("div"), { |
|
className: addon.tab.scratchClass("slider_handle") |
|
}); |
|
saColorPickerHandle.style.pointerEvents = "none"; |
|
|
|
|
|
const saColorLabel = document.createElement("div"); |
|
saColorLabel.className = addon.tab.scratchClass("color-picker_row-header", { |
|
others: "sa-2dcolor-label" |
|
}); |
|
const saColorLabelName = document.createElement("span"); |
|
saColorLabelName.className = addon.tab.scratchClass("color-picker_label-name", { |
|
others: "sa-2dcolor-label-name" |
|
}); |
|
saColorLabelName.innerText = msg("shade"); |
|
const saColorLabelVal = document.createElement("span"); |
|
saColorLabelVal.className = addon.tab.scratchClass("color-picker_label-readout", { |
|
others: "sa-2dcolor-label-val" |
|
}); |
|
saColorLabel.appendChild(saColorLabelName); |
|
saColorLabel.appendChild(saColorLabelVal); |
|
let keyPressed = -1; |
|
let originalPos = { |
|
x: 0, |
|
y: 0 |
|
}; |
|
window.addEventListener("keydown", e => keyPressed = e.keyCode); |
|
window.addEventListener("keyup", () => keyPressed = -1); |
|
let origHue = 0; |
|
let el = null; |
|
let mousemovefunc = function mousemovefunc(e) { |
|
updateHandle(e, keyPressed, originalPos); |
|
return false; |
|
}; |
|
let mouseupfunc = function mouseupfunc(e) { |
|
updateFinal(e, keyPressed, originalPos); |
|
}; |
|
function updateHandle(e, keyPressed, originalPos) { |
|
let cx = Math.min(Math.max(e.clientX - saColorPicker.getBoundingClientRect().x, 0), 150); |
|
let cy = Math.min(Math.max(e.clientY - saColorPicker.getBoundingClientRect().y, 0), 150); |
|
if (keyPressed === 16) { |
|
if (Math.abs(cx - originalPos.x) > Math.abs(cy - originalPos.y)) cy = originalPos.y;else cx = originalPos.x; |
|
} |
|
saColorPickerHandle.style.left = cx - 8 + "px"; |
|
saColorPickerHandle.style.top = cy - 8 + "px"; |
|
saColorLabelVal.innerText = "".concat(Math.round(cx / 150 * 100), ", ").concat(100 - Math.round(cy / 150 * 100)); |
|
|
|
|
|
if ((!addon.tab.redux.state.scratchPaint.fillMode.gradientType || addon.tab.redux.state.scratchPaint.fillMode.gradientType === "SOLID") && el) { |
|
let c = Object(_libraries_thirdparty_cs_tinycolor_min_js__WEBPACK_IMPORTED_MODULE_2__["default"])({ |
|
h: origHue, |
|
s: cx / 150, |
|
v: 1 - cy / 150 |
|
}).toHex(); |
|
if (c.startsWith("#")) el.style.background = c;else el.style.background = "#" + c; |
|
} |
|
} |
|
function updateHandleFinal(s, v) { |
|
saColorPickerHandle.style.left = s * 150 - 8 + "px"; |
|
saColorPickerHandle.style.top = (1 - v) * 150 - 8 + "px"; |
|
saColorLabelVal.innerText = "".concat(Math.round(s * 100), ", ").concat(Math.round(v * 100)); |
|
} |
|
function updateFinal(e, keyPressed, originalPos) { |
|
rateLimiter.limit(() => { |
|
let ox = Math.min(Math.max(e.clientX - saColorPicker.getBoundingClientRect().x, 0), 150); |
|
let oy = Math.min(Math.max(e.clientY - saColorPicker.getBoundingClientRect().y, 0), 150); |
|
if (keyPressed === 16) { |
|
if (Math.abs(ox - originalPos.x) > Math.abs(oy - originalPos.y)) oy = originalPos.y;else ox = originalPos.x; |
|
} |
|
let color = Object(_libraries_thirdparty_cs_tinycolor_min_js__WEBPACK_IMPORTED_MODULE_2__["default"])(getColor(element)).toHsv(); |
|
let s = ox / 150; |
|
let v = 1 - oy / 150; |
|
let newColor = Object(_libraries_thirdparty_cs_tinycolor_min_js__WEBPACK_IMPORTED_MODULE_2__["default"])({ |
|
h: color.h, |
|
s: s, |
|
v: v, |
|
a: color.a |
|
}).toHex8(); |
|
setColor(newColor, element); |
|
updateHandleFinal(s, v); |
|
}); |
|
window.removeEventListener("pointermove", mousemovefunc); |
|
window.removeEventListener("pointerup", mouseupfunc); |
|
} |
|
if (defaultColor) { |
|
let defaultHexColor = Object(_libraries_thirdparty_cs_tinycolor_min_js__WEBPACK_IMPORTED_MODULE_2__["default"])(defaultColor).toHsv(); |
|
updateHandleFinal(defaultHexColor.s, defaultHexColor.v); |
|
} else updateHandleFinal(1, 1); |
|
saColorPicker.addEventListener("pointerdown", e => { |
|
e.preventDefault(); |
|
originalPos = { |
|
x: parseFloat(saColorPickerHandle.style.left) + 8, |
|
y: parseFloat(saColorPickerHandle.style.top) + 8 |
|
}; |
|
let fillOrStroke; |
|
const state = addon.tab.redux.state; |
|
if (state.scratchPaint.modals.fillColor) { |
|
fillOrStroke = "fill"; |
|
} else if (state.scratchPaint.modals.strokeColor) { |
|
fillOrStroke = "stroke"; |
|
} else { |
|
fillOrStroke = "wh"; |
|
} |
|
el = null; |
|
if (fillOrStroke === "fill") el = document.getElementsByClassName(addon.tab.scratchClass("color-button_color-button-swatch"))[0];else if (fillOrStroke === "stroke") el = document.getElementsByClassName(addon.tab.scratchClass("color-button_color-button-swatch"))[1]; |
|
if (el) origHue = Object(_libraries_thirdparty_cs_tinycolor_min_js__WEBPACK_IMPORTED_MODULE_2__["default"])(el.style.background).toHsv().h; |
|
updateHandle(e); |
|
window.addEventListener("pointermove", mousemovefunc); |
|
window.addEventListener("pointerup", mouseupfunc); |
|
}); |
|
prevEventHandler = _ref3 => { |
|
let { |
|
detail |
|
} = _ref3; |
|
if (detail.action.type === "scratch-paint/color-index/CHANGE_COLOR_INDEX") { |
|
setTimeout(() => { |
|
updateColor(); |
|
}, 100); |
|
} |
|
}; |
|
addon.tab.redux.addEventListener("statechanged", prevEventHandler); |
|
saColorPicker.appendChild(saColorPickerImage); |
|
saColorPicker.appendChild(saColorPickerHandle); |
|
const [colorSlider, saturationSlider, brightnessSlider] = [...element.parentElement.querySelectorAll('[class^="color-picker_row-header"]')].map(i => i.parentElement); |
|
saturationSlider.style.display = "none"; |
|
brightnessSlider.style.display = "none"; |
|
colorSlider.insertAdjacentElement("afterend", saColorPicker); |
|
colorSlider.insertAdjacentElement("afterend", saColorLabel); |
|
} |
|
}); |
|
|
|
}), |
|
|
|
"./src/addons/addons/2d-color-picker/userscript.js": |
|
|
|
|
|
|
|
|
|
(function(module, __webpack_exports__, __webpack_require__) { |
|
|
|
"use strict"; |
|
__webpack_require__.r(__webpack_exports__); |
|
var _paint_editor_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__( "./src/addons/addons/2d-color-picker/paint-editor.js"); |
|
|
|
__webpack_exports__["default"] = (async api => { |
|
Object(_paint_editor_js__WEBPACK_IMPORTED_MODULE_0__["default"])(api); |
|
}); |
|
|
|
}), |
|
|
|
"./src/addons/libraries/common/cs/normalize-color.js": |
|
|
|
|
|
|
|
|
|
(function(module, __webpack_exports__, __webpack_require__) { |
|
|
|
"use strict"; |
|
__webpack_require__.r(__webpack_exports__); |
|
__webpack_require__.d(__webpack_exports__, "getHexRegex", function() { return getHexRegex; }); |
|
__webpack_require__.d(__webpack_exports__, "normalizeHex", function() { return normalizeHex; }); |
|
const getHexRegex = () => /^#?[0-9a-fA-F]{3,8}$/; |
|
const normalizeHex = input => { |
|
let hex = String(input); |
|
if (!getHexRegex().test(hex)) return "#000000"; |
|
if (!hex.startsWith("#")) hex = "#".concat(hex); |
|
if (hex.length === 4) { |
|
const [_, r, g, b] = hex; |
|
hex = "#".concat(r).concat(r).concat(g).concat(g).concat(b).concat(b); |
|
} |
|
return hex.toLowerCase(); |
|
}; |
|
|
|
}), |
|
|
|
"./src/addons/libraries/common/cs/rate-limiter.js": |
|
|
|
|
|
|
|
|
|
(function(module, __webpack_exports__, __webpack_require__) { |
|
|
|
"use strict"; |
|
__webpack_require__.r(__webpack_exports__); |
|
__webpack_require__.d(__webpack_exports__, "default", function() { return RateLimiter; }); |
|
class RateLimiter { |
|
constructor(wait) { |
|
this.timeout = null; |
|
this.callback = null; |
|
this.wait = wait; |
|
} |
|
abort() { |
|
let call = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true; |
|
if (this.timeout) { |
|
clearTimeout(this.timeout); |
|
if (call) this.callback(); |
|
this.timeout = this.callback = null; |
|
} |
|
} |
|
limit(callback) { |
|
this.abort(false); |
|
this.callback = callback; |
|
this.timeout = setTimeout(() => { |
|
this.timeout = this.callback = null; |
|
callback(); |
|
}, this.wait); |
|
} |
|
} |
|
|
|
}), |
|
|
|
"./src/addons/libraries/thirdparty/cs/tinycolor-min.js": |
|
|
|
|
|
|
|
|
|
(function(module, __webpack_exports__, __webpack_require__) { |
|
|
|
"use strict"; |
|
__webpack_require__.r(__webpack_exports__); |
|
|
|
|
|
|
|
|
|
|
|
const tinycolor = function (Math) { |
|
var trimLeft = /^\s+/, |
|
trimRight = /\s+$/, |
|
tinyCounter = 0, |
|
mathRound = Math.round, |
|
mathMin = Math.min, |
|
mathMax = Math.max, |
|
mathRandom = Math.random; |
|
function tinycolor(color, opts) { |
|
color = color ? color : ''; |
|
opts = opts || {}; |
|
|
|
|
|
if (color instanceof tinycolor) { |
|
return color; |
|
} |
|
|
|
if (!(this instanceof tinycolor)) { |
|
return new tinycolor(color, opts); |
|
} |
|
var rgb = inputToRGB(color); |
|
this._originalInput = color, this._r = rgb.r, this._g = rgb.g, this._b = rgb.b, this._a = rgb.a, this._roundA = mathRound(100 * this._a) / 100, this._format = opts.format || rgb.format; |
|
this._gradientType = opts.gradientType; |
|
|
|
|
|
|
|
|
|
|
|
if (this._r < 1) { |
|
this._r = mathRound(this._r); |
|
} |
|
if (this._g < 1) { |
|
this._g = mathRound(this._g); |
|
} |
|
if (this._b < 1) { |
|
this._b = mathRound(this._b); |
|
} |
|
this._ok = rgb.ok; |
|
this._tc_id = tinyCounter++; |
|
} |
|
tinycolor.prototype = { |
|
isDark: function isDark() { |
|
return this.getBrightness() < 128; |
|
}, |
|
isLight: function isLight() { |
|
return !this.isDark(); |
|
}, |
|
isValid: function isValid() { |
|
return this._ok; |
|
}, |
|
getOriginalInput: function getOriginalInput() { |
|
return this._originalInput; |
|
}, |
|
getFormat: function getFormat() { |
|
return this._format; |
|
}, |
|
getAlpha: function getAlpha() { |
|
return this._a; |
|
}, |
|
getBrightness: function getBrightness() { |
|
|
|
var rgb = this.toRgb(); |
|
return (rgb.r * 299 + rgb.g * 587 + rgb.b * 114) / 1000; |
|
}, |
|
getLuminance: function getLuminance() { |
|
|
|
var rgb = this.toRgb(); |
|
var RsRGB, GsRGB, BsRGB, R, G, B; |
|
RsRGB = rgb.r / 255; |
|
GsRGB = rgb.g / 255; |
|
BsRGB = rgb.b / 255; |
|
if (RsRGB <= 0.03928) { |
|
R = RsRGB / 12.92; |
|
} else { |
|
R = Math.pow((RsRGB + 0.055) / 1.055, 2.4); |
|
} |
|
if (GsRGB <= 0.03928) { |
|
G = GsRGB / 12.92; |
|
} else { |
|
G = Math.pow((GsRGB + 0.055) / 1.055, 2.4); |
|
} |
|
if (BsRGB <= 0.03928) { |
|
B = BsRGB / 12.92; |
|
} else { |
|
B = Math.pow((BsRGB + 0.055) / 1.055, 2.4); |
|
} |
|
return 0.2126 * R + 0.7152 * G + 0.0722 * B; |
|
}, |
|
setAlpha: function setAlpha(value) { |
|
this._a = boundAlpha(value); |
|
this._roundA = mathRound(100 * this._a) / 100; |
|
return this; |
|
}, |
|
toHsv: function toHsv() { |
|
var hsv = rgbToHsv(this._r, this._g, this._b); |
|
return { |
|
h: hsv.h * 360, |
|
s: hsv.s, |
|
v: hsv.v, |
|
a: this._a |
|
}; |
|
}, |
|
toHsvString: function toHsvString() { |
|
var hsv = rgbToHsv(this._r, this._g, this._b); |
|
var h = mathRound(hsv.h * 360), |
|
s = mathRound(hsv.s * 100), |
|
v = mathRound(hsv.v * 100); |
|
return this._a == 1 ? "hsv(" + h + ", " + s + "%, " + v + "%)" : "hsva(" + h + ", " + s + "%, " + v + "%, " + this._roundA + ")"; |
|
}, |
|
toHsl: function toHsl() { |
|
var hsl = rgbToHsl(this._r, this._g, this._b); |
|
return { |
|
h: hsl.h * 360, |
|
s: hsl.s, |
|
l: hsl.l, |
|
a: this._a |
|
}; |
|
}, |
|
toHslString: function toHslString() { |
|
var hsl = rgbToHsl(this._r, this._g, this._b); |
|
var h = mathRound(hsl.h * 360), |
|
s = mathRound(hsl.s * 100), |
|
l = mathRound(hsl.l * 100); |
|
return this._a == 1 ? "hsl(" + h + ", " + s + "%, " + l + "%)" : "hsla(" + h + ", " + s + "%, " + l + "%, " + this._roundA + ")"; |
|
}, |
|
toHex: function toHex(allow3Char) { |
|
return rgbToHex(this._r, this._g, this._b, allow3Char); |
|
}, |
|
toHexString: function toHexString(allow3Char) { |
|
return '#' + this.toHex(allow3Char); |
|
}, |
|
toHex8: function toHex8(allow4Char) { |
|
return rgbaToHex(this._r, this._g, this._b, this._a, allow4Char); |
|
}, |
|
toHex8String: function toHex8String(allow4Char) { |
|
return '#' + this.toHex8(allow4Char); |
|
}, |
|
toRgb: function toRgb() { |
|
return { |
|
r: mathRound(this._r), |
|
g: mathRound(this._g), |
|
b: mathRound(this._b), |
|
a: this._a |
|
}; |
|
}, |
|
toRgbString: function toRgbString() { |
|
return this._a == 1 ? "rgb(" + mathRound(this._r) + ", " + mathRound(this._g) + ", " + mathRound(this._b) + ")" : "rgba(" + mathRound(this._r) + ", " + mathRound(this._g) + ", " + mathRound(this._b) + ", " + this._roundA + ")"; |
|
}, |
|
toPercentageRgb: function toPercentageRgb() { |
|
return { |
|
r: mathRound(bound01(this._r, 255) * 100) + "%", |
|
g: mathRound(bound01(this._g, 255) * 100) + "%", |
|
b: mathRound(bound01(this._b, 255) * 100) + "%", |
|
a: this._a |
|
}; |
|
}, |
|
toPercentageRgbString: function toPercentageRgbString() { |
|
return this._a == 1 ? "rgb(" + mathRound(bound01(this._r, 255) * 100) + "%, " + mathRound(bound01(this._g, 255) * 100) + "%, " + mathRound(bound01(this._b, 255) * 100) + "%)" : "rgba(" + mathRound(bound01(this._r, 255) * 100) + "%, " + mathRound(bound01(this._g, 255) * 100) + "%, " + mathRound(bound01(this._b, 255) * 100) + "%, " + this._roundA + ")"; |
|
}, |
|
toName: function toName() { |
|
if (this._a === 0) { |
|
return "transparent"; |
|
} |
|
if (this._a < 1) { |
|
return false; |
|
} |
|
return hexNames[rgbToHex(this._r, this._g, this._b, true)] || false; |
|
}, |
|
toFilter: function toFilter(secondColor) { |
|
var hex8String = '#' + rgbaToArgbHex(this._r, this._g, this._b, this._a); |
|
var secondHex8String = hex8String; |
|
var gradientType = this._gradientType ? "GradientType = 1, " : ""; |
|
if (secondColor) { |
|
var s = tinycolor(secondColor); |
|
secondHex8String = '#' + rgbaToArgbHex(s._r, s._g, s._b, s._a); |
|
} |
|
return "progid:DXImageTransform.Microsoft.gradient(" + gradientType + "startColorstr=" + hex8String + ",endColorstr=" + secondHex8String + ")"; |
|
}, |
|
toString: function toString(format) { |
|
var formatSet = !!format; |
|
format = format || this._format; |
|
var formattedString = false; |
|
var hasAlpha = this._a < 1 && this._a >= 0; |
|
var needsAlphaFormat = !formatSet && hasAlpha && (format === "hex" || format === "hex6" || format === "hex3" || format === "hex4" || format === "hex8" || format === "name"); |
|
if (needsAlphaFormat) { |
|
|
|
|
|
if (format === "name" && this._a === 0) { |
|
return this.toName(); |
|
} |
|
return this.toRgbString(); |
|
} |
|
if (format === "rgb") { |
|
formattedString = this.toRgbString(); |
|
} |
|
if (format === "prgb") { |
|
formattedString = this.toPercentageRgbString(); |
|
} |
|
if (format === "hex" || format === "hex6") { |
|
formattedString = this.toHexString(); |
|
} |
|
if (format === "hex3") { |
|
formattedString = this.toHexString(true); |
|
} |
|
if (format === "hex4") { |
|
formattedString = this.toHex8String(true); |
|
} |
|
if (format === "hex8") { |
|
formattedString = this.toHex8String(); |
|
} |
|
if (format === "name") { |
|
formattedString = this.toName(); |
|
} |
|
if (format === "hsl") { |
|
formattedString = this.toHslString(); |
|
} |
|
if (format === "hsv") { |
|
formattedString = this.toHsvString(); |
|
} |
|
return formattedString || this.toHexString(); |
|
}, |
|
clone: function clone() { |
|
return tinycolor(this.toString()); |
|
}, |
|
_applyModification: function _applyModification(fn, args) { |
|
var color = fn.apply(null, [this].concat([].slice.call(args))); |
|
this._r = color._r; |
|
this._g = color._g; |
|
this._b = color._b; |
|
this.setAlpha(color._a); |
|
return this; |
|
}, |
|
lighten: function lighten() { |
|
return this._applyModification(_lighten, arguments); |
|
}, |
|
brighten: function brighten() { |
|
return this._applyModification(_brighten, arguments); |
|
}, |
|
darken: function darken() { |
|
return this._applyModification(_darken, arguments); |
|
}, |
|
desaturate: function desaturate() { |
|
return this._applyModification(_desaturate, arguments); |
|
}, |
|
saturate: function saturate() { |
|
return this._applyModification(_saturate, arguments); |
|
}, |
|
greyscale: function greyscale() { |
|
return this._applyModification(_greyscale, arguments); |
|
}, |
|
spin: function spin() { |
|
return this._applyModification(_spin, arguments); |
|
}, |
|
_applyCombination: function _applyCombination(fn, args) { |
|
return fn.apply(null, [this].concat([].slice.call(args))); |
|
}, |
|
analogous: function analogous() { |
|
return this._applyCombination(_analogous, arguments); |
|
}, |
|
complement: function complement() { |
|
return this._applyCombination(_complement, arguments); |
|
}, |
|
monochromatic: function monochromatic() { |
|
return this._applyCombination(_monochromatic, arguments); |
|
}, |
|
splitcomplement: function splitcomplement() { |
|
return this._applyCombination(_splitcomplement, arguments); |
|
}, |
|
triad: function triad() { |
|
return this._applyCombination(_triad, arguments); |
|
}, |
|
tetrad: function tetrad() { |
|
return this._applyCombination(_tetrad, arguments); |
|
} |
|
}; |
|
|
|
|
|
|
|
tinycolor.fromRatio = function (color, opts) { |
|
if (typeof color == "object") { |
|
var newColor = {}; |
|
for (var i in color) { |
|
if (color.hasOwnProperty(i)) { |
|
if (i === "a") { |
|
newColor[i] = color[i]; |
|
} else { |
|
newColor[i] = convertToPercentage(color[i]); |
|
} |
|
} |
|
} |
|
color = newColor; |
|
} |
|
return tinycolor(color, opts); |
|
}; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function inputToRGB(color) { |
|
var rgb = { |
|
r: 0, |
|
g: 0, |
|
b: 0 |
|
}; |
|
var a = 1; |
|
var s = null; |
|
var v = null; |
|
var l = null; |
|
var ok = false; |
|
var format = false; |
|
if (typeof color == "string") { |
|
color = stringInputToObject(color); |
|
} |
|
if (typeof color == "object") { |
|
if (isValidCSSUnit(color.r) && isValidCSSUnit(color.g) && isValidCSSUnit(color.b)) { |
|
rgb = rgbToRgb(color.r, color.g, color.b); |
|
ok = true; |
|
format = String(color.r).substr(-1) === "%" ? "prgb" : "rgb"; |
|
} else if (isValidCSSUnit(color.h) && isValidCSSUnit(color.s) && isValidCSSUnit(color.v)) { |
|
s = convertToPercentage(color.s); |
|
v = convertToPercentage(color.v); |
|
rgb = hsvToRgb(color.h, s, v); |
|
ok = true; |
|
format = "hsv"; |
|
} else if (isValidCSSUnit(color.h) && isValidCSSUnit(color.s) && isValidCSSUnit(color.l)) { |
|
s = convertToPercentage(color.s); |
|
l = convertToPercentage(color.l); |
|
rgb = hslToRgb(color.h, s, l); |
|
ok = true; |
|
format = "hsl"; |
|
} |
|
if (color.hasOwnProperty("a")) { |
|
a = color.a; |
|
} |
|
} |
|
a = boundAlpha(a); |
|
return { |
|
ok: ok, |
|
format: color.format || format, |
|
r: mathMin(255, mathMax(rgb.r, 0)), |
|
g: mathMin(255, mathMax(rgb.g, 0)), |
|
b: mathMin(255, mathMax(rgb.b, 0)), |
|
a: a |
|
}; |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function rgbToRgb(r, g, b) { |
|
return { |
|
r: bound01(r, 255) * 255, |
|
g: bound01(g, 255) * 255, |
|
b: bound01(b, 255) * 255 |
|
}; |
|
} |
|
|
|
|
|
|
|
|
|
|
|
function rgbToHsl(r, g, b) { |
|
r = bound01(r, 255); |
|
g = bound01(g, 255); |
|
b = bound01(b, 255); |
|
var max = mathMax(r, g, b), |
|
min = mathMin(r, g, b); |
|
var h, |
|
s, |
|
l = (max + min) / 2; |
|
if (max == min) { |
|
h = s = 0; |
|
} else { |
|
var d = max - min; |
|
s = l > 0.5 ? d / (2 - max - min) : d / (max + min); |
|
switch (max) { |
|
case r: |
|
h = (g - b) / d + (g < b ? 6 : 0); |
|
break; |
|
case g: |
|
h = (b - r) / d + 2; |
|
break; |
|
case b: |
|
h = (r - g) / d + 4; |
|
break; |
|
} |
|
h /= 6; |
|
} |
|
return { |
|
h: h, |
|
s: s, |
|
l: l |
|
}; |
|
} |
|
|
|
|
|
|
|
|
|
|
|
function hslToRgb(h, s, l) { |
|
var r, g, b; |
|
h = bound01(h, 360); |
|
s = bound01(s, 100); |
|
l = bound01(l, 100); |
|
function hue2rgb(p, q, t) { |
|
if (t < 0) t += 1; |
|
if (t > 1) t -= 1; |
|
if (t < 1 / 6) return p + (q - p) * 6 * t; |
|
if (t < 1 / 2) return q; |
|
if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6; |
|
return p; |
|
} |
|
if (s === 0) { |
|
r = g = b = l; |
|
} else { |
|
var q = l < 0.5 ? l * (1 + s) : l + s - l * s; |
|
var p = 2 * l - q; |
|
r = hue2rgb(p, q, h + 1 / 3); |
|
g = hue2rgb(p, q, h); |
|
b = hue2rgb(p, q, h - 1 / 3); |
|
} |
|
return { |
|
r: r * 255, |
|
g: g * 255, |
|
b: b * 255 |
|
}; |
|
} |
|
|
|
|
|
|
|
|
|
|
|
function rgbToHsv(r, g, b) { |
|
r = bound01(r, 255); |
|
g = bound01(g, 255); |
|
b = bound01(b, 255); |
|
var max = mathMax(r, g, b), |
|
min = mathMin(r, g, b); |
|
var h, |
|
s, |
|
v = max; |
|
var d = max - min; |
|
s = max === 0 ? 0 : d / max; |
|
if (max == min) { |
|
h = 0; |
|
} else { |
|
switch (max) { |
|
case r: |
|
h = (g - b) / d + (g < b ? 6 : 0); |
|
break; |
|
case g: |
|
h = (b - r) / d + 2; |
|
break; |
|
case b: |
|
h = (r - g) / d + 4; |
|
break; |
|
} |
|
h /= 6; |
|
} |
|
return { |
|
h: h, |
|
s: s, |
|
v: v |
|
}; |
|
} |
|
|
|
|
|
|
|
|
|
|
|
function hsvToRgb(h, s, v) { |
|
h = bound01(h, 360) * 6; |
|
s = bound01(s, 100); |
|
v = bound01(v, 100); |
|
var i = Math.floor(h), |
|
f = h - i, |
|
p = v * (1 - s), |
|
q = v * (1 - f * s), |
|
t = v * (1 - (1 - f) * s), |
|
mod = i % 6, |
|
r = [v, q, p, p, t, v][mod], |
|
g = [t, v, v, q, p, p][mod], |
|
b = [p, p, t, v, v, q][mod]; |
|
return { |
|
r: r * 255, |
|
g: g * 255, |
|
b: b * 255 |
|
}; |
|
} |
|
|
|
|
|
|
|
|
|
|
|
function rgbToHex(r, g, b, allow3Char) { |
|
var hex = [pad2(mathRound(r).toString(16)), pad2(mathRound(g).toString(16)), pad2(mathRound(b).toString(16))]; |
|
|
|
|
|
if (allow3Char && hex[0].charAt(0) == hex[0].charAt(1) && hex[1].charAt(0) == hex[1].charAt(1) && hex[2].charAt(0) == hex[2].charAt(1)) { |
|
return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0); |
|
} |
|
return hex.join(""); |
|
} |
|
|
|
|
|
|
|
|
|
|
|
function rgbaToHex(r, g, b, a, allow4Char) { |
|
var hex = [pad2(mathRound(r).toString(16)), pad2(mathRound(g).toString(16)), pad2(mathRound(b).toString(16)), pad2(convertDecimalToHex(a))]; |
|
|
|
|
|
if (allow4Char && hex[0].charAt(0) == hex[0].charAt(1) && hex[1].charAt(0) == hex[1].charAt(1) && hex[2].charAt(0) == hex[2].charAt(1) && hex[3].charAt(0) == hex[3].charAt(1)) { |
|
return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0) + hex[3].charAt(0); |
|
} |
|
return hex.join(""); |
|
} |
|
|
|
|
|
|
|
|
|
function rgbaToArgbHex(r, g, b, a) { |
|
var hex = [pad2(convertDecimalToHex(a)), pad2(mathRound(r).toString(16)), pad2(mathRound(g).toString(16)), pad2(mathRound(b).toString(16))]; |
|
return hex.join(""); |
|
} |
|
|
|
|
|
|
|
tinycolor.equals = function (color1, color2) { |
|
if (!color1 || !color2) { |
|
return false; |
|
} |
|
return tinycolor(color1).toRgbString() == tinycolor(color2).toRgbString(); |
|
}; |
|
tinycolor.random = function () { |
|
return tinycolor.fromRatio({ |
|
r: mathRandom(), |
|
g: mathRandom(), |
|
b: mathRandom() |
|
}); |
|
}; |
|
|
|
|
|
|
|
|
|
|
|
|
|
function _desaturate(color, amount) { |
|
amount = amount === 0 ? 0 : amount || 10; |
|
var hsl = tinycolor(color).toHsl(); |
|
hsl.s -= amount / 100; |
|
hsl.s = clamp01(hsl.s); |
|
return tinycolor(hsl); |
|
} |
|
function _saturate(color, amount) { |
|
amount = amount === 0 ? 0 : amount || 10; |
|
var hsl = tinycolor(color).toHsl(); |
|
hsl.s += amount / 100; |
|
hsl.s = clamp01(hsl.s); |
|
return tinycolor(hsl); |
|
} |
|
function _greyscale(color) { |
|
return tinycolor(color).desaturate(100); |
|
} |
|
function _lighten(color, amount) { |
|
amount = amount === 0 ? 0 : amount || 10; |
|
var hsl = tinycolor(color).toHsl(); |
|
hsl.l += amount / 100; |
|
hsl.l = clamp01(hsl.l); |
|
return tinycolor(hsl); |
|
} |
|
function _brighten(color, amount) { |
|
amount = amount === 0 ? 0 : amount || 10; |
|
var rgb = tinycolor(color).toRgb(); |
|
rgb.r = mathMax(0, mathMin(255, rgb.r - mathRound(255 * -(amount / 100)))); |
|
rgb.g = mathMax(0, mathMin(255, rgb.g - mathRound(255 * -(amount / 100)))); |
|
rgb.b = mathMax(0, mathMin(255, rgb.b - mathRound(255 * -(amount / 100)))); |
|
return tinycolor(rgb); |
|
} |
|
function _darken(color, amount) { |
|
amount = amount === 0 ? 0 : amount || 10; |
|
var hsl = tinycolor(color).toHsl(); |
|
hsl.l -= amount / 100; |
|
hsl.l = clamp01(hsl.l); |
|
return tinycolor(hsl); |
|
} |
|
|
|
|
|
|
|
function _spin(color, amount) { |
|
var hsl = tinycolor(color).toHsl(); |
|
var hue = (hsl.h + amount) % 360; |
|
hsl.h = hue < 0 ? 360 + hue : hue; |
|
return tinycolor(hsl); |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
function _complement(color) { |
|
var hsl = tinycolor(color).toHsl(); |
|
hsl.h = (hsl.h + 180) % 360; |
|
return tinycolor(hsl); |
|
} |
|
function _triad(color) { |
|
var hsl = tinycolor(color).toHsl(); |
|
var h = hsl.h; |
|
return [tinycolor(color), tinycolor({ |
|
h: (h + 120) % 360, |
|
s: hsl.s, |
|
l: hsl.l |
|
}), tinycolor({ |
|
h: (h + 240) % 360, |
|
s: hsl.s, |
|
l: hsl.l |
|
})]; |
|
} |
|
function _tetrad(color) { |
|
var hsl = tinycolor(color).toHsl(); |
|
var h = hsl.h; |
|
return [tinycolor(color), tinycolor({ |
|
h: (h + 90) % 360, |
|
s: hsl.s, |
|
l: hsl.l |
|
}), tinycolor({ |
|
h: (h + 180) % 360, |
|
s: hsl.s, |
|
l: hsl.l |
|
}), tinycolor({ |
|
h: (h + 270) % 360, |
|
s: hsl.s, |
|
l: hsl.l |
|
})]; |
|
} |
|
function _splitcomplement(color) { |
|
var hsl = tinycolor(color).toHsl(); |
|
var h = hsl.h; |
|
return [tinycolor(color), tinycolor({ |
|
h: (h + 72) % 360, |
|
s: hsl.s, |
|
l: hsl.l |
|
}), tinycolor({ |
|
h: (h + 216) % 360, |
|
s: hsl.s, |
|
l: hsl.l |
|
})]; |
|
} |
|
function _analogous(color, results, slices) { |
|
results = results || 6; |
|
slices = slices || 30; |
|
var hsl = tinycolor(color).toHsl(); |
|
var part = 360 / slices; |
|
var ret = [tinycolor(color)]; |
|
for (hsl.h = (hsl.h - (part * results >> 1) + 720) % 360; --results;) { |
|
hsl.h = (hsl.h + part) % 360; |
|
ret.push(tinycolor(hsl)); |
|
} |
|
return ret; |
|
} |
|
function _monochromatic(color, results) { |
|
results = results || 6; |
|
var hsv = tinycolor(color).toHsv(); |
|
var h = hsv.h, |
|
s = hsv.s, |
|
v = hsv.v; |
|
var ret = []; |
|
var modification = 1 / results; |
|
while (results--) { |
|
ret.push(tinycolor({ |
|
h: h, |
|
s: s, |
|
v: v |
|
})); |
|
v = (v + modification) % 1; |
|
} |
|
return ret; |
|
} |
|
|
|
|
|
|
|
|
|
tinycolor.mix = function (color1, color2, amount) { |
|
amount = amount === 0 ? 0 : amount || 50; |
|
var rgb1 = tinycolor(color1).toRgb(); |
|
var rgb2 = tinycolor(color2).toRgb(); |
|
var p = amount / 100; |
|
var rgba = { |
|
r: (rgb2.r - rgb1.r) * p + rgb1.r, |
|
g: (rgb2.g - rgb1.g) * p + rgb1.g, |
|
b: (rgb2.b - rgb1.b) * p + rgb1.b, |
|
a: (rgb2.a - rgb1.a) * p + rgb1.a |
|
}; |
|
return tinycolor(rgba); |
|
}; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
tinycolor.readability = function (color1, color2) { |
|
var c1 = tinycolor(color1); |
|
var c2 = tinycolor(color2); |
|
return (Math.max(c1.getLuminance(), c2.getLuminance()) + 0.05) / (Math.min(c1.getLuminance(), c2.getLuminance()) + 0.05); |
|
}; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
tinycolor.isReadable = function (color1, color2, wcag2) { |
|
var readability = tinycolor.readability(color1, color2); |
|
var wcag2Parms, out; |
|
out = false; |
|
wcag2Parms = validateWCAG2Parms(wcag2); |
|
switch (wcag2Parms.level + wcag2Parms.size) { |
|
case "AAsmall": |
|
case "AAAlarge": |
|
out = readability >= 4.5; |
|
break; |
|
case "AAlarge": |
|
out = readability >= 3; |
|
break; |
|
case "AAAsmall": |
|
out = readability >= 7; |
|
break; |
|
} |
|
return out; |
|
}; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
tinycolor.mostReadable = function (baseColor, colorList, args) { |
|
var bestColor = null; |
|
var bestScore = 0; |
|
var readability; |
|
var includeFallbackColors, level, size; |
|
args = args || {}; |
|
includeFallbackColors = args.includeFallbackColors; |
|
level = args.level; |
|
size = args.size; |
|
for (var i = 0; i < colorList.length; i++) { |
|
readability = tinycolor.readability(baseColor, colorList[i]); |
|
if (readability > bestScore) { |
|
bestScore = readability; |
|
bestColor = tinycolor(colorList[i]); |
|
} |
|
} |
|
if (tinycolor.isReadable(baseColor, bestColor, { |
|
"level": level, |
|
"size": size |
|
}) || !includeFallbackColors) { |
|
return bestColor; |
|
} else { |
|
args.includeFallbackColors = false; |
|
return tinycolor.mostReadable(baseColor, ["#fff", "#000"], args); |
|
} |
|
}; |
|
|
|
|
|
|
|
|
|
var names = tinycolor.names = { |
|
aliceblue: "f0f8ff", |
|
antiquewhite: "faebd7", |
|
aqua: "0ff", |
|
aquamarine: "7fffd4", |
|
azure: "f0ffff", |
|
beige: "f5f5dc", |
|
bisque: "ffe4c4", |
|
black: "000", |
|
blanchedalmond: "ffebcd", |
|
blue: "00f", |
|
blueviolet: "8a2be2", |
|
brown: "a52a2a", |
|
burlywood: "deb887", |
|
burntsienna: "ea7e5d", |
|
cadetblue: "5f9ea0", |
|
chartreuse: "7fff00", |
|
chocolate: "d2691e", |
|
coral: "ff7f50", |
|
cornflowerblue: "6495ed", |
|
cornsilk: "fff8dc", |
|
crimson: "dc143c", |
|
cyan: "0ff", |
|
darkblue: "00008b", |
|
darkcyan: "008b8b", |
|
darkgoldenrod: "b8860b", |
|
darkgray: "a9a9a9", |
|
darkgreen: "006400", |
|
darkgrey: "a9a9a9", |
|
darkkhaki: "bdb76b", |
|
darkmagenta: "8b008b", |
|
darkolivegreen: "556b2f", |
|
darkorange: "ff8c00", |
|
darkorchid: "9932cc", |
|
darkred: "8b0000", |
|
darksalmon: "e9967a", |
|
darkseagreen: "8fbc8f", |
|
darkslateblue: "483d8b", |
|
darkslategray: "2f4f4f", |
|
darkslategrey: "2f4f4f", |
|
darkturquoise: "00ced1", |
|
darkviolet: "9400d3", |
|
deeppink: "ff1493", |
|
deepskyblue: "00bfff", |
|
dimgray: "696969", |
|
dimgrey: "696969", |
|
dodgerblue: "1e90ff", |
|
firebrick: "b22222", |
|
floralwhite: "fffaf0", |
|
forestgreen: "228b22", |
|
fuchsia: "f0f", |
|
gainsboro: "dcdcdc", |
|
ghostwhite: "f8f8ff", |
|
gold: "ffd700", |
|
goldenrod: "daa520", |
|
gray: "808080", |
|
green: "008000", |
|
greenyellow: "adff2f", |
|
grey: "808080", |
|
honeydew: "f0fff0", |
|
hotpink: "ff69b4", |
|
indianred: "cd5c5c", |
|
indigo: "4b0082", |
|
ivory: "fffff0", |
|
khaki: "f0e68c", |
|
lavender: "e6e6fa", |
|
lavenderblush: "fff0f5", |
|
lawngreen: "7cfc00", |
|
lemonchiffon: "fffacd", |
|
lightblue: "add8e6", |
|
lightcoral: "f08080", |
|
lightcyan: "e0ffff", |
|
lightgoldenrodyellow: "fafad2", |
|
lightgray: "d3d3d3", |
|
lightgreen: "90ee90", |
|
lightgrey: "d3d3d3", |
|
lightpink: "ffb6c1", |
|
lightsalmon: "ffa07a", |
|
lightseagreen: "20b2aa", |
|
lightskyblue: "87cefa", |
|
lightslategray: "789", |
|
lightslategrey: "789", |
|
lightsteelblue: "b0c4de", |
|
lightyellow: "ffffe0", |
|
lime: "0f0", |
|
limegreen: "32cd32", |
|
linen: "faf0e6", |
|
magenta: "f0f", |
|
maroon: "800000", |
|
mediumaquamarine: "66cdaa", |
|
mediumblue: "0000cd", |
|
mediumorchid: "ba55d3", |
|
mediumpurple: "9370db", |
|
mediumseagreen: "3cb371", |
|
mediumslateblue: "7b68ee", |
|
mediumspringgreen: "00fa9a", |
|
mediumturquoise: "48d1cc", |
|
mediumvioletred: "c71585", |
|
midnightblue: "191970", |
|
mintcream: "f5fffa", |
|
mistyrose: "ffe4e1", |
|
moccasin: "ffe4b5", |
|
navajowhite: "ffdead", |
|
navy: "000080", |
|
oldlace: "fdf5e6", |
|
olive: "808000", |
|
olivedrab: "6b8e23", |
|
orange: "ffa500", |
|
orangered: "ff4500", |
|
orchid: "da70d6", |
|
palegoldenrod: "eee8aa", |
|
palegreen: "98fb98", |
|
paleturquoise: "afeeee", |
|
palevioletred: "db7093", |
|
papayawhip: "ffefd5", |
|
peachpuff: "ffdab9", |
|
peru: "cd853f", |
|
pink: "ffc0cb", |
|
plum: "dda0dd", |
|
powderblue: "b0e0e6", |
|
purple: "800080", |
|
rebeccapurple: "663399", |
|
red: "f00", |
|
rosybrown: "bc8f8f", |
|
royalblue: "4169e1", |
|
saddlebrown: "8b4513", |
|
salmon: "fa8072", |
|
sandybrown: "f4a460", |
|
seagreen: "2e8b57", |
|
seashell: "fff5ee", |
|
sienna: "a0522d", |
|
silver: "c0c0c0", |
|
skyblue: "87ceeb", |
|
slateblue: "6a5acd", |
|
slategray: "708090", |
|
slategrey: "708090", |
|
snow: "fffafa", |
|
springgreen: "00ff7f", |
|
steelblue: "4682b4", |
|
tan: "d2b48c", |
|
teal: "008080", |
|
thistle: "d8bfd8", |
|
tomato: "ff6347", |
|
turquoise: "40e0d0", |
|
violet: "ee82ee", |
|
wheat: "f5deb3", |
|
white: "fff", |
|
whitesmoke: "f5f5f5", |
|
yellow: "ff0", |
|
yellowgreen: "9acd32" |
|
}; |
|
|
|
|
|
var hexNames = tinycolor.hexNames = flip(names); |
|
|
|
|
|
|
|
|
|
|
|
function flip(o) { |
|
var flipped = {}; |
|
for (var i in o) { |
|
if (o.hasOwnProperty(i)) { |
|
flipped[o[i]] = i; |
|
} |
|
} |
|
return flipped; |
|
} |
|
|
|
|
|
function boundAlpha(a) { |
|
a = parseFloat(a); |
|
if (isNaN(a) || a < 0 || a > 1) { |
|
a = 1; |
|
} |
|
return a; |
|
} |
|
|
|
|
|
function bound01(n, max) { |
|
if (isOnePointZero(n)) { |
|
n = "100%"; |
|
} |
|
var processPercent = isPercentage(n); |
|
n = mathMin(max, mathMax(0, parseFloat(n))); |
|
|
|
|
|
if (processPercent) { |
|
n = parseInt(n * max, 10) / 100; |
|
} |
|
|
|
|
|
if (Math.abs(n - max) < 0.000001) { |
|
return 1; |
|
} |
|
|
|
|
|
return n % max / parseFloat(max); |
|
} |
|
|
|
|
|
function clamp01(val) { |
|
return mathMin(1, mathMax(0, val)); |
|
} |
|
|
|
|
|
function parseIntFromHex(val) { |
|
return parseInt(val, 16); |
|
} |
|
|
|
|
|
|
|
function isOnePointZero(n) { |
|
return typeof n == "string" && n.indexOf('.') != -1 && parseFloat(n) === 1; |
|
} |
|
|
|
|
|
function isPercentage(n) { |
|
return typeof n === "string" && n.indexOf('%') != -1; |
|
} |
|
|
|
|
|
function pad2(c) { |
|
return c.length == 1 ? '0' + c : '' + c; |
|
} |
|
|
|
|
|
function convertToPercentage(n) { |
|
if (n <= 1) { |
|
n = n * 100 + "%"; |
|
} |
|
return n; |
|
} |
|
|
|
|
|
function convertDecimalToHex(d) { |
|
return Math.round(parseFloat(d) * 255).toString(16); |
|
} |
|
|
|
function convertHexToDecimal(h) { |
|
return parseIntFromHex(h) / 255; |
|
} |
|
var matchers = function () { |
|
|
|
var CSS_INTEGER = "[-\\+]?\\d+%?"; |
|
|
|
|
|
var CSS_NUMBER = "[-\\+]?\\d*\\.\\d+%?"; |
|
|
|
|
|
var CSS_UNIT = "(?:" + CSS_NUMBER + ")|(?:" + CSS_INTEGER + ")"; |
|
|
|
|
|
|
|
|
|
var PERMISSIVE_MATCH3 = "[\\s|\\(]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")\\s*\\)?"; |
|
var PERMISSIVE_MATCH4 = "[\\s|\\(]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")\\s*\\)?"; |
|
return { |
|
CSS_UNIT: new RegExp(CSS_UNIT), |
|
rgb: new RegExp("rgb" + PERMISSIVE_MATCH3), |
|
rgba: new RegExp("rgba" + PERMISSIVE_MATCH4), |
|
hsl: new RegExp("hsl" + PERMISSIVE_MATCH3), |
|
hsla: new RegExp("hsla" + PERMISSIVE_MATCH4), |
|
hsv: new RegExp("hsv" + PERMISSIVE_MATCH3), |
|
hsva: new RegExp("hsva" + PERMISSIVE_MATCH4), |
|
hex3: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/, |
|
hex6: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/, |
|
hex4: /^#?([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/, |
|
hex8: /^#?([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/ |
|
}; |
|
}(); |
|
|
|
|
|
|
|
|
|
function isValidCSSUnit(color) { |
|
return !!matchers.CSS_UNIT.exec(color); |
|
} |
|
|
|
|
|
|
|
|
|
function stringInputToObject(color) { |
|
color = color.replace(trimLeft, '').replace(trimRight, '').toLowerCase(); |
|
var named = false; |
|
if (names[color]) { |
|
color = names[color]; |
|
named = true; |
|
} else if (color == 'transparent') { |
|
return { |
|
r: 0, |
|
g: 0, |
|
b: 0, |
|
a: 0, |
|
format: "name" |
|
}; |
|
} |
|
|
|
|
|
|
|
|
|
|
|
var match; |
|
if (match = matchers.rgb.exec(color)) { |
|
return { |
|
r: match[1], |
|
g: match[2], |
|
b: match[3] |
|
}; |
|
} |
|
if (match = matchers.rgba.exec(color)) { |
|
return { |
|
r: match[1], |
|
g: match[2], |
|
b: match[3], |
|
a: match[4] |
|
}; |
|
} |
|
if (match = matchers.hsl.exec(color)) { |
|
return { |
|
h: match[1], |
|
s: match[2], |
|
l: match[3] |
|
}; |
|
} |
|
if (match = matchers.hsla.exec(color)) { |
|
return { |
|
h: match[1], |
|
s: match[2], |
|
l: match[3], |
|
a: match[4] |
|
}; |
|
} |
|
if (match = matchers.hsv.exec(color)) { |
|
return { |
|
h: match[1], |
|
s: match[2], |
|
v: match[3] |
|
}; |
|
} |
|
if (match = matchers.hsva.exec(color)) { |
|
return { |
|
h: match[1], |
|
s: match[2], |
|
v: match[3], |
|
a: match[4] |
|
}; |
|
} |
|
if (match = matchers.hex8.exec(color)) { |
|
return { |
|
r: parseIntFromHex(match[1]), |
|
g: parseIntFromHex(match[2]), |
|
b: parseIntFromHex(match[3]), |
|
a: convertHexToDecimal(match[4]), |
|
format: named ? "name" : "hex8" |
|
}; |
|
} |
|
if (match = matchers.hex6.exec(color)) { |
|
return { |
|
r: parseIntFromHex(match[1]), |
|
g: parseIntFromHex(match[2]), |
|
b: parseIntFromHex(match[3]), |
|
format: named ? "name" : "hex" |
|
}; |
|
} |
|
if (match = matchers.hex4.exec(color)) { |
|
return { |
|
r: parseIntFromHex(match[1] + '' + match[1]), |
|
g: parseIntFromHex(match[2] + '' + match[2]), |
|
b: parseIntFromHex(match[3] + '' + match[3]), |
|
a: convertHexToDecimal(match[4] + '' + match[4]), |
|
format: named ? "name" : "hex8" |
|
}; |
|
} |
|
if (match = matchers.hex3.exec(color)) { |
|
return { |
|
r: parseIntFromHex(match[1] + '' + match[1]), |
|
g: parseIntFromHex(match[2] + '' + match[2]), |
|
b: parseIntFromHex(match[3] + '' + match[3]), |
|
format: named ? "name" : "hex" |
|
}; |
|
} |
|
return false; |
|
} |
|
function validateWCAG2Parms(parms) { |
|
|
|
|
|
var level, size; |
|
parms = parms || { |
|
"level": "AA", |
|
"size": "small" |
|
}; |
|
level = (parms.level || "AA").toUpperCase(); |
|
size = (parms.size || "small").toLowerCase(); |
|
if (level !== "AA" && level !== "AAA") { |
|
level = "AA"; |
|
} |
|
if (size !== "small" && size !== "large") { |
|
size = "small"; |
|
} |
|
return { |
|
"level": level, |
|
"size": size |
|
}; |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return tinycolor; |
|
}(Math); |
|
__webpack_exports__["default"] = (tinycolor); |
|
|
|
}) |
|
|
|
}]); |
|
|