| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 | /*! * All material copyright ESRI, All Rights Reserved, unless otherwise specified. * See https://github.com/Esri/calcite-components/blob/master/LICENSE.md for details. * v1.0.0-beta.82 */import { Component, Element, Prop, h, Fragment } from "@stencil/core";import { CSS, SLOTS } from "./resources";import { getSlotted } from "../../utils/dom";import { connectConditionalSlotComponent, disconnectConditionalSlotComponent } from "../../utils/conditionalSlot";/** * @slot - A slot for adding content to the shell. This content will appear between any leading and trailing panels added to the shell. (eg. a map) * @slot header - A slot for adding header content. This content will be positioned at the top of the shell. * @slot footer - A slot for adding footer content. This content will be positioned at the bottom of the shell. * @slot primary-panel - A slot for adding the leading `calcite-shell-panel`. * @slot contextual-panel - A slot for adding the trailing `calcite-shell-panel`. * @slot center-row - A slot for adding custom content in the center row. */export class Shell {  constructor() {    // --------------------------------------------------------------------------    //    //  Properties    //    // --------------------------------------------------------------------------    /**     * Positions the center content behind any calcite-shell-panels.     */    this.contentBehind = false;  }  // --------------------------------------------------------------------------  //  //  Lifecycle  //  // --------------------------------------------------------------------------  connectedCallback() {    connectConditionalSlotComponent(this);  }  disconnectedCallback() {    disconnectConditionalSlotComponent(this);  }  // --------------------------------------------------------------------------  //  //  Render Methods  //  // --------------------------------------------------------------------------  renderHeader() {    const hasHeader = !!getSlotted(this.el, SLOTS.header);    return hasHeader ? h("slot", { key: "header", name: SLOTS.header }) : null;  }  renderContent() {    const defaultSlotNode = h("slot", { key: "default-slot" });    const centerRowSlotNode = h("slot", { key: "center-row-slot", name: SLOTS.centerRow });    const contentContainerKey = "content-container";    const content = !!this.contentBehind      ? [        h("div", { class: {            [CSS.content]: true,            [CSS.contentBehind]: true          }, key: contentContainerKey }, defaultSlotNode),        centerRowSlotNode      ]      : [        h("div", { class: CSS.content, key: contentContainerKey },          defaultSlotNode,          centerRowSlotNode)      ];    return content;  }  renderFooter() {    const hasFooter = !!getSlotted(this.el, SLOTS.footer);    return hasFooter ? (h("div", { class: CSS.footer, key: "footer" },      h("slot", { name: SLOTS.footer }))) : null;  }  renderMain() {    const primaryPanel = getSlotted(this.el, SLOTS.primaryPanel);    const mainClasses = {      [CSS.main]: true,      [CSS.mainReversed]: (primaryPanel === null || primaryPanel === void 0 ? void 0 : primaryPanel.position) === "end"    };    return (h("div", { class: mainClasses },      h("slot", { name: SLOTS.primaryPanel }),      this.renderContent(),      h("slot", { name: SLOTS.contextualPanel })));  }  render() {    return (h(Fragment, null,      this.renderHeader(),      this.renderMain(),      this.renderFooter()));  }  static get is() { return "calcite-shell"; }  static get encapsulation() { return "shadow"; }  static get originalStyleUrls() { return {    "$": ["shell.scss"]  }; }  static get styleUrls() { return {    "$": ["shell.css"]  }; }  static get properties() { return {    "contentBehind": {      "type": "boolean",      "mutable": false,      "complexType": {        "original": "boolean",        "resolved": "boolean",        "references": {}      },      "required": false,      "optional": false,      "docs": {        "tags": [],        "text": "Positions the center content behind any calcite-shell-panels."      },      "attribute": "content-behind",      "reflect": true,      "defaultValue": "false"    }  }; }  static get elementRef() { return "el"; }}
 |