@m3e/expansion-panel 1.0.0-rc.1 → 1.0.0-rc.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (46) hide show
  1. package/README.md +1 -2
  2. package/dist/custom-elements.json +2729 -17
  3. package/dist/html-custom-data.json +6 -1
  4. package/dist/index.js +6 -6
  5. package/dist/index.js.map +1 -1
  6. package/dist/index.min.js +24 -24
  7. package/dist/index.min.js.map +1 -1
  8. package/package.json +3 -3
  9. package/cem.config.mjs +0 -16
  10. package/demo/index.html +0 -60
  11. package/dist/src/AccordionElement.d.ts +0 -56
  12. package/dist/src/AccordionElement.d.ts.map +0 -1
  13. package/dist/src/ExpansionHeaderElement.d.ts +0 -60
  14. package/dist/src/ExpansionHeaderElement.d.ts.map +0 -1
  15. package/dist/src/ExpansionPanelElement.d.ts +0 -121
  16. package/dist/src/ExpansionPanelElement.d.ts.map +0 -1
  17. package/dist/src/ExpansionToggleDirection.d.ts +0 -3
  18. package/dist/src/ExpansionToggleDirection.d.ts.map +0 -1
  19. package/dist/src/ExpansionTogglePosition.d.ts +0 -3
  20. package/dist/src/ExpansionTogglePosition.d.ts.map +0 -1
  21. package/dist/src/index.d.ts +0 -6
  22. package/dist/src/index.d.ts.map +0 -1
  23. package/dist/src/styles/ExpansionHeaderStyle.d.ts +0 -6
  24. package/dist/src/styles/ExpansionHeaderStyle.d.ts.map +0 -1
  25. package/dist/src/styles/ExpansionHeaderToken.d.ts +0 -17
  26. package/dist/src/styles/ExpansionHeaderToken.d.ts.map +0 -1
  27. package/dist/src/styles/ExpansionPanelStyle.d.ts +0 -6
  28. package/dist/src/styles/ExpansionPanelStyle.d.ts.map +0 -1
  29. package/dist/src/styles/ExpansionPanelToken.d.ts +0 -21
  30. package/dist/src/styles/ExpansionPanelToken.d.ts.map +0 -1
  31. package/dist/src/styles/index.d.ts +0 -3
  32. package/dist/src/styles/index.d.ts.map +0 -1
  33. package/eslint.config.mjs +0 -13
  34. package/rollup.config.js +0 -32
  35. package/src/AccordionElement.ts +0 -115
  36. package/src/ExpansionHeaderElement.ts +0 -99
  37. package/src/ExpansionPanelElement.ts +0 -260
  38. package/src/ExpansionToggleDirection.ts +0 -2
  39. package/src/ExpansionTogglePosition.ts +0 -2
  40. package/src/index.ts +0 -5
  41. package/src/styles/ExpansionHeaderStyle.ts +0 -85
  42. package/src/styles/ExpansionHeaderToken.ts +0 -24
  43. package/src/styles/ExpansionPanelStyle.ts +0 -85
  44. package/src/styles/ExpansionPanelToken.ts +0 -28
  45. package/src/styles/index.ts +0 -2
  46. package/tsconfig.json +0 -9
@@ -1,99 +0,0 @@
1
- import { CSSResultGroup, html, LitElement, nothing, PropertyValues } from "lit";
2
- import { customElement, property, query } from "lit/decorators.js";
3
-
4
- import {
5
- AttachInternals,
6
- Disabled,
7
- Focusable,
8
- KeyboardClick,
9
- M3eFocusRingElement,
10
- M3eStateLayerElement,
11
- Role,
12
- } from "@m3e/core";
13
-
14
- import { ExpansionTogglePosition } from "./ExpansionTogglePosition";
15
- import { ExpansionToggleDirection } from "./ExpansionToggleDirection";
16
-
17
- import { ExpansionHeaderStyle } from "./styles";
18
-
19
- /**
20
- * A button used to toggle the expanded state of an expansion panel.
21
- *
22
- * @tag m3e-expansion-header
23
- *
24
- * @slot - Renders the content of the header.
25
- * @slot toggle-icon - Renders the icon of the expansion toggle.
26
- *
27
- * @attr hide-toggle - Whether to hide the expansion toggle.
28
- * @attr toggle-direction - The direction of the expansion toggle.
29
- * @attr toggle-position - The position of the expansion toggle.
30
- *
31
- * @cssprop --m3e-expansion-header-collapsed-height - Height of the header when the panel is collapsed.
32
- * @cssprop --m3e-expansion-header-expanded-height - Height of the header when the panel is expanded.
33
- * @cssprop --m3e-expansion-header-padding-left - Left padding inside the header.
34
- * @cssprop --m3e-expansion-header-padding-right - Right padding inside the header.
35
- * @cssprop --m3e-expansion-header-spacing - Spacing between header elements.
36
- * @cssprop --m3e-expansion-header-toggle-icon-size - Size of the toggle icon (e.g. chevron).
37
- * @cssprop --m3e-expansion-header-font-size - The font size of the header text.
38
- * @cssprop --m3e-expansion-header-font-weight - The font weight of the header text.
39
- * @cssprop --m3e-expansion-header-line-height - The line height of the header text.
40
- * @cssprop --m3e-expansion-header-tracking - Letter spacing (tracking) of the header text.
41
- */
42
- @customElement("m3e-expansion-header")
43
- export class M3eExpansionHeaderElement extends KeyboardClick(
44
- Focusable(Disabled(AttachInternals(Role(LitElement, "button"), true)))
45
- ) {
46
- /** The styles of the element. */
47
- static override styles: CSSResultGroup = ExpansionHeaderStyle;
48
-
49
- /** @private */ @query(".focus-ring") private readonly _focusRing?: M3eFocusRingElement;
50
- /** @private */ @query(".state-layer") private readonly _stateLayer?: M3eStateLayerElement;
51
-
52
- /**
53
- * The direction of the expansion toggle.
54
- * @default "vertical"
55
- */
56
- @property({ attribute: "toggle-direction", reflect: true }) toggleDirection: ExpansionToggleDirection = "vertical";
57
-
58
- /**
59
- * The position of the expansion toggle.
60
- * @default "after"
61
- */
62
- @property({ attribute: "toggle-position", reflect: true }) togglePosition: ExpansionTogglePosition = "after";
63
-
64
- /**
65
- * Whether to hide the expansion toggle.
66
- * @default false
67
- */
68
- @property({ attribute: "hide-toggle", type: Boolean, reflect: true }) hideToggle = false;
69
-
70
- /** @inheritdoc */
71
- protected override firstUpdated(_changedProperties: PropertyValues<this>): void {
72
- super.firstUpdated(_changedProperties);
73
- [this._focusRing, this._stateLayer].forEach((x) => x?.attach(this));
74
- }
75
-
76
- /** @inheritdoc */
77
- protected override render(): unknown {
78
- return html`<m3e-focus-ring class="focus-ring" ?disabled="${this.disabled}"></m3e-focus-ring>
79
- <m3e-state-layer class="state-layer" ?disabled="${this.disabled}"></m3e-state-layer>
80
- ${this.togglePosition === "before" ? this.#renderToggle() : nothing}
81
- <div class="content">
82
- <slot></slot>
83
- </div>
84
- ${this.togglePosition === "after" ? this.#renderToggle() : nothing}`;
85
- }
86
-
87
- /** @private */
88
- #renderToggle(): unknown {
89
- return html`<div class="toggle" aria-hidden="true">
90
- <slot name="toggle-icon"></slot>
91
- </div>`;
92
- }
93
- }
94
-
95
- declare global {
96
- interface HTMLElementTagNameMap {
97
- "m3e-expansion-header": M3eExpansionHeaderElement;
98
- }
99
- }
@@ -1,260 +0,0 @@
1
- /* eslint-disable @typescript-eslint/no-unsafe-declaration-merging */
2
-
3
- import { CSSResultGroup, html, LitElement } from "lit";
4
- import { customElement, property, query } from "lit/decorators.js";
5
-
6
- import { AttachInternals, Disabled, EventAttribute, Role } from "@m3e/core";
7
-
8
- import { ExpansionTogglePosition } from "./ExpansionTogglePosition";
9
- import { ExpansionToggleDirection } from "./ExpansionToggleDirection";
10
-
11
- import { ExpansionPanelStyle } from "./styles";
12
- import { M3eExpansionHeaderElement } from "./ExpansionHeaderElement";
13
-
14
- /**
15
- * @summary
16
- * An expandable details-summary view.
17
- *
18
- * @description
19
- * The `m3e-expansion-panel` component provides an accessible, animated details-summary view for
20
- * organizing content in collapsible sections. It supports custom header, content, actions, and
21
- * toggle icon slots, and offers configurable toggle position and direction. The panel responds to
22
- * open/close states, emits lifecycle events, and supports rich theming via CSS custom properties
23
- * for elevation, shape, spacing, and color.
24
- *
25
- * @example
26
- * The following example illustrates the basic use of the `m3e-accordion` and `m3e-expansion-panel` components.
27
- *
28
- * ```html
29
- * <m3e-accordion>
30
- * <m3e-expansion-panel>
31
- * <span slot="header">Panel 1</span>
32
- * I am content for the first expansion panel
33
- * </m3e-expansion-panel>
34
- * <m3e-expansion-panel>
35
- * <span slot="header">Panel 2</span>
36
- * I am content for the second expansion panel
37
- * </m3e-expansion-panel>
38
- * </m3e-accordion>
39
- * ```
40
- *
41
- * @tag m3e-expansion-panel
42
- *
43
- * @slot - Renders the detail of the panel.
44
- * @slot actions- Renders the actions bar of the panel.
45
- * @slot header - Renders the header content.
46
- * @slot toggle-icon - Renders the expansion toggle icon.
47
- *
48
- * @attr disabled - Whether the element is disabled.
49
- * @attr hide-toggle - Whether to hide the expansion toggle.
50
- * @attr open - Whether the panel is expanded.
51
- * @attr toggle-direction - The direction of the expansion toggle.
52
- * @attr toggle-position - The position of the expansion toggle.
53
- *
54
- * @fires opening - Emitted when the expansion panel begins to open.
55
- * @fires opened - Emitted when the expansion panel has opened.
56
- * @fires closing - Emitted when the expansion panel begins to close.
57
- * @fires closed - Emitted when the expansion panel has closed.
58
- *
59
- * @cssprop --m3e-expansion-header-collapsed-height - Height of the header when the panel is collapsed.
60
- * @cssprop --m3e-expansion-header-expanded-height - Height of the header when the panel is expanded.
61
- * @cssprop --m3e-expansion-header-padding-left - Left padding inside the header.
62
- * @cssprop --m3e-expansion-header-padding-right - Right padding inside the header.
63
- * @cssprop --m3e-expansion-header-spacing - Spacing between header elements.
64
- * @cssprop --m3e-expansion-header-toggle-icon-size - Size of the toggle icon (e.g. chevron).
65
- * @cssprop --m3e-expansion-header-font-size - The font size of the header text.
66
- * @cssprop --m3e-expansion-header-font-weight - The font weight of the header text.
67
- * @cssprop --m3e-expansion-header-line-height - The line height of the header text.
68
- * @cssprop --m3e-expansion-header-tracking - Letter spacing (tracking) of the header text.
69
- * @cssprop --m3e-expansion-panel-text-color - Color of the panel's text content.
70
- * @cssprop --m3e-expansion-panel-disabled-text-color - Color of the panel's text content, when disabled.
71
- * @cssprop --m3e-expansion-panel-disabled-text-opacity - Opacity of the panel's text content, when disabled.
72
- * @cssprop --m3e-expansion-panel-container-color - Background color of the panel container.
73
- * @cssprop --m3e-expansion-panel-elevation - Elevation level when the panel is collapsed.
74
- * @cssprop --m3e-expansion-panel-shape - Shape (e.g. border radius) of the panel when collapsed.
75
- * @cssprop --m3e-expansion-panel-open-elevation - Elevation level when the panel is expanded.
76
- * @cssprop --m3e-expansion-panel-open-shape - Shape (e.g. border radius) of the panel when expanded.
77
- * @cssprop --m3e-expansion-panel-content-padding - Padding around the panel's content area.
78
- * @cssprop --m3e-expansion-panel-actions-spacing - Spacing between action buttons or elements.
79
- * @cssprop --m3e-expansion-panel-actions-padding - Padding around the actions section.
80
- * @cssprop --m3e-expansion-panel-actions-divider-thickness - Thickness of the divider above actions.
81
- * @cssprop --m3e-expansion-panel-actions-divider-color - Color of the divider above actions.
82
- */
83
- @customElement("m3e-expansion-panel")
84
- export class M3eExpansionPanelElement extends EventAttribute(
85
- Disabled(AttachInternals(Role(LitElement, "none"), true)),
86
- "opening",
87
- "opened",
88
- "closing",
89
- "closed"
90
- ) {
91
- /** The styles of the element. */
92
- static override styles: CSSResultGroup = ExpansionPanelStyle;
93
-
94
- /** @private */ private static __nextId = 0;
95
- /** @private */ #id = M3eExpansionPanelElement.__nextId++;
96
- /** @private */ #contentId = `m3e-expansion-panel-${this.#id}-content`;
97
- /** @private */ #headerId = `m3e-expansion-panel-${this.#id}-header`;
98
-
99
- /** @private */ @query("m3e-expansion-header") private readonly _header?: M3eExpansionHeaderElement;
100
-
101
- /**
102
- * Whether the panel is expanded.
103
- * @default false
104
- */
105
- @property({ type: Boolean, reflect: true }) open = false;
106
-
107
- /**
108
- * The direction of the expansion toggle.
109
- * @default "vertical"
110
- */
111
- @property({ attribute: "toggle-direction", reflect: true }) toggleDirection: ExpansionToggleDirection = "vertical";
112
-
113
- /**
114
- * The position of the expansion toggle.
115
- * @default "after"
116
- */
117
- @property({ attribute: "toggle-position", reflect: true }) togglePosition: ExpansionTogglePosition = "after";
118
-
119
- /**
120
- * Whether to hide the expansion toggle.
121
- * @default false
122
- */
123
- @property({ attribute: "hide-toggle", type: Boolean, reflect: true }) hideToggle = false;
124
-
125
- /** @inheritdoc */
126
- protected override render(): unknown {
127
- return html` <m3e-expansion-header
128
- id="${this.#headerId}"
129
- toggle-direction="${this.toggleDirection}"
130
- toggle-position="${this.togglePosition}"
131
- ?hide-toggle="${this.hideToggle}"
132
- ?disabled="${this.disabled}"
133
- aria-expanded="${this.open}"
134
- aria-controls="${this.#contentId}"
135
- @click="${this.#handleHeaderClick}"
136
- @keydown="${this.#handleKeyDown}"
137
- >
138
- <div slot="toggle-icon" class="toggle">
139
- <slot name="toggle-icon">${this.#renderToggleIcon()}</slot>
140
- </div>
141
- <slot name="header"></slot>
142
- </m3e-expansion-header>
143
- <m3e-collapsible
144
- id="${this.#contentId}"
145
- role="region"
146
- aria-labelledby="${this.#headerId}"
147
- aria-hidden="${!this.open}"
148
- ?open="${this.open}"
149
- @opening="${this.#handleCollapsibleEvent}"
150
- @opened="${this.#handleCollapsibleEvent}"
151
- @closing="${this.#handleCollapsibleEvent}"
152
- @closed="${this.#handleCollapsibleEvent}"
153
- >
154
- <div class="content">
155
- <slot></slot>
156
- </div>
157
- <slot name="actions"></slot>
158
- </m3e-collapsible>`;
159
- }
160
-
161
- /** @private */
162
- #renderToggleIcon(): unknown {
163
- return this.toggleDirection === "vertical"
164
- ? html`<svg viewBox="0 -960 960 960" fill="currentColor">
165
- <path d="M480-344 240-584l56-56 184 184 184-184 56 56-240 240Z" />
166
- </svg>`
167
- : html`<svg viewBox="0 -960 960 960" fill="currentColor">
168
- <path d="M504-480 320-664l56-56 240 240-240 240-56-56 184-184Z" />
169
- </svg>`;
170
- }
171
-
172
- /** @private */
173
- #handleHeaderClick() {
174
- this.open = !this.open;
175
- }
176
-
177
- /** @private */
178
- #handleKeyDown(e: KeyboardEvent): void {
179
- switch (e.key) {
180
- case "ArrowUp":
181
- {
182
- e.preventDefault();
183
- const accordion = this.closest("m3e-accordion");
184
- if (accordion) {
185
- const panels = [...accordion.panels].reverse();
186
- const index = panels.indexOf(this);
187
- (
188
- panels.find((x, i) => !x.disabled && i > index) ?? panels.find((x, i) => !x.disabled && i < index)
189
- )?._header?.focus();
190
- } else {
191
- this.open = false;
192
- }
193
- }
194
-
195
- break;
196
-
197
- case "ArrowDown":
198
- {
199
- e.preventDefault();
200
- const accordion = this.closest("m3e-accordion");
201
- if (accordion) {
202
- const index = accordion.panels.indexOf(this);
203
- (
204
- accordion.panels.find((x, i) => !x.disabled && i > index) ??
205
- accordion.panels.find((x, i) => !x.disabled && i < index)
206
- )?._header?.focus();
207
- } else {
208
- this.open = true;
209
- }
210
- }
211
-
212
- break;
213
- }
214
- }
215
-
216
- /** @private */
217
- #handleCollapsibleEvent(e: Event): void {
218
- e.stopPropagation();
219
- this.dispatchEvent(new Event(e.type, { bubbles: true }));
220
- }
221
- }
222
-
223
- interface M3eExpansionPanelElementEventMap extends HTMLElementEventMap {
224
- opening: Event;
225
- opened: Event;
226
- closing: Event;
227
- closed: Event;
228
- }
229
-
230
- export interface M3eExpansionPanelElement {
231
- addEventListener<K extends keyof M3eExpansionPanelElementEventMap>(
232
- type: K,
233
- listener: (this: M3eExpansionPanelElement, ev: M3eExpansionPanelElementEventMap[K]) => void,
234
- options?: boolean | AddEventListenerOptions
235
- ): void;
236
-
237
- addEventListener(
238
- type: string,
239
- listener: EventListenerOrEventListenerObject,
240
- options?: boolean | AddEventListenerOptions
241
- ): void;
242
-
243
- removeEventListener<K extends keyof M3eExpansionPanelElementEventMap>(
244
- type: K,
245
- listener: (this: M3eExpansionPanelElement, ev: M3eExpansionPanelElementEventMap[K]) => void,
246
- options?: boolean | EventListenerOptions
247
- ): void;
248
-
249
- removeEventListener(
250
- type: string,
251
- listener: EventListenerOrEventListenerObject,
252
- options?: boolean | EventListenerOptions
253
- ): void;
254
- }
255
-
256
- declare global {
257
- interface HTMLElementTagNameMap {
258
- "m3e-expansion-panel": M3eExpansionPanelElement;
259
- }
260
- }
@@ -1,2 +0,0 @@
1
- /** Specifies the possible directions of an expansion toggle. */
2
- export type ExpansionToggleDirection = "vertical" | "horizontal";
@@ -1,2 +0,0 @@
1
- /** Specifies the possible positions of an expansion toggle. */
2
- export type ExpansionTogglePosition = "before" | "after";
package/src/index.ts DELETED
@@ -1,5 +0,0 @@
1
- export * from "./AccordionElement";
2
- export * from "./ExpansionHeaderElement";
3
- export * from "./ExpansionPanelElement";
4
- export * from "./ExpansionToggleDirection";
5
- export * from "./ExpansionTogglePosition";
@@ -1,85 +0,0 @@
1
- import { css, unsafeCSS } from "lit";
2
-
3
- import { DesignToken } from "@m3e/core";
4
-
5
- import { ExpansionHeaderToken } from "./ExpansionHeaderToken";
6
-
7
- /**
8
- * Styles for `M3eExpansionHeaderElement`.
9
- * @internal
10
- */
11
- export const ExpansionHeaderStyle = css`
12
- :host {
13
- display: flex;
14
- border-radius: inherit;
15
- outline: none;
16
- position: relative;
17
- height: ${ExpansionHeaderToken.collapsedHeight};
18
- padding-inline-start: ${ExpansionHeaderToken.paddingLeft};
19
- padding-inline-end: ${ExpansionHeaderToken.paddingRight};
20
- font-size: ${ExpansionHeaderToken.fontSize};
21
- font-weight: ${ExpansionHeaderToken.fontWeight};
22
- line-height: ${ExpansionHeaderToken.lineHeight};
23
- letter-spacing: ${ExpansionHeaderToken.tracking};
24
- transition: ${unsafeCSS(`height var(--m3e-collapsible-animation-duration, ${DesignToken.motion.duration.medium1})
25
- ${DesignToken.motion.easing.standard}`)};
26
-
27
- column-gap: ${ExpansionHeaderToken.spacing};
28
- }
29
- :host(:not(:disabled)) {
30
- cursor: pointer;
31
- }
32
- :host([aria-expanded="true"]) {
33
- height: ${ExpansionHeaderToken.expandedHeight};
34
- }
35
- :host(:not(:focus-visible)) .state-layer {
36
- --m3e-state-layer-focus-color: transparent;
37
- }
38
- :host([aria-expanded="true"]) .state-layer {
39
- --m3e-state-layer-hover-color: transparent;
40
- }
41
- :host([aria-expanded="true"]) [part="background"],
42
- .content {
43
- flex: 1 1 auto;
44
- display: flex;
45
- align-items: center;
46
- }
47
- .toggle {
48
- display: flex;
49
- align-items: center;
50
- justify-content: center;
51
- vertical-align: middle;
52
- font-size: ${ExpansionHeaderToken.toggleIconSize};
53
- transition: ${unsafeCSS(`transform var(--m3e-collapsible-animation-duration, ${DesignToken.motion.duration.medium1})
54
- ${DesignToken.motion.easing.standard}`)};
55
- }
56
- :host([toggle-direction="vertical"][aria-expanded="true"]) .toggle {
57
- transform: rotate(180deg);
58
- }
59
- :host([toggle-direction="horizontal"][aria-expanded="true"]) .toggle {
60
- transform: rotate(90deg);
61
- }
62
- :host([toggle-position="before"]) .toggle {
63
- margin-inline-start: calc(0px - ${ExpansionHeaderToken.spacing});
64
- }
65
- :host([toggle-position="after"]) .toggle {
66
- margin-inline-end: calc(0px - ${ExpansionHeaderToken.spacing});
67
- }
68
- :host([hide-toggle]) .toggle {
69
- display: none;
70
- }
71
- ::slotted([slot="toggle-icon"]) {
72
- font-size: inherit !important;
73
- flex: none;
74
- }
75
- ::slotted(svg[slot="toggle-icon"]) {
76
- width: 1em;
77
- height: 1em;
78
- }
79
- @media (prefers-reduced-motion) {
80
- :host,
81
- .toggle {
82
- transition: none;
83
- }
84
- }
85
- `;
@@ -1,24 +0,0 @@
1
- import { unsafeCSS } from "lit";
2
-
3
- import { DesignToken } from "@m3e/core";
4
-
5
- /**
6
- * Component design tokens for `M3eExpansionHeaderElement`.
7
- * @internal
8
- */
9
- export const ExpansionHeaderToken = {
10
- collapsedHeight: unsafeCSS("var(--m3e-expansion-header-collapsed-height, 3rem)"),
11
- expandedHeight: unsafeCSS("var(--m3e-expansion-header-expanded-height, 4rem)"),
12
- paddingLeft: unsafeCSS("var(--m3e-expansion-header-padding-left, 1.5rem)"),
13
- paddingRight: unsafeCSS("var(--m3e-expansion-header-padding-right, 1.5rem)"),
14
- spacing: unsafeCSS("var(--m3e-expansion-header-spacing, 0.5rem)"),
15
- toggleIconSize: unsafeCSS("var(--m3e-expansion-header-toggle-icon-size, 1.5rem)"),
16
- fontSize: unsafeCSS(`var(--m3e-expansion-header-font-size, ${DesignToken.typescale.standard.title.medium.fontSize})`),
17
- fontWeight: unsafeCSS(
18
- `var(--m3e-expansion-header-font-weight, ${DesignToken.typescale.standard.title.medium.fontWeight})`
19
- ),
20
- lineHeight: unsafeCSS(
21
- `var(--m3e-expansion-header-line-height, ${DesignToken.typescale.standard.title.medium.lineHeight})`
22
- ),
23
- tracking: unsafeCSS(`var(--m3e-expansion-header-tracking, ${DesignToken.typescale.standard.title.medium.tracking})`),
24
- } as const;
@@ -1,85 +0,0 @@
1
- import { css, unsafeCSS } from "lit";
2
-
3
- import { DesignToken } from "@m3e/core";
4
-
5
- import { ExpansionPanelToken } from "./ExpansionPanelToken";
6
- import { ExpansionHeaderToken } from "./ExpansionHeaderToken";
7
-
8
- /**
9
- * Styles for `M3eExpansionPanelElement`.
10
- * @internal
11
- */
12
- export const ExpansionPanelStyle = css`
13
- :host {
14
- display: block;
15
- background-color: ${ExpansionPanelToken.containerColor};
16
- transition: ${unsafeCSS(`box-shadow var(--m3e-collapsible-animation-duration, ${DesignToken.motion.duration.medium1})
17
- ${DesignToken.motion.easing.standard}`)};
18
- }
19
- :host(:not(:disabled)) {
20
- color: ${ExpansionPanelToken.textColor};
21
- }
22
- :host(:disabled) {
23
- color: color-mix(
24
- in srgb,
25
- ${ExpansionPanelToken.disabledTextColor} ${ExpansionPanelToken.disabledTextOpacity},
26
- transparent
27
- );
28
- }
29
- :host(:not([open])) {
30
- box-shadow: ${ExpansionPanelToken.collapsedElevation};
31
- border-radius: ${ExpansionPanelToken.collapsedShape};
32
- }
33
- :host([open]) {
34
- box-shadow: ${ExpansionPanelToken.expandedElevation};
35
- border-radius: ${ExpansionPanelToken.expandedShape};
36
- margin-block: ${ExpansionPanelToken.expandedSpace};
37
- }
38
- .toggle {
39
- display: flex;
40
- align-items: center;
41
- justify-content: center;
42
- font-size: ${ExpansionHeaderToken.toggleIconSize};
43
- }
44
- ::slotted([slot="toggle-icon"]) {
45
- font-size: inherit !important;
46
- flex: none;
47
- }
48
- .toggle svg,
49
- ::slotted(svg[slot="toggle-icon"]) {
50
- width: 1em;
51
- height: 1em;
52
- }
53
- .content {
54
- padding: ${ExpansionPanelToken.contentPadding};
55
- }
56
- ::slotted([slot="actions"]) {
57
- flex: none;
58
- display: flex;
59
- align-items: center;
60
- column-gap: ${ExpansionPanelToken.actionsSpacing};
61
- padding: ${ExpansionPanelToken.actionsPadding};
62
- border-top-style: solid;
63
- border-top-width: ${ExpansionPanelToken.actionsDividerThickness};
64
- border-top-color: ${ExpansionPanelToken.actionsDividerColor};
65
- }
66
- ::slotted([slot="actions"][end]) {
67
- justify-content: flex-end;
68
- }
69
- @media (prefers-reduced-motion) {
70
- :host {
71
- transition: none;
72
- }
73
- }
74
- @media (forced-colors: active) {
75
- :host {
76
- border: 1px solid CanvasText;
77
- }
78
- :host(:disabled) {
79
- color: GrayText;
80
- }
81
- ::slotted([slot="actions"]) {
82
- border-top-color: GrayText;
83
- }
84
- }
85
- `;
@@ -1,28 +0,0 @@
1
- import { unsafeCSS } from "lit";
2
-
3
- import { DesignToken } from "@m3e/core";
4
-
5
- /**
6
- * Component design tokens for `M3eExpansionPanelElement`.
7
- * @internal
8
- */
9
- export const ExpansionPanelToken = {
10
- textColor: unsafeCSS(`var(--m3e-expansion-panel-text-color, ${DesignToken.color.onSurface})`),
11
- disabledTextColor: unsafeCSS(`var(--m3e-expansion-panel-disabled-text-color, ${DesignToken.color.onSurface})`),
12
- disabledTextOpacity: unsafeCSS(`var(--m3e-expansion-panel-disabled-text-opacity, 38%)`),
13
- containerColor: unsafeCSS("var(--m3e-expansion-panel-container-color)"),
14
- collapsedElevation: unsafeCSS("var(--m3e-expansion-panel-elevation)"),
15
- collapsedShape: unsafeCSS("var(--m3e-expansion-panel-shape)"),
16
- expandedElevation: unsafeCSS("var(--m3e-expansion-panel-open-elevation, var(--m3e-expansion-panel-elevation))"),
17
- expandedShape: unsafeCSS("var(--m3e-expansion-panel-open-shape, var(--m3e-expansion-panel-shape))"),
18
- expandedSpace: unsafeCSS("var(--_expansion-panel-open-spacing)"),
19
- contentPadding: unsafeCSS("var(--m3e-expansion-panel-content-padding, 0 1.5rem 1rem 1.5rem)"),
20
- actionsSpacing: unsafeCSS("var(--m3e-expansion-panel-actions-spacing, 0.5rem)"),
21
- actionsPadding: unsafeCSS("var(--m3e-expansion-panel-actions-padding, 1rem 1.5rem 1rem 1.5rem)"),
22
- actionsDividerThickness: unsafeCSS(
23
- "var(--m3e-expansion-panel-actions-divider-thickness, var(--m3e-divider-thickness, 1px))"
24
- ),
25
- actionsDividerColor: unsafeCSS(
26
- `var(--m3e-expansion-panel-actions-divider-color, var(--m3e-divider-color, ${DesignToken.color.outlineVariant}))`
27
- ),
28
- } as const;
@@ -1,2 +0,0 @@
1
- export * from "./ExpansionHeaderStyle";
2
- export * from "./ExpansionPanelStyle";
package/tsconfig.json DELETED
@@ -1,9 +0,0 @@
1
- {
2
- "extends": "../../tsconfig.json",
3
- "compilerOptions": {
4
- "rootDir": "./src",
5
- "outDir": "./dist/src"
6
- },
7
- "include": ["src/**/*.ts", "**/*.mjs", "**/*.js"],
8
- "exclude": []
9
- }