@studious-creative/yumekit 0.1.2 → 0.1.4

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.
@@ -0,0 +1,28 @@
1
+ export class YumeAppbar extends HTMLElement {
2
+ static get observedAttributes(): string[];
3
+ _onCollapseClick(): void;
4
+ _idCounter: number;
5
+ connectedCallback(): void;
6
+ disconnectedCallback(): void;
7
+ attributeChangedCallback(name: any, oldVal: any, newVal: any): void;
8
+ set orientation(val: string);
9
+ get orientation(): string;
10
+ set collapsed(val: boolean);
11
+ get collapsed(): boolean;
12
+ set items(val: any);
13
+ get items(): any;
14
+ set size(val: string);
15
+ get size(): string;
16
+ set menuDirection(val: string);
17
+ /**
18
+ * Direction menus pop out from nav buttons:
19
+ * "right", "down", or unset (auto: vertical → right, horizontal → down).
20
+ */
21
+ get menuDirection(): string;
22
+ set sticky(val: string | false);
23
+ get sticky(): string | false;
24
+ toggle(): void;
25
+ _uid(prefix: any): string;
26
+ _isItemActive(item: any): boolean;
27
+ render(): void;
28
+ }
@@ -0,0 +1,5 @@
1
+ export class YumeAvatar extends HTMLElement {
2
+ static get observedAttributes(): string[];
3
+ attributeChangedCallback(name: any, oldValue: any, newValue: any): void;
4
+ render(): void;
5
+ }
@@ -0,0 +1,15 @@
1
+ export class YumeBadge extends HTMLElement {
2
+ static get observedAttributes(): string[];
3
+ connectedCallback(): void;
4
+ attributeChangedCallback(name: any, oldValue: any, newValue: any): void;
5
+ get alignment(): string;
6
+ get color(): string;
7
+ get position(): string;
8
+ get size(): string;
9
+ get value(): string;
10
+ getBadgeColor(color: any): any;
11
+ getBadgePosition(position: any, alignment: any): string;
12
+ getSizeAttributes(size: any): any;
13
+ hasTargetContent(): boolean;
14
+ render(): void;
15
+ }
@@ -0,0 +1,19 @@
1
+ export class YumeButton extends HTMLElement {
2
+ static get observedAttributes(): string[];
3
+ connectedCallback(): void;
4
+ attributeChangedCallback(name: any, oldValue: any, newValue: any): void;
5
+ set value(newVal: any);
6
+ get value(): any;
7
+ selectedValues: any;
8
+ setOptions(options: any): void;
9
+ handleClick(): void;
10
+ init(): void;
11
+ proxyNativeOnClick(): void;
12
+ updateButtonAttributes(): void;
13
+ manageSlotVisibility(slotName: any, selector: any): void;
14
+ render(): void;
15
+ button: HTMLButtonElement;
16
+ applyStyles(): void;
17
+ addEventListeners(): void;
18
+ updateStyles(): void;
19
+ }
@@ -0,0 +1,8 @@
1
+ export class YumeCard extends HTMLElement {
2
+ static get observedAttributes(): string[];
3
+ connectedCallback(): void;
4
+ attributeChangedCallback(name: any, oldValue: any, newValue: any): void;
5
+ updateColorStyles(): void;
6
+ updateElevationStyles(): void;
7
+ render(): void;
8
+ }
@@ -0,0 +1,20 @@
1
+ export class YumeCheckbox extends HTMLElement {
2
+ static formAssociated: boolean;
3
+ static get observedAttributes(): string[];
4
+ _internals: ElementInternals;
5
+ connectedCallback(): void;
6
+ attributeChangedCallback(name: any): void;
7
+ set checked(val: boolean);
8
+ get checked(): boolean;
9
+ set disabled(val: boolean);
10
+ get disabled(): boolean;
11
+ set indeterminate(val: boolean);
12
+ get indeterminate(): boolean;
13
+ set value(val: string);
14
+ get value(): string;
15
+ get name(): string;
16
+ toggle(): void;
17
+ updateIcon(): void;
18
+ updateState(): void;
19
+ render(): void;
20
+ }
@@ -0,0 +1,18 @@
1
+ declare class YumeDialog extends HTMLElement {
2
+ static get observedAttributes(): string[];
3
+ onKeyDown(e: any): void;
4
+ onAnchorClick(): void;
5
+ connectedCallback(): void;
6
+ attributeChangedCallback(name: any, oldValue: any, newValue: any): void;
7
+ set visible(val: boolean);
8
+ get visible(): boolean;
9
+ set anchor(id: string);
10
+ get anchor(): string;
11
+ set closable(val: boolean);
12
+ get closable(): boolean;
13
+ show(): void;
14
+ hide(): void;
15
+ setupAnchor(): void;
16
+ _anchorEl: HTMLElement;
17
+ render(): void;
18
+ }
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,15 @@
1
+ export class YumeInput extends HTMLElement {
2
+ static formAssociated: boolean;
3
+ static get observedAttributes(): string[];
4
+ _internals: ElementInternals;
5
+ connectedCallback(): void;
6
+ attributeChangedCallback(name: any, oldValue: any, newValue: any): void;
7
+ set value(val: string);
8
+ get value(): string;
9
+ checkValidity(): boolean;
10
+ updateValidationState(): void;
11
+ render(): void;
12
+ input: HTMLInputElement;
13
+ inputContainer: Element;
14
+ labelWrapper: Element;
15
+ }
@@ -0,0 +1,26 @@
1
+ declare class YumeMenu extends HTMLElement {
2
+ static get observedAttributes(): string[];
3
+ _onAnchorClick(e: any): void;
4
+ _onDocumentClick(e: any): void;
5
+ _onScrollOrResize(): void;
6
+ connectedCallback(): void;
7
+ set items(val: any);
8
+ get items(): any;
9
+ disconnectedCallback(): void;
10
+ attributeChangedCallback(name: any, oldVal: any, newVal: any): void;
11
+ set anchor(val: string);
12
+ get anchor(): string;
13
+ set visible(val: boolean);
14
+ get visible(): boolean;
15
+ set direction(val: string);
16
+ get direction(): string;
17
+ set size(val: string);
18
+ get size(): string;
19
+ _createMenuList(items: any): HTMLUListElement;
20
+ _findTemplate(name: any): Element;
21
+ _setupAnchor(): void;
22
+ _anchorEl: any;
23
+ _teardownAnchor(): void;
24
+ _updatePosition(): void;
25
+ render(): void;
26
+ }
@@ -0,0 +1,23 @@
1
+ export class YumePanel extends HTMLElement {
2
+ static get observedAttributes(): string[];
3
+ _expanded: boolean;
4
+ _checkRouteMatchBound: any;
5
+ connectedCallback(): void;
6
+ disconnectedCallback(): void;
7
+ attributeChangedCallback(name: any, oldValue: any, newValue: any): void;
8
+ set selected(val: boolean);
9
+ get selected(): boolean;
10
+ set expanded(val: boolean);
11
+ get expanded(): boolean;
12
+ toggle(): void;
13
+ expand(): void;
14
+ collapse(): void;
15
+ updateSelectedState(): void;
16
+ updateChildState(): void;
17
+ checkRouteMatch(): void;
18
+ addHeaderListeners(): void;
19
+ hasChildren(): any;
20
+ checkForChildren(): void;
21
+ updateExpandedState(): void;
22
+ render(): void;
23
+ }
@@ -0,0 +1,3 @@
1
+ export class YumePanelBar extends HTMLElement {
2
+ render(): void;
3
+ }
@@ -0,0 +1,38 @@
1
+ export class YumeProgress extends HTMLElement {
2
+ static get observedAttributes(): string[];
3
+ connectedCallback(): void;
4
+ attributeChangedCallback(name: any, oldValue: any, newValue: any): void;
5
+ set value(val: number);
6
+ get value(): number;
7
+ set min(val: number);
8
+ get min(): number;
9
+ set max(val: number);
10
+ get max(): number;
11
+ set step(val: number);
12
+ get step(): number;
13
+ set size(val: string);
14
+ get size(): string;
15
+ set color(val: string);
16
+ get color(): string;
17
+ set labelDisplay(val: boolean);
18
+ get labelDisplay(): boolean;
19
+ set labelFormat(val: string);
20
+ get labelFormat(): string;
21
+ set indeterminate(val: boolean);
22
+ get indeterminate(): boolean;
23
+ set disabled(val: boolean);
24
+ get disabled(): boolean;
25
+ /**
26
+ * Increment the progress value by the step amount (or 1 if no step).
27
+ */
28
+ increment(): void;
29
+ /**
30
+ * Decrement the progress value by the step amount (or 1 if no step).
31
+ */
32
+ decrement(): void;
33
+ get percentage(): number;
34
+ getBarColor(color: any): any;
35
+ getSizeVar(size: any): any;
36
+ getLabel(): string;
37
+ render(): void;
38
+ }
@@ -0,0 +1,16 @@
1
+ export class YumeRadio extends HTMLElement {
2
+ static formAssociated: boolean;
3
+ static get observedAttributes(): string[];
4
+ _internals: ElementInternals;
5
+ _value: string;
6
+ connectedCallback(): void;
7
+ attributeChangedCallback(name: any, oldVal: any, newVal: any): void;
8
+ set value(val: string);
9
+ get value(): string;
10
+ get name(): string;
11
+ set options(val: any);
12
+ get options(): any;
13
+ updateChecked(): void;
14
+ handleKey(e: any, index: any, radios: any): void;
15
+ render(): void;
16
+ }
@@ -0,0 +1,31 @@
1
+ export class YumeSelect extends HTMLElement {
2
+ static formAssociated: boolean;
3
+ static get observedAttributes(): string[];
4
+ _internals: ElementInternals;
5
+ selectedValues: Set<any>;
6
+ connectedCallback(): void;
7
+ attributeChangedCallback(name: any, oldValue: any, newValue: any): void;
8
+ set value(val: any);
9
+ get value(): any;
10
+ _value: any;
11
+ getOptions(): any;
12
+ getDisplayText(): any;
13
+ toggleDropdown(): void;
14
+ _onScrollOrResize: any;
15
+ closeDropdown(): void;
16
+ _positionDropdown(): void;
17
+ queryRefs(): void;
18
+ selectContainer: Element;
19
+ dropdown: Element;
20
+ labelWrapper: Element;
21
+ displayElement: Element;
22
+ attachEventListeners(): void;
23
+ renderTags(): void;
24
+ updateDisplay(): void;
25
+ updateSelectedStyles(): void;
26
+ updateValidation(): void;
27
+ updateValidationState(): void;
28
+ render(): void;
29
+ applyStyles(): void;
30
+ generateTemplate(): string;
31
+ }
@@ -0,0 +1,34 @@
1
+ export class YumeSlider extends HTMLElement {
2
+ static formAssociated: boolean;
3
+ static get observedAttributes(): string[];
4
+ _internals: ElementInternals;
5
+ _dragging: boolean;
6
+ connectedCallback(): void;
7
+ attributeChangedCallback(name: any, oldValue: any, newValue: any): void;
8
+ set value(val: number);
9
+ get value(): number;
10
+ set min(val: number);
11
+ get min(): number;
12
+ set max(val: number);
13
+ get max(): number;
14
+ set step(val: number);
15
+ get step(): number;
16
+ set size(val: string);
17
+ get size(): string;
18
+ set color(val: string);
19
+ get color(): string;
20
+ set disabled(val: boolean);
21
+ get disabled(): boolean;
22
+ set orientation(val: string);
23
+ get orientation(): string;
24
+ get percentage(): number;
25
+ _snapToStep(val: any): any;
26
+ getTrackColor(color: any): any;
27
+ getThumbColor(color: any): any;
28
+ getSizeVars(size: any): any;
29
+ _bindEvents(): void;
30
+ _updateFromPointer(e: any): void;
31
+ /** Fast path: update only the dynamic parts (fill, thumb, label, aria) */
32
+ _updateVisuals(): void;
33
+ render(): void;
34
+ }
@@ -0,0 +1,23 @@
1
+ declare class YumeSwitch extends HTMLElement {
2
+ static formAssociated: boolean;
3
+ static get observedAttributes(): string[];
4
+ _internals: ElementInternals;
5
+ connectedCallback(): void;
6
+ attributeChangedCallback(name: any, oldValue: any, newValue: any): void;
7
+ set checked(val: boolean);
8
+ get checked(): boolean;
9
+ set value(val: string);
10
+ get value(): string;
11
+ toggle(): void;
12
+ labelTag(pos: any): "" | "<label><slot name=\"label\"></slot></label>";
13
+ mirrorToggleLabels(): void;
14
+ update(): void;
15
+ updateSizeStyles(): void;
16
+ updateTogglePosition(): void;
17
+ updateLabelDisplay(): void;
18
+ updateToggleLabelDisplay(): void;
19
+ updateDirection(): void;
20
+ updateAria(): void;
21
+ updateFormValue(): void;
22
+ render(): void;
23
+ }
@@ -0,0 +1,25 @@
1
+ export class YumeTable extends HTMLElement {
2
+ static get observedAttributes(): string[];
3
+ _sortField: any;
4
+ _sortDir: string;
5
+ _parsedData: any[];
6
+ _parsedColumns: any[];
7
+ connectedCallback(): void;
8
+ attributeChangedCallback(name: any, oldVal: any, newVal: any): void;
9
+ set columns(val: string);
10
+ get columns(): string;
11
+ set data(val: string);
12
+ get data(): string;
13
+ set striped(val: boolean);
14
+ get striped(): boolean;
15
+ set size(val: string);
16
+ /**
17
+ * Cell padding size: "small" | "medium" | "large" (default "medium").
18
+ */
19
+ get size(): string;
20
+ _parseAttributes(): void;
21
+ _onHeaderClick(field: any): void;
22
+ _getSortedData(): any[];
23
+ _sortIcon(field: any): string;
24
+ render(): void;
25
+ }
@@ -0,0 +1,21 @@
1
+ export class YumeTabs extends HTMLElement {
2
+ static get observedAttributes(): string[];
3
+ _activeTab: string;
4
+ connectedCallback(): void;
5
+ attributeChangedCallback(name: any, oldVal: any, newVal: any): void;
6
+ set options(val: any);
7
+ get options(): any;
8
+ set size(val: string);
9
+ get size(): string;
10
+ set position(val: string);
11
+ get position(): string;
12
+ activateTab(id: any): void;
13
+ _setupEvents(): void;
14
+ _handleTabKeydown(e: any, buttons: any): void;
15
+ _findSiblingButton(buttons: any, fromIndex: any, direction: any): any;
16
+ _resolveActiveTab(tabs: any): void;
17
+ _getStyles(): string;
18
+ _createTabButton(tab: any): HTMLButtonElement;
19
+ _createPanel(slotName: any): HTMLDivElement;
20
+ render(): void;
21
+ }
@@ -0,0 +1,7 @@
1
+ export class YumeTag extends HTMLElement {
2
+ static get observedAttributes(): string[];
3
+ connectedCallback(): void;
4
+ attributeChangedCallback(name: any, oldValue: any, newValue: any): void;
5
+ render(): void;
6
+ getStyle(color: any, styleType: any, shape: any): string;
7
+ }
@@ -0,0 +1,7 @@
1
+ export class YumeTheme extends HTMLElement {
2
+ static get observedAttributes(): string[];
3
+ connectedCallback(): void;
4
+ attributeChangedCallback(name: any, oldValue: any, newValue: any): void;
5
+ _applyTheme(): Promise<void>;
6
+ applyVariablesToHost(cssText: any): void;
7
+ }
@@ -1,9 +1,23 @@
1
- class YumeTheme extends HTMLElement {
2
- static defaultVariablesLoaded = false;
3
- static defaultVariablesCSS = "";
1
+ var variablesCSS = "/* Colors */\n:root {\n --neutral--: #7f8286ff;\n --neutral-white: #ffffffff;\n --neutral-black: #000000ff;\n --neutral-light-0: #f7f7faff;\n --neutral-light-1: #f0f0f2ff;\n --neutral-light-2: #dfe0e3ff;\n --neutral-light-3: #cacbcfff;\n --neutral-light-4: #bbbdc0ff;\n --neutral-light-5: #acaeb2ff;\n --neutral-light-6: #9d9fa3ff;\n --neutral-light-7: #8e9195ff;\n --neutral-dark-0: #0c0c0dff;\n --neutral-dark-1: #151617ff;\n --neutral-dark-2: #292a2bff;\n --neutral-dark-3: #37383aff;\n --neutral-dark-4: #46474aff;\n --neutral-dark-5: #545659ff;\n --neutral-dark-6: #626568ff;\n --neutral-dark-7: #717377ff;\n --neutral-black-translucent: #0000001f;\n --neutral-white-translucent: #1111111f;\n --red--: #b80421ff;\n --red-light-0: #f2e6e8ff;\n --red-light-1: #ebcacfff;\n --red-light-2: #e4aeb6ff;\n --red-light-3: #dc919dff;\n --red-light-4: #d57585ff;\n --red-light-5: #ce596cff;\n --red-light-6: #c73d53ff;\n --red-light-7: #bf203aff;\n --red-dark-0: #0d0103ff;\n --red-dark-1: #220107ff;\n --red-dark-2: #38020bff;\n --red-dark-3: #4d020eff;\n --red-dark-4: #630312ff;\n --red-dark-5: #780316ff;\n --red-dark-6: #8d031aff;\n --red-dark-7: #a3041dff;\n --red-translucent: #b804211f;\n --orange--: #d13704ff;\n --orange-light-0: #f2e9e6ff;\n --orange-light-1: #eed3caff;\n --orange-light-2: #eabdaeff;\n --orange-light-3: #e6a691ff;\n --orange-light-4: #e29075ff;\n --orange-light-5: #dd7a59ff;\n --orange-light-6: #d9643dff;\n --orange-light-7: #d54d20ff;\n --orange-dark-0: #0d0300ff;\n --orange-dark-1: #260a01ff;\n --orange-dark-2: #3e1001ff;\n --orange-dark-3: #571702ff;\n --orange-dark-4: #6f1d02ff;\n --orange-dark-5: #882403ff;\n --orange-dark-6: #a02a03ff;\n --orange-dark-7: #b93104ff;\n --orange-translucent: #d137041f;\n --amber--: #d16004ff;\n --amber-light-0: #f2ece6ff;\n --amber-light-1: #eedbcaff;\n --amber-light-2: #eac9aeff;\n --amber-light-3: #e6b891ff;\n --amber-light-4: #e2a675ff;\n --amber-light-5: #dd9559ff;\n --amber-light-6: #d9833dff;\n --amber-light-7: #d57220ff;\n --amber-dark-0: #0d0c0cff;\n --amber-dark-1: #26170bff;\n --amber-dark-2: #3e210aff;\n --amber-dark-3: #572c09ff;\n --amber-dark-4: #6f3608ff;\n --amber-dark-5: #884107ff;\n --amber-dark-6: #a04b06ff;\n --amber-dark-7: #b95605ff;\n --amber-translucent: #d160041f;\n --yellow--: #d17f04ff;\n --yellow-light-0: #f2eadfff;\n --yellow-light-1: #eeddc4ff;\n --yellow-light-2: #eacfa8ff;\n --yellow-light-3: #e6c28dff;\n --yellow-light-4: #e2b572ff;\n --yellow-light-5: #dda756ff;\n --yellow-light-6: #d99a3bff;\n --yellow-light-7: #d58c1fff;\n --yellow-dark-0: #0d0c0cff;\n --yellow-dark-1: #261a0bff;\n --yellow-dark-2: #3e290aff;\n --yellow-dark-3: #573709ff;\n --yellow-dark-4: #6f4608ff;\n --yellow-dark-5: #885407ff;\n --yellow-dark-6: #a06206ff;\n --yellow-dark-7: #b97105ff;\n --yellow-translucent: #d17f041f;\n --lime--: #cad104ff;\n --lime-light-0: #f2f2dfff;\n --lime-light-1: #edeec4ff;\n --lime-light-2: #e8eaa8ff;\n --lime-light-3: #e3e68dff;\n --lime-light-4: #dee272ff;\n --lime-light-5: #d9dd56ff;\n --lime-light-6: #d4d93bff;\n --lime-light-7: #cfd51fff;\n --lime-dark-0: #0d0d0cff;\n --lime-dark-1: #25260bff;\n --lime-dark-2: #3c3e0aff;\n --lime-dark-3: #545709ff;\n --lime-dark-4: #6c6f08ff;\n --lime-dark-5: #838807ff;\n --lime-dark-6: #9ba006ff;\n --lime-dark-7: #b2b905ff;\n --lime-translucent: #cad1041f;\n --green--: #2dba73ff;\n --green-light-0: #e6f2ecff;\n --green-light-1: #cfebddff;\n --green-light-2: #b8e4ceff;\n --green-light-3: #a1ddbfff;\n --green-light-4: #8ad6b0ff;\n --green-light-5: #72cfa0ff;\n --green-light-6: #5bc891ff;\n --green-light-7: #44c182ff;\n --green-dark-0: #030d08ff;\n --green-dark-1: #082315ff;\n --green-dark-2: #0e3823ff;\n --green-dark-3: #134e30ff;\n --green-dark-4: #18643eff;\n --green-dark-5: #1d794bff;\n --green-dark-6: #238f58ff;\n --green-dark-7: #28a466ff;\n --green-translucent: #2dba731f;\n --teal--: #04b8b8ff;\n --teal-light-0: #f2fffeff;\n --teal-light-1: #d4f6f5ff;\n --teal-light-2: #b7ededff;\n --teal-light-3: #99e4e4ff;\n --teal-light-4: #7bdcdbff;\n --teal-light-5: #5dd3d2ff;\n --teal-light-6: #40cacaff;\n --teal-light-7: #22c1c1ff;\n --teal-dark-0: #0c0d0dff;\n --teal-dark-1: #0b2624ff;\n --teal-dark-2: #0a3e3cff;\n --teal-dark-3: #095753ff;\n --teal-dark-4: #086f6aff;\n --teal-dark-5: #078881ff;\n --teal-dark-6: #06a099ff;\n --teal-dark-7: #05b9b0ff;\n --teal-translucent: #04b8b81f;\n --blue--: #0576ffff;\n --blue-light-0: #ebf5ffff;\n --blue-light-1: #cee5ffff;\n --blue-light-2: #b2d5ffff;\n --blue-light-3: #95c5ffff;\n --blue-light-4: #78b6ffff;\n --blue-light-5: #5ba6ffff;\n --blue-light-6: #3f96ffff;\n --blue-light-7: #2286ffff;\n --blue-dark-0: #0c0c0dff;\n --blue-dark-1: #0b192bff;\n --blue-dark-2: #0a274aff;\n --blue-dark-3: #093468ff;\n --blue-dark-4: #094186ff;\n --blue-dark-5: #084ea4ff;\n --blue-dark-6: #075cc3ff;\n --blue-dark-7: #0669e1ff;\n --blue-translucent: #0576ff1f;\n --indigo--: #5405ffff;\n --indigo-light-0: #f6f2ffff;\n --indigo-light-1: #e2d4ffff;\n --indigo-light-2: #ceb7ffff;\n --indigo-light-3: #b999ffff;\n --indigo-light-4: #a57cffff;\n --indigo-light-5: #915effff;\n --indigo-light-6: #7d40ffff;\n --indigo-light-7: #6823ffff;\n --indigo-dark-0: #0d0c0cff;\n --indigo-dark-1: #160b2aff;\n --indigo-dark-2: #1f0a49ff;\n --indigo-dark-3: #280967ff;\n --indigo-dark-4: #310986ff;\n --indigo-dark-5: #3908a4ff;\n --indigo-dark-6: #4207c2ff;\n --indigo-dark-7: #4b06e1ff;\n --indigo-translucent: #5405ff1f;\n --purple--: #8a05ffff;\n --purple-light-0: #f9f2ffff;\n --purple-light-1: #ebd4ffff;\n --purple-light-2: #ddb7ffff;\n --purple-light-3: #cf99ffff;\n --purple-light-4: #c27cffff;\n --purple-light-5: #b45effff;\n --purple-light-6: #a640ffff;\n --purple-light-7: #9823ffff;\n --purple-dark-0: #0c0c0dff;\n --purple-dark-1: #1c0b2bff;\n --purple-dark-2: #2c0a4aff;\n --purple-dark-3: #3b0968ff;\n --purple-dark-4: #4b0986ff;\n --purple-dark-5: #5b08a4ff;\n --purple-dark-6: #6b07c3ff;\n --purple-dark-7: #7a06e1ff;\n --purple-translucent: #8a05ff1f;\n --pink--: #ff05a8ff;\n --pink-light-0: #f9f2ffff;\n --pink-light-1: #fad4f4ff;\n --pink-light-2: #fbb7e9ff;\n --pink-light-3: #fb99deff;\n --pink-light-4: #fc7cd4ff;\n --pink-light-5: #fd5ec9ff;\n --pink-light-6: #fe40beff;\n --pink-light-7: #fe23b3ff;\n --pink-dark-0: #0c0c0dff;\n --pink-dark-1: #2a0b20ff;\n --pink-dark-2: #490a34ff;\n --pink-dark-3: #670947ff;\n --pink-dark-4: #86095bff;\n --pink-dark-5: #a4086eff;\n --pink-dark-6: #c20781ff;\n --pink-dark-7: #e10695ff;\n --pink-translucent: #ff05a81f;\n --brown--: #ab642eff;\n --brown-light-0: #f2dfdfff;\n --brown-light-1: #e9d0c9ff;\n --brown-light-2: #e0c0b3ff;\n --brown-light-3: #d7b19dff;\n --brown-light-4: #cfa287ff;\n --brown-light-5: #c69270ff;\n --brown-light-6: #bd835aff;\n --brown-light-7: #b47344ff;\n --brown-dark-0: #0d0c0cff;\n --brown-dark-1: #211710ff;\n --brown-dark-2: #352215ff;\n --brown-dark-3: #482d19ff;\n --brown-dark-4: #5c381dff;\n --brown-dark-5: #704321ff;\n --brown-dark-6: #844e26ff;\n --brown-dark-7: #97592aff;\n --brown-translucent: #ab642e1f;\n}\n\n/* Numerics */\n:root {\n --border-none: 0px;\n --border-x-thin: 1px;\n --border-thin: 2px;\n --border-medium: 4px;\n --border-thick: 8px;\n --border-x-thick: 10px;\n --spacing-none: 0px;\n --spacing-4x-small: 1px;\n --spacing-2x-small: 2px;\n --spacing-x-small: 4px;\n --spacing-small: 6px;\n --spacing-medium: 8px;\n --spacing-large: 12px;\n --spacing-x-large: 16px;\n --spacing-2x-large: 24px;\n --spacing-4x-large: 32px;\n --font-size-display-1: 6em;\n --font-size-display-2: 5.5em;\n --font-size-display-3: 4.5em;\n --font-size-display-4: 3.5em;\n --font-size-h1: 2em;\n --font-size-h2: 1.5em;\n --font-size-h3: 1.17em;\n --font-size-h4: 1em;\n --font-size-h5: 0.83em;\n --font-size-paragraph: 1em;\n --font-size-small: 0.8em;\n --font-size-label: 0.83em;\n --font-size-button: 1em;\n --font-size-quote: 1.17em;\n --radii-none: 0px;\n --radii-x-small: 0.125em;\n --radii-small: 0.25em;\n --radii-medium: 0.375em;\n --radii-large: 0.5px;\n --radii-x-large: 1em;\n --radii-full: 9999px;\n --sizing-2x-small: 16px;\n --sizing-x-small: 19px;\n --sizing-small: 32px;\n --sizing-medium: 40px;\n --sizing-large: 56px;\n}\n\n/* Components */\n\n:root {\n --component-appbar-collapsed-width: 48px;\n --component-appbar-padding: var(--spacing-medium);\n --component-appbar-width: 240px;\n --component-avatar-border-radius-circle: var(--radii-full);\n --component-avatar-border-radius-square: var(--radii-small);\n --component-avatar-size-large: var(--sizing-large);\n --component-avatar-size-medium: var(--sizing-medium);\n --component-avatar-size-small: var(--sizing-small);\n --component-badge-border-radius-circle: var(--radii-full);\n --component-badge-border-radius-square: var(--radii-small);\n --component-badge-padding-large: var(--spacing-small);\n --component-badge-padding-medium: var(--spacing-x-small);\n --component-badge-padding-small: var(--spacing-2x-small);\n --component-badge-size-large: var(--sizing-medium);\n --component-badge-size-medium: var(--sizing-small);\n --component-badge-size-small: var(--sizing-2x-small);\n --component-button-border-radius-inner: var(--radii-x-small);\n --component-button-border-radius-outer: var(--radii-small);\n --component-button-border-width: var(--border-thin);\n --component-button-border-width-2: var(--border-x-thin);\n --component-button-border-width-2: var(--border-x-thin);\n --component-button-padding-large: var(--spacing-x-large);\n --component-button-padding-medium: var(--spacing-medium);\n --component-button-padding-small: var(--spacing-x-small);\n --component-card-border-radius-inner: var(--radii-small);\n --component-card-border-radius-outer: var(--radii-medium);\n --component-card-border-width: var(--border-x-thin);\n --component-card-inner-border-width: var(--border-x-thin);\n --component-card-padding-inner: var(--spacing-medium);\n --component-card-padding-outer: var(--spacing-x-large);\n --component-checkbox-icon-size: var(--sizing-2x-small);\n --component-checkbox-size: var(--sizing-x-small);\n --component-dialog-border-radius-inner: var(--radii-x-small);\n --component-dialog-border-radius-outer: var(--radii-small);\n --component-dialog-border-width: var(--border-x-thin);\n --component-dialog-inner-border-width: var(--border-x-thin);\n --component-dialog-padding: var(--spacing-medium);\n --component-drawer-border-radius: var(--radii-small);\n --component-drawer-border-width: var(--border-x-thin);\n --component-drawer-handle-padding: var(--spacing-x-small);\n --component-drawer-handle-width: var(--spacing-x-small);\n --component-drawer-padding: var(--spacing-medium);\n --component-inputs-border-radius-inner: var(--radii-x-small);\n --component-inputs-border-radius-outer: var(--radii-small);\n --component-inputs-border-width: var(--border-thin);\n --component-inputs-padding-large: var(--spacing-x-large);\n --component-inputs-padding-medium: var(--spacing-medium);\n --component-inputs-padding-small: var(--spacing-x-small);\n --component-menu-border-radius: var(--radii-x-small);\n --component-menu-border-width: var(--border-x-thin);\n --component-menu-padding-horizontal: var(--spacing-small);\n --component-menu-padding-vertical: var(--spacing-x-small);\n --component-panelbar-border-radius: var(--radii-x-small);\n --component-panelbar-border-width: var(--border-x-thin);\n --component-panelbar-border-width: var(--border-x-thin);\n --component-panelbar-padding: var(--spacing-medium);\n --component-progress-border-radius-inner: var(--radii-small);\n --component-progress-border-radius-outer: calc(var(--radii-small) + 4px);\n --component-progress-border-width: var(--border-x-thin);\n --component-progress-padding: var(--spacing-x-small);\n --component-progress-size-large: var(--sizing-large);\n --component-progress-size-medium: var(--sizing-medium);\n --component-progress-size-small: var(--sizing-small);\n --component-radio-dot-offset: var(--spacing-2x-small);\n --component-radio-dot-size: var(--spacing-medium);\n --component-radio-size: var(--sizing-2x-small);\n --component-sidebar-border-radius: var(--radii-small);\n --component-sidebar-border-width: var(--border-x-thin);\n --component-slider-border-radius-inner: var(--radii-small);\n --component-slider-border-radius-outer: calc(var(--radii-small) + 4px);\n --component-slider-border-width: var(--border-x-thin);\n --component-slider-padding: var(--spacing-x-small);\n --component-slider-thumb-border-radius: var(--radii-x-small);\n --component-switch-border-radius: var(--radii-full);\n --component-switch-border-width: var(--border-x-thin);\n --component-switch-padding: var(--spacing-2x-small);\n --component-tab-border-radius-inner: var(--radii-x-small);\n --component-tab-border-radius-outer: var(--radii-small);\n --component-tab-border-width: var(--border-x-thin);\n --component-tab-gap-large: var(--spacing-large);\n --component-tab-gap-medium: var(--spacing-small);\n --component-tab-gap-small: var(--spacing-2x-small);\n --component-tab-padding-large: var(--spacing-2x-large);\n --component-tab-padding-medium: var(--spacing-large);\n --component-tab-padding-small: var(--spacing-small);\n --component-table-border-radius: var(--radii-small);\n --component-table-border-width: var(--border-x-thin);\n --component-table-border-width-header: var(--border-thin);\n --component-table-padding-large: var(--spacing-large);\n --component-table-padding-medium: var(--spacing-medium);\n --component-table-padding-small: var(--spacing-small);\n --component-tag-border-radius-circle: var(--radii-full);\n --component-tag-border-radius-square: var(--radii-small);\n --component-tag-padding-large: var(--spacing-small);\n --component-tag-padding-medium: var(--spacing-x-small);\n --component-tag-padding-small: var(--spacing-2x-small);\n --component-tag-size-large: var(--sizing-large);\n --component-tag-size-medium: var(--sizing-medium);\n --component-tag-size-small: var(--sizing-small);\n --component-toast-border-radius: var(--radii-small);\n --component-toast-offset: var(--spacing-x-large);\n --component-toast-padding: var(--spacing-medium);\n --component-toast-padding-h: var(--spacing-x-large);\n --component-tooltip-border-radius: var(--radii-small);\n --component-tooltip-padding: var(--spacing-x-small);\n --component-tooltip-padding-h: var(--spacing-medium);\n}\n";
2
+
3
+ var blueLightCSS = "/* Themes - Blue Light */\n:root {\n --base-background-app: var(--neutral-light-1);\n --base-background-component: var(--neutral-light-0);\n --base-background-hover: var(--neutral-light-2);\n --base-background-border: var(--neutral-light-3);\n --base-background-active: var(--neutral-light-4);\n --base-content--: var(--neutral-dark-0);\n --base-content-light: var(--neutral-dark-1);\n --base-content-lighter: var(--neutral-dark-3);\n --base-content-lightest: var(--neutral-dark-5);\n --base-shadow: 0 2px 6px var(--neutral-black-translucent);\n --primary-background-app: var(--blue-light-1);\n --primary-background-component: var(--blue-light-0);\n --primary-background-hover: var(--blue-light-2);\n --primary-background-active: var(--blue-light-3);\n --primary-background-border: var(--blue-light-4);\n --primary-content--: var(--blue--);\n --primary-content-hover: var(--blue-dark-7);\n --primary-content-active: var(--blue-dark-6);\n --secondary-background-app: var(--teal-light-1);\n --secondary-background-component: var(--teal-light-0);\n --secondary-background-hover: var(--teal-light-2);\n --secondary-background-border: var(--teal-light-3);\n --secondary-background-active: var(--teal-light-4);\n --secondary-content--: var(--teal--);\n --secondary-content-hover: var(--teal-dark-7);\n --secondary-content-active: var(--teal-dark-6);\n --success-background-app: var(--green-light-1);\n --success-background-component: var(--green-light-0);\n --success-background-hover: var(--green-light-2);\n --success-background-border: var(--green-light-3);\n --success-background-active: var(--green-light-4);\n --success-content--: var(--green--);\n --success-content-hover: var(--green-dark-7);\n --success-content-active: var(--green-dark-6);\n --warning-background-app: var(--yellow-light-1);\n --warning-background-component: var(--yellow-light-0);\n --warning-background-hover: var(--yellow-light-2);\n --warning-background-border: var(--yellow-light-3);\n --warning-background-active: var(--yellow-light-4);\n --warning-content--: var(--yellow--);\n --warning-content-hover: var(--yellow-dark-7);\n --warning-content-active: var(--yellow-dark-6);\n --error-background-app: var(--red-light-1);\n --error-background-component: var(--red-light-0);\n --error-background-hover: var(--red-light-2);\n --error-background-border: var(--red-light-3);\n --error-background-active: var(--red-light-4);\n --error-content--: var(--red--);\n --error-content-hover: var(--red-dark-7);\n --error-content-active: var(--red-dark-6);\n --help-background-app: var(--indigo-light-1);\n --help-background-component: var(--indigo-light-0);\n --help-background-hover: var(--indigo-light-2);\n --help-background-active: var(--indigo-light-3);\n --help-background-border: var(--indigo-light-4);\n --help-content--: var(--indigo--);\n --help-content-hover: var(--indigo-dark-7);\n --help-content-active: var(--indigo-dark-6);\n --component-appbar-background: var(--base-background-component);\n --component-appbar-color: var(--base-content--);\n --component-appbar-border-color: var(--base-background-border);\n --component-checkbox-background: var(--base-background-component);\n --component-checkbox-color: var(--base-content--);\n --component-checkbox-border-color: var(--base-content--);\n --component-checkbox-accent: var(--primary-content--);\n --component-dialog-background: var(--base-background-component);\n --component-dialog-color: var(--base-content--);\n --component-dialog-border-color: var(--base-background-border);\n --component-dialog-hover-background: var(--base-background-hover);\n --component-dialog-accent: var(--primary-content--);\n --component-drawer-background: var(--base-background-component);\n --component-drawer-color: var(--base-content--);\n --component-drawer-border-color: var(--base-background-border);\n --component-drawer-hover-background: var(--base-background-hover);\n --component-input-background: var(--base-background-app);\n --component-input-background-disabled: var(--base-background-component);\n --component-input-color: var(--base-content--);\n --component-input-border-color: var(--base-background-border);\n --component-input-accent: var(--primary-content--);\n --component-input-label-color: var(--base-content-light);\n --component-input-icon-color: var(--base-content-lighter);\n --component-input-error-color: var(--error-content--);\n --component-input-error-background: var(--error-background-component);\n --component-input-error-border-color: var(--error-background-border);\n --component-menu-background: var(--base-background-component);\n --component-menu-color: var(--base-content--);\n --component-menu-border-color: var(--base-background-border);\n --component-menu-hover-background: var(--base-background-hover);\n --component-menu-shadow: var(--base-shadow);\n --component-panel-background: var(--base-background-component);\n --component-panel-color: var(--base-content--);\n --component-panel-expanded-background: var(--base-background-app);\n --component-panel-accent: var(--primary-content--);\n --component-panel-active-border: var(--base-background-active);\n --component-panel-accent-hover-background: var(--primary-background-active);\n --component-panel-hover-background: var(--base-background-hover);\n --component-radio-color: var(--base-content--);\n --component-radio-accent: var(--primary-content--);\n --component-select-background: var(--base-background-app);\n --component-select-color: var(--base-content--);\n --component-select-border-color: var(--base-background-border);\n --component-select-accent: var(--primary-content--);\n --component-select-accent-contrast: var(--base-background-component);\n --component-select-label-color: var(--base-content-light);\n --component-select-hover-background: var(--base-background-hover);\n --component-select-shadow: var(--base-shadow);\n --component-select-error-color: var(--error-content--);\n --component-select-error-background: var(--error-background-component);\n --component-select-error-border-color: var(--error-background-border);\n --component-table-color: var(--base-content--);\n --component-table-border-color: var(--base-background-border);\n --component-table-hover-background: var(--base-background-hover);\n --component-table-active-background: var(--base-background-active);\n --component-table-color-light: var(--base-content-lightest);\n --component-tabs-background: var(--base-background-component);\n --component-tabs-color: var(--base-content--);\n --component-tabs-border-color: var(--base-background-border);\n --component-tabs-accent: var(--primary-content--);\n --font-family-header: \"Lexend\", sans-serif;\n --font-family-body: \"Lexend\", sans-serif;\n}\n";
4
+
5
+ var blueDarkCSS = "/* Themes - Blue Dark */\n:root {\n --base-background-app: var(--neutral-dark-1);\n --base-background-component: var(--neutral-dark-0);\n --base-background-hover: var(--neutral-dark-2);\n --base-background-border: var(--neutral-dark-3);\n --base-background-active: var(--neutral-dark-4);\n --base-content--: var(--neutral-light-0);\n --base-content-light: var(--neutral-light-1);\n --base-content-lighter: var(--neutral-light-3);\n --base-content-lightest: var(--neutral-light-5);\n --base-shadow: 0 2px 6px var(--neutral-black-translucent);\n --primary-background-app: var(--blue-dark-1);\n --primary-background-component: var(--blue-dark-0);\n --primary-background-hover: var(--blue-dark-2);\n --primary-background-active: var(--blue-dark-3);\n --primary-background-border: var(--blue-dark-4);\n --primary-content--: var(--blue--);\n --primary-content-hover: var(--blue-light-7);\n --primary-content-active: var(--blue-light-6);\n --secondary-background-app: var(--teal-dark-1);\n --secondary-background-component: var(--teal-dark-0);\n --secondary-background-hover: var(--teal-dark-2);\n --secondary-background-border: var(--teal-dark-3);\n --secondary-background-active: var(--teal-dark-4);\n --secondary-content--: var(--teal--);\n --secondary-content-hover: var(--teal-light-7);\n --secondary-content-active: var(--teal-light-6);\n --success-background-app: var(--green-dark-1);\n --success-background-component: var(--green-dark-0);\n --success-background-hover: var(--green-dark-2);\n --success-background-border: var(--green-dark-3);\n --success-background-active: var(--green-dark-4);\n --success-content--: var(--green--);\n --success-content-hover: var(--green-light-7);\n --success-content-active: var(--green-light-6);\n --warning-background-app: var(--yellow-dark-1);\n --warning-background-component: var(--yellow-dark-0);\n --warning-background-hover: var(--yellow-dark-2);\n --warning-background-border: var(--yellow-dark-3);\n --warning-background-active: var(--yellow-dark-4);\n --warning-content--: var(--yellow--);\n --warning-content-hover: var(--yellow-light-7);\n --warning-content-active: var(--yellow-light-6);\n --error-background-app: var(--red-dark-1);\n --error-background-component: var(--red-dark-0);\n --error-background-hover: var(--red-dark-2);\n --error-background-border: var(--red-dark-3);\n --error-background-active: var(--red-dark-4);\n --error-content--: var(--red--);\n --error-content-hover: var(--red-light-7);\n --error-content-active: var(--red-light-6);\n --help-background-app: var(--indigo-dark-1);\n --help-background-component: var(--indigo-light-0);\n --help-background-hover: var(--indigo-dark-2);\n --help-background-active: var(--indigo-dark-3);\n --help-background-border: var(--indigo-dark-4);\n --help-content--: var(--indigo--);\n --help-content-hover: var(--indigo-light-7);\n --help-content-active: var(--indigo-light-6);\n --component-appbar-background: var(--base-background-component);\n --component-appbar-color: var(--base-content--);\n --component-appbar-border-color: var(--base-background-border);\n --component-checkbox-background: var(--base-background-component);\n --component-checkbox-color: var(--base-content--);\n --component-checkbox-border-color: var(--base-content--);\n --component-checkbox-accent: var(--primary-content--);\n --component-dialog-background: var(--base-background-component);\n --component-dialog-color: var(--base-content--);\n --component-dialog-border-color: var(--base-background-border);\n --component-dialog-hover-background: var(--base-background-hover);\n --component-dialog-accent: var(--primary-content--);\n --component-drawer-background: var(--base-background-component);\n --component-drawer-color: var(--base-content--);\n --component-drawer-border-color: var(--base-background-border);\n --component-drawer-hover-background: var(--base-background-hover);\n --component-input-background: var(--base-background-app);\n --component-input-background-disabled: var(--base-background-component);\n --component-input-color: var(--base-content--);\n --component-input-border-color: var(--base-background-border);\n --component-input-accent: var(--primary-content--);\n --component-input-label-color: var(--base-content-light);\n --component-input-icon-color: var(--base-content-lighter);\n --component-input-error-color: var(--error-content--);\n --component-input-error-background: var(--error-background-component);\n --component-input-error-border-color: var(--error-background-border);\n --component-menu-background: var(--base-background-component);\n --component-menu-color: var(--base-content--);\n --component-menu-border-color: var(--base-background-border);\n --component-menu-hover-background: var(--base-background-hover);\n --component-menu-shadow: var(--base-shadow);\n --component-panel-background: var(--base-background-component);\n --component-panel-color: var(--base-content--);\n --component-panel-expanded-background: var(--base-background-app);\n --component-panel-accent: var(--primary-content--);\n --component-panel-active-border: var(--base-background-active);\n --component-panel-accent-hover-background: var(--primary-background-active);\n --component-panel-hover-background: var(--base-background-hover);\n --component-radio-color: var(--base-content--);\n --component-radio-accent: var(--primary-content--);\n --component-select-background: var(--base-background-app);\n --component-select-color: var(--base-content--);\n --component-select-border-color: var(--base-background-border);\n --component-select-accent: var(--primary-content--);\n --component-select-accent-contrast: var(--base-background-component);\n --component-select-label-color: var(--base-content-light);\n --component-select-hover-background: var(--base-background-hover);\n --component-select-shadow: var(--base-shadow);\n --component-select-error-color: var(--error-content--);\n --component-select-error-background: var(--error-background-component);\n --component-select-error-border-color: var(--error-background-border);\n --component-table-color: var(--base-content--);\n --component-table-border-color: var(--base-background-border);\n --component-table-hover-background: var(--base-background-hover);\n --component-table-active-background: var(--base-background-active);\n --component-table-color-light: var(--base-content-lightest);\n --component-tabs-background: var(--base-background-component);\n --component-tabs-color: var(--base-content--);\n --component-tabs-border-color: var(--base-background-border);\n --component-tabs-accent: var(--primary-content--);\n --font-family-header: \"Lexend\", sans-serif;\n --font-family-body: \"Lexend\", sans-serif;\n}\n";
6
+
7
+ var orangeLightCSS = "/* Themes - Orange Light */\n:root {\n --base-background-app: var(--neutral-light-1);\n --base-background-component: var(--neutral-light-0);\n --base-background-hover: var(--neutral-light-2);\n --base-background-border: var(--neutral-light-3);\n --base-background-active: var(--neutral-light-4);\n --base-content--: var(--neutral-dark-0);\n --base-content-light: var(--neutral-dark-1);\n --base-content-lighter: var(--neutral-dark-3);\n --base-content-lightest: var(--neutral-dark-5);\n --base-shadow: 0 2px 6px var(--neutral-black-translucent);\n --primary-background-app: var(--orange-light-1);\n --primary-background-component: var(--orange-light-0);\n --primary-background-hover: var(--orange-light-2);\n --primary-background-active: var(--orange-light-3);\n --primary-background-border: var(--orange-light-4);\n --primary-content--: var(--orange--);\n --primary-content-hover: var(--orange-dark-7);\n --primary-content-active: var(--orange-dark-6);\n --secondary-background-app: var(--amber-light-1);\n --secondary-background-component: var(--amber-light-0);\n --secondary-background-hover: var(--amber-light-2);\n --secondary-background-border: var(--amber-light-3);\n --secondary-background-active: var(--amber-light-4);\n --secondary-content--: var(--amber--);\n --secondary-content-hover: var(--amber-dark-7);\n --secondary-content-active: var(--amber-dark-6);\n --success-background-app: var(--green-light-1);\n --success-background-component: var(--green-light-0);\n --success-background-hover: var(--green-light-2);\n --success-background-border: var(--green-light-3);\n --success-background-active: var(--green-light-4);\n --success-content--: var(--green--);\n --success-content-hover: var(--green-dark-7);\n --success-content-active: var(--green-dark-6);\n --warning-background-app: var(--yellow-light-1);\n --warning-background-component: var(--yellow-light-0);\n --warning-background-hover: var(--yellow-light-2);\n --warning-background-border: var(--yellow-light-3);\n --warning-background-active: var(--yellow-light-4);\n --warning-content--: var(--yellow--);\n --warning-content-hover: var(--yellow-dark-7);\n --warning-content-active: var(--yellow-dark-6);\n --error-background-app: var(--red-light-1);\n --error-background-component: var(--red-light-0);\n --error-background-hover: var(--red-light-2);\n --error-background-border: var(--red-light-3);\n --error-background-active: var(--red-light-4);\n --error-content--: var(--red--);\n --error-content-hover: var(--red-dark-7);\n --error-content-active: var(--red-dark-6);\n --help-background-app: var(--indigo-light-1);\n --help-background-component: var(--indigo-light-0);\n --help-background-hover: var(--indigo-light-2);\n --help-background-active: var(--indigo-light-3);\n --help-background-border: var(--indigo-light-4);\n --help-content--: var(--indigo--);\n --help-content-hover: var(--indigo-dark-7);\n --help-content-active: var(--indigo-dark-6);\n --component-appbar-background: var(--base-background-component);\n --component-appbar-color: var(--base-content--);\n --component-appbar-border-color: var(--base-background-border);\n --component-checkbox-background: var(--base-background-component);\n --component-checkbox-color: var(--base-content--);\n --component-checkbox-border-color: var(--base-content--);\n --component-checkbox-accent: var(--primary-content--);\n --component-dialog-background: var(--base-background-component);\n --component-dialog-color: var(--base-content--);\n --component-dialog-border-color: var(--base-background-border);\n --component-dialog-hover-background: var(--base-background-hover);\n --component-dialog-accent: var(--primary-content--);\n --component-drawer-background: var(--base-background-component);\n --component-drawer-color: var(--base-content--);\n --component-drawer-border-color: var(--base-background-border);\n --component-drawer-hover-background: var(--base-background-hover);\n --component-input-background: var(--base-background-app);\n --component-input-background-disabled: var(--base-background-component);\n --component-input-color: var(--base-content--);\n --component-input-border-color: var(--base-background-border);\n --component-input-accent: var(--primary-content--);\n --component-input-label-color: var(--base-content-light);\n --component-input-icon-color: var(--base-content-lighter);\n --component-input-error-color: var(--error-content--);\n --component-input-error-background: var(--error-background-component);\n --component-input-error-border-color: var(--error-background-border);\n --component-menu-background: var(--base-background-component);\n --component-menu-color: var(--base-content--);\n --component-menu-border-color: var(--base-background-border);\n --component-menu-hover-background: var(--base-background-hover);\n --component-menu-shadow: var(--base-shadow);\n --component-panel-background: var(--base-background-component);\n --component-panel-color: var(--base-content--);\n --component-panel-expanded-background: var(--base-background-app);\n --component-panel-accent: var(--primary-content--);\n --component-panel-active-border: var(--base-background-active);\n --component-panel-accent-hover-background: var(--primary-background-active);\n --component-panel-hover-background: var(--base-background-hover);\n --component-radio-color: var(--base-content--);\n --component-radio-accent: var(--primary-content--);\n --component-select-background: var(--base-background-app);\n --component-select-color: var(--base-content--);\n --component-select-border-color: var(--base-background-border);\n --component-select-accent: var(--primary-content--);\n --component-select-accent-contrast: var(--base-background-component);\n --component-select-label-color: var(--base-content-light);\n --component-select-hover-background: var(--base-background-hover);\n --component-select-shadow: var(--base-shadow);\n --component-select-error-color: var(--error-content--);\n --component-select-error-background: var(--error-background-component);\n --component-select-error-border-color: var(--error-background-border);\n --component-table-color: var(--base-content--);\n --component-table-border-color: var(--base-background-border);\n --component-table-hover-background: var(--base-background-hover);\n --component-table-active-background: var(--base-background-active);\n --component-table-color-light: var(--base-content-lightest);\n --component-tabs-background: var(--base-background-component);\n --component-tabs-color: var(--base-content--);\n --component-tabs-border-color: var(--base-background-border);\n --component-tabs-accent: var(--primary-content--);\n --font-family-header: \"Lexend\", sans-serif;\n --font-family-body: \"Lexend\", sans-serif;\n}\n";
8
+
9
+ var orangeDarkCSS = "/* Themes - Orange Dark */\n:root {\n --base-background-app: var(--neutral-dark-1);\n --base-background-component: var(--neutral-dark-0);\n --base-background-hover: var(--neutral-dark-2);\n --base-background-border: var(--neutral-dark-3);\n --base-background-active: var(--neutral-dark-4);\n --base-content--: var(--neutral-light-0);\n --base-content-light: var(--neutral-light-1);\n --base-content-lighter: var(--neutral-light-3);\n --base-content-lightest: var(--neutral-light-5);\n --base-shadow: 0 2px 6px var(--neutral-black-translucent);\n --primary-background-app: var(--orange-dark-1);\n --primary-background-component: var(--orange-dark-0);\n --primary-background-hover: var(--orange-dark-2);\n --primary-background-active: var(--orange-dark-3);\n --primary-background-border: var(--orange-dark-4);\n --primary-content--: var(--orange--);\n --primary-content-hover: var(--orange-light-7);\n --primary-content-active: var(--orange-light-6);\n --secondary-background-app: var(--amber-dark-1);\n --secondary-background-component: var(--amber-light-0);\n --secondary-background-hover: var(--amber-dark-2);\n --secondary-background-border: var(--amber-dark-3);\n --secondary-background-active: var(--amber-dark-4);\n --secondary-content--: var(--amber--);\n --secondary-content-hover: var(--amber-light-7);\n --secondary-content-active: var(--amber-light-6);\n --success-background-app: var(--green-dark-1);\n --success-background-component: var(--green-dark-0);\n --success-background-hover: var(--green-dark-2);\n --success-background-border: var(--green-dark-3);\n --success-background-active: var(--green-dark-4);\n --success-content--: var(--green--);\n --success-content-hover: var(--green-light-7);\n --success-content-active: var(--green-light-6);\n --warning-background-app: var(--yellow-dark-1);\n --warning-background-component: var(--yellow-dark-0);\n --warning-background-hover: var(--yellow-dark-2);\n --warning-background-border: var(--yellow-dark-3);\n --warning-background-active: var(--yellow-dark-4);\n --warning-content--: var(--yellow--);\n --warning-content-hover: var(--yellow-light-7);\n --warning-content-active: var(--yellow-light-6);\n --error-background-app: var(--red-dark-1);\n --error-background-component: var(--red-dark-0);\n --error-background-hover: var(--red-dark-2);\n --error-background-border: var(--red-dark-3);\n --error-background-active: var(--red-dark-4);\n --error-content--: var(--red--);\n --error-content-hover: var(--red-light-7);\n --error-content-active: var(--red-light-6);\n --help-background-app: var(--indigo-dark-1);\n --help-background-component: var(--indigo-light-0);\n --help-background-hover: var(--indigo-dark-2);\n --help-background-active: var(--indigo-dark-3);\n --help-background-border: var(--indigo-dark-4);\n --help-content--: var(--indigo--);\n --help-content-hover: var(--indigo-light-7);\n --help-content-active: var(--indigo-light-6);\n --component-appbar-background: var(--base-background-component);\n --component-appbar-color: var(--base-content--);\n --component-appbar-border-color: var(--base-background-border);\n --component-checkbox-background: var(--base-background-component);\n --component-checkbox-color: var(--base-content--);\n --component-checkbox-border-color: var(--base-content--);\n --component-checkbox-accent: var(--primary-content--);\n --component-dialog-background: var(--base-background-component);\n --component-dialog-color: var(--base-content--);\n --component-dialog-border-color: var(--base-background-border);\n --component-dialog-hover-background: var(--base-background-hover);\n --component-dialog-accent: var(--primary-content--);\n --component-drawer-background: var(--base-background-component);\n --component-drawer-color: var(--base-content--);\n --component-drawer-border-color: var(--base-background-border);\n --component-drawer-hover-background: var(--base-background-hover);\n --component-input-background: var(--base-background-app);\n --component-input-background-disabled: var(--base-background-component);\n --component-input-color: var(--base-content--);\n --component-input-border-color: var(--base-background-border);\n --component-input-accent: var(--primary-content--);\n --component-input-label-color: var(--base-content-light);\n --component-input-icon-color: var(--base-content-lighter);\n --component-input-error-color: var(--error-content--);\n --component-input-error-background: var(--error-background-component);\n --component-input-error-border-color: var(--error-background-border);\n --component-menu-background: var(--base-background-component);\n --component-menu-color: var(--base-content--);\n --component-menu-border-color: var(--base-background-border);\n --component-menu-hover-background: var(--base-background-hover);\n --component-menu-shadow: var(--base-shadow);\n --component-panel-background: var(--base-background-component);\n --component-panel-color: var(--base-content--);\n --component-panel-expanded-background: var(--base-background-app);\n --component-panel-accent: var(--primary-content--);\n --component-panel-active-border: var(--base-background-active);\n --component-panel-accent-hover-background: var(--primary-background-active);\n --component-panel-hover-background: var(--base-background-hover);\n --component-radio-color: var(--base-content--);\n --component-radio-accent: var(--primary-content--);\n --component-select-background: var(--base-background-app);\n --component-select-color: var(--base-content--);\n --component-select-border-color: var(--base-background-border);\n --component-select-accent: var(--primary-content--);\n --component-select-accent-contrast: var(--base-background-component);\n --component-select-label-color: var(--base-content-light);\n --component-select-hover-background: var(--base-background-hover);\n --component-select-shadow: var(--base-shadow);\n --component-select-error-color: var(--error-content--);\n --component-select-error-background: var(--error-background-component);\n --component-select-error-border-color: var(--error-background-border);\n --component-table-color: var(--base-content--);\n --component-table-border-color: var(--base-background-border);\n --component-table-hover-background: var(--base-background-hover);\n --component-table-active-background: var(--base-background-active);\n --component-table-color-light: var(--base-content-lightest);\n --component-tabs-background: var(--base-background-component);\n --component-tabs-color: var(--base-content--);\n --component-tabs-border-color: var(--base-background-border);\n --component-tabs-accent: var(--primary-content--);\n --font-family-header: \"Lexend\", sans-serif;\n --font-family-body: \"Lexend\", sans-serif;\n}\n";
10
+
11
+ const THEMES = {
12
+ "blue-light": blueLightCSS,
13
+ "blue-dark": blueDarkCSS,
14
+ "orange-light": orangeLightCSS,
15
+ "orange-dark": orangeDarkCSS,
16
+ };
4
17
 
18
+ class YumeTheme extends HTMLElement {
5
19
  static get observedAttributes() {
6
- return ["theme-path"];
20
+ return ["theme", "mode", "theme-path"];
7
21
  }
8
22
 
9
23
  constructor() {
@@ -12,59 +26,41 @@ class YumeTheme extends HTMLElement {
12
26
  }
13
27
 
14
28
  connectedCallback() {
15
- this.loadDefaultVariables().then(() => {
16
- const themePath = this.getAttribute("theme-path");
17
- this.loadTheme(themePath);
18
- });
29
+ this._applyTheme();
19
30
  }
20
31
 
21
32
  attributeChangedCallback(name, oldValue, newValue) {
22
- if (name === "theme-path" && oldValue !== newValue) {
23
- this.loadTheme(newValue);
33
+ if (oldValue !== newValue) {
34
+ this._applyTheme();
24
35
  }
25
36
  }
26
37
 
27
- async loadDefaultVariables() {
28
- if (!YumeTheme.defaultVariablesLoaded) {
29
- try {
30
- const variablesUrl = new URL(
31
- "styles/variables.css",
32
- document.baseURI,
33
- );
34
- const response = await fetch(variablesUrl.href);
35
- YumeTheme.defaultVariablesCSS = await response.text();
36
- YumeTheme.defaultVariablesLoaded = true;
37
- } catch (e) {
38
- console.error(
39
- "Failed to load default variables from styles/variables.css:",
40
- e,
41
- );
42
- }
43
- }
44
- return Promise.resolve();
45
- }
38
+ async _applyTheme() {
39
+ const themePath = this.getAttribute("theme-path");
40
+ let themeCSS;
46
41
 
47
- async loadTheme(themePath) {
48
- let themeCSS = "";
49
42
  if (themePath) {
50
43
  try {
51
- const themeUrl = new URL(themePath, document.baseURI);
52
- const response = await fetch(themeUrl.href);
44
+ const url = new URL(themePath, document.baseURI);
45
+ const response = await fetch(url.href);
53
46
  themeCSS = await response.text();
54
47
  } catch (e) {
55
48
  console.error(`Failed to load theme from ${themePath}:`, e);
49
+ themeCSS = "";
56
50
  }
51
+ } else {
52
+ const theme = this.getAttribute("theme") || "blue";
53
+ const mode = this.getAttribute("mode") || "light";
54
+ themeCSS = THEMES[`${theme}-${mode}`] || "";
57
55
  }
58
56
 
59
- const combinedCSS = `
60
- <style>
61
- ${YumeTheme.defaultVariablesCSS}
62
- </style>
63
- ${themeCSS ? `<style>${themeCSS}</style>` : ""}
64
- `;
57
+ this.shadowRoot.innerHTML = `
58
+ <style>${variablesCSS}</style>
59
+ ${themeCSS ? `<style>${themeCSS}</style>` : ""}
60
+ <slot></slot>
61
+ `;
65
62
 
66
- this.shadowRoot.innerHTML = `${combinedCSS}<slot></slot>`;
67
- this.applyVariablesToHost(YumeTheme.defaultVariablesCSS + themeCSS);
63
+ this.applyVariablesToHost(variablesCSS + themeCSS);
68
64
  }
69
65
 
70
66
  applyVariablesToHost(cssText) {
@@ -0,0 +1,34 @@
1
+ export class YumeToast extends HTMLElement {
2
+ static get observedAttributes(): string[];
3
+ _queue: any[];
4
+ connectedCallback(): void;
5
+ attributeChangedCallback(name: any, oldVal: any, newVal: any): void;
6
+ set position(val: string);
7
+ get position(): string;
8
+ set duration(val: number);
9
+ get duration(): number;
10
+ set max(val: number);
11
+ get max(): number;
12
+ /**
13
+ * Show a toast notification.
14
+ * @param {Object} opts
15
+ * @param {string} opts.message — Required text content.
16
+ * @param {string} [opts.color] — base|primary|secondary|success|warning|error|help (default base).
17
+ * @param {number} [opts.duration] — Override container-level duration for this toast.
18
+ * @param {boolean} [opts.dismissible] — Show a close button (default true).
19
+ * @param {string} [opts.icon] — Optional Font Awesome class e.g. "fas fa-check".
20
+ * @returns {HTMLElement} The toast element (for manual removal).
21
+ */
22
+ show(opts?: {
23
+ message: string;
24
+ color?: string;
25
+ duration?: number;
26
+ dismissible?: boolean;
27
+ icon?: string;
28
+ }): HTMLElement;
29
+ clear(): void;
30
+ _removeToast(toast: any): void;
31
+ _getPositionStyles(): any;
32
+ _getColorBg(color: any): any;
33
+ render(): void;
34
+ }