UNPKG

@ribajs/bs4

Version:

Bootstrap 4 module for Riba.js

231 lines 21 kB
import { extend } from "@ribajs/utils"; import { Component } from "@ribajs/core"; import { hasChildNodesTrim } from "@ribajs/utils/src/dom.js"; import template from "./bs4-tagged-image.component.html?raw"; import { debounce } from "@ribajs/utils/src/control.js"; export class Bs4TaggedImageComponent extends Component { static tagName = "bs4-tagged-image"; autobind = true; _debug = false; static get observedAttributes() { return ["tags", "options", "debug"]; } image; scope = { debug: false, tags: [], options: { popoverOptions: {}, multiPopover: false, tagOptions: {}, }, fillPopoverOptions: (options) => { return { ...this.scope.options.popoverOptions, ...this.scope.options.tagOptions.popoverOptions, ...options, }; }, triggerOnFocus: (options) => { return this.scope.fillPopoverOptions(options).trigger ? 0 : null; }, onClick: this.onClick.bind(this), onPopoverBound: this.onPopoverBound.bind(this), onPopoverShown: this.onPopoverShown.bind(this), onPopoverHidden: this.onPopoverHidden.bind(this), updateTagPositions: debounce(this.updateTagPositions.bind(this)), }; constructor() { super(); this.scope.options.popoverOptions.container = this; } parsedAttributeChangedCallback(attributeName, oldValue, newValue) { if (attributeName === "options") { if (this.bound) { this.scope.options = newValue; } else { this.scope.options = extend({ deep: true }, oldValue, newValue); } const po = this.scope.options.popoverOptions; if (po && typeof po.container === "string") { po.container = document.querySelector(po.container) || undefined; } } } template() { if (hasChildNodesTrim(this)) { this.parseChildTags(); } return template; } async beforeBind() { await super.beforeBind(); this.image = this.querySelector("img"); this.addEventListeners(); this.initTags(); } addEventListeners() { const img = this.image; img.addEventListener("load", this.scope.updateTagPositions); img.addEventListener("click", this.scope.onClick); window.addEventListener("resize", this.scope.updateTagPositions, { passive: true, }); } removeEventListeners() { const img = this.image; img.removeEventListener("load", this.scope.updateTagPositions); img.removeEventListener("click", this.scope.onClick); window.removeEventListener("resize", this.scope.updateTagPositions); } async afterBind() { this.passImageAttributes(); await super.afterBind(); } connectedCallback() { super.connectedCallback(); this.init(Bs4TaggedImageComponent.observedAttributes); } disconnectedCallback() { this.removeEventListener("click", this.scope.onClick); window.removeEventListener("resize", this.scope.updateTagPositions); } parseChildTags() { this.debug(`parseChildTags()`); for (const tagEl of Array.from(this.querySelectorAll("tag"))) { const title = tagEl.getAttribute("title") || ""; const content = tagEl.innerHTML; const x = ((v) => (isNaN(v) ? Math.random() : v))(parseFloat(tagEl.getAttribute("x") || "")); const y = ((v) => (isNaN(v) ? Math.random() : v))(parseFloat(tagEl.getAttribute("y") || "")); const shape = tagEl.getAttribute("shape") || undefined; const color = tagEl.getAttribute("color") || undefined; const borderRadius = tagEl.getAttribute("border-radius") || undefined; const fullSize = tagEl.getAttribute("full-size") || undefined; const smallSize = tagEl.getAttribute("small-size") || undefined; const tagData = { ...this.scope.options.tagOptions, popoverOptions: this.scope.fillPopoverOptions({ title, content, html: true, }), x, y, shape, color, borderRadius, fullSize, smallSize, }; this.scope.tags.push(tagData); } } initTags() { const scopeTagOptions = this.scope.options.tagOptions; for (const [index, tag] of this.scope.tags.entries()) { tag.index = index; tag.shape = tag.shape || scopeTagOptions.shape; tag.borderRadius = tag.borderRadius || scopeTagOptions.borderRadius; tag.smallSize = tag.smallSize || scopeTagOptions.smallSize; tag.fullSize = tag.fullSize || scopeTagOptions.fullSize; tag.color = tag.color || scopeTagOptions.color; } } passImageAttributes() { const img = this.image; const attrs = this.attributes; for (let i = attrs.length - 1; i >= 0; i--) { if (attrs[i].name.startsWith("img-")) { img.setAttribute(attrs[i].name.substr(4), attrs[i].value); } } } onClick(e) { if (this.scope.debug) { const img = this.image; const { clientTop, clientLeft, width, height, naturalWidth, naturalHeight, } = img; const { clientX, clientY } = e; let x = clientX - clientLeft; let y = clientY - clientTop; const wRatio = width / naturalWidth; const hRatio = height / naturalHeight; let actualWidth = width; let actualHeight = height; if (wRatio < hRatio) { actualWidth = (width * hRatio) / wRatio; x += (actualWidth - width) / 2; } else if (hRatio < wRatio) { actualHeight = (height * wRatio) / hRatio; y += (actualHeight - height) / 2; } x *= 100 / actualWidth; y *= 100 / actualHeight; console.log({ x, y }); } } onPopoverBound(event) { const boundIndexAttr = event.target.getAttribute("index"); if (boundIndexAttr === null) { throw new Error("popup bound on no index"); } const boundIndex = parseInt(boundIndexAttr); if (isNaN(boundIndex)) { throw new Error(`boundIndex "${boundIndexAttr}" is not a number!`); } const foundTag = this.scope.tags.find((tag) => tag.index === boundIndex); if (foundTag) { foundTag.el = event.target; } else { throw new Error(`Tag with index (${boundIndex}, "${boundIndexAttr}") not found`); } } onPopoverShown(event) { for (const tag of this.scope.tags) { if (tag.el === event.target) { tag.el.classList.add("active"); } else { if (!this.scope.options.multiPopover) { tag.el?.classList.remove("active"); tag.el?.dispatchEvent(new CustomEvent("trigger-hide")); } } } } onPopoverHidden(event) { const found = this.scope.tags.find((tag) => tag.el === event.target); if (found) { found.el?.classList.remove("active"); } } updateTagPositions() { const img = this.image; const { width, height, naturalWidth, naturalHeight } = img; const wRatio = naturalWidth / width; const hRatio = naturalHeight / height; const fit = window.getComputedStyle(img).getPropertyValue("object-fit"); if ((fit === "cover" && wRatio > hRatio) || (fit === "contain" && hRatio > wRatio)) { for (const tag of this.scope.tags) { tag.top = tag.y * 100 + "%"; tag.left = ((wRatio / hRatio) * (tag.x - 0.5) + 0.5) * 100 + "%"; } } else if (fit === "cover" || fit === "contain") { for (const tag of this.scope.tags) { tag.left = tag.x * 100 + "%"; tag.top = ((hRatio / wRatio) * (tag.y - 0.5) + 0.5) * 100 + "%"; } } else { for (const tag of this.scope.tags) { tag.left = tag.x * 100 + "%"; tag.top = tag.y * 100 + "%"; } } } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bs4-tagged-image.component.js","sourceRoot":"","sources":["../../../src/components/bs4-tagged-image/bs4-tagged-image.component.ts"],"names":[],"mappings":"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"}