@universal-material/web 3.4.2 → 3.5.0
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.
- package/button/button-base.d.ts +1 -1
- package/button/button-base.d.ts.map +1 -1
- package/button/button-base.js +1 -1
- package/button/button-base.js.map +1 -1
- package/button/button-base.styles.d.ts.map +1 -1
- package/button/button-base.styles.js +3 -0
- package/button/button-base.styles.js.map +1 -1
- package/button/button.d.ts +5 -11
- package/button/button.d.ts.map +1 -1
- package/button/button.js +29 -20
- package/button/button.js.map +1 -1
- package/button/button.styles.d.ts.map +1 -1
- package/button/button.styles.js +41 -50
- package/button/button.styles.js.map +1 -1
- package/button/fab-menu-color-context.d.ts +5 -0
- package/button/fab-menu-color-context.d.ts.map +1 -0
- package/button/fab-menu-color-context.js +3 -0
- package/button/fab-menu-color-context.js.map +1 -0
- package/button/fab-menu-item.d.ts +23 -0
- package/button/fab-menu-item.d.ts.map +1 -0
- package/button/fab-menu-item.js +70 -0
- package/button/fab-menu-item.js.map +1 -0
- package/button/fab-menu-item.styles.d.ts +2 -0
- package/button/fab-menu-item.styles.d.ts.map +1 -0
- package/button/fab-menu-item.styles.js +82 -0
- package/button/fab-menu-item.styles.js.map +1 -0
- package/button/fab-menu-open-context.d.ts +4 -0
- package/button/fab-menu-open-context.d.ts.map +1 -0
- package/button/fab-menu-open-context.js +3 -0
- package/button/fab-menu-open-context.js.map +1 -0
- package/button/fab-menu.d.ts +26 -0
- package/button/fab-menu.d.ts.map +1 -0
- package/button/fab-menu.js +93 -0
- package/button/fab-menu.js.map +1 -0
- package/button/fab-menu.styles.d.ts +2 -0
- package/button/fab-menu.styles.d.ts.map +1 -0
- package/button/fab-menu.styles.js +145 -0
- package/button/fab-menu.styles.js.map +1 -0
- package/button/fab.d.ts +2 -1
- package/button/fab.d.ts.map +1 -1
- package/button/fab.js +13 -7
- package/button/fab.js.map +1 -1
- package/button/fab.styles.d.ts.map +1 -1
- package/button/fab.styles.js +50 -56
- package/button/fab.styles.js.map +1 -1
- package/button/icon-button.d.ts +3 -2
- package/button/icon-button.d.ts.map +1 -1
- package/button/icon-button.js +12 -4
- package/button/icon-button.js.map +1 -1
- package/button/icon-button.styles.d.ts.map +1 -1
- package/button/icon-button.styles.js +28 -30
- package/button/icon-button.styles.js.map +1 -1
- package/button/toggle-button.d.ts +6 -5
- package/button/toggle-button.d.ts.map +1 -1
- package/button/toggle-button.js +27 -8
- package/button/toggle-button.js.map +1 -1
- package/button/toggle-button.styles.d.ts.map +1 -1
- package/button/toggle-button.styles.js +18 -13
- package/button/toggle-button.styles.js.map +1 -1
- package/chip/chip.d.ts +9 -23
- package/chip/chip.d.ts.map +1 -1
- package/chip/chip.js +60 -60
- package/chip/chip.js.map +1 -1
- package/chip/chip.styles.d.ts.map +1 -1
- package/chip/chip.styles.js +32 -39
- package/chip/chip.styles.js.map +1 -1
- package/custom-elements.json +4289 -3625
- package/index.d.ts +2 -0
- package/index.d.ts.map +1 -1
- package/index.js +2 -0
- package/index.js.map +1 -1
- package/list/list-item.d.ts.map +1 -1
- package/list/list-item.js +13 -9
- package/list/list-item.js.map +1 -1
- package/list/list-item.styles.d.ts.map +1 -1
- package/list/list-item.styles.js +5 -1
- package/list/list-item.styles.js.map +1 -1
- package/menu/menu-item.d.ts +6 -24
- package/menu/menu-item.d.ts.map +1 -1
- package/menu/menu-item.js +22 -44
- package/menu/menu-item.js.map +1 -1
- package/menu/menu-item.styles.d.ts.map +1 -1
- package/menu/menu-item.styles.js +6 -5
- package/menu/menu-item.styles.js.map +1 -1
- package/navigation/drawer-item.d.ts +5 -14
- package/navigation/drawer-item.d.ts.map +1 -1
- package/navigation/drawer-item.js +18 -21
- package/navigation/drawer-item.js.map +1 -1
- package/navigation/drawer-item.styles.d.ts.map +1 -1
- package/navigation/drawer-item.styles.js +8 -7
- package/navigation/drawer-item.styles.js.map +1 -1
- package/package.json +1 -1
- package/select/option.d.ts +1 -1
- package/select/option.d.ts.map +1 -1
- package/select/option.js +1 -1
- package/select/option.js.map +1 -1
- package/shared/base.styles.d.ts.map +1 -1
- package/shared/base.styles.js +1 -0
- package/shared/base.styles.js.map +1 -1
- package/shared/button-wrapper.d.ts +4 -6
- package/shared/button-wrapper.d.ts.map +1 -1
- package/shared/button-wrapper.js +20 -12
- package/shared/button-wrapper.js.map +1 -1
- package/shared/button-wrapper.styles.d.ts.map +1 -1
- package/shared/button-wrapper.styles.js +7 -5
- package/shared/button-wrapper.styles.js.map +1 -1
- package/tab-bar/tab.d.ts +2 -2
- package/tab-bar/tab.d.ts.map +1 -1
- package/tab-bar/tab.js +3 -3
- package/tab-bar/tab.js.map +1 -1
- package/tab-bar/tab.styles.d.ts.map +1 -1
- package/tab-bar/tab.styles.js +4 -1
- package/tab-bar/tab.styles.js.map +1 -1
- package/typeahead/typeahead.styles.d.ts.map +1 -1
- package/typeahead/typeahead.styles.js +1 -4
- package/typeahead/typeahead.styles.js.map +1 -1
- package/vscode.html-custom-data.json +334 -317
package/button/button-base.d.ts
CHANGED
|
@@ -8,6 +8,6 @@ export declare abstract class UmButtonBase extends UmButtonWrapper {
|
|
|
8
8
|
value: string;
|
|
9
9
|
get form(): HTMLFormElement | null;
|
|
10
10
|
constructor();
|
|
11
|
-
protected
|
|
11
|
+
protected _handleClick(_: UIEvent): void;
|
|
12
12
|
}
|
|
13
13
|
//# sourceMappingURL=button-base.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"button-base.d.ts","sourceRoot":"","sources":["../../src/button/button-base.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAI/D,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAG9D,8BAAsB,YAAa,SAAQ,eAAe;;IAExD,MAAM,CAAC,QAAQ,CAAC,cAAc,QAAQ;IAEtC,OAAgB,MAAM,EAAE,cAAc,CAAoC;IAE9D,IAAI,SAAY;IAEC,KAAK,SAAM;IAExC,IAAI,IAAI,IAAI,eAAe,GAAG,IAAI,CAEjC;;cASkB,
|
|
1
|
+
{"version":3,"file":"button-base.d.ts","sourceRoot":"","sources":["../../src/button/button-base.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAI/D,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAG9D,8BAAsB,YAAa,SAAQ,eAAe;;IAExD,MAAM,CAAC,QAAQ,CAAC,cAAc,QAAQ;IAEtC,OAAgB,MAAM,EAAE,cAAc,CAAoC;IAE9D,IAAI,SAAY;IAEC,KAAK,SAAM;IAExC,IAAI,IAAI,IAAI,eAAe,GAAG,IAAI,CAEjC;;cASkB,YAAY,CAAC,CAAC,EAAE,OAAO,GAAG,IAAI;CA8BlD"}
|
package/button/button-base.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"button-base.js","sourceRoot":"","sources":["../../src/button/button-base.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE7C,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAC9D,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAC;AAEjD,MAAM,OAAgB,YAAa,SAAQ,eAAe;aAExC,mBAAc,GAAG,IAAI,AAAP,CAAQ;aAEtB,WAAM,GAAmB,CAAC,eAAe,CAAC,MAAM,EAAE,MAAM,CAAC,AAAnD,CAAoD;IAM1E,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC;IACrC,CAAC;IAEQ,iBAAiB,CAAmB;IAE7C;QACE,KAAK,EAAE,CAAC;QAXE,SAAI,GAAG,QAAQ,CAAC;QAEC,UAAK,GAAG,EAAE,CAAC;QAUtC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;IAClD,CAAC;IAEkB,
|
|
1
|
+
{"version":3,"file":"button-base.js","sourceRoot":"","sources":["../../src/button/button-base.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE7C,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAC9D,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAC;AAEjD,MAAM,OAAgB,YAAa,SAAQ,eAAe;aAExC,mBAAc,GAAG,IAAI,AAAP,CAAQ;aAEtB,WAAM,GAAmB,CAAC,eAAe,CAAC,MAAM,EAAE,MAAM,CAAC,AAAnD,CAAoD;IAM1E,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC;IACrC,CAAC;IAEQ,iBAAiB,CAAmB;IAE7C;QACE,KAAK,EAAE,CAAC;QAXE,SAAI,GAAG,QAAQ,CAAC;QAEC,UAAK,GAAG,EAAE,CAAC;QAUtC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;IAClD,CAAC;IAEkB,YAAY,CAAC,CAAU;QAExC,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;YAC1C,OAAO;QACT,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;YACf,OAAO;QACT,CAAC;QAED,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAEhD,IAAI,IAAI,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;YAC1B,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YAClB,OAAO;QACT,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,gBAAgB,CACxB,QAAQ,EACR,WAAW,CAAC,EAAE;YACZ,MAAM,CAAC,cAAc,CAAC,WAAW,EAAE,WAAW,EAAE;gBAC9C,YAAY,EAAE,IAAI;gBAClB,UAAU,EAAE,IAAI;gBAChB,GAAG,EAAE,GAAG,EAAE,CAAC,IAAI;aAChB,CAAC,CAAC;QACL,CAAC,EACD,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,CAC9B,CAAC;QACF,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;IAC5B,CAAC;;AA5CW;IAAX,QAAQ,EAAE;0CAAiB;AAEC;IAA5B,QAAQ,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;2CAAY","sourcesContent":["import { CSSResultGroup } from '@lit/reactive-element/css-tag';\n\nimport { property } from 'lit/decorators.js';\n\nimport { UmButtonWrapper } from '../shared/button-wrapper.js';\nimport { styles } from './button-base.styles.js';\n\nexport abstract class UmButtonBase extends UmButtonWrapper {\n\n static readonly formAssociated = true;\n\n static override styles: CSSResultGroup = [UmButtonWrapper.styles, styles];\n\n @property() type = 'submit';\n\n @property({ reflect: true }) value = '';\n\n get form(): HTMLFormElement | null {\n return this.#elementInternals.form;\n }\n\n readonly #elementInternals: ElementInternals;\n\n constructor() {\n super();\n this.#elementInternals = this.attachInternals();\n }\n\n protected override _handleClick(_: UIEvent): void {\n\n if (this.type === 'button' || !!this.href) {\n return;\n }\n\n if (!this.form) {\n return;\n }\n\n this.#elementInternals.setFormValue(this.value);\n\n if (this.type === 'reset') {\n this.form.reset();\n return;\n }\n\n this.form.addEventListener(\n 'submit',\n submitEvent => {\n Object.defineProperty(submitEvent, 'submitter', {\n configurable: true,\n enumerable: true,\n get: () => this,\n });\n },\n { capture: true, once: true },\n );\n this.form.requestSubmit();\n }\n}\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"button-base.styles.d.ts","sourceRoot":"","sources":["../../src/button/button-base.styles.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,MAAM,
|
|
1
|
+
{"version":3,"file":"button-base.styles.d.ts","sourceRoot":"","sources":["../../src/button/button-base.styles.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,MAAM,yBAqBlB,CAAC"}
|
|
@@ -2,6 +2,9 @@ import { css } from 'lit';
|
|
|
2
2
|
export const styles = css `
|
|
3
3
|
:host {
|
|
4
4
|
--_morph-duration: var(--u-button-morph-duration, 125ms);
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
.container {
|
|
5
8
|
transition: background-color var(--_morph-duration) linear, border-radius var(--_morph-duration) linear, color var(--_morph-duration) linear;
|
|
6
9
|
}
|
|
7
10
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"button-base.styles.js","sourceRoot":"","sources":["../../src/button/button-base.styles.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAE1B,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAC
|
|
1
|
+
{"version":3,"file":"button-base.styles.js","sourceRoot":"","sources":["../../src/button/button-base.styles.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAE1B,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAC;;;;;;;;;;;;;;;;;;;;;CAqBzB,CAAC","sourcesContent":["import { css } from 'lit';\n\nexport const styles = css `\n :host {\n --_morph-duration: var(--u-button-morph-duration, 125ms);\n }\n\n .container {\n transition: background-color var(--_morph-duration) linear, border-radius var(--_morph-duration) linear, color var(--_morph-duration) linear;\n }\n\n .icon {\n display: flex;\n justify-content: center;\n align-items: center;\n width: 1em;\n height: 1em;\n line-height: 1em;\n }\n\n ::slotted([slot=icon]) {\n display: inline-block;\n }\n`;\n"]}
|
package/button/button.d.ts
CHANGED
|
@@ -4,7 +4,7 @@ import { HTMLTemplateResult } from 'lit';
|
|
|
4
4
|
import { UmToggleButton } from './toggle-button.js';
|
|
5
5
|
import '../ripple/ripple.js';
|
|
6
6
|
export type UmButtonVariant = 'filled' | 'tonal' | 'elevated' | 'outlined' | 'text';
|
|
7
|
-
export type UmButtonColor = 'primary' | 'secondary' | 'tertiary' | 'error'
|
|
7
|
+
export type UmButtonColor = 'primary' | 'secondary' | 'tertiary' | 'error';
|
|
8
8
|
export declare class UmButton extends UmToggleButton {
|
|
9
9
|
#private;
|
|
10
10
|
static styles: CSSResultGroup;
|
|
@@ -17,20 +17,14 @@ export declare class UmButton extends UmToggleButton {
|
|
|
17
17
|
*/
|
|
18
18
|
color: UmButtonColor;
|
|
19
19
|
trailingIcon: boolean;
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
*
|
|
23
|
-
* _Note:_ Readonly
|
|
24
|
-
*/
|
|
25
|
-
hasIcon: boolean;
|
|
26
|
-
hasSelectionLabel: boolean;
|
|
20
|
+
private _hasIcon;
|
|
21
|
+
private _hasSelectionLabel;
|
|
27
22
|
animateTextChange: boolean;
|
|
28
23
|
private readonly _textWrapper;
|
|
29
24
|
private readonly _text;
|
|
30
25
|
firstUpdated(changedProperties: PropertyValues): void;
|
|
31
|
-
protected
|
|
32
|
-
|
|
33
|
-
protected handleSelectedLabelSlotChange(e: Event): void;
|
|
26
|
+
protected _getContainerClasses(): Record<string, boolean>;
|
|
27
|
+
protected _renderContent(): HTMLTemplateResult;
|
|
34
28
|
}
|
|
35
29
|
declare global {
|
|
36
30
|
interface HTMLElementTagNameMap {
|
package/button/button.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"button.d.ts","sourceRoot":"","sources":["../../src/button/button.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAE/D,OAAO,EAAQ,kBAAkB,EAAE,MAAM,KAAK,CAAC;AAK/C,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAEpD,OAAO,qBAAqB,CAAC;AAE7B,MAAM,MAAM,eAAe,GAAG,QAAQ,GAAG,OAAO,GAAG,UAAU,GAAG,UAAU,GAAG,MAAM,CAAC;AACpF,MAAM,MAAM,aAAa,GAAG,SAAS,GAAG,WAAW,GAAG,UAAU,GAAG,OAAO,
|
|
1
|
+
{"version":3,"file":"button.d.ts","sourceRoot":"","sources":["../../src/button/button.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAE/D,OAAO,EAAQ,kBAAkB,EAAE,MAAM,KAAK,CAAC;AAK/C,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAEpD,OAAO,qBAAqB,CAAC;AAE7B,MAAM,MAAM,eAAe,GAAG,QAAQ,GAAG,OAAO,GAAG,UAAU,GAAG,UAAU,GAAG,MAAM,CAAC;AACpF,MAAM,MAAM,aAAa,GAAG,SAAS,GAAG,WAAW,GAAG,UAAU,GAAG,OAAO,CAAC;AAE3E,qBACa,QAAS,SAAQ,cAAc;;IAC1C,OAAgB,MAAM,EAAE,cAAc,CAAmC;IAEzE;;OAEG;IACS,OAAO,EAAE,eAAe,CAAY;IAEhD;;OAEG;IACS,KAAK,EAAE,aAAa,CAAa;IAE2B,YAAY,UAAS;IAEpF,OAAO,CAAC,QAAQ,CAAS;IACzB,OAAO,CAAC,kBAAkB,CAAS;IACnC,iBAAiB,UAAS;IAEF,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAe;IACtD,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAe;IAInD,YAAY,CAAC,iBAAiB,EAAE,cAAc;cAuBpC,oBAAoB,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;cAW/C,cAAc,IAAI,kBAAkB;CAiCxD;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,UAAU,EAAE,QAAQ,CAAC;KACtB;CACF"}
|
package/button/button.js
CHANGED
|
@@ -12,14 +12,13 @@ let UmButton = class UmButton extends UmToggleButton {
|
|
|
12
12
|
* The Button variant to render
|
|
13
13
|
*/
|
|
14
14
|
this.variant = 'filled';
|
|
15
|
-
this.trailingIcon = false;
|
|
16
15
|
/**
|
|
17
|
-
*
|
|
18
|
-
*
|
|
19
|
-
* _Note:_ Readonly
|
|
16
|
+
* The Button color
|
|
20
17
|
*/
|
|
21
|
-
this.
|
|
22
|
-
this.
|
|
18
|
+
this.color = 'primary';
|
|
19
|
+
this.trailingIcon = false;
|
|
20
|
+
this._hasIcon = false;
|
|
21
|
+
this._hasSelectionLabel = false;
|
|
23
22
|
this.animateTextChange = false;
|
|
24
23
|
}
|
|
25
24
|
static { this.styles = [UmToggleButton.styles, styles]; }
|
|
@@ -39,15 +38,25 @@ let UmButton = class UmButton extends UmToggleButton {
|
|
|
39
38
|
}
|
|
40
39
|
setTimeout(() => this.animateTextChange = animateTextChange);
|
|
41
40
|
}
|
|
42
|
-
|
|
41
|
+
_getContainerClasses() {
|
|
42
|
+
return {
|
|
43
|
+
...super._getContainerClasses(),
|
|
44
|
+
[this.color]: true,
|
|
45
|
+
[this.variant]: true,
|
|
46
|
+
'trailing-icon': this.trailingIcon,
|
|
47
|
+
'has-icon': this._hasIcon,
|
|
48
|
+
'has-selection-label': this._hasSelectionLabel,
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
_renderContent() {
|
|
43
52
|
const labelContainerClasses = { animate: this.animateTextChange };
|
|
44
53
|
return html `
|
|
45
54
|
<span class="icon-container" aria-hidden="true">
|
|
46
55
|
<span class="icon icon-default">
|
|
47
|
-
<slot name="icon" @slotchange="${this
|
|
56
|
+
<slot name="icon" @slotchange="${this.#handleIconSlotChange}"></slot>
|
|
48
57
|
</span>
|
|
49
58
|
<span class="icon icon-selected">
|
|
50
|
-
<slot name="icon-selected" @slotchange="${this.
|
|
59
|
+
<slot name="icon-selected" @slotchange="${this._handleSelectedIconSlotChange}"></slot>
|
|
51
60
|
</span>
|
|
52
61
|
</span>
|
|
53
62
|
|
|
@@ -57,34 +66,34 @@ let UmButton = class UmButton extends UmToggleButton {
|
|
|
57
66
|
<slot></slot>
|
|
58
67
|
</span>
|
|
59
68
|
<span class="label label-selected">
|
|
60
|
-
<slot name="label-selected" @slotchange="${this
|
|
69
|
+
<slot name="label-selected" @slotchange="${this.#handleSelectedLabelSlotChange}"></slot>
|
|
61
70
|
</span>
|
|
62
71
|
</span>
|
|
63
72
|
</span>
|
|
64
73
|
`;
|
|
65
74
|
}
|
|
66
|
-
handleIconSlotChange(e) {
|
|
67
|
-
this.
|
|
75
|
+
#handleIconSlotChange(e) {
|
|
76
|
+
this._hasIcon = e.target.assignedElements({ flatten: true }).length > 0;
|
|
68
77
|
}
|
|
69
|
-
handleSelectedLabelSlotChange(e) {
|
|
70
|
-
this.
|
|
78
|
+
#handleSelectedLabelSlotChange(e) {
|
|
79
|
+
this._hasSelectionLabel = e.target.assignedElements({ flatten: true }).length > 0;
|
|
71
80
|
}
|
|
72
81
|
};
|
|
73
82
|
__decorate([
|
|
74
|
-
property(
|
|
83
|
+
property()
|
|
75
84
|
], UmButton.prototype, "variant", void 0);
|
|
76
85
|
__decorate([
|
|
77
|
-
property(
|
|
86
|
+
property()
|
|
78
87
|
], UmButton.prototype, "color", void 0);
|
|
79
88
|
__decorate([
|
|
80
89
|
property({ type: Boolean, attribute: 'trailing-icon', reflect: true })
|
|
81
90
|
], UmButton.prototype, "trailingIcon", void 0);
|
|
82
91
|
__decorate([
|
|
83
|
-
|
|
84
|
-
], UmButton.prototype, "
|
|
92
|
+
state()
|
|
93
|
+
], UmButton.prototype, "_hasIcon", void 0);
|
|
85
94
|
__decorate([
|
|
86
|
-
|
|
87
|
-
], UmButton.prototype, "
|
|
95
|
+
state()
|
|
96
|
+
], UmButton.prototype, "_hasSelectionLabel", void 0);
|
|
88
97
|
__decorate([
|
|
89
98
|
state()
|
|
90
99
|
], UmButton.prototype, "animateTextChange", void 0);
|
package/button/button.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"button.js","sourceRoot":"","sources":["../../src/button/button.ts"],"names":[],"mappings":";AAGA,OAAO,EAAE,IAAI,EAAsB,MAAM,KAAK,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAC1E,OAAO,EAAE,QAAQ,EAAE,MAAM,6BAA6B,CAAC;AAEvD,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAC5C,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAEpD,OAAO,qBAAqB,CAAC;AAMtB,IAAM,QAAQ,GAAd,MAAM,QAAS,SAAQ,cAAc;IAArC;;QAGL;;WAEG;
|
|
1
|
+
{"version":3,"file":"button.js","sourceRoot":"","sources":["../../src/button/button.ts"],"names":[],"mappings":";AAGA,OAAO,EAAE,IAAI,EAAsB,MAAM,KAAK,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAC1E,OAAO,EAAE,QAAQ,EAAE,MAAM,6BAA6B,CAAC;AAEvD,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAC5C,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAEpD,OAAO,qBAAqB,CAAC;AAMtB,IAAM,QAAQ,GAAd,MAAM,QAAS,SAAQ,cAAc;IAArC;;QAGL;;WAEG;QACS,YAAO,GAAoB,QAAQ,CAAC;QAEhD;;WAEG;QACS,UAAK,GAAkB,SAAS,CAAC;QAE2B,iBAAY,GAAG,KAAK,CAAC;QAE5E,aAAQ,GAAG,KAAK,CAAC;QACjB,uBAAkB,GAAG,KAAK,CAAC;QACnC,sBAAiB,GAAG,KAAK,CAAC;IA0ErC,CAAC;aA1FiB,WAAM,GAAmB,CAAC,cAAc,CAAC,MAAM,EAAE,MAAM,CAAC,AAAlD,CAAmD;IAqBzE,iBAAiB,CAAyB;IAEjC,YAAY,CAAC,iBAAiC;QACrD,KAAK,CAAC,YAAY,CAAC,iBAAiB,CAAC,CAAC;QAEtC,IAAI,CAAC,iBAAiB,GAAG,IAAI,cAAc,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,oBAAoB,EAAE,CAAC,CAAC;QAC/E,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC3C,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC9B,CAAC;IAED,oBAAoB;QAElB,MAAM,KAAK,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,IAAI,CAAC;QAC5C,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;QAEtC,MAAM,iBAAiB,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEhD,IAAI,IAAI,CAAC,iBAAiB,KAAK,iBAAiB,EAAE,CAAC;YACjD,OAAO;QACT,CAAC;QAED,UAAU,CAAC,GAAG,EAAE,CACd,IAAI,CAAC,iBAAiB,GAAG,iBAAiB,CAAC,CAAC;IAChD,CAAC;IAEkB,oBAAoB;QACrC,OAAO;YACL,GAAG,KAAK,CAAC,oBAAoB,EAAE;YAC/B,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,IAAI;YAClB,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,IAAI;YACpB,eAAe,EAAE,IAAI,CAAC,YAAY;YAClC,UAAU,EAAE,IAAI,CAAC,QAAQ;YACzB,qBAAqB,EAAE,IAAI,CAAC,kBAAkB;SAC/C,CAAC;IACJ,CAAC;IAEkB,cAAc;QAC/B,MAAM,qBAAqB,GAAG,EAAE,OAAO,EAAE,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAElE,OAAO,IAAI,CAAA;;;2CAG4B,IAAI,CAAC,qBAAqB;;;oDAGjB,IAAI,CAAC,6BAA6B;;;;qCAIjD,QAAQ,CAAC,qBAAqB,CAAC;;;;;;uDAMb,IAAI,CAAC,8BAA8B;;;;KAIrF,CAAC;IACJ,CAAC;IAED,qBAAqB,CAAC,CAAQ;QAC5B,IAAI,CAAC,QAAQ,GAAI,CAAC,CAAC,MAA0B,CAAC,gBAAgB,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;IAC/F,CAAC;IAED,8BAA8B,CAAC,CAAQ;QACrC,IAAI,CAAC,kBAAkB,GAAI,CAAC,CAAC,MAA0B,CAAC,gBAAgB,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;IACzG,CAAC;;AApFW;IAAX,QAAQ,EAAE;yCAAqC;AAKpC;IAAX,QAAQ,EAAE;uCAAkC;AAE2B;IAAvE,QAAQ,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;8CAAsB;AAE5E;IAAhB,KAAK,EAAE;0CAA0B;AACjB;IAAhB,KAAK,EAAE;oDAAoC;AACnC;IAAR,KAAK,EAAE;mDAA2B;AAEe;IAAjD,KAAK,CAAC,kBAAkB,EAAE,IAAI,CAAC;8CAA6C;AACrC;IAAvC,KAAK,CAAC,QAAQ,EAAE,IAAI,CAAC;uCAAsC;AApBjD,QAAQ;IADpB,aAAa,CAAC,UAAU,CAAC;GACb,QAAQ,CA2FpB","sourcesContent":["import { PropertyValues } from '@lit/reactive-element';\nimport { CSSResultGroup } from '@lit/reactive-element/css-tag';\n\nimport { html, HTMLTemplateResult } from 'lit';\nimport { customElement, property, query, state } from 'lit/decorators.js';\nimport { classMap } from 'lit/directives/class-map.js';\n\nimport { styles } from './button.styles.js';\nimport { UmToggleButton } from './toggle-button.js';\n\nimport '../ripple/ripple.js';\n\nexport type UmButtonVariant = 'filled' | 'tonal' | 'elevated' | 'outlined' | 'text';\nexport type UmButtonColor = 'primary' | 'secondary' | 'tertiary' | 'error';\n\n@customElement('u-button')\nexport class UmButton extends UmToggleButton {\n static override styles: CSSResultGroup = [UmToggleButton.styles, styles];\n\n /**\n * The Button variant to render\n */\n @property() variant: UmButtonVariant = 'filled';\n\n /**\n * The Button color\n */\n @property() color: UmButtonColor = 'primary';\n\n @property({ type: Boolean, attribute: 'trailing-icon', reflect: true }) trailingIcon = false;\n\n @state() private _hasIcon = false;\n @state() private _hasSelectionLabel = false;\n @state() animateTextChange = false;\n\n @query('.label-container', true) private readonly _textWrapper!: HTMLElement;\n @query('#label', true) private readonly _text!: HTMLElement;\n\n #textSizeObserver!: ResizeObserver | null;\n\n override firstUpdated(changedProperties: PropertyValues) {\n super.firstUpdated(changedProperties);\n\n this.#textSizeObserver = new ResizeObserver(() => this.#setTextWrapperWidth());\n this.#textSizeObserver.observe(this._text);\n this.#setTextWrapperWidth();\n }\n\n #setTextWrapperWidth(): void {\n\n const width = `${this._text.offsetWidth}px`;\n this._textWrapper.style.width = width;\n\n const animateTextChange = !!parseInt(width, 10);\n\n if (this.animateTextChange === animateTextChange) {\n return;\n }\n\n setTimeout(() =>\n this.animateTextChange = animateTextChange);\n }\n\n protected override _getContainerClasses(): Record<string, boolean> {\n return {\n ...super._getContainerClasses(),\n [this.color]: true,\n [this.variant]: true,\n 'trailing-icon': this.trailingIcon,\n 'has-icon': this._hasIcon,\n 'has-selection-label': this._hasSelectionLabel,\n };\n }\n\n protected override _renderContent(): HTMLTemplateResult {\n const labelContainerClasses = { animate: this.animateTextChange };\n\n return html`\n <span class=\"icon-container\" aria-hidden=\"true\">\n <span class=\"icon icon-default\">\n <slot name=\"icon\" @slotchange=\"${this.#handleIconSlotChange}\"></slot>\n </span>\n <span class=\"icon icon-selected\">\n <slot name=\"icon-selected\" @slotchange=\"${this._handleSelectedIconSlotChange}\"></slot>\n </span>\n </span>\n\n <span class=\"label-container ${classMap(labelContainerClasses)}\">\n <span id=\"label\">\n <span class=\"label label-default\">\n <slot></slot>\n </span>\n <span class=\"label label-selected\">\n <slot name=\"label-selected\" @slotchange=\"${this.#handleSelectedLabelSlotChange}\"></slot>\n </span>\n </span>\n </span>\n `;\n }\n\n #handleIconSlotChange(e: Event) {\n this._hasIcon = (e.target as HTMLSlotElement).assignedElements({ flatten: true }).length > 0;\n }\n\n #handleSelectedLabelSlotChange(e: Event): void {\n this._hasSelectionLabel = (e.target as HTMLSlotElement).assignedElements({ flatten: true }).length > 0;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'u-button': UmButton;\n }\n}\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"button.styles.d.ts","sourceRoot":"","sources":["../../src/button/button.styles.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,MAAM,
|
|
1
|
+
{"version":3,"file":"button.styles.d.ts","sourceRoot":"","sources":["../../src/button/button.styles.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,MAAM,yBAyNlB,CAAC"}
|
package/button/button.styles.js
CHANGED
|
@@ -50,128 +50,119 @@ export const styles = css `
|
|
|
50
50
|
--_padding: var(--_small-padding);
|
|
51
51
|
--_icon-margin: var(--_small-icon-margin);
|
|
52
52
|
--_round-shape-corner: var(--u-common-button-round-shape-corner, calc(var(--_size) / 2));
|
|
53
|
-
font-family: var(--u-font-family, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", "Noto Sans", "Liberation Sans", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
|
|
54
|
-
font-size: var(--_font-size);
|
|
55
|
-
font-weight: var(--_font-weight);
|
|
56
|
-
padding-inline: var(--_padding);
|
|
57
|
-
box-sizing: border-box;
|
|
58
53
|
}
|
|
59
54
|
|
|
60
|
-
|
|
55
|
+
.extra-small {
|
|
61
56
|
--_font-size: var(--_extra-small-font-size);
|
|
62
57
|
--_font-weight: var(--_extra-small-font-weight);
|
|
63
58
|
--_padding: var(--_extra-small-padding);
|
|
64
59
|
--_icon-margin: var(--_extra-small-icon-margin);
|
|
65
60
|
}
|
|
66
61
|
|
|
67
|
-
|
|
62
|
+
.medium {
|
|
68
63
|
--_font-size: var(--_medium-font-size);
|
|
69
64
|
--_font-weight: var(--_medium-font-weight);
|
|
70
65
|
--_padding: var(--_medium-padding);
|
|
71
66
|
--_icon-margin: var(--_medium-icon-margin);
|
|
72
67
|
}
|
|
73
68
|
|
|
74
|
-
|
|
69
|
+
.large {
|
|
75
70
|
--_font-size: var(--_large-font-size);
|
|
76
71
|
--_font-weight: var(--_large-font-weight);
|
|
77
72
|
--_padding: var(--_large-padding);
|
|
78
73
|
--_icon-margin: var(--_large-icon-margin);
|
|
79
74
|
}
|
|
80
75
|
|
|
81
|
-
|
|
76
|
+
.extra-large {
|
|
82
77
|
--_font-size: var(--_extra-large-font-size);
|
|
83
78
|
--_font-weight: var(--_extra-large-font-weight);
|
|
84
79
|
--_padding: var(--_extra-large-padding);
|
|
85
80
|
--_icon-margin: var(--_extra-large-icon-margin);
|
|
86
81
|
}
|
|
87
82
|
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
83
|
+
.container {
|
|
84
|
+
font-family: var(--u-font-family, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", "Noto Sans", "Liberation Sans", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
|
|
85
|
+
font-size: var(--_font-size);
|
|
86
|
+
font-weight: var(--_font-weight);
|
|
87
|
+
padding-inline: var(--_padding);
|
|
88
|
+
box-sizing: border-box;
|
|
91
89
|
}
|
|
92
90
|
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
:host([variant=filled][color=primary]:not([toggle])),
|
|
96
|
-
:host([variant=filled][color=primary][selected]) {
|
|
97
|
-
background-color: var(--u-filled-button-primary-container-color, var(--_color-primary));
|
|
91
|
+
.filled.primary, .filled.primary.selected {
|
|
92
|
+
background-color: var(--u-filled-button-primary-container-color, var(--u-color-primary, rgb(103, 80, 164)));
|
|
98
93
|
color: var(--u-filled-button-primary-text-color, var(--u-color-on-primary, rgb(255, 255, 255)));
|
|
99
94
|
}
|
|
100
|
-
|
|
101
|
-
:host([variant=filled][color=secondary]:not([toggle])),
|
|
102
|
-
:host([variant=filled][color=secondary][selected]) {
|
|
95
|
+
.filled.secondary, .filled.secondary.selected {
|
|
103
96
|
background-color: var(--u-filled-button-secondary-container-color, var(--u-color-secondary, rgb(98, 91, 113)));
|
|
104
97
|
color: var(--u-filled-button-secondary-text-color, var(--u-color-on-secondary, rgb(255, 255, 255)));
|
|
105
98
|
}
|
|
106
|
-
|
|
107
|
-
:host([variant=filled][color=tertiary]:not([toggle])),
|
|
108
|
-
:host([variant=filled][color=tertiary][selected]) {
|
|
99
|
+
.filled.tertiary, .filled.tertiary.selected {
|
|
109
100
|
background-color: var(--u-filled-button-tertiary-container-color, var(--u-color-tertiary, rgb(125, 82, 96)));
|
|
110
101
|
color: var(--u-filled-button-tertiary-text-color, var(--u-color-on-tertiary, rgb(255, 255, 255)));
|
|
111
102
|
}
|
|
112
|
-
|
|
113
|
-
:host([variant=filled][color=error]:not([toggle])),
|
|
114
|
-
:host([variant=filled][color=error][selected]) {
|
|
103
|
+
.filled.error, .filled.error.selected {
|
|
115
104
|
background-color: var(--u-filled-button-error-container-color, var(--u-color-error, rgb(179, 38, 30)));
|
|
116
105
|
color: var(--u-filled-button-error-text-color, var(--u-color-on-error, rgb(255, 255, 255)));
|
|
117
106
|
}
|
|
107
|
+
.filled.toggle {
|
|
108
|
+
background-color: var(--u-filled-button-container-unselected-color, var(--u-color-surface-container, rgb(243, 237, 247)));
|
|
109
|
+
color: var(--u-filled-button-unselected-text-color, var(--u-color-on-surface-variant, rgb(73, 69, 79)));
|
|
110
|
+
}
|
|
118
111
|
|
|
119
|
-
|
|
112
|
+
.tonal {
|
|
120
113
|
background-color: var(--u-tonal-button-container-color, var(--u-color-secondary-container, rgb(232, 222, 248)));
|
|
121
114
|
color: var(--u-tonal-button-text-color, var(--u-color-on-secondary-container, rgb(29, 25, 43)));
|
|
122
115
|
}
|
|
123
|
-
|
|
124
|
-
:host([variant=tonal][selected]) {
|
|
116
|
+
.tonal.selected {
|
|
125
117
|
background-color: var(--u-tonal-button-container-selected-color, var(--u-color-secondary, rgb(98, 91, 113)));
|
|
126
118
|
color: var(--u-tonal-button-text-selected-color, var(--u-color-on-secondary, rgb(255, 255, 255)));
|
|
127
119
|
}
|
|
128
120
|
|
|
129
|
-
|
|
121
|
+
.elevated {
|
|
130
122
|
background-color: var(--u-elevated-button-container-color, var(--u-color-surface-container-low, rgb(247, 242, 250)));
|
|
131
123
|
color: var(--u-elevated-button-text-color, var(--u-color-primary, rgb(103, 80, 164)));
|
|
132
124
|
}
|
|
133
|
-
|
|
134
|
-
:host([variant=elevated][selected]) {
|
|
125
|
+
.elevated.selected {
|
|
135
126
|
background-color: var(--u-elevated-button-container-selected-color, var(--u-color-primary, rgb(103, 80, 164)));
|
|
136
127
|
color: var(--u-elevated-button-text-selected-color, var(--u-color-on-primary, rgb(255, 255, 255)));
|
|
137
128
|
}
|
|
138
129
|
|
|
139
130
|
@media (hover: hover) {
|
|
140
|
-
|
|
141
|
-
|
|
131
|
+
.filled:hover:not(:focus-within):not(:active),
|
|
132
|
+
.tonal:hover:not(:focus-within):not(:active) {
|
|
142
133
|
--u-elevation-level: var(--u-filled-button-hover-elevation-level, 1);
|
|
143
134
|
}
|
|
144
135
|
}
|
|
145
|
-
|
|
136
|
+
.text {
|
|
146
137
|
color: var(--u-text-button-text-color, var(--_color-primary));
|
|
147
138
|
}
|
|
148
139
|
|
|
149
|
-
|
|
140
|
+
.outlined {
|
|
150
141
|
color: var(--u-outlined-button-text-color, var(--u-text-button-text-color, var(--_color-primary)));
|
|
151
142
|
border: 1px solid var(--u-outlined-button-outline-color, var(--u-color-outline, rgb(121, 116, 126)));
|
|
152
143
|
}
|
|
153
|
-
|
|
154
|
-
:host([variant=outlined][selected]) {
|
|
144
|
+
.outlined.selected {
|
|
155
145
|
background-color: var(--u-outlined-button-container-selected-color, var(--u-color-inverse-surface, rgb(50, 47, 53)));
|
|
156
146
|
color: var(--u-outlined-button-text-selected-color, var(--u-color-on-inverse-surface, rgb(245, 239, 247)));
|
|
157
147
|
}
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
--u-elevation-level: var(--u-elevated-button-elevation-level, 1);
|
|
161
|
-
color: var(--u-elevated-button-text-color, var(--_color-primary));
|
|
148
|
+
.outlined.disabled {
|
|
149
|
+
border-color: var(--u-outlined-button-disabled-border-color, color-mix(in srgb, var(--u-color-on-surface, rgb(29, 27, 32)) var(--u-outlined-button-disabled-border-opacity, 12%), transparent)) !important;
|
|
162
150
|
}
|
|
163
|
-
|
|
164
|
-
:host([disabled][variant=outlined]) {
|
|
151
|
+
.outlined.disabled:not(.selected) {
|
|
165
152
|
background-color: transparent !important;
|
|
166
|
-
border-color: var(--u-outlined-button-disabled-border-color, color-mix(in srgb, var(--u-color-on-surface, rgb(29, 27, 32)) var(--u-outlined-button-disabled-border-opacity, 12%), transparent)) !important;
|
|
167
153
|
}
|
|
168
154
|
|
|
155
|
+
.elevated {
|
|
156
|
+
--u-elevation-level: var(--u-elevated-button-elevation-level, 1);
|
|
157
|
+
color: var(--u-elevated-button-text-color, var(--_color-primary));
|
|
158
|
+
}
|
|
169
159
|
@media (hover: hover) {
|
|
170
|
-
|
|
160
|
+
.elevated:hover {
|
|
171
161
|
--u-elevation-level: var(--u-elevated-button-hover-elevation-level, 2);
|
|
172
162
|
}
|
|
173
163
|
}
|
|
174
|
-
|
|
164
|
+
|
|
165
|
+
.container:not(.has-icon) .icon-container {
|
|
175
166
|
display: none;
|
|
176
167
|
}
|
|
177
168
|
|
|
@@ -183,7 +174,7 @@ export const styles = css `
|
|
|
183
174
|
font-size: var(--_icon-size);
|
|
184
175
|
}
|
|
185
176
|
|
|
186
|
-
|
|
177
|
+
.trailing-icon .content {
|
|
187
178
|
flex-direction: row-reverse;
|
|
188
179
|
}
|
|
189
180
|
|
|
@@ -215,12 +206,12 @@ export const styles = css `
|
|
|
215
206
|
transition-delay: 0ms;
|
|
216
207
|
}
|
|
217
208
|
|
|
218
|
-
|
|
209
|
+
.selected.has-selection-label .label-default {
|
|
219
210
|
position: absolute;
|
|
220
211
|
opacity: 0;
|
|
221
212
|
transition-delay: 0ms;
|
|
222
213
|
}
|
|
223
|
-
|
|
214
|
+
.selected.has-selection-label .label-selected {
|
|
224
215
|
position: static;
|
|
225
216
|
opacity: 1;
|
|
226
217
|
transition-delay: calc(var(--_morph-duration) / 2);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"button.styles.js","sourceRoot":"","sources":["../../src/button/button.styles.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAE1B,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAkOzB,CAAC","sourcesContent":["import { css } from 'lit';\n\nexport const styles = css `\n :host {\n --u-common-button-line-height: var(--u-label-large-line-height, 1.25rem);\n --u-common-button-font-size: var(--u-label-large-font-size, .875rem);\n --u-common-button-font-weight: var(--u-font-weight-medium, 500);\n --_common-button-padding: var(--u-common-button-padding, 16px);\n --_extra-small-font-size: var(--u-common-button-extra-small-font-size, .875rem);\n --_small-font-size: var(--u-common-button-small-font-size, .875rem);\n --_medium-font-size: var(--u-common-button-medium-font-size, 1rem);\n --_large-font-size: var(--u-common-button-large-font-size, 1.5rem);\n --_extra-large-font-size: var(--u-common-button-extra-large-font-size, 2rem);\n --_extra-small-font-weight: var(--u-common-button-extra-small-font-weight, var(--u-font-weight-medium, 500));\n --_small-font-weight: var(--u-common-button-small-font-weight, var(--u-font-weight-medium, 500));\n --_medium-font-weight: var(--u-common-button-medium-font-weight, var(--u-font-weight-medium, 500));\n --_large-font-weight: var(--u-common-button-large-font-weight, var(--u-font-weight-regular, 400));\n --_extra-large-font-weight: var(--u-common-button-extra-large-font-weight, var(--u-font-weight-regular, 400));\n --_extra-small-size: var(--u-common-button-extra-small-height, 32px);\n --_small-size: var(--u-common-button-small-height, 40px);\n --_medium-size: var(--u-common-button-medium-height, 56px);\n --_large-size: var(--u-common-button-large-height, 96px);\n --_extra-large-size: var(--u-common-button-extra-large-height, 136px);\n --_extra-small-icon-size: var(--u-icon-button-extra-small-icon-size, 1.25rem);\n --_small-icon-size: var(--u-icon-button-small-icon-size, 1.25rem);\n --_medium-icon-size: var(--u-icon-button-medium-icon-size, 1.5rem);\n --_large-icon-size: var(--u-icon-button-large-icon-size, 2rem);\n --_extra-large-icon-size: var(--u-icon-button-extra-large-icon-size, 2.5rem);\n --_extra-small-icon-margin: var(--u-icon-button-extra-small-icon-margin, 8px);\n --_small-icon-margin: var(--u-icon-button-small-icon-margin, 8px);\n --_medium-icon-margin: var(--u-icon-button-medium-icon-margin, 8px);\n --_large-icon-margin: var(--u-icon-button-large-icon-margin, 12px);\n --_extra-large-icon-margin: var(--u-icon-button-extra-large-icon-margin, 16px);\n --_extra-small-padding: var(--u-common-button-extra-small-padding, 12px);\n --_small-padding: var(--u-common-button-small-padding, 16px);\n --_medium-padding: var(--u-common-button-medium-padding, 24px);\n --_large-padding: var(--u-common-button-large-padding, 48px);\n --_extra-large-padding: var(--u-common-button-extra-large-padding, 64px);\n --_extra-small-square-shape-corner: var(--u-common-button-extra-small-square-shape-corner, 12px);\n --_small-square-shape-corner: var(--u-common-button-small-square-shape-corner, 12px);\n --_medium-square-shape-corner: var(--u-common-button-medium-square-shape-corner, 16px);\n --_large-square-shape-corner: var(--u-common-button-large-square-shape-corner, 28px);\n --_extra-large-square-shape-corner: var(--u-common-button-extra-large-square-shape-corner, 28px);\n --_extra-small-pressed-shape-corner: var(--u-common-button-extra-small-pressed-shape-corner, 8px);\n --_small-pressed-shape-corner: var(--u-common-button-small-pressed-shape-corner, 8px);\n --_medium-pressed-shape-corner: var(--u-common-button-medium-pressed-shape-corner, 12px);\n --_large-pressed-shape-corner: var(--u-common-button-large-pressed-shape-corner, 16px);\n --_extra-large-pressed-shape-corner: var(--u-common-button-extra-large-pressed-shape-corner, 16px);\n --_font-size: var(--_small-font-size);\n --_font-weight: var(--_small-font-weight);\n --_padding: var(--_small-padding);\n --_icon-margin: var(--_small-icon-margin);\n --_round-shape-corner: var(--u-common-button-round-shape-corner, calc(var(--_size) / 2));\n font-family: var(--u-font-family, system-ui, -apple-system, \"Segoe UI\", Roboto, \"Helvetica Neue\", \"Noto Sans\", \"Liberation Sans\", Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\", \"Noto Color Emoji\");\n font-size: var(--_font-size);\n font-weight: var(--_font-weight);\n padding-inline: var(--_padding);\n box-sizing: border-box;\n }\n\n :host([size=extra-small]) {\n --_font-size: var(--_extra-small-font-size);\n --_font-weight: var(--_extra-small-font-weight);\n --_padding: var(--_extra-small-padding);\n --_icon-margin: var(--_extra-small-icon-margin);\n }\n\n :host([size=medium]) {\n --_font-size: var(--_medium-font-size);\n --_font-weight: var(--_medium-font-weight);\n --_padding: var(--_medium-padding);\n --_icon-margin: var(--_medium-icon-margin);\n }\n\n :host([size=large]) {\n --_font-size: var(--_large-font-size);\n --_font-weight: var(--_large-font-weight);\n --_padding: var(--_large-padding);\n --_icon-margin: var(--_large-icon-margin);\n }\n\n :host([size=extra-large]) {\n --_font-size: var(--_extra-large-font-size);\n --_font-weight: var(--_extra-large-font-weight);\n --_padding: var(--_extra-large-padding);\n --_icon-margin: var(--_extra-large-icon-margin);\n }\n\n :host([variant=filled][toggle]) {\n background-color: var(--u-filled-button-primary-container-unselected-color, var(--u-color-surface-container, rgb(243, 237, 247)));\n color: var(--u-filled-button-primary-text-color, var(--u-color-on-surface-variant, rgb(73, 69, 79)));\n }\n\n :host([variant=filled]:not([toggle])),\n :host([variant=filled][selected]),\n :host([variant=filled][color=primary]:not([toggle])),\n :host([variant=filled][color=primary][selected]) {\n background-color: var(--u-filled-button-primary-container-color, var(--_color-primary));\n color: var(--u-filled-button-primary-text-color, var(--u-color-on-primary, rgb(255, 255, 255)));\n }\n\n :host([variant=filled][color=secondary]:not([toggle])),\n :host([variant=filled][color=secondary][selected]) {\n background-color: var(--u-filled-button-secondary-container-color, var(--u-color-secondary, rgb(98, 91, 113)));\n color: var(--u-filled-button-secondary-text-color, var(--u-color-on-secondary, rgb(255, 255, 255)));\n }\n\n :host([variant=filled][color=tertiary]:not([toggle])),\n :host([variant=filled][color=tertiary][selected]) {\n background-color: var(--u-filled-button-tertiary-container-color, var(--u-color-tertiary, rgb(125, 82, 96)));\n color: var(--u-filled-button-tertiary-text-color, var(--u-color-on-tertiary, rgb(255, 255, 255)));\n }\n\n :host([variant=filled][color=error]:not([toggle])),\n :host([variant=filled][color=error][selected]) {\n background-color: var(--u-filled-button-error-container-color, var(--u-color-error, rgb(179, 38, 30)));\n color: var(--u-filled-button-error-text-color, var(--u-color-on-error, rgb(255, 255, 255)));\n }\n\n :host([variant=tonal]) {\n background-color: var(--u-tonal-button-container-color, var(--u-color-secondary-container, rgb(232, 222, 248)));\n color: var(--u-tonal-button-text-color, var(--u-color-on-secondary-container, rgb(29, 25, 43)));\n }\n\n :host([variant=tonal][selected]) {\n background-color: var(--u-tonal-button-container-selected-color, var(--u-color-secondary, rgb(98, 91, 113)));\n color: var(--u-tonal-button-text-selected-color, var(--u-color-on-secondary, rgb(255, 255, 255)));\n }\n\n :host([variant=elevated]) {\n background-color: var(--u-elevated-button-container-color, var(--u-color-surface-container-low, rgb(247, 242, 250)));\n color: var(--u-elevated-button-text-color, var(--u-color-primary, rgb(103, 80, 164)));\n }\n\n :host([variant=elevated][selected]) {\n background-color: var(--u-elevated-button-container-selected-color, var(--u-color-primary, rgb(103, 80, 164)));\n color: var(--u-elevated-button-text-selected-color, var(--u-color-on-primary, rgb(255, 255, 255)));\n }\n\n @media (hover: hover) {\n :host([variant=filled]:hover:not(:focus-within):not(:active)),\n :host([variant=tonal]:hover:not(:focus-within):not(:active)) {\n --u-elevation-level: var(--u-filled-button-hover-elevation-level, 1);\n }\n }\n :host([variant=text]) {\n color: var(--u-text-button-text-color, var(--_color-primary));\n }\n\n :host([variant=outlined]) {\n color: var(--u-outlined-button-text-color, var(--u-text-button-text-color, var(--_color-primary)));\n border: 1px solid var(--u-outlined-button-outline-color, var(--u-color-outline, rgb(121, 116, 126)));\n }\n\n :host([variant=outlined][selected]) {\n background-color: var(--u-outlined-button-container-selected-color, var(--u-color-inverse-surface, rgb(50, 47, 53)));\n color: var(--u-outlined-button-text-selected-color, var(--u-color-on-inverse-surface, rgb(245, 239, 247)));\n }\n\n :host([variant=elevated]) {\n --u-elevation-level: var(--u-elevated-button-elevation-level, 1);\n color: var(--u-elevated-button-text-color, var(--_color-primary));\n }\n\n :host([disabled][variant=outlined]) {\n background-color: transparent !important;\n border-color: var(--u-outlined-button-disabled-border-color, color-mix(in srgb, var(--u-color-on-surface, rgb(29, 27, 32)) var(--u-outlined-button-disabled-border-opacity, 12%), transparent)) !important;\n }\n\n @media (hover: hover) {\n :host([variant=elevated]:hover) {\n --u-elevation-level: var(--u-elevated-button-hover-elevation-level, 2);\n }\n }\n :host(:not([has-icon])) .icon-container {\n display: none;\n }\n\n .content {\n gap: var(--_icon-margin);\n }\n\n .icon {\n font-size: var(--_icon-size);\n }\n\n :host([trailing-icon]) .content {\n flex-direction: row-reverse;\n }\n\n #label {\n display: inline-block;\n }\n\n .label {\n display: inline-block;\n inset-inline-start: 0;\n transition-duration: calc(var(--_morph-duration) * 0.7);\n }\n\n .label-container {\n position: relative;\n }\n .label-container.animate {\n transition: width var(--_morph-duration) linear;\n }\n\n .label-default {\n opacity: 1;\n transition-delay: calc(var(--_morph-duration) / 2);\n }\n\n .label-selected {\n position: absolute;\n opacity: 0;\n transition-delay: 0ms;\n }\n\n :host([selected][has-selection-label]) .label-default {\n position: absolute;\n opacity: 0;\n transition-delay: 0ms;\n }\n :host([selected][has-selection-label]) .label-selected {\n position: static;\n opacity: 1;\n transition-delay: calc(var(--_morph-duration) / 2);\n }\n`;\n"]}
|
|
1
|
+
{"version":3,"file":"button.styles.js","sourceRoot":"","sources":["../../src/button/button.styles.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAE1B,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAyNzB,CAAC","sourcesContent":["import { css } from 'lit';\n\nexport const styles = css `\n :host {\n --u-common-button-line-height: var(--u-label-large-line-height, 1.25rem);\n --u-common-button-font-size: var(--u-label-large-font-size, .875rem);\n --u-common-button-font-weight: var(--u-font-weight-medium, 500);\n --_common-button-padding: var(--u-common-button-padding, 16px);\n --_extra-small-font-size: var(--u-common-button-extra-small-font-size, .875rem);\n --_small-font-size: var(--u-common-button-small-font-size, .875rem);\n --_medium-font-size: var(--u-common-button-medium-font-size, 1rem);\n --_large-font-size: var(--u-common-button-large-font-size, 1.5rem);\n --_extra-large-font-size: var(--u-common-button-extra-large-font-size, 2rem);\n --_extra-small-font-weight: var(--u-common-button-extra-small-font-weight, var(--u-font-weight-medium, 500));\n --_small-font-weight: var(--u-common-button-small-font-weight, var(--u-font-weight-medium, 500));\n --_medium-font-weight: var(--u-common-button-medium-font-weight, var(--u-font-weight-medium, 500));\n --_large-font-weight: var(--u-common-button-large-font-weight, var(--u-font-weight-regular, 400));\n --_extra-large-font-weight: var(--u-common-button-extra-large-font-weight, var(--u-font-weight-regular, 400));\n --_extra-small-size: var(--u-common-button-extra-small-height, 32px);\n --_small-size: var(--u-common-button-small-height, 40px);\n --_medium-size: var(--u-common-button-medium-height, 56px);\n --_large-size: var(--u-common-button-large-height, 96px);\n --_extra-large-size: var(--u-common-button-extra-large-height, 136px);\n --_extra-small-icon-size: var(--u-icon-button-extra-small-icon-size, 1.25rem);\n --_small-icon-size: var(--u-icon-button-small-icon-size, 1.25rem);\n --_medium-icon-size: var(--u-icon-button-medium-icon-size, 1.5rem);\n --_large-icon-size: var(--u-icon-button-large-icon-size, 2rem);\n --_extra-large-icon-size: var(--u-icon-button-extra-large-icon-size, 2.5rem);\n --_extra-small-icon-margin: var(--u-icon-button-extra-small-icon-margin, 8px);\n --_small-icon-margin: var(--u-icon-button-small-icon-margin, 8px);\n --_medium-icon-margin: var(--u-icon-button-medium-icon-margin, 8px);\n --_large-icon-margin: var(--u-icon-button-large-icon-margin, 12px);\n --_extra-large-icon-margin: var(--u-icon-button-extra-large-icon-margin, 16px);\n --_extra-small-padding: var(--u-common-button-extra-small-padding, 12px);\n --_small-padding: var(--u-common-button-small-padding, 16px);\n --_medium-padding: var(--u-common-button-medium-padding, 24px);\n --_large-padding: var(--u-common-button-large-padding, 48px);\n --_extra-large-padding: var(--u-common-button-extra-large-padding, 64px);\n --_extra-small-square-shape-corner: var(--u-common-button-extra-small-square-shape-corner, 12px);\n --_small-square-shape-corner: var(--u-common-button-small-square-shape-corner, 12px);\n --_medium-square-shape-corner: var(--u-common-button-medium-square-shape-corner, 16px);\n --_large-square-shape-corner: var(--u-common-button-large-square-shape-corner, 28px);\n --_extra-large-square-shape-corner: var(--u-common-button-extra-large-square-shape-corner, 28px);\n --_extra-small-pressed-shape-corner: var(--u-common-button-extra-small-pressed-shape-corner, 8px);\n --_small-pressed-shape-corner: var(--u-common-button-small-pressed-shape-corner, 8px);\n --_medium-pressed-shape-corner: var(--u-common-button-medium-pressed-shape-corner, 12px);\n --_large-pressed-shape-corner: var(--u-common-button-large-pressed-shape-corner, 16px);\n --_extra-large-pressed-shape-corner: var(--u-common-button-extra-large-pressed-shape-corner, 16px);\n --_font-size: var(--_small-font-size);\n --_font-weight: var(--_small-font-weight);\n --_padding: var(--_small-padding);\n --_icon-margin: var(--_small-icon-margin);\n --_round-shape-corner: var(--u-common-button-round-shape-corner, calc(var(--_size) / 2));\n }\n\n .extra-small {\n --_font-size: var(--_extra-small-font-size);\n --_font-weight: var(--_extra-small-font-weight);\n --_padding: var(--_extra-small-padding);\n --_icon-margin: var(--_extra-small-icon-margin);\n }\n\n .medium {\n --_font-size: var(--_medium-font-size);\n --_font-weight: var(--_medium-font-weight);\n --_padding: var(--_medium-padding);\n --_icon-margin: var(--_medium-icon-margin);\n }\n\n .large {\n --_font-size: var(--_large-font-size);\n --_font-weight: var(--_large-font-weight);\n --_padding: var(--_large-padding);\n --_icon-margin: var(--_large-icon-margin);\n }\n\n .extra-large {\n --_font-size: var(--_extra-large-font-size);\n --_font-weight: var(--_extra-large-font-weight);\n --_padding: var(--_extra-large-padding);\n --_icon-margin: var(--_extra-large-icon-margin);\n }\n\n .container {\n font-family: var(--u-font-family, system-ui, -apple-system, \"Segoe UI\", Roboto, \"Helvetica Neue\", \"Noto Sans\", \"Liberation Sans\", Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\", \"Noto Color Emoji\");\n font-size: var(--_font-size);\n font-weight: var(--_font-weight);\n padding-inline: var(--_padding);\n box-sizing: border-box;\n }\n\n .filled.primary, .filled.primary.selected {\n background-color: var(--u-filled-button-primary-container-color, var(--u-color-primary, rgb(103, 80, 164)));\n color: var(--u-filled-button-primary-text-color, var(--u-color-on-primary, rgb(255, 255, 255)));\n }\n .filled.secondary, .filled.secondary.selected {\n background-color: var(--u-filled-button-secondary-container-color, var(--u-color-secondary, rgb(98, 91, 113)));\n color: var(--u-filled-button-secondary-text-color, var(--u-color-on-secondary, rgb(255, 255, 255)));\n }\n .filled.tertiary, .filled.tertiary.selected {\n background-color: var(--u-filled-button-tertiary-container-color, var(--u-color-tertiary, rgb(125, 82, 96)));\n color: var(--u-filled-button-tertiary-text-color, var(--u-color-on-tertiary, rgb(255, 255, 255)));\n }\n .filled.error, .filled.error.selected {\n background-color: var(--u-filled-button-error-container-color, var(--u-color-error, rgb(179, 38, 30)));\n color: var(--u-filled-button-error-text-color, var(--u-color-on-error, rgb(255, 255, 255)));\n }\n .filled.toggle {\n background-color: var(--u-filled-button-container-unselected-color, var(--u-color-surface-container, rgb(243, 237, 247)));\n color: var(--u-filled-button-unselected-text-color, var(--u-color-on-surface-variant, rgb(73, 69, 79)));\n }\n\n .tonal {\n background-color: var(--u-tonal-button-container-color, var(--u-color-secondary-container, rgb(232, 222, 248)));\n color: var(--u-tonal-button-text-color, var(--u-color-on-secondary-container, rgb(29, 25, 43)));\n }\n .tonal.selected {\n background-color: var(--u-tonal-button-container-selected-color, var(--u-color-secondary, rgb(98, 91, 113)));\n color: var(--u-tonal-button-text-selected-color, var(--u-color-on-secondary, rgb(255, 255, 255)));\n }\n\n .elevated {\n background-color: var(--u-elevated-button-container-color, var(--u-color-surface-container-low, rgb(247, 242, 250)));\n color: var(--u-elevated-button-text-color, var(--u-color-primary, rgb(103, 80, 164)));\n }\n .elevated.selected {\n background-color: var(--u-elevated-button-container-selected-color, var(--u-color-primary, rgb(103, 80, 164)));\n color: var(--u-elevated-button-text-selected-color, var(--u-color-on-primary, rgb(255, 255, 255)));\n }\n\n @media (hover: hover) {\n .filled:hover:not(:focus-within):not(:active),\n .tonal:hover:not(:focus-within):not(:active) {\n --u-elevation-level: var(--u-filled-button-hover-elevation-level, 1);\n }\n }\n .text {\n color: var(--u-text-button-text-color, var(--_color-primary));\n }\n\n .outlined {\n color: var(--u-outlined-button-text-color, var(--u-text-button-text-color, var(--_color-primary)));\n border: 1px solid var(--u-outlined-button-outline-color, var(--u-color-outline, rgb(121, 116, 126)));\n }\n .outlined.selected {\n background-color: var(--u-outlined-button-container-selected-color, var(--u-color-inverse-surface, rgb(50, 47, 53)));\n color: var(--u-outlined-button-text-selected-color, var(--u-color-on-inverse-surface, rgb(245, 239, 247)));\n }\n .outlined.disabled {\n border-color: var(--u-outlined-button-disabled-border-color, color-mix(in srgb, var(--u-color-on-surface, rgb(29, 27, 32)) var(--u-outlined-button-disabled-border-opacity, 12%), transparent)) !important;\n }\n .outlined.disabled:not(.selected) {\n background-color: transparent !important;\n }\n\n .elevated {\n --u-elevation-level: var(--u-elevated-button-elevation-level, 1);\n color: var(--u-elevated-button-text-color, var(--_color-primary));\n }\n @media (hover: hover) {\n .elevated:hover {\n --u-elevation-level: var(--u-elevated-button-hover-elevation-level, 2);\n }\n }\n\n .container:not(.has-icon) .icon-container {\n display: none;\n }\n\n .content {\n gap: var(--_icon-margin);\n }\n\n .icon {\n font-size: var(--_icon-size);\n }\n\n .trailing-icon .content {\n flex-direction: row-reverse;\n }\n\n #label {\n display: inline-block;\n }\n\n .label {\n display: inline-block;\n inset-inline-start: 0;\n transition-duration: calc(var(--_morph-duration) * 0.7);\n }\n\n .label-container {\n position: relative;\n }\n .label-container.animate {\n transition: width var(--_morph-duration) linear;\n }\n\n .label-default {\n opacity: 1;\n transition-delay: calc(var(--_morph-duration) / 2);\n }\n\n .label-selected {\n position: absolute;\n opacity: 0;\n transition-delay: 0ms;\n }\n\n .selected.has-selection-label .label-default {\n position: absolute;\n opacity: 0;\n transition-delay: 0ms;\n }\n .selected.has-selection-label .label-selected {\n position: static;\n opacity: 1;\n transition-delay: calc(var(--_morph-duration) / 2);\n }\n`;\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fab-menu-color-context.d.ts","sourceRoot":"","sources":["../../src/button/fab-menu-color-context.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAEtC,eAAO,MAAM,mBAAmB;;CAA2D,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fab-menu-color-context.js","sourceRoot":"","sources":["../../src/button/fab-menu-color-context.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAI7C,MAAM,CAAC,MAAM,mBAAmB,GAAG,aAAa,CAAa,MAAM,CAAC,qBAAqB,CAAC,CAAC,CAAC","sourcesContent":["import { createContext } from '@lit/context';\n\nimport { UmFabColor } from './fab.js';\n\nexport const fabMenuColorContext = createContext<UmFabColor>(Symbol('fabMenuColorContext'));\n"]}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { HTMLTemplateResult } from 'lit';
|
|
2
|
+
import { UmButtonBase } from './button-base.js';
|
|
3
|
+
export declare class UmFabMenuItem extends UmButtonBase {
|
|
4
|
+
#private;
|
|
5
|
+
static styles: import("lit").CSSResultGroup[];
|
|
6
|
+
private readonly _color;
|
|
7
|
+
private readonly _menuOpen;
|
|
8
|
+
/**
|
|
9
|
+
* The text to display the FAB menu item.
|
|
10
|
+
*/
|
|
11
|
+
label: string | null;
|
|
12
|
+
private _hasIcon;
|
|
13
|
+
get _index(): number;
|
|
14
|
+
set _index(value: number);
|
|
15
|
+
protected _getContainerClasses(): Record<string, boolean>;
|
|
16
|
+
protected _renderContent(): HTMLTemplateResult;
|
|
17
|
+
}
|
|
18
|
+
declare global {
|
|
19
|
+
interface HTMLElementTagNameMap {
|
|
20
|
+
'u-fab-menu-item': UmFabMenuItem;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=fab-menu-item.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fab-menu-item.d.ts","sourceRoot":"","sources":["../../src/button/fab-menu-item.ts"],"names":[],"mappings":"AAEA,OAAO,EAAQ,kBAAkB,EAAE,MAAM,KAAK,CAAC;AAG/C,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAMhD,qBACa,aAAc,SAAQ,YAAY;;IAE7C,OAAgB,MAAM,iCAAiC;IAKvD,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAc;IAIrC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAW;IAErC;;OAEG;IACS,KAAK,EAAE,MAAM,GAAG,IAAI,CAAQ;IAE/B,OAAO,CAAC,QAAQ,CAAS;IAElC,IACI,MAAM,WAET;IAED,IAAI,MAAM,CAAC,KAAK,QAAA,EAGf;cAEkB,oBAAoB,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;cAS/C,cAAc,IAAI,kBAAkB;CAaxD;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,iBAAiB,EAAE,aAAa,CAAC;KAClC;CACF"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { consume } from '@lit/context';
|
|
3
|
+
import { html } from 'lit';
|
|
4
|
+
import { customElement, property, state } from 'lit/decorators.js';
|
|
5
|
+
import { UmButtonBase } from './button-base.js';
|
|
6
|
+
import { fabMenuColorContext } from './fab-menu-color-context.js';
|
|
7
|
+
import { styles } from './fab-menu-item.styles.js';
|
|
8
|
+
import { fabMenuOpenContext } from './fab-menu-open-context.js';
|
|
9
|
+
let UmFabMenuItem = class UmFabMenuItem extends UmButtonBase {
|
|
10
|
+
constructor() {
|
|
11
|
+
super(...arguments);
|
|
12
|
+
this.#index = 0;
|
|
13
|
+
/**
|
|
14
|
+
* The text to display the FAB menu item.
|
|
15
|
+
*/
|
|
16
|
+
this.label = null;
|
|
17
|
+
this._hasIcon = false;
|
|
18
|
+
}
|
|
19
|
+
static { this.styles = [UmButtonBase.styles, styles]; }
|
|
20
|
+
#index;
|
|
21
|
+
get _index() {
|
|
22
|
+
return this.#index;
|
|
23
|
+
}
|
|
24
|
+
set _index(value) {
|
|
25
|
+
this.#index = value;
|
|
26
|
+
this.style.setProperty('--_animation-delay-increment', value.toString());
|
|
27
|
+
}
|
|
28
|
+
_getContainerClasses() {
|
|
29
|
+
return {
|
|
30
|
+
...super._getContainerClasses(),
|
|
31
|
+
open: this._menuOpen,
|
|
32
|
+
[this._color]: true,
|
|
33
|
+
'has-icon': this._hasIcon,
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
_renderContent() {
|
|
37
|
+
return html `
|
|
38
|
+
<span class="clipper"></span>
|
|
39
|
+
<span class="icon" aria-hidden="true">
|
|
40
|
+
<slot @slotchange=${this.#handleIconSlotChange}></slot>
|
|
41
|
+
</span>
|
|
42
|
+
<span class="label">${this.label}</span>
|
|
43
|
+
`;
|
|
44
|
+
}
|
|
45
|
+
#handleIconSlotChange(e) {
|
|
46
|
+
this._hasIcon = e.target.assignedElements({ flatten: true }).length > 0;
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
__decorate([
|
|
50
|
+
consume({ context: fabMenuColorContext, subscribe: true }),
|
|
51
|
+
state()
|
|
52
|
+
], UmFabMenuItem.prototype, "_color", void 0);
|
|
53
|
+
__decorate([
|
|
54
|
+
consume({ context: fabMenuOpenContext, subscribe: true }),
|
|
55
|
+
state()
|
|
56
|
+
], UmFabMenuItem.prototype, "_menuOpen", void 0);
|
|
57
|
+
__decorate([
|
|
58
|
+
property()
|
|
59
|
+
], UmFabMenuItem.prototype, "label", void 0);
|
|
60
|
+
__decorate([
|
|
61
|
+
state()
|
|
62
|
+
], UmFabMenuItem.prototype, "_hasIcon", void 0);
|
|
63
|
+
__decorate([
|
|
64
|
+
state()
|
|
65
|
+
], UmFabMenuItem.prototype, "_index", null);
|
|
66
|
+
UmFabMenuItem = __decorate([
|
|
67
|
+
customElement('u-fab-menu-item')
|
|
68
|
+
], UmFabMenuItem);
|
|
69
|
+
export { UmFabMenuItem };
|
|
70
|
+
//# sourceMappingURL=fab-menu-item.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fab-menu-item.js","sourceRoot":"","sources":["../../src/button/fab-menu-item.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAEvC,OAAO,EAAE,IAAI,EAAsB,MAAM,KAAK,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAEnE,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAChD,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAC;AAClE,OAAO,EAAE,MAAM,EAAE,MAAM,2BAA2B,CAAC;AACnD,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAIzD,IAAM,aAAa,GAAnB,MAAM,aAAc,SAAQ,YAAY;IAAxC;;QAGL,WAAM,GAAG,CAAC,CAAC;QAUX;;WAEG;QACS,UAAK,GAAkB,IAAI,CAAC;QAEvB,aAAQ,GAAG,KAAK,CAAC;IAkCpC,CAAC;aAlDiB,WAAM,GAAG,CAAC,YAAY,CAAC,MAAM,EAAE,MAAM,CAAC,AAAhC,CAAiC;IACvD,MAAM,CAAK;IAkBX,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,IAAI,MAAM,CAAC,KAAK;QACd,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,8BAA8B,EAAE,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC;IAC3E,CAAC;IAEkB,oBAAoB;QACrC,OAAO;YACL,GAAG,KAAK,CAAC,oBAAoB,EAAE;YAC/B,IAAI,EAAE,IAAI,CAAC,SAAS;YACpB,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,IAAI;YACnB,UAAU,EAAE,IAAI,CAAC,QAAQ;SAC1B,CAAC;IACJ,CAAC;IAEkB,cAAc;QAC/B,OAAO,IAAI,CAAA;;;4BAGa,IAAI,CAAC,qBAAqB;;4BAE1B,IAAI,CAAC,KAAK;KACjC,CAAC;IACJ,CAAC;IAED,qBAAqB,CAAC,CAAQ;QAC5B,IAAI,CAAC,QAAQ,GAAI,CAAC,CAAC,MAA0B,CAAC,gBAAgB,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;IAC/F,CAAC;;AA5CgB;IAFhB,OAAO,CAAC,EAAE,OAAO,EAAE,mBAAmB,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;IAC1D,KAAK,EAAE;6CAC6B;AAIpB;IAFhB,OAAO,CAAC,EAAE,OAAO,EAAE,kBAAkB,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;IACzD,KAAK,EAAE;gDAC6B;AAKzB;IAAX,QAAQ,EAAE;4CAA6B;AAEvB;IAAhB,KAAK,EAAE;+CAA0B;AAGlC;IADC,KAAK,EAAE;2CAGP;AAvBU,aAAa;IADzB,aAAa,CAAC,iBAAiB,CAAC;GACpB,aAAa,CAoDzB","sourcesContent":["import { consume } from '@lit/context';\n\nimport { html, HTMLTemplateResult } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\n\nimport { UmButtonBase } from './button-base.js';\nimport { fabMenuColorContext } from './fab-menu-color-context.js';\nimport { styles } from './fab-menu-item.styles.js';\nimport { fabMenuOpenContext } from './fab-menu-open-context.js';\nimport { UmFabColor } from './fab.js';\n\n@customElement('u-fab-menu-item')\nexport class UmFabMenuItem extends UmButtonBase {\n\n static override styles = [UmButtonBase.styles, styles];\n #index = 0;\n\n @consume({ context: fabMenuColorContext, subscribe: true })\n @state()\n private readonly _color!: UmFabColor;\n\n @consume({ context: fabMenuOpenContext, subscribe: true })\n @state()\n private readonly _menuOpen!: boolean;\n\n /**\n * The text to display the FAB menu item.\n */\n @property() label: string | null = null;\n\n @state() private _hasIcon = false;\n\n @state()\n get _index() {\n return this.#index;\n }\n\n set _index(value) {\n this.#index = value;\n this.style.setProperty('--_animation-delay-increment', value.toString());\n }\n\n protected override _getContainerClasses(): Record<string, boolean> {\n return {\n ...super._getContainerClasses(),\n open: this._menuOpen,\n [this._color]: true,\n 'has-icon': this._hasIcon,\n };\n }\n\n protected override _renderContent(): HTMLTemplateResult {\n return html`\n <span class=\"clipper\"></span>\n <span class=\"icon\" aria-hidden=\"true\">\n <slot @slotchange=${this.#handleIconSlotChange}></slot>\n </span>\n <span class=\"label\">${this.label}</span>\n `;\n }\n\n #handleIconSlotChange(e: Event) {\n this._hasIcon = (e.target as HTMLSlotElement).assignedElements({ flatten: true }).length > 0;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'u-fab-menu-item': UmFabMenuItem;\n }\n}\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fab-menu-item.styles.d.ts","sourceRoot":"","sources":["../../src/button/fab-menu-item.styles.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,MAAM,yBA+ElB,CAAC"}
|