@hufe921/canvas-editor-plugin-floating-toolbar
Version:
floating toolbar plugin for canvas-editor
643 lines (634 loc) • 51.3 kB
JavaScript
(function(){"use strict";try{if(typeof document<"u"){var e=document.createElement("style");e.id="floatingToolbar-style",e.appendChild(document.createTextNode(`/*! Pickr 1.9.0 MIT | https://github.com/Simonwep/pickr */.pickr{position:relative;overflow:visible;transform:translateY(0)}.pickr *{box-sizing:border-box;outline:none;border:none;-webkit-appearance:none}.pickr .pcr-button{position:relative;height:2em;width:2em;padding:.5em;cursor:pointer;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;border-radius:.15em;background:url('data:image/svg+xml;utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 50 50" stroke="%2342445A" stroke-width="5px" stroke-linecap="round"><path d="M45,45L5,5"></path><path d="M45,5L5,45"></path></svg>') no-repeat center;background-size:0;transition:all .3s}.pickr .pcr-button:before{position:absolute;content:"";top:0;left:0;width:100%;height:100%;background:url('data:image/svg+xml;utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 2 2"><path fill="white" d="M1,0H2V1H1V0ZM0,1H1V2H0V1Z"/><path fill="gray" d="M0,0H1V1H0V0ZM1,1H2V2H1V1Z"/></svg>');background-size:.5em;border-radius:.15em;z-index:-1}.pickr .pcr-button:before{z-index:initial}.pickr .pcr-button:after{position:absolute;content:"";top:0;left:0;height:100%;width:100%;transition:background .3s;background:var(--pcr-color);border-radius:.15em}.pickr .pcr-button.clear{background-size:70%}.pickr .pcr-button.clear:before{opacity:0}.pickr .pcr-button.clear:focus{box-shadow:0 0 0 1px #ffffffd9,0 0 0 3px var(--pcr-color)}.pickr .pcr-button.disabled{cursor:not-allowed}.pickr *,.pcr-app *{box-sizing:border-box;outline:none;border:none;-webkit-appearance:none}.pickr input:focus,.pickr input.pcr-active,.pickr button:focus,.pickr button.pcr-active,.pcr-app input:focus,.pcr-app input.pcr-active,.pcr-app button:focus,.pcr-app button.pcr-active{box-shadow:0 0 0 1px #ffffffd9,0 0 0 3px var(--pcr-color)}.pickr .pcr-palette,.pickr .pcr-slider,.pcr-app .pcr-palette,.pcr-app .pcr-slider{transition:box-shadow .3s}.pickr .pcr-palette:focus,.pickr .pcr-slider:focus,.pcr-app .pcr-palette:focus,.pcr-app .pcr-slider:focus{box-shadow:0 0 0 1px #ffffffd9,0 0 0 3px #00000040}.pcr-app{position:fixed;display:flex;flex-direction:column;z-index:10000;border-radius:.1em;background:#fff;opacity:0;visibility:hidden;transition:opacity .3s,visibility 0s .3s;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;box-shadow:0 .15em 1.5em #0000001a,0 0 1em #00000008;left:0;top:0}.pcr-app.visible{transition:opacity .3s;visibility:visible;opacity:1}.pcr-app .pcr-swatches{display:flex;flex-wrap:wrap;margin-top:.75em}.pcr-app .pcr-swatches.pcr-last{margin:0}@supports (display: grid){.pcr-app .pcr-swatches{display:grid;align-items:center;grid-template-columns:repeat(auto-fit,1.75em)}}.pcr-app .pcr-swatches>button{font-size:1em;position:relative;width:calc(1.75em - 5px);height:calc(1.75em - 5px);border-radius:.15em;cursor:pointer;margin:2.5px;flex-shrink:0;justify-self:center;transition:all .15s;overflow:hidden;background:rgba(0,0,0,0);z-index:1}.pcr-app .pcr-swatches>button:before{position:absolute;content:"";top:0;left:0;width:100%;height:100%;background:url('data:image/svg+xml;utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 2 2"><path fill="white" d="M1,0H2V1H1V0ZM0,1H1V2H0V1Z"/><path fill="gray" d="M0,0H1V1H0V0ZM1,1H2V2H1V1Z"/></svg>');background-size:6px;border-radius:.15em;z-index:-1}.pcr-app .pcr-swatches>button:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:var(--pcr-color);border:1px solid rgba(0,0,0,.05);border-radius:.15em;box-sizing:border-box}.pcr-app .pcr-swatches>button:hover{filter:brightness(1.05)}.pcr-app .pcr-swatches>button:not(.pcr-active){box-shadow:none}.pcr-app .pcr-interaction{display:flex;flex-wrap:wrap;align-items:center;margin:0 -.2em}.pcr-app .pcr-interaction>*{margin:0 .2em}.pcr-app .pcr-interaction input{letter-spacing:.07em;font-size:.75em;text-align:center;cursor:pointer;color:#75797e;background:#f1f3f4;border-radius:.15em;transition:all .15s;padding:.45em .5em;margin-top:.75em}.pcr-app .pcr-interaction input:hover{filter:brightness(.975)}.pcr-app .pcr-interaction input:focus{box-shadow:0 0 0 1px #ffffffd9,0 0 0 3px #4285f4bf}.pcr-app .pcr-interaction .pcr-result{color:#75797e;text-align:left;flex:1 1 8em;min-width:8em;transition:all .2s;border-radius:.15em;background:#f1f3f4;cursor:text}.pcr-app .pcr-interaction .pcr-result::-moz-selection{background:#4285f4;color:#fff}.pcr-app .pcr-interaction .pcr-result::selection{background:#4285f4;color:#fff}.pcr-app .pcr-interaction .pcr-type.active{color:#fff;background:#4285f4}.pcr-app .pcr-interaction .pcr-save,.pcr-app .pcr-interaction .pcr-cancel,.pcr-app .pcr-interaction .pcr-clear{color:#fff;width:auto}.pcr-app .pcr-interaction .pcr-save,.pcr-app .pcr-interaction .pcr-cancel,.pcr-app .pcr-interaction .pcr-clear{color:#fff}.pcr-app .pcr-interaction .pcr-save:hover,.pcr-app .pcr-interaction .pcr-cancel:hover,.pcr-app .pcr-interaction .pcr-clear:hover{filter:brightness(.925)}.pcr-app .pcr-interaction .pcr-save{background:#4285f4}.pcr-app .pcr-interaction .pcr-clear,.pcr-app .pcr-interaction .pcr-cancel{background:#f44250}.pcr-app .pcr-interaction .pcr-clear:focus,.pcr-app .pcr-interaction .pcr-cancel:focus{box-shadow:0 0 0 1px #ffffffd9,0 0 0 3px #f44250bf}.pcr-app .pcr-selection .pcr-picker{position:absolute;height:18px;width:18px;border:2px solid #fff;border-radius:100%;-webkit-user-select:none;-moz-user-select:none;user-select:none}.pcr-app .pcr-selection .pcr-color-palette,.pcr-app .pcr-selection .pcr-color-chooser,.pcr-app .pcr-selection .pcr-color-opacity{position:relative;-webkit-user-select:none;-moz-user-select:none;user-select:none;display:flex;flex-direction:column;cursor:grab;cursor:-webkit-grab}.pcr-app .pcr-selection .pcr-color-palette:active,.pcr-app .pcr-selection .pcr-color-chooser:active,.pcr-app .pcr-selection .pcr-color-opacity:active{cursor:grabbing;cursor:-webkit-grabbing}.pcr-app[data-theme=nano]{width:14.25em;max-width:95vw}.pcr-app[data-theme=nano] .pcr-swatches{margin-top:.6em;padding:0 .6em}.pcr-app[data-theme=nano] .pcr-interaction{padding:0 .6em .6em}.pcr-app[data-theme=nano] .pcr-selection{display:grid;grid-gap:.6em;grid-template-columns:1fr 4fr;grid-template-rows:5fr auto auto;align-items:center;height:10.5em;width:100%;align-self:flex-start}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-preview{grid-area:2/1/4/1;height:100%;width:100%;display:flex;flex-direction:row;justify-content:center;margin-left:.6em}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-preview .pcr-last-color{display:none}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-preview .pcr-current-color{position:relative;background:var(--pcr-color);width:2em;height:2em;border-radius:50em;overflow:hidden}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-preview .pcr-current-color:before{position:absolute;content:"";top:0;left:0;width:100%;height:100%;background:url('data:image/svg+xml;utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 2 2"><path fill="white" d="M1,0H2V1H1V0ZM0,1H1V2H0V1Z"/><path fill="gray" d="M0,0H1V1H0V0ZM1,1H2V2H1V1Z"/></svg>');background-size:.5em;border-radius:.15em;z-index:-1}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-palette{grid-area:1/1/2/3;width:100%;height:100%;z-index:1}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-palette .pcr-palette{border-radius:.15em;width:100%;height:100%}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-palette .pcr-palette:before{position:absolute;content:"";top:0;left:0;width:100%;height:100%;background:url('data:image/svg+xml;utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 2 2"><path fill="white" d="M1,0H2V1H1V0ZM0,1H1V2H0V1Z"/><path fill="gray" d="M0,0H1V1H0V0ZM1,1H2V2H1V1Z"/></svg>');background-size:.5em;border-radius:.15em;z-index:-1}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-chooser{grid-area:2/2/2/2}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-opacity{grid-area:3/2/3/2}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-chooser,.pcr-app[data-theme=nano] .pcr-selection .pcr-color-opacity{height:.5em;margin:0 .6em}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-chooser .pcr-picker,.pcr-app[data-theme=nano] .pcr-selection .pcr-color-opacity .pcr-picker{top:50%;transform:translateY(-50%)}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-chooser .pcr-slider,.pcr-app[data-theme=nano] .pcr-selection .pcr-color-opacity .pcr-slider{flex-grow:1;border-radius:50em}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-chooser .pcr-slider{background:linear-gradient(to right,hsl(0,100%,50%),hsl(60,100%,50%),hsl(120,100%,50%),hsl(180,100%,50%),hsl(240,100%,50%),hsl(300,100%,50%),hsl(0,100%,50%))}.pcr-app[data-theme=nano] .pcr-selection .pcr-color-opacity .pcr-slider{background:linear-gradient(to right,transparent,black),url('data:image/svg+xml;utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 2 2"><path fill="white" d="M1,0H2V1H1V0ZM0,1H1V2H0V1Z"/><path fill="gray" d="M0,0H1V1H0V0ZM1,1H2V2H1V1Z"/></svg>');background-size:100%,.25em}.ce-floating-toolbar{display:flex;position:absolute;z-index:9;align-items:center;height:36px;background:#ffffff;transition:all .3s ease-in-out;box-shadow:0 2px 8px #44494d29;border-radius:4px;padding:0 8px}.ce-floating-toolbar.hide{display:none}.ce-floating-toolbar>div{min-width:20px;margin:0 3px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:2px}.ce-floating-toolbar>div:hover,.ce-floating-toolbar>div.active{background-color:#19375812}.ce-floating-toolbar>div i{width:16px;height:16px;display:inline-block}.ce-floating-toolbar>div.ce-divider{padding:0;min-width:unset;width:1px;height:16px;margin:0 3px;display:inline-block;background-color:#cfd2d8}.ce-floating-toolbar>div.ce-size-add i{background:url()}.ce-floating-toolbar>div.ce-size-minus i{background:url()}.ce-floating-toolbar>div.ce-bold i{background:url()}.ce-floating-toolbar>div.ce-italic i{background:url()}.ce-floating-toolbar>div.ce-underline i{background:url()}.ce-floating-toolbar>div.ce-strikeout i{background:url()}.ce-floating-toolbar>div.ce-picker{height:20px;display:flex;flex-direction:column}.ce-floating-toolbar>div.ce-picker>span{width:16px;height:3px;display:inline-block;border:1px solid #e2e6ed}.ce-floating-toolbar>div.ce-picker .ce-picker-container{position:relative}.ce-floating-toolbar>div.ce-picker .ce-picker-container .pcr-app{position:absolute!important}.ce-floating-toolbar>div.ce-color i{background:url()}.ce-floating-toolbar>div.ce-highlight i{background:url()}`)),document.head.appendChild(e)}}catch(i){console.error("vite-plugin-css-injected-by-js",i)}})();
var Dt = Object.defineProperty;
var Rt = (p, h, g) => h in p ? Dt(p, h, { enumerable: !0, configurable: !0, writable: !0, value: g }) : p[h] = g;
var $ = (p, h, g) => (Rt(p, typeof h != "symbol" ? h + "" : h, g), g);
function Bt(p) {
return p && p.__esModule && Object.prototype.hasOwnProperty.call(p, "default") ? p.default : p;
}
var ct = { exports: {} };
/*! Pickr 1.9.0 MIT | https://github.com/Simonwep/pickr */
(function(p, h) {
(function(g, y) {
p.exports = y();
})(self, () => (() => {
var g = { d: (c, t) => {
for (var e in t)
g.o(t, e) && !g.o(c, e) && Object.defineProperty(c, e, { enumerable: !0, get: t[e] });
}, o: (c, t) => Object.prototype.hasOwnProperty.call(c, t), r: (c) => {
typeof Symbol < "u" && Symbol.toStringTag && Object.defineProperty(c, Symbol.toStringTag, { value: "Module" }), Object.defineProperty(c, "__esModule", { value: !0 });
} }, y = {};
g.d(y, { default: () => R });
var _ = {};
function A(c, t, e, n, r = {}) {
t instanceof HTMLCollection || t instanceof NodeList ? t = Array.from(t) : Array.isArray(t) || (t = [t]), Array.isArray(e) || (e = [e]);
for (const o of t)
for (const i of e)
o[c](i, n, { capture: !1, ...r });
return Array.prototype.slice.call(arguments, 1);
}
g.r(_), g.d(_, { adjustableInputNumbers: () => Q, createElementFromString: () => x, createFromTemplate: () => O, eventPath: () => P, off: () => k, on: () => b, resolveElement: () => D });
const b = A.bind(null, "addEventListener"), k = A.bind(null, "removeEventListener");
function x(c) {
const t = document.createElement("div");
return t.innerHTML = c.trim(), t.firstElementChild;
}
function O(c) {
const t = (n, r) => {
const o = n.getAttribute(r);
return n.removeAttribute(r), o;
}, e = (n, r = {}) => {
const o = t(n, ":obj"), i = t(n, ":ref"), a = o ? r[o] = {} : r;
i && (r[i] = n);
for (const s of Array.from(n.children)) {
const l = t(s, ":arr"), u = e(s, l ? {} : a);
l && (a[l] || (a[l] = [])).push(Object.keys(u).length ? u : s);
}
return r;
};
return e(x(c));
}
function P(c) {
let t = c.path || c.composedPath && c.composedPath();
if (t)
return t;
let e = c.target.parentElement;
for (t = [c.target, e]; e = e.parentElement; )
t.push(e);
return t.push(document, window), t;
}
function D(c) {
return c instanceof Element ? c : typeof c == "string" ? c.split(/>>/g).reduce((t, e, n, r) => (t = t.querySelector(e), n < r.length - 1 ? t.shadowRoot : t), document) : null;
}
function Q(c, t = (e) => e) {
function e(n) {
const r = [1e-3, 0.01, 0.1][Number(n.shiftKey || 2 * n.ctrlKey)] * (n.deltaY < 0 ? 1 : -1);
let o = 0, i = c.selectionStart;
c.value = c.value.replace(/[\d.]+/g, (a, s) => s <= i && s + a.length >= i ? (i = s, t(Number(a), r, o)) : (o++, a)), c.focus(), c.setSelectionRange(i, i), n.preventDefault(), c.dispatchEvent(new Event("input"));
}
b(c, "focus", () => b(window, "wheel", e, { passive: !1 })), b(c, "blur", () => k(window, "wheel", e));
}
const { min: N, max: lt, floor: pt, round: ut } = Math;
function X(c, t, e) {
t /= 100, e /= 100;
const n = pt(c = c / 360 * 6), r = c - n, o = e * (1 - t), i = e * (1 - r * t), a = e * (1 - (1 - r) * t), s = n % 6;
return [255 * [e, i, o, o, a, e][s], 255 * [a, e, e, i, o, o][s], 255 * [o, o, a, e, e, i][s]];
}
function dt(c, t, e) {
const n = (2 - (t /= 100)) * (e /= 100) / 2;
return n !== 0 && (t = n === 1 ? 0 : n < 0.5 ? t * e / (2 * n) : t * e / (2 - 2 * n)), [c, 100 * t, 100 * n];
}
function q(c, t, e) {
const n = N(c /= 255, t /= 255, e /= 255), r = lt(c, t, e), o = r - n;
let i, a;
if (o === 0)
i = a = 0;
else {
a = o / r;
const s = ((r - c) / 6 + o / 2) / o, l = ((r - t) / 6 + o / 2) / o, u = ((r - e) / 6 + o / 2) / o;
c === r ? i = u - l : t === r ? i = 1 / 3 + s - u : e === r && (i = 2 / 3 + l - s), i < 0 ? i += 1 : i > 1 && (i -= 1);
}
return [360 * i, 100 * a, 100 * r];
}
function ht(c, t, e, n) {
return t /= 100, e /= 100, [...q(255 * (1 - N(1, (c /= 100) * (1 - (n /= 100)) + n)), 255 * (1 - N(1, t * (1 - n) + n)), 255 * (1 - N(1, e * (1 - n) + n)))];
}
function mt(c, t, e) {
t /= 100;
const n = 2 * (t *= (e /= 100) < 0.5 ? e : 1 - e) / (e + t) * 100, r = 100 * (e + t);
return [c, isNaN(n) ? 0 : n, r];
}
function ft(c) {
return q(...c.match(/.{2}/g).map((t) => parseInt(t, 16)));
}
function vt(c) {
c = c.match(/^[a-zA-Z]+$/) ? function(r) {
if (r.toLowerCase() === "black")
return "#000";
const o = document.createElement("canvas").getContext("2d");
return o.fillStyle = r, o.fillStyle === "#000" ? null : o.fillStyle;
}(c) : c;
const t = { cmyk: /^cmyk\D+([\d.]+)\D+([\d.]+)\D+([\d.]+)\D+([\d.]+)/i, rgba: /^rgba?\D+([\d.]+)(%?)\D+([\d.]+)(%?)\D+([\d.]+)(%?)\D*?(([\d.]+)(%?)|$)/i, hsla: /^hsla?\D+([\d.]+)\D+([\d.]+)\D+([\d.]+)\D*?(([\d.]+)(%?)|$)/i, hsva: /^hsva?\D+([\d.]+)\D+([\d.]+)\D+([\d.]+)\D*?(([\d.]+)(%?)|$)/i, hexa: /^#?(([\dA-Fa-f]{3,4})|([\dA-Fa-f]{6})|([\dA-Fa-f]{8}))$/i }, e = (r) => r.map((o) => /^(|\d+)\.\d+|\d+$/.test(o) ? Number(o) : void 0);
let n;
t:
for (const r in t)
if (n = t[r].exec(c))
switch (r) {
case "cmyk": {
const [, o, i, a, s] = e(n);
if (o > 100 || i > 100 || a > 100 || s > 100)
break t;
return { values: ht(o, i, a, s), type: r };
}
case "rgba": {
let [, o, , i, , a, , , s] = e(n);
if (o = n[2] === "%" ? o / 100 * 255 : o, i = n[4] === "%" ? i / 100 * 255 : i, a = n[6] === "%" ? a / 100 * 255 : a, s = n[9] === "%" ? s / 100 : s, o > 255 || i > 255 || a > 255 || s < 0 || s > 1)
break t;
return { values: [...q(o, i, a), s], a: s, type: r };
}
case "hexa": {
let [, o] = n;
o.length !== 4 && o.length !== 3 || (o = o.split("").map((s) => s + s).join(""));
const i = o.substring(0, 6);
let a = o.substring(6);
return a = a ? parseInt(a, 16) / 255 : void 0, { values: [...ft(i), a], a, type: r };
}
case "hsla": {
let [, o, i, a, , s] = e(n);
if (s = n[6] === "%" ? s / 100 : s, o > 360 || i > 100 || a > 100 || s < 0 || s > 1)
break t;
return { values: [...mt(o, i, a), s], a: s, type: r };
}
case "hsva": {
let [, o, i, a, , s] = e(n);
if (s = n[6] === "%" ? s / 100 : s, o > 360 || i > 100 || a > 100 || s < 0 || s > 1)
break t;
return { values: [o, i, a, s], a: s, type: r };
}
}
return { values: null, type: null };
}
function j(c = 0, t = 0, e = 0, n = 1) {
const r = (i, a) => (s = -1) => a(~s ? i.map((l) => Number(l.toFixed(s))) : i), o = { h: c, s: t, v: e, a: n, toHSVA() {
const i = [o.h, o.s, o.v, o.a];
return i.toString = r(i, (a) => `hsva(${a[0]}, ${a[1]}%, ${a[2]}%, ${o.a})`), i;
}, toHSLA() {
const i = [...dt(o.h, o.s, o.v), o.a];
return i.toString = r(i, (a) => `hsla(${a[0]}, ${a[1]}%, ${a[2]}%, ${o.a})`), i;
}, toRGBA() {
const i = [...X(o.h, o.s, o.v), o.a];
return i.toString = r(i, (a) => `rgba(${a[0]}, ${a[1]}, ${a[2]}, ${o.a})`), i;
}, toCMYK() {
const i = function(a, s, l) {
const u = X(a, s, l), d = u[0] / 255, f = u[1] / 255, m = u[2] / 255, v = N(1 - d, 1 - f, 1 - m);
return [100 * (v === 1 ? 0 : (1 - d - v) / (1 - v)), 100 * (v === 1 ? 0 : (1 - f - v) / (1 - v)), 100 * (v === 1 ? 0 : (1 - m - v) / (1 - v)), 100 * v];
}(o.h, o.s, o.v);
return i.toString = r(i, (a) => `cmyk(${a[0]}%, ${a[1]}%, ${a[2]}%, ${a[3]}%)`), i;
}, toHEXA() {
const i = function(s, l, u) {
return X(s, l, u).map((d) => ut(d).toString(16).padStart(2, "0"));
}(o.h, o.s, o.v), a = o.a >= 1 ? "" : Number((255 * o.a).toFixed(0)).toString(16).toUpperCase().padStart(2, "0");
return a && i.push(a), i.toString = () => `#${i.join("").toUpperCase()}`, i;
}, clone: () => j(o.h, o.s, o.v, o.a) };
return o;
}
const M = (c) => Math.max(Math.min(c, 1), 0);
function K(c) {
const t = { options: Object.assign({ lock: null, onchange: () => 0, onstop: () => 0 }, c), _keyboard(o) {
const { options: i } = t, { type: a, key: s } = o;
if (document.activeElement === i.wrapper) {
const { lock: l } = t.options, u = s === "ArrowUp", d = s === "ArrowRight", f = s === "ArrowDown", m = s === "ArrowLeft";
if (a === "keydown" && (u || d || f || m)) {
let v = 0, C = 0;
l === "v" ? v = u || d ? 1 : -1 : l === "h" ? v = u || d ? -1 : 1 : (C = u ? -1 : f ? 1 : 0, v = m ? -1 : d ? 1 : 0), t.update(M(t.cache.x + 0.01 * v), M(t.cache.y + 0.01 * C)), o.preventDefault();
} else
s.startsWith("Arrow") && (t.options.onstop(), o.preventDefault());
}
}, _tapstart(o) {
b(document, ["mouseup", "touchend", "touchcancel"], t._tapstop), b(document, ["mousemove", "touchmove"], t._tapmove), o.cancelable && o.preventDefault(), t._tapmove(o);
}, _tapmove(o) {
const { options: i, cache: a } = t, { lock: s, element: l, wrapper: u } = i, d = u.getBoundingClientRect();
let f = 0, m = 0;
if (o) {
const H = o && o.touches && o.touches[0];
f = o ? (H || o).clientX : 0, m = o ? (H || o).clientY : 0, f < d.left ? f = d.left : f > d.left + d.width && (f = d.left + d.width), m < d.top ? m = d.top : m > d.top + d.height && (m = d.top + d.height), f -= d.left, m -= d.top;
} else
a && (f = a.x * d.width, m = a.y * d.height);
s !== "h" && (l.style.left = `calc(${f / d.width * 100}% - ${l.offsetWidth / 2}px)`), s !== "v" && (l.style.top = `calc(${m / d.height * 100}% - ${l.offsetHeight / 2}px)`), t.cache = { x: f / d.width, y: m / d.height };
const v = M(f / d.width), C = M(m / d.height);
switch (s) {
case "v":
return i.onchange(v);
case "h":
return i.onchange(C);
default:
return i.onchange(v, C);
}
}, _tapstop() {
t.options.onstop(), k(document, ["mouseup", "touchend", "touchcancel"], t._tapstop), k(document, ["mousemove", "touchmove"], t._tapmove);
}, trigger() {
t._tapmove();
}, update(o = 0, i = 0) {
const { left: a, top: s, width: l, height: u } = t.options.wrapper.getBoundingClientRect();
t.options.lock === "h" && (i = o), t._tapmove({ clientX: a + l * o, clientY: s + u * i });
}, destroy() {
const { options: o, _tapstart: i, _keyboard: a } = t;
k(document, ["keydown", "keyup"], a), k([o.wrapper, o.element], "mousedown", i), k([o.wrapper, o.element], "touchstart", i, { passive: !1 });
} }, { options: e, _tapstart: n, _keyboard: r } = t;
return b([e.wrapper, e.element], "mousedown", n), b([e.wrapper, e.element], "touchstart", n, { passive: !1 }), b(document, ["keydown", "keyup"], r), t;
}
function bt(c = {}) {
c = Object.assign({ onchange: () => 0, className: "", elements: [] }, c);
const t = b(c.elements, "click", (e) => {
c.elements.forEach((n) => n.classList[e.target === n ? "add" : "remove"](c.className)), c.onchange(e), e.stopPropagation();
});
return { destroy: () => k(...t) };
}
const gt = { variantFlipOrder: { start: "sme", middle: "mse", end: "ems" }, positionFlipOrder: { top: "tbrl", right: "rltb", bottom: "btrl", left: "lrbt" }, position: "bottom", margin: 8, padding: 0 }, yt = (c, t, e) => {
const n = typeof c != "object" || c instanceof HTMLElement ? { reference: c, popper: t, ...e } : c;
return { update(r = n) {
const { reference: o, popper: i } = Object.assign(n, r);
if (!i || !o)
throw new Error("Popper- or reference-element missing.");
return ((a, s, l) => {
const { container: u, arrow: d, margin: f, padding: m, position: v, variantFlipOrder: C, positionFlipOrder: H } = { container: document.documentElement.getBoundingClientRect(), ...gt, ...l }, { left: W, top: Y } = s.style;
s.style.left = "0", s.style.top = "0";
const w = a.getBoundingClientRect(), S = s.getBoundingClientRect(), _t = { t: w.top - S.height - f, b: w.bottom + f, r: w.right + f, l: w.left - S.width - f }, wt = { vs: w.left, vm: w.left + w.width / 2 - S.width / 2, ve: w.left + w.width - S.width, hs: w.top, hm: w.bottom - w.height / 2 - S.height / 2, he: w.bottom - S.height }, [kt, Ct = "middle"] = v.split("-"), $t = H[kt], At = C[Ct], { top: tt, left: et, bottom: ot, right: nt } = u;
for (const T of $t) {
const I = T === "t" || T === "b";
let B = _t[T];
const [z, G] = I ? ["top", "left"] : ["left", "top"], [it, Z] = I ? [S.height, S.width] : [S.width, S.height], [St, Lt] = I ? [ot, nt] : [nt, ot], [Et, Ot] = I ? [tt, et] : [et, tt];
if (!(B < Et || B + it + m > St))
for (const st of At) {
let U = wt[(I ? "v" : "h") + st];
if (!(U < Ot || U + Z + m > Lt)) {
if (U -= S[G], B -= S[z], s.style[G] = `${U}px`, s.style[z] = `${B}px`, d) {
const rt = I ? w.width / 2 : w.height / 2, xt = 2 * rt < Z ? w[G] + rt : U + Z / 2;
B < w[z] && (B += it), d.style[G] = `${xt}px`, d.style[z] = `${B}px`;
}
return T + st;
}
}
}
return s.style.left = W, s.style.top = Y, null;
})(o, i, n);
} };
}, F = class {
constructor(t) {
$(this, "_initializingActive", !0);
$(this, "_recalc", !0);
$(this, "_nanopop", null);
$(this, "_root", null);
$(this, "_color", j());
$(this, "_lastColor", j());
$(this, "_swatchColors", []);
$(this, "_setupAnimationFrame", null);
$(this, "_eventListener", { init: [], save: [], hide: [], show: [], clear: [], change: [], changestop: [], cancel: [], swatchselect: [] });
this.options = t = Object.assign({ ...F.DEFAULT_OPTIONS }, t);
const { swatches: e, components: n, theme: r, sliders: o, lockOpacity: i, padding: a } = t;
["nano", "monolith"].includes(r) && !o && (t.sliders = "h"), n.interaction || (n.interaction = {});
const { preview: s, opacity: l, hue: u, palette: d } = n;
n.opacity = !i && l, n.palette = d || s || l || u, this._preBuild(), this._buildComponents(), this._bindEvents(), this._finalBuild(), e && e.length && e.forEach((C) => this.addSwatch(C));
const { button: f, app: m } = this._root;
this._nanopop = yt(f, m, { margin: a }), f.setAttribute("role", "button"), f.setAttribute("aria-label", this._t("btn:toggle"));
const v = this;
this._setupAnimationFrame = requestAnimationFrame(function C() {
if (!m.offsetWidth)
return requestAnimationFrame(C);
v.setColor(t.default), v._rePositioningPicker(), t.defaultRepresentation && (v._representation = t.defaultRepresentation, v.setColorRepresentation(v._representation)), t.showAlways && v.show(), v._initializingActive = !1, v._emit("init");
});
}
_preBuild() {
const { options: t } = this;
for (const e of ["el", "container"])
t[e] = D(t[e]);
this._root = ((e) => {
const { components: n, useAsButton: r, inline: o, appClass: i, theme: a, lockOpacity: s } = e.options, l = (m) => m ? "" : 'style="display:none" hidden', u = (m) => e._t(m), d = O(`
<div :ref="root" class="pickr">
${r ? "" : '<button type="button" :ref="button" class="pcr-button"></button>'}
<div :ref="app" class="pcr-app ${i || ""}" data-theme="${a}" ${o ? 'style="position: unset"' : ""} aria-label="${u("ui:dialog")}" role="window">
<div class="pcr-selection" ${l(n.palette)}>
<div :obj="preview" class="pcr-color-preview" ${l(n.preview)}>
<button type="button" :ref="lastColor" class="pcr-last-color" aria-label="${u("btn:last-color")}"></button>
<div :ref="currentColor" class="pcr-current-color"></div>
</div>
<div :obj="palette" class="pcr-color-palette">
<div :ref="picker" class="pcr-picker"></div>
<div :ref="palette" class="pcr-palette" tabindex="0" aria-label="${u("aria:palette")}" role="listbox"></div>
</div>
<div :obj="hue" class="pcr-color-chooser" ${l(n.hue)}>
<div :ref="picker" class="pcr-picker"></div>
<div :ref="slider" class="pcr-hue pcr-slider" tabindex="0" aria-label="${u("aria:hue")}" role="slider"></div>
</div>
<div :obj="opacity" class="pcr-color-opacity" ${l(n.opacity)}>
<div :ref="picker" class="pcr-picker"></div>
<div :ref="slider" class="pcr-opacity pcr-slider" tabindex="0" aria-label="${u("aria:opacity")}" role="slider"></div>
</div>
</div>
<div class="pcr-swatches ${n.palette ? "" : "pcr-last"}" :ref="swatches"></div>
<div :obj="interaction" class="pcr-interaction" ${l(Object.keys(n.interaction).length)}>
<input :ref="result" class="pcr-result" type="text" spellcheck="false" ${l(n.interaction.input)} aria-label="${u("aria:input")}">
<input :arr="options" class="pcr-type" data-type="HEXA" value="${s ? "HEX" : "HEXA"}" type="button" ${l(n.interaction.hex)}>
<input :arr="options" class="pcr-type" data-type="RGBA" value="${s ? "RGB" : "RGBA"}" type="button" ${l(n.interaction.rgba)}>
<input :arr="options" class="pcr-type" data-type="HSLA" value="${s ? "HSL" : "HSLA"}" type="button" ${l(n.interaction.hsla)}>
<input :arr="options" class="pcr-type" data-type="HSVA" value="${s ? "HSV" : "HSVA"}" type="button" ${l(n.interaction.hsva)}>
<input :arr="options" class="pcr-type" data-type="CMYK" value="CMYK" type="button" ${l(n.interaction.cmyk)}>
<input :ref="save" class="pcr-save" value="${u("btn:save")}" type="button" ${l(n.interaction.save)} aria-label="${u("aria:btn:save")}">
<input :ref="cancel" class="pcr-cancel" value="${u("btn:cancel")}" type="button" ${l(n.interaction.cancel)} aria-label="${u("aria:btn:cancel")}">
<input :ref="clear" class="pcr-clear" value="${u("btn:clear")}" type="button" ${l(n.interaction.clear)} aria-label="${u("aria:btn:clear")}">
</div>
</div>
</div>
`), f = d.interaction;
return f.options.find((m) => !m.hidden && !m.classList.add("active")), f.type = () => f.options.find((m) => m.classList.contains("active")), d;
})(this), t.useAsButton && (this._root.button = t.el), t.container.appendChild(this._root.root);
}
_finalBuild() {
const t = this.options, e = this._root;
if (t.container.removeChild(e.root), t.inline) {
const n = t.el.parentElement;
t.el.nextSibling ? n.insertBefore(e.app, t.el.nextSibling) : n.appendChild(e.app);
} else
t.container.appendChild(e.app);
t.useAsButton ? t.inline && t.el.remove() : t.el.parentNode.replaceChild(e.root, t.el), t.disabled && this.disable(), t.comparison || (e.button.style.transition = "none", t.useAsButton || (e.preview.lastColor.style.transition = "none")), this.hide();
}
_buildComponents() {
const t = this, e = this.options.components, n = (t.options.sliders || "v").repeat(2), [r, o] = n.match(/^[vh]+$/g) ? n : [], i = () => this._color || (this._color = this._lastColor.clone()), a = { palette: K({ element: t._root.palette.picker, wrapper: t._root.palette.palette, onstop: () => t._emit("changestop", "slider", t), onchange(s, l) {
if (!e.palette)
return;
const u = i(), { _root: d, options: f } = t, { lastColor: m, currentColor: v } = d.preview;
t._recalc && (u.s = 100 * s, u.v = 100 - 100 * l, u.v < 0 && (u.v = 0), t._updateOutput("slider"));
const C = u.toRGBA().toString(0);
this.element.style.background = C, this.wrapper.style.background = `
linear-gradient(to top, rgba(0, 0, 0, ${u.a}), transparent),
linear-gradient(to left, hsla(${u.h}, 100%, 50%, ${u.a}), rgba(255, 255, 255, ${u.a}))
`, f.comparison ? f.useAsButton || t._lastColor || m.style.setProperty("--pcr-color", C) : (d.button.style.setProperty("--pcr-color", C), d.button.classList.remove("clear"));
const H = u.toHEXA().toString();
for (const { el: W, color: Y } of t._swatchColors)
W.classList[H === Y.toHEXA().toString() ? "add" : "remove"]("pcr-active");
v.style.setProperty("--pcr-color", C);
} }), hue: K({ lock: o === "v" ? "h" : "v", element: t._root.hue.picker, wrapper: t._root.hue.slider, onstop: () => t._emit("changestop", "slider", t), onchange(s) {
if (!e.hue || !e.palette)
return;
const l = i();
t._recalc && (l.h = 360 * s), this.element.style.backgroundColor = `hsl(${l.h}, 100%, 50%)`, a.palette.trigger();
} }), opacity: K({ lock: r === "v" ? "h" : "v", element: t._root.opacity.picker, wrapper: t._root.opacity.slider, onstop: () => t._emit("changestop", "slider", t), onchange(s) {
if (!e.opacity || !e.palette)
return;
const l = i();
t._recalc && (l.a = Math.round(100 * s) / 100), this.element.style.background = `rgba(0, 0, 0, ${l.a})`, a.palette.trigger();
} }), selectable: bt({ elements: t._root.interaction.options, className: "active", onchange(s) {
t._representation = s.target.getAttribute("data-type").toUpperCase(), t._recalc && t._updateOutput("swatch");
} }) };
this._components = a;
}
_bindEvents() {
const { _root: t, options: e } = this, n = [b(t.interaction.clear, "click", () => this._clearColor()), b([t.interaction.cancel, t.preview.lastColor], "click", () => {
this.setHSVA(...(this._lastColor || this._color).toHSVA(), !0), this._emit("cancel");
}), b(t.interaction.save, "click", () => {
!this.applyColor() && !e.showAlways && this.hide();
}), b(t.interaction.result, ["keyup", "input"], (r) => {
this.setColor(r.target.value, !0) && !this._initializingActive && (this._emit("change", this._color, "input", this), this._emit("changestop", "input", this)), r.stopImmediatePropagation();
}), b(t.interaction.result, ["focus", "blur"], (r) => {
this._recalc = r.type === "blur", this._recalc && this._updateOutput(null);
}), b([t.palette.palette, t.palette.picker, t.hue.slider, t.hue.picker, t.opacity.slider, t.opacity.picker], ["mousedown", "touchstart"], () => this._recalc = !0, { passive: !0 })];
if (!e.showAlways) {
const r = e.closeWithKey;
n.push(b(t.button, "click", () => this.isOpen() ? this.hide() : this.show()), b(document, "keyup", (o) => this.isOpen() && (o.key === r || o.code === r) && this.hide()), b(document, ["touchstart", "mousedown"], (o) => {
this.isOpen() && !P(o).some((i) => i === t.app || i === t.button) && this.hide();
}, { capture: !0 }));
}
if (e.adjustableNumbers) {
const r = { rgba: [255, 255, 255, 1], hsva: [360, 100, 100, 1], hsla: [360, 100, 100, 1], cmyk: [100, 100, 100, 100] };
Q(t.interaction.result, (o, i, a) => {
const s = r[this.getColorRepresentation().toLowerCase()];
if (s) {
const l = s[a], u = o + (l >= 100 ? 1e3 * i : i);
return u <= 0 ? 0 : Number((u < l ? u : l).toPrecision(3));
}
return o;
});
}
if (e.autoReposition && !e.inline) {
let r = null;
const o = this;
n.push(b(window, ["scroll", "resize"], () => {
o.isOpen() && (e.closeOnScroll && o.hide(), r === null ? (r = setTimeout(() => r = null, 100), requestAnimationFrame(function i() {
o._rePositioningPicker(), r !== null && requestAnimationFrame(i);
})) : (clearTimeout(r), r = setTimeout(() => r = null, 100)));
}, { capture: !0 }));
}
this._eventBindings = n;
}
_rePositioningPicker() {
const { options: t } = this;
if (!t.inline && !this._nanopop.update({ container: document.body.getBoundingClientRect(), position: t.position })) {
const e = this._root.app, n = e.getBoundingClientRect();
e.style.top = (window.innerHeight - n.height) / 2 + "px", e.style.left = (window.innerWidth - n.width) / 2 + "px";
}
}
_updateOutput(t) {
const { _root: e, _color: n, options: r } = this;
if (e.interaction.type()) {
const o = `to${e.interaction.type().getAttribute("data-type")}`;
e.interaction.result.value = typeof n[o] == "function" ? n[o]().toString(r.outputPrecision) : "";
}
!this._initializingActive && this._recalc && this._emit("change", n, t, this);
}
_clearColor(t = !1) {
const { _root: e, options: n } = this;
n.useAsButton || e.button.style.setProperty("--pcr-color", "rgba(0, 0, 0, 0.15)"), e.button.classList.add("clear"), n.showAlways || this.hide(), this._lastColor = null, this._initializingActive || t || (this._emit("save", null), this._emit("clear"));
}
_parseLocalColor(t) {
const { values: e, type: n, a: r } = vt(t), { lockOpacity: o } = this.options, i = r !== void 0 && r !== 1;
return e && e.length === 3 && (e[3] = void 0), { values: !e || o && i ? null : e, type: n };
}
_t(t) {
return this.options.i18n[t] || F.I18N_DEFAULTS[t];
}
_emit(t, ...e) {
this._eventListener[t].forEach((n) => n(...e, this));
}
on(t, e) {
return this._eventListener[t].push(e), this;
}
off(t, e) {
const n = this._eventListener[t] || [], r = n.indexOf(e);
return ~r && n.splice(r, 1), this;
}
addSwatch(t) {
const { values: e } = this._parseLocalColor(t);
if (e) {
const { _swatchColors: n, _root: r } = this, o = j(...e), i = x(`<button type="button" style="--pcr-color: ${o.toRGBA().toString(0)}" aria-label="${this._t("btn:swatch")}"/>`);
return r.swatches.appendChild(i), n.push({ el: i, color: o }), this._eventBindings.push(b(i, "click", () => {
this.setHSVA(...o.toHSVA(), !0), this._emit("swatchselect", o), this._emit("change", o, "swatch", this);
})), !0;
}
return !1;
}
removeSwatch(t) {
const e = this._swatchColors[t];
if (e) {
const { el: n } = e;
return this._root.swatches.removeChild(n), this._swatchColors.splice(t, 1), !0;
}
return !1;
}
applyColor(t = !1) {
const { preview: e, button: n } = this._root, r = this._color.toRGBA().toString(0);
return e.lastColor.style.setProperty("--pcr-color", r), this.options.useAsButton || n.style.setProperty("--pcr-color", r), n.classList.remove("clear"), this._lastColor = this._color.clone(), this._initializingActive || t || this._emit("save", this._color), this;
}
destroy() {
cancelAnimationFrame(this._setupAnimationFrame), this._eventBindings.forEach((t) => k(...t)), Object.keys(this._components).forEach((t) => this._components[t].destroy());
}
destroyAndRemove() {
this.destroy();
const { root: t, app: e } = this._root;
t.parentElement && t.parentElement.removeChild(t), e.parentElement.removeChild(e), Object.keys(this).forEach((n) => this[n] = null);
}
hide() {
return !!this.isOpen() && (this._root.app.classList.remove("visible"), this._emit("hide"), !0);
}
show() {
return !this.options.disabled && !this.isOpen() && (this._root.app.classList.add("visible"), this._rePositioningPicker(), this._emit("show", this._color), this);
}
isOpen() {
return this._root.app.classList.contains("visible");
}
setHSVA(t = 360, e = 0, n = 0, r = 1, o = !1) {
const i = this._recalc;
if (this._recalc = !1, t < 0 || t > 360 || e < 0 || e > 100 || n < 0 || n > 100 || r < 0 || r > 1)
return !1;
this._color = j(t, e, n, r);
const { hue: a, opacity: s, palette: l } = this._components;
return a.update(t / 360), s.update(r), l.update(e / 100, 1 - n / 100), o || this.applyColor(), i && this._updateOutput(), this._recalc = i, !0;
}
setColor(t, e = !1) {
if (t === null)
return this._clearColor(e), !0;
const { values: n, type: r } = this._parseLocalColor(t);
if (n) {
const o = r.toUpperCase(), { options: i } = this._root.interaction, a = i.find((s) => s.getAttribute("data-type") === o);
if (a && !a.hidden)
for (const s of i)
s.classList[s === a ? "add" : "remove"]("active");
return !!this.setHSVA(...n, e) && this.setColorRepresentation(o);
}
return !1;
}
setColorRepresentation(t) {
return t = t.toUpperCase(), !!this._root.interaction.options.find((e) => e.getAttribute("data-type").startsWith(t) && !e.click());
}
getColorRepresentation() {
return this._representation;
}
getColor() {
return this._color;
}
getSelectedColor() {
return this._lastColor;
}
getRoot() {
return this._root;
}
disable() {
return this.hide(), this.options.disabled = !0, this._root.button.classList.add("disabled"), this;
}
enable() {
return this.options.disabled = !1, this._root.button.classList.remove("disabled"), this;
}
};
let R = F;
return $(R, "utils", _), $(R, "version", "1.9.0"), $(R, "I18N_DEFAULTS", { "ui:dialog": "color picker dialog", "btn:toggle": "toggle color picker dialog", "btn:swatch": "color swatch", "btn:last-color": "use previous color", "btn:save": "Save", "btn:cancel": "Cancel", "btn:clear": "Clear", "aria:btn:save": "save and close", "aria:btn:cancel": "cancel and close", "aria:btn:clear": "clear and close", "aria:input": "color input field", "aria:palette": "color selection area", "aria:hue": "hue selection slider", "aria:opacity": "selection slider" }), $(R, "DEFAULT_OPTIONS", { appClass: null, theme: "classic", useAsButton: !1, padding: 8, disabled: !1, comparison: !0, closeOnScroll: !1, outputPrecision: 0, lockOpacity: !1, autoReposition: !0, container: "body", components: { interaction: {} }, i18n: {}, swatches: null, inline: !1, sliders: null, default: "#42445a", defaultRepresentation: null, position: "bottom-middle", adjustableNumbers: !0, showAlways: !1, closeWithKey: "Escape" }), $(R, "create", (t) => new F(t)), y = y.default;
})());
})(ct);
var Pt = ct.exports;
const Ht = /* @__PURE__ */ Bt(Pt);
var L;
(function(p) {
p.SIZE_ADD = "size-add", p.SIZE_MINUS = "size-minus", p.BOLD = "bold", p.ITALIC = "italic", p.UNDERLINE = "underline", p.STRIKEOUT = "strikeout", p.COLOR = "color", p.HIGHLIGHT = "highlight";
})(L || (L = {}));
const E = "ce";
function at(p, h, g) {
const y = document.createElement("div");
y.classList.add(`${E}-picker`), y.classList.add(`${E}-${h}`);
const _ = document.createElement("div");
_.classList.add(`${E}-picker-container`);
const A = document.createElement("div");
_.append(A), y.append(_), p.append(y);
const b = "#000000", k = new Ht({
el: A,
theme: "nano",
useAsButton: !0,
inline: !0,
default: b,
i18n: {
"btn:save": "✓"
},
components: {
preview: !0,
opacity: !0,
hue: !0,
interaction: {
input: !0,
save: !0
}
}
}), x = document.createElement("i");
y.append(x);
const O = document.createElement("span");
O.style.backgroundColor = b, y.append(O), y.onclick = (P) => {
const D = P.target;
_ !== D && !_.contains(D) && k.show();
}, k.on("save", (P) => {
k.hide();
const D = P.toHEXA().toString();
O.style.backgroundColor = D, g(D);
});
}
const It = [
{
key: L.SIZE_ADD,
callback(p) {
p.command.executeSizeAdd();
}
},
{
key: L.SIZE_MINUS,
callback(p) {
p.command.executeSizeMinus();
}
},
{
isDivider: !0
},
{
key: L.BOLD,
callback(p) {
p.command.executeBold();
}
},
{
key: L.ITALIC,
callback(p) {
p.command.executeItalic();
}
},
{
key: L.UNDERLINE,
callback(p) {
p.command.executeUnderline();
}
},
{
key: L.STRIKEOUT,
callback(p) {
p.command.executeStrikeout();
}
},
{
isDivider: !0
},
{
render(p, h) {
at(p, L.COLOR, (g) => {
h.command.executeColor(g);
});
}
},
{
render(p, h) {
at(p, L.HIGHLIGHT, (g) => {
h.command.executeHighlight(g);
});
}
}
];
function Nt(p) {
const h = document.createElement("div");
h.classList.add(`${E}-floating-toolbar`);
for (const g of It)
if (g.render)
g.render(h, p);
else if (g.isDivider) {
const y = document.createElement("div");
y.classList.add(`${E}-divider`), h.ap