@e280/shiny 0.1.0-1 → 0.1.0-10
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/README.md +110 -3
- package/package.json +3 -3
- package/s/{ui → components}/copy/component.ts +11 -6
- package/s/{ui → components}/copy/style.css.ts +6 -6
- package/s/components/drawer/component.ts +92 -0
- package/s/components/drawer/control.ts +31 -0
- package/s/components/drawer/style.css.ts +120 -0
- package/s/{ui → components}/example/component.ts +7 -5
- package/s/{ui → components}/example/style.css.ts +2 -2
- package/s/components/foundation.css.ts +15 -0
- package/s/components/framework.ts +10 -0
- package/s/components/raw-components.ts +13 -0
- package/s/components/tabs/component.ts +59 -0
- package/s/components/tabs/control.ts +31 -0
- package/s/components/tabs/style.css.ts +6 -0
- package/s/demo/aura-views.ts +6 -0
- package/s/demo/demo.bundle.ts +204 -14
- package/s/demo/demo.css +3 -1
- package/s/demo/utils/lipsum.ts +19 -0
- package/s/demo/views/demonstration/style.css.ts +10 -2
- package/s/demo/views/demonstration/view.ts +18 -14
- package/s/icons/tabler/menu-2.svg.ts +4 -0
- package/s/icons/tabler/x.svg.ts +4 -0
- package/s/index.html.ts +2 -2
- package/s/index.ts +16 -4
- package/s/install/aura.bundle.ts +9 -0
- package/s/install/plain.bundle.ts +9 -0
- package/s/shiny.ts +15 -0
- package/s/themes/aura.css.ts +48 -0
- package/s/themes/index.barrel.ts +2 -1
- package/s/themes/index.ts +1 -0
- package/s/themes/infra/css-vars.ts +33 -0
- package/s/themes/plain.css.ts +12 -0
- package/s/utils/states.ts +15 -0
- package/x/{ui → components}/copy/component.d.ts +8 -4
- package/x/{ui → components}/copy/component.js +10 -5
- package/x/components/copy/component.js.map +1 -0
- package/x/{ui → components}/copy/style.css.js +6 -6
- package/x/components/copy/style.css.js.map +1 -0
- package/x/components/drawer/component.d.ts +387 -0
- package/x/components/drawer/component.js +76 -0
- package/x/components/drawer/component.js.map +1 -0
- package/x/components/drawer/control.d.ts +9 -0
- package/x/components/drawer/control.js +24 -0
- package/x/components/drawer/control.js.map +1 -0
- package/x/components/drawer/style.css.js +119 -0
- package/x/components/drawer/style.css.js.map +1 -0
- package/x/{ui → components}/example/component.d.ts +3 -3
- package/x/{ui → components}/example/component.js +6 -4
- package/x/components/example/component.js.map +1 -0
- package/x/components/example/style.css.d.ts +2 -0
- package/x/components/example/style.css.js +10 -0
- package/x/components/example/style.css.js.map +1 -0
- package/x/components/foundation.css.d.ts +1 -0
- package/x/components/foundation.css.js +14 -0
- package/x/components/foundation.css.js.map +1 -0
- package/x/components/framework.d.ts +8 -0
- package/x/components/framework.js +5 -0
- package/x/components/framework.js.map +1 -0
- package/x/components/raw-components.d.ts +10 -0
- package/x/components/raw-components.js +11 -0
- package/x/components/raw-components.js.map +1 -0
- package/x/components/tabs/component.d.ts +374 -0
- package/x/components/tabs/component.js +49 -0
- package/x/components/tabs/component.js.map +1 -0
- package/x/components/tabs/control.d.ts +9 -0
- package/x/components/tabs/control.js +24 -0
- package/x/components/tabs/control.js.map +1 -0
- package/x/components/tabs/style.css.d.ts +2 -0
- package/x/components/tabs/style.css.js +5 -0
- package/x/components/tabs/style.css.js.map +1 -0
- package/x/demo/aura-views.d.ts +14 -0
- package/x/demo/aura-views.js +4 -0
- package/x/demo/aura-views.js.map +1 -0
- package/x/demo/demo.bundle.js +198 -14
- package/x/demo/demo.bundle.js.map +1 -1
- package/x/demo/demo.bundle.min.js +383 -48
- package/x/demo/demo.bundle.min.js.map +4 -4
- package/x/demo/demo.css +3 -1
- package/x/demo/utils/lipsum.d.ts +2 -0
- package/x/demo/utils/lipsum.js +11 -0
- package/x/demo/utils/lipsum.js.map +1 -0
- package/x/demo/views/demonstration/style.css.js +10 -2
- package/x/demo/views/demonstration/style.css.js.map +1 -1
- package/x/demo/views/demonstration/view.d.ts +6 -4
- package/x/demo/views/demonstration/view.js +16 -10
- package/x/demo/views/demonstration/view.js.map +1 -1
- package/x/icons/tabler/menu-2.svg.d.ts +2 -0
- package/x/icons/tabler/menu-2.svg.js +3 -0
- package/x/icons/tabler/menu-2.svg.js.map +1 -0
- package/x/icons/tabler/x.svg.d.ts +2 -0
- package/x/icons/tabler/x.svg.js +3 -0
- package/x/icons/tabler/x.svg.js.map +1 -0
- package/x/index.d.ts +10 -4
- package/x/index.html +7 -5
- package/x/index.html.js +2 -2
- package/x/index.js +10 -4
- package/x/index.js.map +1 -1
- package/x/install/aura.bundle.d.ts +1 -0
- package/x/install/aura.bundle.js +5 -0
- package/x/install/aura.bundle.js.map +1 -0
- package/x/install/aura.bundle.min.js +321 -0
- package/x/install/aura.bundle.min.js.map +7 -0
- package/x/install/plain.bundle.d.ts +1 -0
- package/x/install/plain.bundle.js +5 -0
- package/x/install/plain.bundle.js.map +1 -0
- package/x/install/plain.bundle.min.js +287 -0
- package/x/install/plain.bundle.min.js.map +7 -0
- package/x/shiny.d.ts +42 -0
- package/x/shiny.js +8 -0
- package/x/shiny.js.map +1 -0
- package/x/themes/aura.css.d.ts +1 -0
- package/x/themes/aura.css.js +47 -0
- package/x/themes/aura.css.js.map +1 -0
- package/x/themes/index.barrel.d.ts +2 -1
- package/x/themes/index.barrel.js +2 -1
- package/x/themes/index.barrel.js.map +1 -1
- package/x/themes/index.d.ts +1 -0
- package/x/themes/infra/css-vars.d.ts +11 -0
- package/x/themes/infra/css-vars.js +18 -0
- package/x/themes/infra/css-vars.js.map +1 -0
- package/x/themes/plain.css.d.ts +1 -0
- package/x/themes/plain.css.js +11 -0
- package/x/themes/plain.css.js.map +1 -0
- package/x/utils/states.d.ts +5 -0
- package/x/utils/states.js +13 -0
- package/x/utils/states.js.map +1 -0
- package/s/themes/basic.css.ts +0 -18
- package/s/tools/untab.ts +0 -30
- package/s/ui/components.ts +0 -9
- package/s/ui/framework.ts +0 -8
- package/s/ui/themers.ts +0 -28
- package/x/themes/basic.css.d.ts +0 -1
- package/x/themes/basic.css.js +0 -17
- package/x/themes/basic.css.js.map +0 -1
- package/x/tools/untab.d.ts +0 -1
- package/x/tools/untab.js +0 -26
- package/x/tools/untab.js.map +0 -1
- package/x/ui/components.d.ts +0 -6
- package/x/ui/components.js +0 -7
- package/x/ui/components.js.map +0 -1
- package/x/ui/copy/component.js.map +0 -1
- package/x/ui/copy/style.css.js.map +0 -1
- package/x/ui/example/component.js.map +0 -1
- package/x/ui/example/style.css.js +0 -10
- package/x/ui/example/style.css.js.map +0 -1
- package/x/ui/framework.d.ts +0 -4
- package/x/ui/framework.js +0 -6
- package/x/ui/framework.js.map +0 -1
- package/x/ui/themers.d.ts +0 -8
- package/x/ui/themers.js +0 -12
- package/x/ui/themers.js.map +0 -1
- /package/x/{ui → components}/copy/style.css.d.ts +0 -0
- /package/x/{ui/example → components/drawer}/style.css.d.ts +0 -0
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { css } from "lit";
|
|
2
|
-
export default css
|
|
2
|
+
export default css `@layer view {
|
|
3
3
|
|
|
4
4
|
button {
|
|
5
5
|
background: transparent;
|
|
@@ -8,7 +8,7 @@ button {
|
|
|
8
8
|
}
|
|
9
9
|
|
|
10
10
|
button {
|
|
11
|
-
opacity:
|
|
11
|
+
opacity: var(--inactive-opacity);
|
|
12
12
|
cursor: pointer;
|
|
13
13
|
cursor: copy;
|
|
14
14
|
|
|
@@ -21,18 +21,18 @@ button {
|
|
|
21
21
|
}
|
|
22
22
|
|
|
23
23
|
[data-status="invalid"] {
|
|
24
|
-
color: var(--
|
|
24
|
+
color: var(--lame);
|
|
25
25
|
}
|
|
26
26
|
|
|
27
27
|
[data-status="good"] {
|
|
28
28
|
opacity: 1;
|
|
29
|
-
color: var(--
|
|
29
|
+
color: var(--happy);
|
|
30
30
|
filter: drop-shadow(0 0 0.3em color-mix(in oklab, transparent, currentColor 50%));
|
|
31
31
|
}
|
|
32
32
|
|
|
33
33
|
[data-status="bad"] {
|
|
34
34
|
opacity: 1;
|
|
35
|
-
color: var(--
|
|
35
|
+
color: var(--angry);
|
|
36
36
|
filter: drop-shadow(0 0 0.3em color-mix(in oklab, transparent, currentColor 50%));
|
|
37
37
|
}
|
|
38
38
|
|
|
@@ -41,5 +41,5 @@ svg {
|
|
|
41
41
|
height: 1em;
|
|
42
42
|
}
|
|
43
43
|
|
|
44
|
-
`;
|
|
44
|
+
}`;
|
|
45
45
|
//# sourceMappingURL=style.css.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"style.css.js","sourceRoot":"","sources":["../../../s/components/copy/style.css.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,GAAG,EAAC,MAAM,KAAK,CAAA;AACvB,eAAe,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA0ChB,CAAA"}
|
|
@@ -0,0 +1,387 @@
|
|
|
1
|
+
import { DrawerControl } from "./control.js";
|
|
2
|
+
import { ShinyContext } from "../framework.js";
|
|
3
|
+
declare const ShinyDrawer_base: import("@e280/sly").ComponentClass<{
|
|
4
|
+
new (): {
|
|
5
|
+
#attrs: import("@e280/sly").AttrTypes<{
|
|
6
|
+
open: BooleanConstructor;
|
|
7
|
+
button: BooleanConstructor;
|
|
8
|
+
side: StringConstructor;
|
|
9
|
+
}>;
|
|
10
|
+
get button(): boolean;
|
|
11
|
+
set button(v: boolean);
|
|
12
|
+
get side(): "left" | "right";
|
|
13
|
+
set side(v: "left" | "right");
|
|
14
|
+
control: DrawerControl;
|
|
15
|
+
get isOpen(): boolean;
|
|
16
|
+
get toggle(): () => Promise<boolean>;
|
|
17
|
+
get open(): () => Promise<void>;
|
|
18
|
+
get close(): () => Promise<void>;
|
|
19
|
+
context: ShinyContext;
|
|
20
|
+
#private: any;
|
|
21
|
+
readonly shadow: ShadowRoot;
|
|
22
|
+
createShadow(): ShadowRoot;
|
|
23
|
+
render(_use: import("@e280/sly").Use): import("@e280/sly").Content;
|
|
24
|
+
updateNow: () => void;
|
|
25
|
+
update: import("@e280/stz").DebounceReturn<() => void>;
|
|
26
|
+
connectedCallback(): void;
|
|
27
|
+
disconnectedCallback(): void;
|
|
28
|
+
accessKey: string;
|
|
29
|
+
readonly accessKeyLabel: string;
|
|
30
|
+
autocapitalize: string;
|
|
31
|
+
autocorrect: boolean;
|
|
32
|
+
dir: string;
|
|
33
|
+
draggable: boolean;
|
|
34
|
+
hidden: boolean;
|
|
35
|
+
inert: boolean;
|
|
36
|
+
innerText: string;
|
|
37
|
+
lang: string;
|
|
38
|
+
readonly offsetHeight: number;
|
|
39
|
+
readonly offsetLeft: number;
|
|
40
|
+
readonly offsetParent: Element | null;
|
|
41
|
+
readonly offsetTop: number;
|
|
42
|
+
readonly offsetWidth: number;
|
|
43
|
+
outerText: string;
|
|
44
|
+
popover: string | null;
|
|
45
|
+
spellcheck: boolean;
|
|
46
|
+
title: string;
|
|
47
|
+
translate: boolean;
|
|
48
|
+
writingSuggestions: string;
|
|
49
|
+
attachInternals(): ElementInternals;
|
|
50
|
+
click(): void;
|
|
51
|
+
hidePopover(): void;
|
|
52
|
+
showPopover(): void;
|
|
53
|
+
togglePopover(options?: boolean): boolean;
|
|
54
|
+
addEventListener<K extends keyof HTMLElementEventMap>(type: K, listener: (this: HTMLElement, ev: HTMLElementEventMap[K]) => any, options?: boolean | AddEventListenerOptions): void;
|
|
55
|
+
addEventListener(type: string, listener: EventListenerOrEventListenerObject, options?: boolean | AddEventListenerOptions): void;
|
|
56
|
+
removeEventListener<K extends keyof HTMLElementEventMap>(type: K, listener: (this: HTMLElement, ev: HTMLElementEventMap[K]) => any, options?: boolean | EventListenerOptions): void;
|
|
57
|
+
removeEventListener(type: string, listener: EventListenerOrEventListenerObject, options?: boolean | EventListenerOptions): void;
|
|
58
|
+
readonly attributes: NamedNodeMap;
|
|
59
|
+
get classList(): DOMTokenList;
|
|
60
|
+
set classList(value: string);
|
|
61
|
+
className: string;
|
|
62
|
+
readonly clientHeight: number;
|
|
63
|
+
readonly clientLeft: number;
|
|
64
|
+
readonly clientTop: number;
|
|
65
|
+
readonly clientWidth: number;
|
|
66
|
+
readonly currentCSSZoom: number;
|
|
67
|
+
id: string;
|
|
68
|
+
innerHTML: string;
|
|
69
|
+
readonly localName: string;
|
|
70
|
+
readonly namespaceURI: string | null;
|
|
71
|
+
onfullscreenchange: ((this: Element, ev: Event) => any) | null;
|
|
72
|
+
onfullscreenerror: ((this: Element, ev: Event) => any) | null;
|
|
73
|
+
outerHTML: string;
|
|
74
|
+
readonly ownerDocument: Document;
|
|
75
|
+
get part(): DOMTokenList;
|
|
76
|
+
set part(value: string);
|
|
77
|
+
readonly prefix: string | null;
|
|
78
|
+
readonly scrollHeight: number;
|
|
79
|
+
scrollLeft: number;
|
|
80
|
+
scrollTop: number;
|
|
81
|
+
readonly scrollWidth: number;
|
|
82
|
+
readonly shadowRoot: ShadowRoot | null;
|
|
83
|
+
slot: string;
|
|
84
|
+
readonly tagName: string;
|
|
85
|
+
attachShadow(init: ShadowRootInit): ShadowRoot;
|
|
86
|
+
checkVisibility(options?: CheckVisibilityOptions): boolean;
|
|
87
|
+
closest<K extends keyof HTMLElementTagNameMap>(selector: K): HTMLElementTagNameMap[K] | null;
|
|
88
|
+
closest<K extends keyof SVGElementTagNameMap>(selector: K): SVGElementTagNameMap[K] | null;
|
|
89
|
+
closest<K extends keyof MathMLElementTagNameMap>(selector: K): MathMLElementTagNameMap[K] | null;
|
|
90
|
+
closest<E extends Element = Element>(selectors: string): E | null;
|
|
91
|
+
computedStyleMap(): StylePropertyMapReadOnly;
|
|
92
|
+
getAttribute(qualifiedName: string): string | null;
|
|
93
|
+
getAttributeNS(namespace: string | null, localName: string): string | null;
|
|
94
|
+
getAttributeNames(): string[];
|
|
95
|
+
getAttributeNode(qualifiedName: string): Attr | null;
|
|
96
|
+
getAttributeNodeNS(namespace: string | null, localName: string): Attr | null;
|
|
97
|
+
getBoundingClientRect(): DOMRect;
|
|
98
|
+
getClientRects(): DOMRectList;
|
|
99
|
+
getElementsByClassName(classNames: string): HTMLCollectionOf<Element>;
|
|
100
|
+
getElementsByTagName<K extends keyof HTMLElementTagNameMap>(qualifiedName: K): HTMLCollectionOf<HTMLElementTagNameMap[K]>;
|
|
101
|
+
getElementsByTagName<K extends keyof SVGElementTagNameMap>(qualifiedName: K): HTMLCollectionOf<SVGElementTagNameMap[K]>;
|
|
102
|
+
getElementsByTagName<K extends keyof MathMLElementTagNameMap>(qualifiedName: K): HTMLCollectionOf<MathMLElementTagNameMap[K]>;
|
|
103
|
+
getElementsByTagName<K extends keyof HTMLElementDeprecatedTagNameMap>(qualifiedName: K): HTMLCollectionOf<HTMLElementDeprecatedTagNameMap[K]>;
|
|
104
|
+
getElementsByTagName(qualifiedName: string): HTMLCollectionOf<Element>;
|
|
105
|
+
getElementsByTagNameNS(namespaceURI: "http://www.w3.org/1999/xhtml", localName: string): HTMLCollectionOf<HTMLElement>;
|
|
106
|
+
getElementsByTagNameNS(namespaceURI: "http://www.w3.org/2000/svg", localName: string): HTMLCollectionOf<SVGElement>;
|
|
107
|
+
getElementsByTagNameNS(namespaceURI: "http://www.w3.org/1998/Math/MathML", localName: string): HTMLCollectionOf<MathMLElement>;
|
|
108
|
+
getElementsByTagNameNS(namespace: string | null, localName: string): HTMLCollectionOf<Element>;
|
|
109
|
+
getHTML(options?: GetHTMLOptions): string;
|
|
110
|
+
hasAttribute(qualifiedName: string): boolean;
|
|
111
|
+
hasAttributeNS(namespace: string | null, localName: string): boolean;
|
|
112
|
+
hasAttributes(): boolean;
|
|
113
|
+
hasPointerCapture(pointerId: number): boolean;
|
|
114
|
+
insertAdjacentElement(where: InsertPosition, element: Element): Element | null;
|
|
115
|
+
insertAdjacentHTML(position: InsertPosition, string: string): void;
|
|
116
|
+
insertAdjacentText(where: InsertPosition, data: string): void;
|
|
117
|
+
matches(selectors: string): boolean;
|
|
118
|
+
releasePointerCapture(pointerId: number): void;
|
|
119
|
+
removeAttribute(qualifiedName: string): void;
|
|
120
|
+
removeAttributeNS(namespace: string | null, localName: string): void;
|
|
121
|
+
removeAttributeNode(attr: Attr): Attr;
|
|
122
|
+
requestFullscreen(options?: FullscreenOptions): Promise<void>;
|
|
123
|
+
requestPointerLock(options?: PointerLockOptions): Promise<void>;
|
|
124
|
+
scroll(options?: ScrollToOptions): void;
|
|
125
|
+
scroll(x: number, y: number): void;
|
|
126
|
+
scrollBy(options?: ScrollToOptions): void;
|
|
127
|
+
scrollBy(x: number, y: number): void;
|
|
128
|
+
scrollIntoView(arg?: boolean | ScrollIntoViewOptions): void;
|
|
129
|
+
scrollTo(options?: ScrollToOptions): void;
|
|
130
|
+
scrollTo(x: number, y: number): void;
|
|
131
|
+
setAttribute(qualifiedName: string, value: string): void;
|
|
132
|
+
setAttributeNS(namespace: string | null, qualifiedName: string, value: string): void;
|
|
133
|
+
setAttributeNode(attr: Attr): Attr | null;
|
|
134
|
+
setAttributeNodeNS(attr: Attr): Attr | null;
|
|
135
|
+
setHTMLUnsafe(html: string): void;
|
|
136
|
+
setPointerCapture(pointerId: number): void;
|
|
137
|
+
toggleAttribute(qualifiedName: string, force?: boolean): boolean;
|
|
138
|
+
webkitMatchesSelector(selectors: string): boolean;
|
|
139
|
+
get textContent(): string;
|
|
140
|
+
set textContent(value: string | null);
|
|
141
|
+
readonly baseURI: string;
|
|
142
|
+
readonly childNodes: NodeListOf<ChildNode>;
|
|
143
|
+
readonly firstChild: ChildNode | null;
|
|
144
|
+
readonly isConnected: boolean;
|
|
145
|
+
readonly lastChild: ChildNode | null;
|
|
146
|
+
readonly nextSibling: ChildNode | null;
|
|
147
|
+
readonly nodeName: string;
|
|
148
|
+
readonly nodeType: number;
|
|
149
|
+
nodeValue: string | null;
|
|
150
|
+
readonly parentElement: HTMLElement | null;
|
|
151
|
+
readonly parentNode: ParentNode | null;
|
|
152
|
+
readonly previousSibling: ChildNode | null;
|
|
153
|
+
appendChild<T extends Node>(node: T): T;
|
|
154
|
+
cloneNode(subtree?: boolean): Node;
|
|
155
|
+
compareDocumentPosition(other: Node): number;
|
|
156
|
+
contains(other: Node | null): boolean;
|
|
157
|
+
getRootNode(options?: GetRootNodeOptions): Node;
|
|
158
|
+
hasChildNodes(): boolean;
|
|
159
|
+
insertBefore<T extends Node>(node: T, child: Node | null): T;
|
|
160
|
+
isDefaultNamespace(namespace: string | null): boolean;
|
|
161
|
+
isEqualNode(otherNode: Node | null): boolean;
|
|
162
|
+
isSameNode(otherNode: Node | null): boolean;
|
|
163
|
+
lookupNamespaceURI(prefix: string | null): string | null;
|
|
164
|
+
lookupPrefix(namespace: string | null): string | null;
|
|
165
|
+
normalize(): void;
|
|
166
|
+
removeChild<T extends Node>(child: T): T;
|
|
167
|
+
replaceChild<T extends Node>(node: Node, child: T): T;
|
|
168
|
+
readonly ELEMENT_NODE: 1;
|
|
169
|
+
readonly ATTRIBUTE_NODE: 2;
|
|
170
|
+
readonly TEXT_NODE: 3;
|
|
171
|
+
readonly CDATA_SECTION_NODE: 4;
|
|
172
|
+
readonly ENTITY_REFERENCE_NODE: 5;
|
|
173
|
+
readonly ENTITY_NODE: 6;
|
|
174
|
+
readonly PROCESSING_INSTRUCTION_NODE: 7;
|
|
175
|
+
readonly COMMENT_NODE: 8;
|
|
176
|
+
readonly DOCUMENT_NODE: 9;
|
|
177
|
+
readonly DOCUMENT_TYPE_NODE: 10;
|
|
178
|
+
readonly DOCUMENT_FRAGMENT_NODE: 11;
|
|
179
|
+
readonly NOTATION_NODE: 12;
|
|
180
|
+
readonly DOCUMENT_POSITION_DISCONNECTED: 1;
|
|
181
|
+
readonly DOCUMENT_POSITION_PRECEDING: 2;
|
|
182
|
+
readonly DOCUMENT_POSITION_FOLLOWING: 4;
|
|
183
|
+
readonly DOCUMENT_POSITION_CONTAINS: 8;
|
|
184
|
+
readonly DOCUMENT_POSITION_CONTAINED_BY: 16;
|
|
185
|
+
readonly DOCUMENT_POSITION_IMPLEMENTATION_SPECIFIC: 32;
|
|
186
|
+
dispatchEvent(event: Event): boolean;
|
|
187
|
+
ariaActiveDescendantElement: Element | null;
|
|
188
|
+
ariaAtomic: string | null;
|
|
189
|
+
ariaAutoComplete: string | null;
|
|
190
|
+
ariaBrailleLabel: string | null;
|
|
191
|
+
ariaBrailleRoleDescription: string | null;
|
|
192
|
+
ariaBusy: string | null;
|
|
193
|
+
ariaChecked: string | null;
|
|
194
|
+
ariaColCount: string | null;
|
|
195
|
+
ariaColIndex: string | null;
|
|
196
|
+
ariaColIndexText: string | null;
|
|
197
|
+
ariaColSpan: string | null;
|
|
198
|
+
ariaControlsElements: ReadonlyArray<Element> | null;
|
|
199
|
+
ariaCurrent: string | null;
|
|
200
|
+
ariaDescribedByElements: ReadonlyArray<Element> | null;
|
|
201
|
+
ariaDescription: string | null;
|
|
202
|
+
ariaDetailsElements: ReadonlyArray<Element> | null;
|
|
203
|
+
ariaDisabled: string | null;
|
|
204
|
+
ariaErrorMessageElements: ReadonlyArray<Element> | null;
|
|
205
|
+
ariaExpanded: string | null;
|
|
206
|
+
ariaFlowToElements: ReadonlyArray<Element> | null;
|
|
207
|
+
ariaHasPopup: string | null;
|
|
208
|
+
ariaHidden: string | null;
|
|
209
|
+
ariaInvalid: string | null;
|
|
210
|
+
ariaKeyShortcuts: string | null;
|
|
211
|
+
ariaLabel: string | null;
|
|
212
|
+
ariaLabelledByElements: ReadonlyArray<Element> | null;
|
|
213
|
+
ariaLevel: string | null;
|
|
214
|
+
ariaLive: string | null;
|
|
215
|
+
ariaModal: string | null;
|
|
216
|
+
ariaMultiLine: string | null;
|
|
217
|
+
ariaMultiSelectable: string | null;
|
|
218
|
+
ariaOrientation: string | null;
|
|
219
|
+
ariaOwnsElements: ReadonlyArray<Element> | null;
|
|
220
|
+
ariaPlaceholder: string | null;
|
|
221
|
+
ariaPosInSet: string | null;
|
|
222
|
+
ariaPressed: string | null;
|
|
223
|
+
ariaReadOnly: string | null;
|
|
224
|
+
ariaRelevant: string | null;
|
|
225
|
+
ariaRequired: string | null;
|
|
226
|
+
ariaRoleDescription: string | null;
|
|
227
|
+
ariaRowCount: string | null;
|
|
228
|
+
ariaRowIndex: string | null;
|
|
229
|
+
ariaRowIndexText: string | null;
|
|
230
|
+
ariaRowSpan: string | null;
|
|
231
|
+
ariaSelected: string | null;
|
|
232
|
+
ariaSetSize: string | null;
|
|
233
|
+
ariaSort: string | null;
|
|
234
|
+
ariaValueMax: string | null;
|
|
235
|
+
ariaValueMin: string | null;
|
|
236
|
+
ariaValueNow: string | null;
|
|
237
|
+
ariaValueText: string | null;
|
|
238
|
+
role: string | null;
|
|
239
|
+
animate(keyframes: Keyframe[] | PropertyIndexedKeyframes | null, options?: number | KeyframeAnimationOptions): Animation;
|
|
240
|
+
getAnimations(options?: GetAnimationsOptions): Animation[];
|
|
241
|
+
after(...nodes: (Node | string)[]): void;
|
|
242
|
+
before(...nodes: (Node | string)[]): void;
|
|
243
|
+
remove(): void;
|
|
244
|
+
replaceWith(...nodes: (Node | string)[]): void;
|
|
245
|
+
readonly nextElementSibling: Element | null;
|
|
246
|
+
readonly previousElementSibling: Element | null;
|
|
247
|
+
readonly childElementCount: number;
|
|
248
|
+
readonly children: HTMLCollection;
|
|
249
|
+
readonly firstElementChild: Element | null;
|
|
250
|
+
readonly lastElementChild: Element | null;
|
|
251
|
+
append(...nodes: (Node | string)[]): void;
|
|
252
|
+
prepend(...nodes: (Node | string)[]): void;
|
|
253
|
+
querySelector<K extends keyof HTMLElementTagNameMap>(selectors: K): HTMLElementTagNameMap[K] | null;
|
|
254
|
+
querySelector<K extends keyof SVGElementTagNameMap>(selectors: K): SVGElementTagNameMap[K] | null;
|
|
255
|
+
querySelector<K extends keyof MathMLElementTagNameMap>(selectors: K): MathMLElementTagNameMap[K] | null;
|
|
256
|
+
querySelector<K extends keyof HTMLElementDeprecatedTagNameMap>(selectors: K): HTMLElementDeprecatedTagNameMap[K] | null;
|
|
257
|
+
querySelector<E extends Element = Element>(selectors: string): E | null;
|
|
258
|
+
querySelectorAll<K extends keyof HTMLElementTagNameMap>(selectors: K): NodeListOf<HTMLElementTagNameMap[K]>;
|
|
259
|
+
querySelectorAll<K extends keyof SVGElementTagNameMap>(selectors: K): NodeListOf<SVGElementTagNameMap[K]>;
|
|
260
|
+
querySelectorAll<K extends keyof MathMLElementTagNameMap>(selectors: K): NodeListOf<MathMLElementTagNameMap[K]>;
|
|
261
|
+
querySelectorAll<K extends keyof HTMLElementDeprecatedTagNameMap>(selectors: K): NodeListOf<HTMLElementDeprecatedTagNameMap[K]>;
|
|
262
|
+
querySelectorAll<E extends Element = Element>(selectors: string): NodeListOf<E>;
|
|
263
|
+
replaceChildren(...nodes: (Node | string)[]): void;
|
|
264
|
+
readonly assignedSlot: HTMLSlotElement | null;
|
|
265
|
+
readonly attributeStyleMap: StylePropertyMap;
|
|
266
|
+
get style(): CSSStyleDeclaration;
|
|
267
|
+
set style(cssText: string);
|
|
268
|
+
contentEditable: string;
|
|
269
|
+
enterKeyHint: string;
|
|
270
|
+
inputMode: string;
|
|
271
|
+
readonly isContentEditable: boolean;
|
|
272
|
+
onabort: ((this: GlobalEventHandlers, ev: UIEvent) => any) | null;
|
|
273
|
+
onanimationcancel: ((this: GlobalEventHandlers, ev: AnimationEvent) => any) | null;
|
|
274
|
+
onanimationend: ((this: GlobalEventHandlers, ev: AnimationEvent) => any) | null;
|
|
275
|
+
onanimationiteration: ((this: GlobalEventHandlers, ev: AnimationEvent) => any) | null;
|
|
276
|
+
onanimationstart: ((this: GlobalEventHandlers, ev: AnimationEvent) => any) | null;
|
|
277
|
+
onauxclick: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
|
|
278
|
+
onbeforeinput: ((this: GlobalEventHandlers, ev: InputEvent) => any) | null;
|
|
279
|
+
onbeforematch: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
280
|
+
onbeforetoggle: ((this: GlobalEventHandlers, ev: ToggleEvent) => any) | null;
|
|
281
|
+
onblur: ((this: GlobalEventHandlers, ev: FocusEvent) => any) | null;
|
|
282
|
+
oncancel: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
283
|
+
oncanplay: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
284
|
+
oncanplaythrough: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
285
|
+
onchange: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
286
|
+
onclick: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
|
|
287
|
+
onclose: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
288
|
+
oncontextlost: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
289
|
+
oncontextmenu: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
|
|
290
|
+
oncontextrestored: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
291
|
+
oncopy: ((this: GlobalEventHandlers, ev: ClipboardEvent) => any) | null;
|
|
292
|
+
oncuechange: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
293
|
+
oncut: ((this: GlobalEventHandlers, ev: ClipboardEvent) => any) | null;
|
|
294
|
+
ondblclick: ((this: GlobalEventHandlers, ev: MouseEvent) => any) | null;
|
|
295
|
+
ondrag: ((this: GlobalEventHandlers, ev: DragEvent) => any) | null;
|
|
296
|
+
ondragend: ((this: GlobalEventHandlers, ev: DragEvent) => any) | null;
|
|
297
|
+
ondragenter: ((this: GlobalEventHandlers, ev: DragEvent) => any) | null;
|
|
298
|
+
ondragleave: ((this: GlobalEventHandlers, ev: DragEvent) => any) | null;
|
|
299
|
+
ondragover: ((this: GlobalEventHandlers, ev: DragEvent) => any) | null;
|
|
300
|
+
ondragstart: ((this: GlobalEventHandlers, ev: DragEvent) => any) | null;
|
|
301
|
+
ondrop: ((this: GlobalEventHandlers, ev: DragEvent) => any) | null;
|
|
302
|
+
ondurationchange: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
303
|
+
onemptied: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
304
|
+
onended: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
305
|
+
onerror: OnErrorEventHandler;
|
|
306
|
+
onfocus: ((this: GlobalEventHandlers, ev: FocusEvent) => any) | null;
|
|
307
|
+
onformdata: ((this: GlobalEventHandlers, ev: FormDataEvent) => any) | null;
|
|
308
|
+
ongotpointercapture: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
|
|
309
|
+
oninput: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
310
|
+
oninvalid: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
311
|
+
onkeydown: ((this: GlobalEventHandlers, ev: KeyboardEvent) => any) | null;
|
|
312
|
+
onkeypress: ((this: GlobalEventHandlers, ev: KeyboardEvent) => any) | null;
|
|
313
|
+
onkeyup: ((this: GlobalEventHandlers, ev: KeyboardEvent) => any) | null;
|
|
314
|
+
onload: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
315
|
+
onloadeddata: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
316
|
+
onloadedmetadata: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
317
|
+
onloadstart: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
318
|
+
onlostpointercapture: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
|
|
319
|
+
onmousedown: ((this: GlobalEventHandlers, ev: MouseEvent) => any) | null;
|
|
320
|
+
onmouseenter: ((this: GlobalEventHandlers, ev: MouseEvent) => any) | null;
|
|
321
|
+
onmouseleave: ((this: GlobalEventHandlers, ev: MouseEvent) => any) | null;
|
|
322
|
+
onmousemove: ((this: GlobalEventHandlers, ev: MouseEvent) => any) | null;
|
|
323
|
+
onmouseout: ((this: GlobalEventHandlers, ev: MouseEvent) => any) | null;
|
|
324
|
+
onmouseover: ((this: GlobalEventHandlers, ev: MouseEvent) => any) | null;
|
|
325
|
+
onmouseup: ((this: GlobalEventHandlers, ev: MouseEvent) => any) | null;
|
|
326
|
+
onpaste: ((this: GlobalEventHandlers, ev: ClipboardEvent) => any) | null;
|
|
327
|
+
onpause: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
328
|
+
onplay: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
329
|
+
onplaying: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
330
|
+
onpointercancel: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
|
|
331
|
+
onpointerdown: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
|
|
332
|
+
onpointerenter: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
|
|
333
|
+
onpointerleave: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
|
|
334
|
+
onpointermove: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
|
|
335
|
+
onpointerout: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
|
|
336
|
+
onpointerover: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
|
|
337
|
+
onpointerrawupdate: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
338
|
+
onpointerup: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
|
|
339
|
+
onprogress: ((this: GlobalEventHandlers, ev: ProgressEvent) => any) | null;
|
|
340
|
+
onratechange: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
341
|
+
onreset: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
342
|
+
onresize: ((this: GlobalEventHandlers, ev: UIEvent) => any) | null;
|
|
343
|
+
onscroll: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
344
|
+
onscrollend: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
345
|
+
onsecuritypolicyviolation: ((this: GlobalEventHandlers, ev: SecurityPolicyViolationEvent) => any) | null;
|
|
346
|
+
onseeked: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
347
|
+
onseeking: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
348
|
+
onselect: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
349
|
+
onselectionchange: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
350
|
+
onselectstart: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
351
|
+
onslotchange: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
352
|
+
onstalled: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
353
|
+
onsubmit: ((this: GlobalEventHandlers, ev: SubmitEvent) => any) | null;
|
|
354
|
+
onsuspend: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
355
|
+
ontimeupdate: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
356
|
+
ontoggle: ((this: GlobalEventHandlers, ev: ToggleEvent) => any) | null;
|
|
357
|
+
ontouchcancel?: ((this: GlobalEventHandlers, ev: TouchEvent) => any) | null | undefined;
|
|
358
|
+
ontouchend?: ((this: GlobalEventHandlers, ev: TouchEvent) => any) | null | undefined;
|
|
359
|
+
ontouchmove?: ((this: GlobalEventHandlers, ev: TouchEvent) => any) | null | undefined;
|
|
360
|
+
ontouchstart?: ((this: GlobalEventHandlers, ev: TouchEvent) => any) | null | undefined;
|
|
361
|
+
ontransitioncancel: ((this: GlobalEventHandlers, ev: TransitionEvent) => any) | null;
|
|
362
|
+
ontransitionend: ((this: GlobalEventHandlers, ev: TransitionEvent) => any) | null;
|
|
363
|
+
ontransitionrun: ((this: GlobalEventHandlers, ev: TransitionEvent) => any) | null;
|
|
364
|
+
ontransitionstart: ((this: GlobalEventHandlers, ev: TransitionEvent) => any) | null;
|
|
365
|
+
onvolumechange: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
366
|
+
onwaiting: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
367
|
+
onwebkitanimationend: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
368
|
+
onwebkitanimationiteration: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
369
|
+
onwebkitanimationstart: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
370
|
+
onwebkittransitionend: ((this: GlobalEventHandlers, ev: Event) => any) | null;
|
|
371
|
+
onwheel: ((this: GlobalEventHandlers, ev: WheelEvent) => any) | null;
|
|
372
|
+
autofocus: boolean;
|
|
373
|
+
readonly dataset: DOMStringMap;
|
|
374
|
+
nonce?: string;
|
|
375
|
+
tabIndex: number;
|
|
376
|
+
blur(): void;
|
|
377
|
+
focus(options?: FocusOptions): void;
|
|
378
|
+
};
|
|
379
|
+
styles: import("lit").CSSResultGroup | undefined;
|
|
380
|
+
}, [context: ShinyContext, options: {
|
|
381
|
+
button: boolean;
|
|
382
|
+
side?: "left" | "right";
|
|
383
|
+
control?: DrawerControl;
|
|
384
|
+
}]>;
|
|
385
|
+
export declare class ShinyDrawer extends ShinyDrawer_base {
|
|
386
|
+
}
|
|
387
|
+
export {};
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { html } from "lit";
|
|
2
|
+
import { dom, view } from "@e280/sly";
|
|
3
|
+
import styleCss from "./style.css.js";
|
|
4
|
+
import { DrawerControl } from "./control.js";
|
|
5
|
+
import { States } from "../../utils/states.js";
|
|
6
|
+
import xSvg from "../../icons/tabler/x.svg.js";
|
|
7
|
+
import { foundationCss } from "../foundation.css.js";
|
|
8
|
+
import menu2Svg from "../../icons/tabler/menu-2.svg.js";
|
|
9
|
+
import { ShinyElement } from "../framework.js";
|
|
10
|
+
export class ShinyDrawer extends (view(use => (context, options) => {
|
|
11
|
+
use.name("shiny-drawer");
|
|
12
|
+
use.styles(foundationCss, context.theme, styleCss);
|
|
13
|
+
const states = use.once(() => new States(use.element));
|
|
14
|
+
const side = options.side ?? "left";
|
|
15
|
+
const drawer = use.once(() => (options.control ?? new DrawerControl()));
|
|
16
|
+
states.assign(side);
|
|
17
|
+
use.mount(() => dom.events(window, { keydown: (event) => {
|
|
18
|
+
if (event.code === "Escape")
|
|
19
|
+
drawer.close();
|
|
20
|
+
} }));
|
|
21
|
+
dom.attrs(use.element).booleans.open = drawer.isOpen;
|
|
22
|
+
return html `
|
|
23
|
+
<div class=shell ?data-open="${drawer.isOpen}" data-side="${side}">
|
|
24
|
+
<slot name=plate ?inert="${drawer.isOpen}"></slot>
|
|
25
|
+
|
|
26
|
+
<div class=clipper>
|
|
27
|
+
<div part=blanket @click="${drawer.close}" ?inert="${!drawer.isOpen}"></div>
|
|
28
|
+
|
|
29
|
+
<div part=tray>
|
|
30
|
+
<slot ?inert="${!drawer.isOpen}"></slot>
|
|
31
|
+
|
|
32
|
+
${options.button
|
|
33
|
+
? html `
|
|
34
|
+
<button @click="${drawer.toggle}">
|
|
35
|
+
${drawer.isOpen
|
|
36
|
+
? html `
|
|
37
|
+
<slot name=button-x>
|
|
38
|
+
${xSvg}
|
|
39
|
+
</slot>
|
|
40
|
+
`
|
|
41
|
+
: html `
|
|
42
|
+
<slot name=button>
|
|
43
|
+
${menu2Svg}
|
|
44
|
+
</slot>
|
|
45
|
+
`}
|
|
46
|
+
</button>
|
|
47
|
+
`
|
|
48
|
+
: null}
|
|
49
|
+
</div>
|
|
50
|
+
</div>
|
|
51
|
+
</div>
|
|
52
|
+
`;
|
|
53
|
+
})
|
|
54
|
+
.component(class extends ShinyElement {
|
|
55
|
+
#attrs = dom.attrs(this).spec({
|
|
56
|
+
open: Boolean,
|
|
57
|
+
button: Boolean,
|
|
58
|
+
side: String,
|
|
59
|
+
});
|
|
60
|
+
get button() { return this.#attrs.button; }
|
|
61
|
+
set button(v) { this.#attrs.button = v; }
|
|
62
|
+
get side() { return this.#attrs.side === "right" ? "right" : "left"; }
|
|
63
|
+
set side(v) { this.#attrs.side = v; }
|
|
64
|
+
control = new DrawerControl(this.#attrs.open);
|
|
65
|
+
get isOpen() { return this.control.isOpen; }
|
|
66
|
+
get toggle() { return this.control.toggle; }
|
|
67
|
+
get open() { return this.control.open; }
|
|
68
|
+
get close() { return this.control.close; }
|
|
69
|
+
})
|
|
70
|
+
.props(el => [el.context, {
|
|
71
|
+
control: el.control,
|
|
72
|
+
button: el.button,
|
|
73
|
+
side: el.side,
|
|
74
|
+
}])) {
|
|
75
|
+
}
|
|
76
|
+
//# sourceMappingURL=component.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../s/components/drawer/component.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export declare class DrawerControl {
|
|
2
|
+
$open: import("@e280/strata").SignalFn<boolean>;
|
|
3
|
+
constructor(startOpen?: boolean);
|
|
4
|
+
get isOpen(): boolean;
|
|
5
|
+
setOpen(value: boolean): Promise<boolean>;
|
|
6
|
+
open: () => Promise<void>;
|
|
7
|
+
close: () => Promise<void>;
|
|
8
|
+
toggle: () => Promise<boolean>;
|
|
9
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { signal } from "@e280/strata";
|
|
2
|
+
export class DrawerControl {
|
|
3
|
+
$open = signal(false);
|
|
4
|
+
constructor(startOpen = false) {
|
|
5
|
+
if (startOpen)
|
|
6
|
+
this.$open.set(true);
|
|
7
|
+
}
|
|
8
|
+
get isOpen() {
|
|
9
|
+
return this.$open.get();
|
|
10
|
+
}
|
|
11
|
+
async setOpen(value) {
|
|
12
|
+
return this.$open.set(value);
|
|
13
|
+
}
|
|
14
|
+
open = async () => {
|
|
15
|
+
await this.setOpen(true);
|
|
16
|
+
};
|
|
17
|
+
close = async () => {
|
|
18
|
+
await this.setOpen(false);
|
|
19
|
+
};
|
|
20
|
+
toggle = async () => {
|
|
21
|
+
return this.setOpen(!this.isOpen);
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=control.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"control.js","sourceRoot":"","sources":["../../../s/components/drawer/control.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,MAAM,EAAC,MAAM,cAAc,CAAA;AAEnC,MAAM,OAAO,aAAa;IACzB,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,CAAA;IAErB,YAAY,SAAS,GAAG,KAAK;QAC5B,IAAI,SAAS;YAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;IACpC,CAAC;IAED,IAAI,MAAM;QACT,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,CAAA;IACxB,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,KAAc;QAC3B,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,CAAA;IAC7B,CAAC;IAED,IAAI,GAAG,KAAK,IAAG,EAAE;QAChB,MAAM,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;IACzB,CAAC,CAAA;IAED,KAAK,GAAG,KAAK,IAAG,EAAE;QACjB,MAAM,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;IAC1B,CAAC,CAAA;IAED,MAAM,GAAG,KAAK,IAAG,EAAE;QAClB,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;IAClC,CAAC,CAAA;CACD"}
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
import { css } from "lit";
|
|
2
|
+
export default css `@layer view {
|
|
3
|
+
|
|
4
|
+
:host {
|
|
5
|
+
display: block;
|
|
6
|
+
width: 100%;
|
|
7
|
+
height: 100%;
|
|
8
|
+
--button-size: 2em;
|
|
9
|
+
--anim-duration: 200ms;
|
|
10
|
+
--blanket-backdrop-filter: blur(0.5em);
|
|
11
|
+
--blanket-bg: color-mix(in oklab, transparent, var(--bg));
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
.shell {
|
|
15
|
+
position: relative;
|
|
16
|
+
width: 100%;
|
|
17
|
+
height: 100%;
|
|
18
|
+
|
|
19
|
+
[part="blanket"] {
|
|
20
|
+
opacity: 0;
|
|
21
|
+
|
|
22
|
+
content: "";
|
|
23
|
+
display: block;
|
|
24
|
+
position: absolute;
|
|
25
|
+
inset: 0;
|
|
26
|
+
|
|
27
|
+
background: var(--blanket-bg);
|
|
28
|
+
backdrop-filter: var(--blanket-backdrop-filter);
|
|
29
|
+
|
|
30
|
+
will-change: opacity;
|
|
31
|
+
transition: all var(--anim-duration) ease;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
.clipper {
|
|
35
|
+
pointer-events: none;
|
|
36
|
+
position: absolute;
|
|
37
|
+
inset: 0;
|
|
38
|
+
width: 100%;
|
|
39
|
+
height: 100%;
|
|
40
|
+
overflow: hidden;
|
|
41
|
+
> * { pointer-events: all; }
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
[part="tray"] {
|
|
45
|
+
position: absolute;
|
|
46
|
+
top: 0;
|
|
47
|
+
width: calc(100% - var(--button-size));
|
|
48
|
+
|
|
49
|
+
display: flex;
|
|
50
|
+
flex-direction: column;
|
|
51
|
+
height: auto;
|
|
52
|
+
max-height: 100%;
|
|
53
|
+
|
|
54
|
+
opacity: 1;
|
|
55
|
+
transform: translateX(-100%);
|
|
56
|
+
will-change: opacity, transform;
|
|
57
|
+
transition: all var(--anim-duration) ease;
|
|
58
|
+
|
|
59
|
+
> slot {
|
|
60
|
+
display: block;
|
|
61
|
+
height: 100%;
|
|
62
|
+
overflow-y: auto;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
> button {
|
|
66
|
+
position: absolute;
|
|
67
|
+
top: 0;
|
|
68
|
+
left: 100%;
|
|
69
|
+
|
|
70
|
+
opacity: var(--inactive-opacity);
|
|
71
|
+
background: transparent;
|
|
72
|
+
border: none;
|
|
73
|
+
cursor: pointer;
|
|
74
|
+
|
|
75
|
+
&:is(:hover, :focus-visible) {
|
|
76
|
+
opacity: 1;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
> slot {
|
|
80
|
+
display: contents;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
svg {
|
|
84
|
+
width: var(--button-size);
|
|
85
|
+
height: var(--button-size);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
&[data-side="right"] {
|
|
91
|
+
[part="tray"] {
|
|
92
|
+
right: 0;
|
|
93
|
+
transform: translateX(100%);
|
|
94
|
+
> button {
|
|
95
|
+
left: unset;
|
|
96
|
+
right: 100%;
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
slot[name="plate"] {
|
|
102
|
+
display: block;
|
|
103
|
+
width: 100%;
|
|
104
|
+
height: 100%;
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
&[data-open] {
|
|
108
|
+
[part="blanket"] {
|
|
109
|
+
opacity: 1;
|
|
110
|
+
}
|
|
111
|
+
[part="tray"] {
|
|
112
|
+
opacity: 1;
|
|
113
|
+
transform: translateX(0%);
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
}`;
|
|
119
|
+
//# sourceMappingURL=style.css.js.map
|