@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.
Files changed (154) hide show
  1. package/README.md +110 -3
  2. package/package.json +3 -3
  3. package/s/{ui → components}/copy/component.ts +11 -6
  4. package/s/{ui → components}/copy/style.css.ts +6 -6
  5. package/s/components/drawer/component.ts +92 -0
  6. package/s/components/drawer/control.ts +31 -0
  7. package/s/components/drawer/style.css.ts +120 -0
  8. package/s/{ui → components}/example/component.ts +7 -5
  9. package/s/{ui → components}/example/style.css.ts +2 -2
  10. package/s/components/foundation.css.ts +15 -0
  11. package/s/components/framework.ts +10 -0
  12. package/s/components/raw-components.ts +13 -0
  13. package/s/components/tabs/component.ts +59 -0
  14. package/s/components/tabs/control.ts +31 -0
  15. package/s/components/tabs/style.css.ts +6 -0
  16. package/s/demo/aura-views.ts +6 -0
  17. package/s/demo/demo.bundle.ts +204 -14
  18. package/s/demo/demo.css +3 -1
  19. package/s/demo/utils/lipsum.ts +19 -0
  20. package/s/demo/views/demonstration/style.css.ts +10 -2
  21. package/s/demo/views/demonstration/view.ts +18 -14
  22. package/s/icons/tabler/menu-2.svg.ts +4 -0
  23. package/s/icons/tabler/x.svg.ts +4 -0
  24. package/s/index.html.ts +2 -2
  25. package/s/index.ts +16 -4
  26. package/s/install/aura.bundle.ts +9 -0
  27. package/s/install/plain.bundle.ts +9 -0
  28. package/s/shiny.ts +15 -0
  29. package/s/themes/aura.css.ts +48 -0
  30. package/s/themes/index.barrel.ts +2 -1
  31. package/s/themes/index.ts +1 -0
  32. package/s/themes/infra/css-vars.ts +33 -0
  33. package/s/themes/plain.css.ts +12 -0
  34. package/s/utils/states.ts +15 -0
  35. package/x/{ui → components}/copy/component.d.ts +8 -4
  36. package/x/{ui → components}/copy/component.js +10 -5
  37. package/x/components/copy/component.js.map +1 -0
  38. package/x/{ui → components}/copy/style.css.js +6 -6
  39. package/x/components/copy/style.css.js.map +1 -0
  40. package/x/components/drawer/component.d.ts +387 -0
  41. package/x/components/drawer/component.js +76 -0
  42. package/x/components/drawer/component.js.map +1 -0
  43. package/x/components/drawer/control.d.ts +9 -0
  44. package/x/components/drawer/control.js +24 -0
  45. package/x/components/drawer/control.js.map +1 -0
  46. package/x/components/drawer/style.css.js +119 -0
  47. package/x/components/drawer/style.css.js.map +1 -0
  48. package/x/{ui → components}/example/component.d.ts +3 -3
  49. package/x/{ui → components}/example/component.js +6 -4
  50. package/x/components/example/component.js.map +1 -0
  51. package/x/components/example/style.css.d.ts +2 -0
  52. package/x/components/example/style.css.js +10 -0
  53. package/x/components/example/style.css.js.map +1 -0
  54. package/x/components/foundation.css.d.ts +1 -0
  55. package/x/components/foundation.css.js +14 -0
  56. package/x/components/foundation.css.js.map +1 -0
  57. package/x/components/framework.d.ts +8 -0
  58. package/x/components/framework.js +5 -0
  59. package/x/components/framework.js.map +1 -0
  60. package/x/components/raw-components.d.ts +10 -0
  61. package/x/components/raw-components.js +11 -0
  62. package/x/components/raw-components.js.map +1 -0
  63. package/x/components/tabs/component.d.ts +374 -0
  64. package/x/components/tabs/component.js +49 -0
  65. package/x/components/tabs/component.js.map +1 -0
  66. package/x/components/tabs/control.d.ts +9 -0
  67. package/x/components/tabs/control.js +24 -0
  68. package/x/components/tabs/control.js.map +1 -0
  69. package/x/components/tabs/style.css.d.ts +2 -0
  70. package/x/components/tabs/style.css.js +5 -0
  71. package/x/components/tabs/style.css.js.map +1 -0
  72. package/x/demo/aura-views.d.ts +14 -0
  73. package/x/demo/aura-views.js +4 -0
  74. package/x/demo/aura-views.js.map +1 -0
  75. package/x/demo/demo.bundle.js +198 -14
  76. package/x/demo/demo.bundle.js.map +1 -1
  77. package/x/demo/demo.bundle.min.js +383 -48
  78. package/x/demo/demo.bundle.min.js.map +4 -4
  79. package/x/demo/demo.css +3 -1
  80. package/x/demo/utils/lipsum.d.ts +2 -0
  81. package/x/demo/utils/lipsum.js +11 -0
  82. package/x/demo/utils/lipsum.js.map +1 -0
  83. package/x/demo/views/demonstration/style.css.js +10 -2
  84. package/x/demo/views/demonstration/style.css.js.map +1 -1
  85. package/x/demo/views/demonstration/view.d.ts +6 -4
  86. package/x/demo/views/demonstration/view.js +16 -10
  87. package/x/demo/views/demonstration/view.js.map +1 -1
  88. package/x/icons/tabler/menu-2.svg.d.ts +2 -0
  89. package/x/icons/tabler/menu-2.svg.js +3 -0
  90. package/x/icons/tabler/menu-2.svg.js.map +1 -0
  91. package/x/icons/tabler/x.svg.d.ts +2 -0
  92. package/x/icons/tabler/x.svg.js +3 -0
  93. package/x/icons/tabler/x.svg.js.map +1 -0
  94. package/x/index.d.ts +10 -4
  95. package/x/index.html +7 -5
  96. package/x/index.html.js +2 -2
  97. package/x/index.js +10 -4
  98. package/x/index.js.map +1 -1
  99. package/x/install/aura.bundle.d.ts +1 -0
  100. package/x/install/aura.bundle.js +5 -0
  101. package/x/install/aura.bundle.js.map +1 -0
  102. package/x/install/aura.bundle.min.js +321 -0
  103. package/x/install/aura.bundle.min.js.map +7 -0
  104. package/x/install/plain.bundle.d.ts +1 -0
  105. package/x/install/plain.bundle.js +5 -0
  106. package/x/install/plain.bundle.js.map +1 -0
  107. package/x/install/plain.bundle.min.js +287 -0
  108. package/x/install/plain.bundle.min.js.map +7 -0
  109. package/x/shiny.d.ts +42 -0
  110. package/x/shiny.js +8 -0
  111. package/x/shiny.js.map +1 -0
  112. package/x/themes/aura.css.d.ts +1 -0
  113. package/x/themes/aura.css.js +47 -0
  114. package/x/themes/aura.css.js.map +1 -0
  115. package/x/themes/index.barrel.d.ts +2 -1
  116. package/x/themes/index.barrel.js +2 -1
  117. package/x/themes/index.barrel.js.map +1 -1
  118. package/x/themes/index.d.ts +1 -0
  119. package/x/themes/infra/css-vars.d.ts +11 -0
  120. package/x/themes/infra/css-vars.js +18 -0
  121. package/x/themes/infra/css-vars.js.map +1 -0
  122. package/x/themes/plain.css.d.ts +1 -0
  123. package/x/themes/plain.css.js +11 -0
  124. package/x/themes/plain.css.js.map +1 -0
  125. package/x/utils/states.d.ts +5 -0
  126. package/x/utils/states.js +13 -0
  127. package/x/utils/states.js.map +1 -0
  128. package/s/themes/basic.css.ts +0 -18
  129. package/s/tools/untab.ts +0 -30
  130. package/s/ui/components.ts +0 -9
  131. package/s/ui/framework.ts +0 -8
  132. package/s/ui/themers.ts +0 -28
  133. package/x/themes/basic.css.d.ts +0 -1
  134. package/x/themes/basic.css.js +0 -17
  135. package/x/themes/basic.css.js.map +0 -1
  136. package/x/tools/untab.d.ts +0 -1
  137. package/x/tools/untab.js +0 -26
  138. package/x/tools/untab.js.map +0 -1
  139. package/x/ui/components.d.ts +0 -6
  140. package/x/ui/components.js +0 -7
  141. package/x/ui/components.js.map +0 -1
  142. package/x/ui/copy/component.js.map +0 -1
  143. package/x/ui/copy/style.css.js.map +0 -1
  144. package/x/ui/example/component.js.map +0 -1
  145. package/x/ui/example/style.css.js +0 -10
  146. package/x/ui/example/style.css.js.map +0 -1
  147. package/x/ui/framework.d.ts +0 -4
  148. package/x/ui/framework.js +0 -6
  149. package/x/ui/framework.js.map +0 -1
  150. package/x/ui/themers.d.ts +0 -8
  151. package/x/ui/themers.js +0 -12
  152. package/x/ui/themers.js.map +0 -1
  153. /package/x/{ui → components}/copy/style.css.d.ts +0 -0
  154. /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: 0.5;
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(--invalid);
24
+ color: var(--lame);
25
25
  }
26
26
 
27
27
  [data-status="good"] {
28
28
  opacity: 1;
29
- color: var(--good);
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(--bad);
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