@ribajs/bs4
Version:
Bootstrap 4 module for Riba.js
231 lines • 21 kB
JavaScript
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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"}