123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193 |
- /*!
- * (C) Ionic http://ionicframework.com - MIT License
- */
- import { proxyCustomElement, HTMLElement, createEvent, Build, h, Host } from '@stencil/core/internal/client';
- import { a as printIonWarning } from './index4.js';
- import { b as getIonMode } from './ionic-global.js';
- const splitPaneIosCss = ":host{--side-width:100%;left:0;right:0;top:0;bottom:0;display:-ms-flexbox;display:flex;position:absolute;-ms-flex-direction:row;flex-direction:row;-ms-flex-wrap:nowrap;flex-wrap:nowrap;contain:strict}:host(.split-pane-visible) ::slotted(.split-pane-main){left:0;right:0;top:0;bottom:0;position:relative;-ms-flex:1;flex:1;-webkit-box-shadow:none;box-shadow:none;overflow:hidden;z-index:0}::slotted(.split-pane-side:not(ion-menu)){display:none}:host{--border:0.55px solid var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-250, var(--ion-background-color-step-250, #c8c7cc))));--side-min-width:270px;--side-max-width:28%}";
- const IonSplitPaneIosStyle0 = splitPaneIosCss;
- const splitPaneMdCss = ":host{--side-width:100%;left:0;right:0;top:0;bottom:0;display:-ms-flexbox;display:flex;position:absolute;-ms-flex-direction:row;flex-direction:row;-ms-flex-wrap:nowrap;flex-wrap:nowrap;contain:strict}:host(.split-pane-visible) ::slotted(.split-pane-main){left:0;right:0;top:0;bottom:0;position:relative;-ms-flex:1;flex:1;-webkit-box-shadow:none;box-shadow:none;overflow:hidden;z-index:0}::slotted(.split-pane-side:not(ion-menu)){display:none}:host{--border:1px solid var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-150, var(--ion-background-color-step-150, rgba(0, 0, 0, 0.13)))));--side-min-width:270px;--side-max-width:28%}";
- const IonSplitPaneMdStyle0 = splitPaneMdCss;
- // TODO(FW-2832): types
- const SPLIT_PANE_MAIN = 'split-pane-main';
- const SPLIT_PANE_SIDE = 'split-pane-side';
- const QUERY = {
- xs: '(min-width: 0px)',
- sm: '(min-width: 576px)',
- md: '(min-width: 768px)',
- lg: '(min-width: 992px)',
- xl: '(min-width: 1200px)',
- never: '',
- };
- const SplitPane = /*@__PURE__*/ proxyCustomElement(class SplitPane extends HTMLElement {
- constructor() {
- super();
- this.__registerHost();
- this.__attachShadow();
- this.ionSplitPaneVisible = createEvent(this, "ionSplitPaneVisible", 7);
- this.visible = false;
- this.contentId = undefined;
- this.disabled = false;
- this.when = QUERY['lg'];
- }
- visibleChanged(visible) {
- this.ionSplitPaneVisible.emit({ visible });
- }
- /**
- * @internal
- */
- async isVisible() {
- return Promise.resolve(this.visible);
- }
- async connectedCallback() {
- // TODO: connectedCallback is fired in CE build
- // before WC is defined. This needs to be fixed in Stencil.
- if (typeof customElements !== 'undefined' && customElements != null) {
- await customElements.whenDefined('ion-split-pane');
- }
- this.styleMainElement();
- this.updateState();
- }
- disconnectedCallback() {
- if (this.rmL) {
- this.rmL();
- this.rmL = undefined;
- }
- }
- updateState() {
- if (!Build.isBrowser) {
- return;
- }
- if (this.rmL) {
- this.rmL();
- this.rmL = undefined;
- }
- // Check if the split-pane is disabled
- if (this.disabled) {
- this.visible = false;
- return;
- }
- // When query is a boolean
- const query = this.when;
- if (typeof query === 'boolean') {
- this.visible = query;
- return;
- }
- // When query is a string, let's find first if it is a shortcut
- const mediaQuery = QUERY[query] || query;
- // Media query is empty or null, we hide it
- if (mediaQuery.length === 0) {
- this.visible = false;
- return;
- }
- // Listen on media query
- const callback = (q) => {
- this.visible = q.matches;
- };
- const mediaList = window.matchMedia(mediaQuery);
- // TODO FW-5869
- mediaList.addListener(callback);
- this.rmL = () => mediaList.removeListener(callback);
- this.visible = mediaList.matches;
- }
- /**
- * Attempt to find the main content
- * element inside of the split pane.
- * If found, set it as the main node.
- *
- * We assume that the main node
- * is available in the DOM on split
- * pane load.
- */
- styleMainElement() {
- if (!Build.isBrowser) {
- return;
- }
- const contentId = this.contentId;
- const children = this.el.children;
- const nu = this.el.childElementCount;
- let foundMain = false;
- for (let i = 0; i < nu; i++) {
- const child = children[i];
- const isMain = contentId !== undefined && child.id === contentId;
- if (isMain) {
- if (foundMain) {
- printIonWarning('[ion-split-pane] - Cannot have more than one main node.');
- return;
- }
- else {
- setPaneClass(child, isMain);
- foundMain = true;
- }
- }
- }
- if (!foundMain) {
- printIonWarning('[ion-split-pane] - Does not have a specified main node.');
- }
- }
- render() {
- const mode = getIonMode(this);
- return (h(Host, { key: '098801b5a318e2fc6913fb0d9079b1552927b99b', class: {
- [mode]: true,
- // Used internally for styling
- [`split-pane-${mode}`]: true,
- 'split-pane-visible': this.visible,
- } }, h("slot", { key: '8cbc6a942ecba54fc3c62027d46917db067b65c8' })));
- }
- get el() { return this; }
- static get watchers() { return {
- "visible": ["visibleChanged"],
- "disabled": ["updateState"],
- "when": ["updateState"]
- }; }
- static get style() { return {
- ios: IonSplitPaneIosStyle0,
- md: IonSplitPaneMdStyle0
- }; }
- }, [33, "ion-split-pane", {
- "contentId": [513, "content-id"],
- "disabled": [4],
- "when": [8],
- "visible": [32],
- "isVisible": [64]
- }, undefined, {
- "visible": ["visibleChanged"],
- "disabled": ["updateState"],
- "when": ["updateState"]
- }]);
- const setPaneClass = (el, isMain) => {
- let toAdd;
- let toRemove;
- if (isMain) {
- toAdd = SPLIT_PANE_MAIN;
- toRemove = SPLIT_PANE_SIDE;
- }
- else {
- toAdd = SPLIT_PANE_SIDE;
- toRemove = SPLIT_PANE_MAIN;
- }
- const classList = el.classList;
- classList.add(toAdd);
- classList.remove(toRemove);
- };
- function defineCustomElement$1() {
- if (typeof customElements === "undefined") {
- return;
- }
- const components = ["ion-split-pane"];
- components.forEach(tagName => { switch (tagName) {
- case "ion-split-pane":
- if (!customElements.get(tagName)) {
- customElements.define(tagName, SplitPane);
- }
- break;
- } });
- }
- const IonSplitPane = SplitPane;
- const defineCustomElement = defineCustomElement$1;
- export { IonSplitPane, defineCustomElement };
|