UNPKG

@ribajs/bs4

Version:

Bootstrap 4 module for Riba.js

274 lines 20.9 kB
import { Component } from "@ribajs/core"; import { EventDispatcher } from "@ribajs/events"; import { getViewportDimensions, hasChildNodesTrim, } from "@ribajs/utils/src/dom.js"; import { TOGGLE_BUTTON } from "../../constants/index.js"; import { debounce } from "@ribajs/utils/src/control"; export class Bs4SidebarComponent extends Component { static tagName = "bs4-sidebar"; computedStyle; autobind = true; static get observedAttributes() { return [ "id", "container-selector", "position", "width", "auto-show-on-wider-than", "auto-hide-on-slimmer-than", "force-hide-on-location-pathnames", "force-show-on-location-pathnames", "overlay-on-slimmer-than", "watch-new-page-ready-event", ]; } eventDispatcher; routerEvents = new EventDispatcher("main"); scope = { containerSelector: undefined, state: "hidden", oldState: "hidden", id: undefined, width: "250px", position: "left", autoShowOnWiderThan: 1199, autoHideOnSlimmerThan: 1200, watchNewPageReadyEvent: true, forceHideOnLocationPathnames: [], forceShowOnLocationPathnames: [], overlayOnSlimmerThan: 1200, hide: this.hide, show: this.show, toggle: this.toggle, }; constructor() { super(); this.onEnvironmentChanges = this.onEnvironmentChanges.bind(this); } setState(state) { this.scope.oldState = `${this.scope.state}`; this.scope.state = state; this.onStateChange(); } getState() { return this.scope.state; } getShowMode() { let mode; const vw = getViewportDimensions().w; if (vw < this.scope.overlayOnSlimmerThan) { mode = ("overlay-" + this.scope.position); } else { mode = ("side-" + this.scope.position); } return mode; } hide() { this.setState("hidden"); } show() { const state = this.getShowMode(); this.setState(state); } toggle() { if (this.scope.state === "hidden") { this.show(); } else { this.hide(); } } connectedCallback() { super.connectedCallback(); this.init(Bs4SidebarComponent.observedAttributes); this.computedStyle = window.getComputedStyle(this); window.addEventListener("resize", this.onEnvironmentChanges, { passive: true, }); this.onEnvironmentChanges(); } initToggleButtonEventDispatcher() { if (this.eventDispatcher) { this.eventDispatcher.off(TOGGLE_BUTTON.eventNames.toggle, this.toggle, this); this.eventDispatcher.off(TOGGLE_BUTTON.eventNames.init, this.triggerState, this); } this.eventDispatcher = new EventDispatcher(TOGGLE_BUTTON.nsPrefix + this.scope.id); this.eventDispatcher.on(TOGGLE_BUTTON.eventNames.toggle, this.toggle, this); this.eventDispatcher.on(TOGGLE_BUTTON.eventNames.init, this.triggerState, this); } initRouterEventDispatcher() { if (this.scope.watchNewPageReadyEvent) { this.routerEvents.on("newPageReady", this.onEnvironmentChanges, this); } } onHidden() { this.setContainersStyle(this.scope.state); const translateX = this.scope.position === "left" ? "-100%" : "100%"; this.setAttribute("style", `transform:translateX(${translateX});width:${this.scope.width};`); } onSide(state) { this.setContainersStyle(state); this.setAttribute("style", `transform:translateX(0);width:${this.scope.width};`); } onOverlay(state) { this.setContainersStyle(state); this.setAttribute("style", `transform:translateX(0);width:${this.scope.width};`); } triggerState() { this.eventDispatcher?.trigger("state", this.scope.state); } onStateChange() { switch (this.scope.state) { case "side-left": case "side-right": this.onSide(this.scope.state); break; case "overlay-left": case "overlay-right": this.onOverlay(this.scope.state); break; default: this.onHidden(); break; } if (this.eventDispatcher) { this.eventDispatcher.trigger(TOGGLE_BUTTON.eventNames.toggled, this.scope.state); } } get width() { return this.offsetWidth ? this.offsetWidth + "px" : this.scope.width; } setStateByEnvironment() { if (this.scope.forceHideOnLocationPathnames.includes(window.location.pathname)) { return this.hide(); } if (this.scope.forceShowOnLocationPathnames.includes(window.location.pathname)) { return this.show(); } const vw = getViewportDimensions().w; if (this.scope.autoHideOnSlimmerThan > -1 && vw < this.scope.autoHideOnSlimmerThan) { return this.hide(); } if (this.scope.autoShowOnWiderThan > -1 && vw > this.scope.autoShowOnWiderThan) { return this.show(); } } _onEnvironmentChanges() { this.setStateByEnvironment(); } onEnvironmentChanges = debounce(this._onEnvironmentChanges.bind(this)); getContainers() { return this.scope.containerSelector ? document.querySelectorAll(this.scope.containerSelector) : undefined; } initContainers(state) { this.setContainersStyle(state); } setContainersStyle(state) { const containers = this.getContainers() || []; if (containers) { for (let i = 0; i < containers.length; i++) { const container = containers[i]; this.setContainerStyle(container, state); } } } setContainerStyle(container, state) { const currStyle = container.style; if (state) { const width = this.width; const conStyle = window.getComputedStyle(container); switch (state) { case "side-left": switch (conStyle.position) { case "fixed": currStyle.left = width; break; default: currStyle.marginLeft = width; break; } break; case "side-right": switch (conStyle.position) { case "fixed": currStyle.right = width; break; default: currStyle.marginRight = width; break; } break; case "hidden": switch (this.scope.oldState) { case "side-left": switch (conStyle.position) { case "fixed": currStyle.left = "0"; break; default: currStyle.marginLeft = "0"; break; } break; case "side-right": switch (conStyle.position) { case "fixed": currStyle.right = "0"; break; default: currStyle.marginRight = "0"; break; } break; default: break; } default: break; } } container.style.transition = this.computedStyle ? this.computedStyle.transition : ""; } async beforeBind() { await super.beforeBind(); this.scope.oldState = this.getShowMode(); this.initRouterEventDispatcher(); return this.onEnvironmentChanges(); } async afterBind() { this.onEnvironmentChanges(); await super.afterBind(); } requiredAttributes() { return ["id"]; } parsedAttributeChangedCallback(attributeName, oldValue, newValue, namespace) { super.parsedAttributeChangedCallback(attributeName, oldValue, newValue, namespace); if (attributeName === "containerSelector") { this.initContainers(this.scope.state); } if (attributeName === "id") { this.initToggleButtonEventDispatcher(); } } disconnectedCallback() { super.disconnectedCallback(); this.eventDispatcher?.off(TOGGLE_BUTTON.eventNames.init, this.triggerState, this); this.eventDispatcher?.off(TOGGLE_BUTTON.eventNames.toggle, this.toggle, this); this.routerEvents.off("newPageReady", this.onEnvironmentChanges, this); window.removeEventListener("resize", this.onEnvironmentChanges, false); } template() { if (!hasChildNodesTrim(this)) { console.warn("No child elements found, this component as no template so you need to define your own as child of this component."); } return null; } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bs4-sidebar.component.js","sourceRoot":"","sources":["../../../src/components/bs4-sidebar/bs4-sidebar.component.ts"],"names":[],"mappings":"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"}