UNPKG

@postnord/web-components

Version:
81 lines (76 loc) 4.31 kB
/*! * Built with Stencil * By PostNord. */ 'use strict'; var index = require('./index-CfUQZtlH.js'); var index$1 = require('./index.cjs.js'); var arrow_left = require('./arrow_left-Crkz484c.js'); const pnHeaderCss = () => `${index.transformTag("pn-header")}{display:block}${index.transformTag("pn-header")} h1{color:#2d2013;margin:0}${index.transformTag("pn-header")} p{color:#5e554a;margin:0}${index.transformTag("pn-header")} .pn-header-breadcrumbs{width:100%}${index.transformTag("pn-header")} .pn-header-container{position:relative;width:100%;max-width:var(--max-width);margin:0 auto;padding:clamp(1em, 3vw, 2em) clamp(0.5em, 3vw, 2em);display:flex;flex-wrap:wrap;align-items:center;gap:1.5em}${index.transformTag("pn-header")} .pn-header-container>${index.transformTag("pn-text-link")}{display:block}${index.transformTag("pn-header")} .pn-header-content{flex:1 1 auto;display:flex;flex-direction:column;gap:1em}${index.transformTag("pn-header")} .pn-header [slot=buttons]{display:flex;flex-direction:column;gap:1em}`; const translations = { sv: 'Tillbaka', en: 'Back', da: 'Tilbage', fi: 'Takaisin', no: 'Tilbake', }; const PnHeader = class { constructor(hostRef) { index.registerInstance(this, hostRef); } mo; hasBreadcrumb = false; hasButtons = false; get hostElement() { return index.getElement(this); } /** The `h1` text content. */ heading; /** Set a inner container max-width, any width CSS value is accepted. */ maxWidth; setMaxWidth() { if (!this.maxWidth) return; this.hostElement.style.setProperty('--max-width', this.maxWidth); } /** The href for the go back link. If this is provided a button be displayed. */ goBackHref; /** The text for the back link. */ goBackText; /** Set the language manually, only use this prop if the pnTopbar is not loaded. Supported: sv, en, da, fi and no. */ language = null; connectedCallback() { this.mo = new MutationObserver(() => { index.forceUpdate(this.hostElement); this.checkSlots(); }); this.mo.observe(this.hostElement, { subtree: true, childList: true }); } disconnectedCallback() { this.mo?.disconnect(); } async componentWillLoad() { this.checkSlots(); this.setMaxWidth(); if (this.language === null) await index$1.awaitTopbar(this.hostElement); } checkSlots() { this.hasBreadcrumb = !!this.hostElement.querySelector('[slot="breadcrumb"]'); this.hasButtons = !!this.hostElement.querySelector('[slot="buttons"]'); } showBreadcrumb() { return this.hasBreadcrumb || !!this.goBackHref?.length; } getButtonText() { return this.goBackText || translations[this.language || index$1.en]; } render() { return (index.h(index.Host, { key: 'f19310a092999791304499d72c1b8e566949c0d3' }, index.h("header", { key: 'c6b50a1d93bf18f2050b37a9bdf69d3706b8aea4', class: "pn-header" }, index.h("div", { key: '7bfa1bd37978daf85d266b7306a71705bdc8cac5', class: "pn-header-container" }, index.h("div", { key: '09ed187b0f201d435c99b3c6e0f245ca48857d47', class: "pn-header-breadcrumbs", hidden: !this.showBreadcrumb() }, this.goBackHref && (index.h("pn-text-link", { key: 'ba657cb77da06d42009738c64d815a23d8dae527', label: this.getButtonText(), href: this.goBackHref, icon: arrow_left.arrow_left, leftIcon: true })), index.h("slot", { key: '278bf254489dbd76f53e047cd16c247bcfd696eb', name: "breadcrumb" })), index.h("div", { key: 'e9b2e873fb9ed01fabbd669aa7cace973a55cbfa', class: "pn-header-content" }, this.heading && index.h("h1", { key: 'baec009bf6807009ea53d184be9a8c15ea0253a0' }, this.heading), index.h("slot", { key: '7a777967b19a19077486d88d775b4a1c4f9d3134' })), index.h("div", { key: '46fa0cc4120b341e4a03c60bb865e077c6231986', class: "pn-header-buttons", hidden: !this.hasButtons }, index.h("slot", { key: '8932d6bbb5e1647be6b666d1879b163575dfd760', name: "buttons" })), index.h("slot", { key: 'afc6e39f45ef72ba762772f84a66cc24fdbcf368', name: "menu" }))))); } static get watchers() { return { "maxWidth": [{ "setMaxWidth": 0 }] }; } }; PnHeader.style = pnHeaderCss(); exports.pn_header = PnHeader;