{"version":3,"file":"sidebar.D9ahL5K-.js","sources":["../../../../../packages/web-components/src/lib/components/sidebar/sidebar.ts"],"sourcesContent":["import { html } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { pdsCustomElement as customElement } from '../../decorators/pds-custom-element';\nimport { PdsElement } from '../PdsElement';\nimport styles from './sidebar.scss?inline';\n\n/**\n * @summary This components provides a layout for webpages containing sidebars\n *\n * @slot default Required: Main content\n * @slot left-sidebar Optional: Content to be rendered at left sidebar\n * @slot right-sidebar Optional: Content to be rendered at right sidebar\n */\n@customElement('pds-sidebar', {\n category: 'layout',\n type: 'component',\n state: 'stable',\n styles,\n})\nexport class PdsSidebar extends PdsElement {\n /**\n * - **default** stacks at (64rem/ 1024px) viewport\n * - **faster** stacks at a smaller viewport (48rem/ 768px)\n * - **slower** stacks at a larger viewport (85.375rem/ 1366px)\n */\n @property()\n break: 'faster' | 'slower' | 'default' = 'default';\n\n /**\n * - **default** spaced with a default gap (24px)\n * - **none** no gap between content and sidebar\n * - **sm** spaced with a smaller gap (8px)\n * - **lg** spaced with a larger gap (32px)\n */\n @property()\n gap: 'none' | 'sm' | 'lg' | 'default' = 'default';\n\n /**\n * @internal\n */\n get classNames() {\n return {\n [`break-${this.break}`]: !!this.break,\n [`gap-${this.gap}`]: !!this.gap,\n 'right-sidebar': !!(\n this.slotNotEmpty('right-sidebar') && this.slotEmpty('left-sidebar')\n ),\n 'left-sidebar': !!(\n this.slotNotEmpty('left-sidebar') && this.slotEmpty('right-sidebar')\n ),\n 'leftandright-sidebars': !!(\n this.slotNotEmpty('left-sidebar') && this.slotNotEmpty('right-sidebar')\n ),\n };\n }\n\n render() {\n return html`