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