@ribajs/bs4
Version:
Bootstrap 4 module for Riba.js
341 lines • 28.1 kB
JavaScript
import Color from "@sphinxxxx/color-conversion";
import { Component } from "@ribajs/core";
import { EventDispatcher } from "@ribajs/events";
import { hasChildNodesTrim } from "@ribajs/utils/src/dom.js";
import { debounce } from "@ribajs/utils/src/control";
class EventBucket {
events = [];
add(target, type, handler) {
target.addEventListener(type, handler, false);
this.events.push({
target,
type,
handler,
});
}
remove(target, type, handler) {
this.events = this.events.filter((e) => {
let isMatch = true;
if (target && target !== e.target) {
isMatch = false;
}
if (type && type !== e.type) {
isMatch = false;
}
if (handler && handler !== e.handler) {
isMatch = false;
}
if (isMatch) {
EventBucket._doRemove(e.target, e.type, e.handler);
}
return !isMatch;
});
}
static _doRemove(target, type, handler) {
target.removeEventListener(type, handler, false);
}
destroy() {
this.events.forEach((e) => EventBucket._doRemove(e.target, e.type, e.handler));
this.events = [];
}
}
const dragTrack = (eventBucket, area, callback) => {
let dragging = false;
const clamp = (val, min, max) => {
return Math.max(min, Math.min(val, max));
};
const onMove = (e, info, starting) => {
if (starting) {
dragging = true;
}
if (!dragging) {
return;
}
e.preventDefault();
const bounds = area.getBoundingClientRect(), w = bounds.width, h = bounds.height, x = info.clientX, y = info.clientY;
const relX = clamp(x - bounds.left, 0, w), relY = clamp(y - bounds.top, 0, h);
callback(relX / w, relY / h);
};
const onMouse = (e, starting) => {
const button = e.buttons === undefined ? e.which : e.buttons;
if (button === 1) {
onMove(e, e, starting);
}
else {
dragging = false;
}
};
function onTouch(e, starting) {
if (e.touches.length === 1) {
onMove(e, e.touches[0], starting);
}
else {
dragging = false;
}
}
eventBucket.add(area, "mousedown", (e) => {
onMouse(e, true);
});
eventBucket.add(area, "touchstart", (e) => {
onTouch(e, true);
});
eventBucket.add(window, "mousemove", onMouse);
eventBucket.add(area, "touchmove", onTouch);
eventBucket.add(window, "mouseup", () => {
dragging = false;
});
eventBucket.add(area, "touchend", () => {
dragging = false;
});
eventBucket.add(area, "touchcancel", () => {
dragging = false;
});
};
const BG_TRANSP = `url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='2' height='2'%3E%3Cpath d='M1,0H0V1H2V2H1' fill='lightgrey'/%3E%3C/svg%3E")`;
const HUES = 360;
const EVENT_KEY = "keydown";
function stopEvent(e) {
e.preventDefault();
e.stopPropagation();
}
function onKey(bucket, target, keys, handler, stop = false) {
bucket.add(target, EVENT_KEY, function (e) {
if (keys.indexOf(e.key) >= 0) {
if (stop) {
stopEvent(e);
}
handler(e);
}
});
}
export class Bs4ColorPickerComponent extends Component {
static tagName = "bs4-colorpicker";
static get observedAttributes() {
return [
"namespace",
"alpha",
"editor",
"editor-format",
"cancel-button",
"okay-button",
"color",
];
}
eventDispatcher;
color;
_debug = false;
scope = {
namespace: "main",
hsl: [],
cssHue: "",
cssHsl: "",
cssHsla: "",
alphaBg: "",
color: "#0cf",
alpha: true,
editor: true,
editorFormat: "hex",
cancelButton: false,
okayButton: false,
};
events = new EventBucket();
_domH = null;
_domSL = null;
_domA = null;
_domEdit = null;
_domSample = null;
_domOkay = null;
_domCancel = null;
constructor() {
super();
}
connectedCallback() {
super.connectedCallback();
super.init(Bs4ColorPickerComponent.observedAttributes);
}
requiredAttributes() {
return [];
}
async beforeBind() {
await super.beforeBind();
this.eventDispatcher = EventDispatcher.getInstance("bs4-colorpicker:" + this.scope.namespace);
this.setColor(this.scope.color);
this.updateUI();
this.bindEvents();
}
async afterTemplate(template) {
await super.afterTemplate(template);
this.setElements();
}
onChange(color) {
this.debug("onChange", color);
this.eventDispatcher?.trigger("change", color);
}
onDone(color) {
this.debug("onDone", color);
this.eventDispatcher?.trigger("done", color);
}
async template() {
if (hasChildNodesTrim(this)) {
return null;
}
else {
const { default: template } = await import("./bs4-colorpicker.component.html?raw");
return template;
}
}
parsedAttributeChangedCallback(attributeName, oldValue, newValue, namespace) {
super.parsedAttributeChangedCallback(attributeName, oldValue, newValue, namespace);
if (attributeName === "color") {
this.setColor(this.scope.color);
}
}
setColor(color, flags = { silent: false }) {
return debounce(this._setColor.bind(this))(color, flags);
}
_setColor(color, flags = { silent: false }) {
if (typeof color === "string") {
color = color.trim();
}
if (!color) {
return;
}
flags = flags || {};
let c;
try {
c = new Color(color);
}
catch (ex) {
if (flags.failSilently) {
return;
}
throw ex;
}
if (!this.scope.alpha) {
const hsla = c.hsla;
hsla[3] = 1;
c.hsla = hsla;
}
this.color = c;
this.setHSLA(null, null, null, null, flags);
}
setElements() {
this._domH = this.querySelector(".picker_hue");
this._domSL = this.querySelector(".picker_sl");
this._domA = this.querySelector(".picker_alpha");
this._domEdit =
this.querySelector(".picker_editor") || null;
this._domSample = this.querySelector(".picker_sample");
this._domOkay = this.querySelector(".picker_done");
this._domCancel = this.querySelector(".picker_cancel");
}
disconnectedCallback() {
this.events.destroy();
}
bindEvents() {
const events = this.events;
const addEvent = (target, type, handler) => {
events.add(target, type, handler);
};
addEvent(this, "click", (e) => e.preventDefault());
const _dragTrack = dragTrack.bind(this);
if (!this._domH ||
!this._domSL ||
!this._domA ||
!this._domEdit ||
!this._domOkay) {
throw new Error("Not ready!");
}
_dragTrack(events, this._domH, (x) => this.setHSLA(x));
_dragTrack(events, this._domSL, (x, y) => this.setHSLA(null, x, 1 - y));
if (this.scope.alpha) {
_dragTrack(events, this._domA, (x, y) => this.setHSLA(null, null, null, 1 - y));
}
addEvent(this._domEdit, "input", (e) => {
const input = e.target;
this.setColor(input.value, {
fromEditor: true,
failSilently: true,
});
});
addEvent(this._domEdit, "focus", (e) => {
const input = e.target;
if (input.selectionStart === input.selectionEnd) {
input.select();
}
});
const onDoneProxy = () => {
this.onDone(this.color);
};
addEvent(this._domOkay, "click", onDoneProxy);
onKey(events, this, ["Enter"], onDoneProxy);
}
setHSLA(h = null, s = null, l = null, a = null, flags = {}) {
if (!this.color) {
throw new Error("Not ready!");
}
const hsla = this.color.hsla;
[h, s, l, a].forEach((x, i) => {
if (x || x === 0) {
hsla[i] = x;
}
});
this.color.hsla = hsla;
this.updateUI(flags);
if (this.onChange && !flags.silent) {
this.onChange(this.color);
}
}
updateUI(flags = {}) {
return debounce(this._updateUI.bind(this))(flags);
}
_updateUI(flags = {}) {
if (!this || !this.color) {
return;
}
this.scope.hsl = this.color.hsla;
this.scope.cssHue = `hsl(${this.scope.hsl[0] * HUES}, 100%, 50%)`;
this.scope.cssHsl = this.color.hslString;
this.scope.cssHsla = this.color.hslaString;
if (!this._domH || !this._domSL || !this._domA) {
throw new Error("Color ui elements not found!");
}
const thumbH = this._domH.querySelector(".picker_selector");
const thumbSL = this._domSL.querySelector(".picker_selector");
const thumbA = this._domA.querySelector(".picker_selector");
if (!thumbH || !thumbSL || !thumbA || !this._domEdit || !this._domSample) {
console.error(thumbH, thumbSL, thumbA, this._domA, this._domSL, this._domH, this._domEdit, this._domSample);
throw new Error("Not ready!");
}
const posX = (parent, child, relX) => {
child.style.left = relX * 100 + "%";
};
const posY = (parent, child, relY) => {
child.style.top = relY * 100 + "%";
};
posX(this._domH, thumbH, this.scope.hsl[0]);
posX(this._domSL, thumbSL, this.scope.hsl[1]);
posY(this._domSL, thumbSL, 1 - this.scope.hsl[2]);
posY(this._domA, thumbA, 1 - this.scope.hsl[3]);
const opaque = this.scope.cssHsl;
const transp = opaque.replace("hsl", "hsla").replace(")", ", 0)");
const bg = `linear-gradient(${[opaque, transp]})`;
this.scope.alphaBg = bg + ", " + BG_TRANSP;
if (!flags.fromEditor) {
const format = this.scope.editorFormat, alpha = this.scope.alpha;
let color;
switch (format) {
case "rgb":
color = this.color.printRGB(alpha);
break;
case "hsl":
color = this.color.printHSL(alpha);
break;
default:
color = this.color.printHex(alpha);
}
this.scope.color = color;
}
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bs4-colorpicker.component.js","sourceRoot":"","sources":["../../../src/components/bs4-colorpicker/bs4-colorpicker.component.ts"],"names":[],"mappings":"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"}