@rvx/ui 0.1.6

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 (159) hide show
  1. package/LICENSE +21 -0
  2. package/dist/common/events.d.ts +72 -0
  3. package/dist/common/events.js +58 -0
  4. package/dist/common/events.js.map +1 -0
  5. package/dist/common/parsers.d.ts +88 -0
  6. package/dist/common/parsers.js +62 -0
  7. package/dist/common/parsers.js.map +1 -0
  8. package/dist/common/theme-test.d.ts +7 -0
  9. package/dist/common/theme-test.js +14 -0
  10. package/dist/common/theme-test.js.map +1 -0
  11. package/dist/common/theme.d.ts +144 -0
  12. package/dist/common/theme.js +2 -0
  13. package/dist/common/theme.js.map +1 -0
  14. package/dist/common/trim.d.ts +12 -0
  15. package/dist/common/trim.js +16 -0
  16. package/dist/common/trim.js.map +1 -0
  17. package/dist/common/types.d.ts +13 -0
  18. package/dist/common/types.js +10 -0
  19. package/dist/common/types.js.map +1 -0
  20. package/dist/common/writing-mode.d.ts +82 -0
  21. package/dist/common/writing-mode.js +61 -0
  22. package/dist/common/writing-mode.js.map +1 -0
  23. package/dist/components/button.d.ts +42 -0
  24. package/dist/components/button.js +26 -0
  25. package/dist/components/button.js.map +1 -0
  26. package/dist/components/checkbox.d.ts +9 -0
  27. package/dist/components/checkbox.js +32 -0
  28. package/dist/components/checkbox.js.map +1 -0
  29. package/dist/components/collapse-test.d.ts +8 -0
  30. package/dist/components/collapse-test.js +15 -0
  31. package/dist/components/collapse-test.js.map +1 -0
  32. package/dist/components/collapse.d.ts +13 -0
  33. package/dist/components/collapse.js +44 -0
  34. package/dist/components/collapse.js.map +1 -0
  35. package/dist/components/column.d.ts +12 -0
  36. package/dist/components/column.js +12 -0
  37. package/dist/components/column.js.map +1 -0
  38. package/dist/components/control-group.d.ts +7 -0
  39. package/dist/components/control-group.js +11 -0
  40. package/dist/components/control-group.js.map +1 -0
  41. package/dist/components/dialog.d.ts +33 -0
  42. package/dist/components/dialog.js +67 -0
  43. package/dist/components/dialog.js.map +1 -0
  44. package/dist/components/dropdown-input.d.ts +27 -0
  45. package/dist/components/dropdown-input.js +31 -0
  46. package/dist/components/dropdown-input.js.map +1 -0
  47. package/dist/components/dropdown.d.ts +123 -0
  48. package/dist/components/dropdown.js +176 -0
  49. package/dist/components/dropdown.js.map +1 -0
  50. package/dist/components/flex-space.d.ts +4 -0
  51. package/dist/components/flex-space.js +10 -0
  52. package/dist/components/flex-space.js.map +1 -0
  53. package/dist/components/heading.d.ts +9 -0
  54. package/dist/components/heading.js +14 -0
  55. package/dist/components/heading.js.map +1 -0
  56. package/dist/components/label.d.ts +14 -0
  57. package/dist/components/label.js +15 -0
  58. package/dist/components/label.js.map +1 -0
  59. package/dist/components/layer.d.ts +81 -0
  60. package/dist/components/layer.js +164 -0
  61. package/dist/components/layer.js.map +1 -0
  62. package/dist/components/link.d.ts +57 -0
  63. package/dist/components/link.js +26 -0
  64. package/dist/components/link.js.map +1 -0
  65. package/dist/components/page.d.ts +9 -0
  66. package/dist/components/page.js +17 -0
  67. package/dist/components/page.js.map +1 -0
  68. package/dist/components/popout.d.ts +134 -0
  69. package/dist/components/popout.js +259 -0
  70. package/dist/components/popout.js.map +1 -0
  71. package/dist/components/popover.d.ts +139 -0
  72. package/dist/components/popover.js +101 -0
  73. package/dist/components/popover.js.map +1 -0
  74. package/dist/components/radio-buttons.d.ts +17 -0
  75. package/dist/components/radio-buttons.js +26 -0
  76. package/dist/components/radio-buttons.js.map +1 -0
  77. package/dist/components/row.d.ts +10 -0
  78. package/dist/components/row.js +23 -0
  79. package/dist/components/row.js.map +1 -0
  80. package/dist/components/scroll-view.d.ts +6 -0
  81. package/dist/components/scroll-view.js +72 -0
  82. package/dist/components/scroll-view.js.map +1 -0
  83. package/dist/components/text-input.d.ts +53 -0
  84. package/dist/components/text-input.js +35 -0
  85. package/dist/components/text-input.js.map +1 -0
  86. package/dist/components/text.d.ts +7 -0
  87. package/dist/components/text.js +11 -0
  88. package/dist/components/text.js.map +1 -0
  89. package/dist/components/validation.d.ts +109 -0
  90. package/dist/components/validation.js +151 -0
  91. package/dist/components/validation.js.map +1 -0
  92. package/dist/components/value.d.ts +7 -0
  93. package/dist/components/value.js +11 -0
  94. package/dist/components/value.js.map +1 -0
  95. package/dist/index.d.ts +29 -0
  96. package/dist/index.js +30 -0
  97. package/dist/index.js.map +1 -0
  98. package/dist/test.d.ts +2 -0
  99. package/dist/test.js +3 -0
  100. package/dist/test.js.map +1 -0
  101. package/dist/theme.module.css +679 -0
  102. package/dist/theme.module.css.map +1 -0
  103. package/package.json +29 -0
  104. package/src/common/events.tsx +130 -0
  105. package/src/common/parsers.tsx +167 -0
  106. package/src/common/theme-test.tsx +20 -0
  107. package/src/common/theme.tsx +165 -0
  108. package/src/common/trim.tsx +30 -0
  109. package/src/common/types.tsx +23 -0
  110. package/src/common/writing-mode.tsx +150 -0
  111. package/src/components/button.tsx +94 -0
  112. package/src/components/checkbox.tsx +64 -0
  113. package/src/components/collapse-test.tsx +23 -0
  114. package/src/components/collapse.tsx +75 -0
  115. package/src/components/column.tsx +28 -0
  116. package/src/components/control-group.tsx +22 -0
  117. package/src/components/dialog.tsx +137 -0
  118. package/src/components/dropdown-input.tsx +82 -0
  119. package/src/components/dropdown.tsx +352 -0
  120. package/src/components/flex-space.tsx +15 -0
  121. package/src/components/heading.tsx +23 -0
  122. package/src/components/label.tsx +37 -0
  123. package/src/components/layer.tsx +299 -0
  124. package/src/components/link.tsx +118 -0
  125. package/src/components/page.tsx +36 -0
  126. package/src/components/popout.tsx +461 -0
  127. package/src/components/popover.tsx +292 -0
  128. package/src/components/radio-buttons.tsx +81 -0
  129. package/src/components/row.tsx +37 -0
  130. package/src/components/scroll-view.tsx +97 -0
  131. package/src/components/text-input.tsx +117 -0
  132. package/src/components/text.tsx +22 -0
  133. package/src/components/validation.tsx +272 -0
  134. package/src/components/value.tsx +22 -0
  135. package/src/index.tsx +29 -0
  136. package/src/test.tsx +2 -0
  137. package/src/theme/base.scss +69 -0
  138. package/src/theme/common.scss +51 -0
  139. package/src/theme/components/button.scss +116 -0
  140. package/src/theme/components/checkbox.scss +25 -0
  141. package/src/theme/components/collapse.scss +64 -0
  142. package/src/theme/components/column.scss +28 -0
  143. package/src/theme/components/control-group.scss +14 -0
  144. package/src/theme/components/dialog.scss +44 -0
  145. package/src/theme/components/dropdown.scss +50 -0
  146. package/src/theme/components/flex-space.scss +6 -0
  147. package/src/theme/components/heading.scss +39 -0
  148. package/src/theme/components/label.scss +24 -0
  149. package/src/theme/components/link.scss +25 -0
  150. package/src/theme/components/page.scss +22 -0
  151. package/src/theme/components/popover.scss +58 -0
  152. package/src/theme/components/radio-buttons.scss +31 -0
  153. package/src/theme/components/row.scss +17 -0
  154. package/src/theme/components/scroll-view.scss +51 -0
  155. package/src/theme/components/text-input.scss +45 -0
  156. package/src/theme/components/text.scss +12 -0
  157. package/src/theme/components/validation.scss +15 -0
  158. package/src/theme/components/value.scss +4 -0
  159. package/src/theme/theme.scss +22 -0
@@ -0,0 +1,176 @@
1
+ import { jsx as _jsx } from "rvx/jsx-runtime";
2
+ import { extract, For, get, map, memo, optionalString, render, sig, uniqueId, watch } from "rvx";
3
+ import { createPassiveActionEvent, handleActionEvent, keyFor, startDelayedHoverOnMouseenter } from "../common/events.js";
4
+ import { THEME } from "../common/theme.js";
5
+ import { LAYER } from "./layer.js";
6
+ import { Popout } from "./popout.js";
7
+ export function createDropdown(props) {
8
+ return new Popout({
9
+ placement: map(props.placement, v => v ?? "block-end"),
10
+ alignment: map(props.alignment, v => v ?? "start"),
11
+ foreignEvents: props.foreignEvents,
12
+ content: ({ popout, placement }) => {
13
+ const theme = extract(THEME);
14
+ const layer = extract(LAYER);
15
+ const activeItem = sig(undefined);
16
+ const instances = new WeakMap();
17
+ const items = memo(props.items);
18
+ watch(items, items => {
19
+ const current = activeItem.value;
20
+ if (current !== undefined && !items.includes(current)) {
21
+ activeItem.value = undefined;
22
+ }
23
+ });
24
+ const scrollToActive = () => {
25
+ const active = activeItem.value;
26
+ if (active) {
27
+ instances.get(active)?.root.scrollIntoView({ block: "nearest", inline: "nearest" });
28
+ }
29
+ };
30
+ layer.useEvent("keydown", event => {
31
+ const currentItems = items();
32
+ const current = activeItem.value;
33
+ switch (keyFor(event)) {
34
+ case "escape": {
35
+ popout.hide();
36
+ break;
37
+ }
38
+ case "arrowleft": {
39
+ if (props.expansion) {
40
+ popout.hide();
41
+ break;
42
+ }
43
+ return;
44
+ }
45
+ case "arrowdown": {
46
+ activeItem.value = currentItems[(current === undefined ? 0 : (currentItems.indexOf(current) + 1)) % currentItems.length];
47
+ scrollToActive();
48
+ break;
49
+ }
50
+ case "arrowup": {
51
+ const index = current === undefined ? -1 : (currentItems.indexOf(current) - 1);
52
+ activeItem.value = currentItems[index < 0 ? currentItems.length - 1 : index];
53
+ scrollToActive();
54
+ break;
55
+ }
56
+ case "arrowright": {
57
+ if (current) {
58
+ const instance = instances.get(current);
59
+ if (instance?.children) {
60
+ instance.children.show(instance.view, event);
61
+ event.stopImmediatePropagation();
62
+ event.preventDefault();
63
+ }
64
+ }
65
+ break;
66
+ }
67
+ case "enter": {
68
+ if (current?.action && handleActionEvent(event, current.action)) {
69
+ popout.hide();
70
+ }
71
+ else if (current) {
72
+ const instance = instances.get(current);
73
+ if (instance?.children) {
74
+ instance.children.show(instance.view, event);
75
+ event.stopImmediatePropagation();
76
+ event.preventDefault();
77
+ }
78
+ }
79
+ break;
80
+ }
81
+ default: return;
82
+ }
83
+ event.stopImmediatePropagation();
84
+ event.preventDefault();
85
+ });
86
+ const content = _jsx("div", { class: [
87
+ theme?.dropdown_content,
88
+ ], children: _jsx(For, { each: items, children: item => {
89
+ const id = uniqueId();
90
+ let childrenId;
91
+ let children;
92
+ if (item.children) {
93
+ childrenId = uniqueId();
94
+ children = createDropdown({
95
+ placement: () => {
96
+ const parentPlacement = get(placement)?.placement;
97
+ if (parentPlacement === "block-end" || parentPlacement === "block-start") {
98
+ return "inline-end";
99
+ }
100
+ return parentPlacement ?? "inline-end";
101
+ },
102
+ alignment: props.alignment,
103
+ items: item.children,
104
+ expansion: true,
105
+ foreignEvents: props.foreignEvents,
106
+ class: props.class,
107
+ style: props.style,
108
+ });
109
+ }
110
+ const root = _jsx("div", { id: id, class: [
111
+ theme?.dropdown_item,
112
+ () => activeItem.value === item && theme?.dropdown_item_active,
113
+ ], role: "option", "aria-selected": item.selected, "aria-haspopup": children ? "listbox" : undefined, "aria-controls": () => children?.visible ? childrenId : undefined, "aria-expanded": optionalString(() => children?.visible), "on:click": event => {
114
+ activeItem.value = item;
115
+ if (item.action && handleActionEvent(event, item.action)) {
116
+ popout.hide();
117
+ }
118
+ else if (children) {
119
+ children.show(view, event);
120
+ event.stopImmediatePropagation();
121
+ event.preventDefault();
122
+ }
123
+ }, "on:mouseenter": event => {
124
+ activeItem.value = item;
125
+ startDelayedHoverOnMouseenter(event, () => {
126
+ event.target?.dispatchEvent(createPassiveActionEvent());
127
+ if (activeItem.value === item) {
128
+ children?.show(view, event);
129
+ }
130
+ });
131
+ }, children: item.label });
132
+ const view = render(root);
133
+ instances.set(item, { id, children, root, view });
134
+ return view;
135
+ } }) });
136
+ const root = _jsx("div", { id: props.id, style: props.style, class: [
137
+ props.class,
138
+ theme?.dropdown,
139
+ map(props.expansion, v => v && theme?.dropdown_expansion),
140
+ ], role: "listbox", tabindex: "0", "aria-activedescendant": () => {
141
+ const item = activeItem.value;
142
+ return item === undefined ? undefined : instances.get(item)?.id;
143
+ }, "on:focus": () => {
144
+ if (!activeItem.value) {
145
+ const currentItems = items();
146
+ activeItem.value = currentItems.find(v => get(v.selected)) ?? currentItems[0];
147
+ }
148
+ }, children: _jsx("div", { class: theme?.dropdown_scroll_area, children: content }) });
149
+ layer.useAutoFocusFallback(root);
150
+ return root;
151
+ },
152
+ });
153
+ }
154
+ export function Dropdown(props) {
155
+ const defaultId = uniqueId();
156
+ const id = map(props.id, v => v ?? defaultId);
157
+ const dropdown = createDropdown({
158
+ items: props.items,
159
+ id,
160
+ style: props.style,
161
+ class: props.class,
162
+ placement: props.placement,
163
+ alignment: props.alignment,
164
+ foreignEvents: props.foreignEvents,
165
+ });
166
+ const anchor = render(props.anchor({
167
+ action: event => {
168
+ dropdown.toggle(anchor, event);
169
+ },
170
+ "aria-haspopup": "listbox",
171
+ "aria-controls": () => dropdown.visible ? get(id) : undefined,
172
+ "aria-expanded": () => dropdown.visible,
173
+ }));
174
+ return anchor;
175
+ }
176
+ //# sourceMappingURL=dropdown.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dropdown.js","sourceRoot":"","sources":["../../src/components/dropdown.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ import { Expression } from "rvx";
2
+ export declare function FlexSpace(props: {
3
+ grow?: Expression<number | undefined>;
4
+ }): unknown;
@@ -0,0 +1,10 @@
1
+ import { jsx as _jsx } from "rvx/jsx-runtime";
2
+ import { extract, get } from "rvx";
3
+ import { THEME } from "../common/theme.js";
4
+ export function FlexSpace(props) {
5
+ const theme = extract(THEME);
6
+ return _jsx("div", { class: theme?.flex_space, style: {
7
+ "flex-grow": () => String(get(props.grow) ?? 1),
8
+ } });
9
+ }
10
+ //# sourceMappingURL=flex-space.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"flex-space.js","sourceRoot":"","sources":["../../src/components/flex-space.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAc,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAE/C,OAAO,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAE3C,MAAM,UAAU,SAAS,CAAC,KAEzB;IACA,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC;IAC7B,OAAO,cACN,KAAK,EAAE,KAAK,EAAE,UAAU,EACxB,KAAK,EAAE;YACN,WAAW,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAC/C,GACA,CAAC;AACJ,CAAC"}
@@ -0,0 +1,9 @@
1
+ import { ClassValue, Expression, StyleValue } from "rvx";
2
+ export type HeadingLevel = "1" | "2" | "3" | "4" | "5" | "6";
3
+ export declare function Heading(props: {
4
+ level: HeadingLevel;
5
+ class?: ClassValue;
6
+ style?: StyleValue;
7
+ id?: Expression<string | undefined>;
8
+ children?: unknown;
9
+ }): unknown;
@@ -0,0 +1,14 @@
1
+ import { createElement, extract } from "rvx";
2
+ import { THEME } from "../common/theme.js";
3
+ export function Heading(props) {
4
+ const theme = extract(THEME);
5
+ return createElement(`h${props.level}`, {
6
+ class: [
7
+ theme?.heading,
8
+ props.class,
9
+ ],
10
+ style: props.style,
11
+ id: props.id,
12
+ }, props.children);
13
+ }
14
+ //# sourceMappingURL=heading.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"heading.js","sourceRoot":"","sources":["../../src/components/heading.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAc,aAAa,EAAc,OAAO,EAAc,MAAM,KAAK,CAAC;AAEjF,OAAO,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAI3C,MAAM,UAAU,OAAO,CAAC,KAMvB;IACA,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC;IAC7B,OAAO,aAAa,CAAC,IAAI,KAAK,CAAC,KAAK,EAAE,EAAE;QACvC,KAAK,EAAE;YACN,KAAK,EAAE,OAAO;YACd,KAAK,CAAC,KAAK;SACX;QACD,KAAK,EAAE,KAAK,CAAC,KAAK;QAClB,EAAE,EAAE,KAAK,CAAC,EAAE;KACZ,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC;AACpB,CAAC"}
@@ -0,0 +1,14 @@
1
+ import { ClassValue, Expression, StyleValue } from "rvx";
2
+ export declare function Label(props: {
3
+ class?: ClassValue;
4
+ style?: StyleValue;
5
+ for?: Expression<string | undefined>;
6
+ id?: Expression<string | undefined>;
7
+ children?: unknown;
8
+ }): unknown;
9
+ export declare function LabelFor(props: {
10
+ class?: ClassValue;
11
+ style?: StyleValue;
12
+ label: unknown;
13
+ children: (id: string) => unknown;
14
+ }): unknown;
@@ -0,0 +1,15 @@
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "rvx/jsx-runtime";
2
+ import { extract, uniqueId } from "rvx";
3
+ import { THEME } from "../common/theme.js";
4
+ export function Label(props) {
5
+ const theme = extract(THEME);
6
+ return _jsx("label", { class: [
7
+ theme?.label,
8
+ props.class,
9
+ ], style: props.style, for: props.for, id: props.id, children: props.children });
10
+ }
11
+ export function LabelFor(props) {
12
+ const id = uniqueId();
13
+ return _jsxs(_Fragment, { children: [_jsx(Label, { class: props.class, style: props.style, for: id, children: props.label }), props.children(id)] });
14
+ }
15
+ //# sourceMappingURL=label.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"label.js","sourceRoot":"","sources":["../../src/components/label.tsx"],"names":[],"mappings":";AAAA,OAAO,EAA0B,OAAO,EAAc,QAAQ,EAAE,MAAM,KAAK,CAAC;AAE5E,OAAO,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAE3C,MAAM,UAAU,KAAK,CAAC,KAMrB;IACA,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC;IAC7B,OAAO,gBACN,KAAK,EAAE;YACN,KAAK,EAAE,KAAK;YACZ,KAAK,CAAC,KAAK;SACX,EACD,KAAK,EAAE,KAAK,CAAC,KAAK,EAClB,GAAG,EAAE,KAAK,CAAC,GAAG,EACd,EAAE,EAAE,KAAK,CAAC,EAAE,YAEX,KAAK,CAAC,QAAQ,GACR,CAAC;AACV,CAAC;AAED,MAAM,UAAU,QAAQ,CAAC,KAKxB;IACA,MAAM,EAAE,GAAG,QAAQ,EAAE,CAAC;IACtB,OAAO,8BACN,KAAC,KAAK,IAAC,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE,YAAG,KAAK,CAAC,KAAK,GAAS,EAC5E,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC,IACjB,CAAC;AACL,CAAC"}
@@ -0,0 +1,81 @@
1
+ import { Context, ContextKey, Expression } from "rvx";
2
+ import { Action } from "../common/events.js";
3
+ export declare const LAYER: ContextKey<LayerHandle>;
4
+ /**
5
+ * Render content inside the root layer.
6
+ */
7
+ export declare function RootLayer(props: {
8
+ children: (ctx: Context) => unknown;
9
+ }): unknown;
10
+ /**
11
+ * An input layer that is inert while there are other modal layers on top of it.
12
+ *
13
+ * After creation, the first element with the "autofocus" attribute inside this layer is focused.
14
+ *
15
+ * When disposed, focus is moved back to the previously focused element.
16
+ */
17
+ export declare function Layer(props: {
18
+ children: (ctx: Context) => unknown;
19
+ /**
20
+ * If true, all layers below this one are marked as inert until the current context is disposed.
21
+ */
22
+ modal?: boolean;
23
+ /**
24
+ * If false, the layer doesn't affect other layers but is marked as inert. Default is true.
25
+ */
26
+ enabled?: Expression<boolean | undefined>;
27
+ }): unknown;
28
+ export interface LayerHandle {
29
+ /**
30
+ * Reactively check if this layer is inert.
31
+ */
32
+ get inert(): boolean;
33
+ /**
34
+ * Reactively check if this is the top layer.
35
+ */
36
+ get top(): boolean;
37
+ /**
38
+ * Add a global event listener that is only called when this is the top layer.
39
+ *
40
+ * The current context is available in the event listener.
41
+ *
42
+ * The event listener is removed when the current context is disposed.
43
+ *
44
+ * @param type The event type.
45
+ * @param listener The event listener.
46
+ * @param options Event listener options. See {@link window.addEventListener}.
47
+ */
48
+ useEvent<K extends keyof WindowEventMap>(type: K, listener: (event: WindowEventMap[K]) => void, options?: boolean | AddEventListenerOptions): void;
49
+ useEvent(type: string, listener: (event: Event) => void, options?: boolean | AddEventListenerOptions): void;
50
+ /**
51
+ * Shorthand for adding a global "keydown" event listener using {@link useEvent} and {@link keyFor}.
52
+ */
53
+ useHotkey(key: string, action: Action): void;
54
+ /**
55
+ * Check if this layer contains the specified node.
56
+ *
57
+ * @param node The node to check.
58
+ */
59
+ contains(node: Node): boolean;
60
+ /**
61
+ * Check if this layer or any layers in top contain the specified node.
62
+ *
63
+ * @param node The node to check.
64
+ * @param includeModals If false (default), any modal layers on top or layers above that are ignored.
65
+ */
66
+ stackContains(node: Node, includeModals?: boolean): boolean;
67
+ /**
68
+ * Try focusing the specified element after the layer is created (in the next microtask), if no element with the `autofocus` attribute has been found or successfully focused.
69
+ *
70
+ * @param element The element to use as fallback.
71
+ */
72
+ useAutoFocusFallback(element: Element): void;
73
+ }
74
+ /**
75
+ * Reactively check if the layer in the current context (or the root layer if there is none) is inert.
76
+ */
77
+ export declare function isInertLayer(): boolean;
78
+ /**
79
+ * Reactively check if the layer in the current context (or the root layer if there is none) is the top layer.
80
+ */
81
+ export declare function isTopLayer(): boolean;
@@ -0,0 +1,164 @@
1
+ import { jsx as _jsx } from "rvx/jsx-runtime";
2
+ import { DeriveContext, extract, get, memo, sig, teardown, uncapture, untrack, watch, wrapContext } from "rvx";
3
+ import { handleActionEvent, keyFor } from "../common/events.js";
4
+ export const LAYER = Symbol.for("rvx-ui:layer-handle");
5
+ const LAYERS = sig([
6
+ {
7
+ roots: [],
8
+ modal: false,
9
+ inert: sig(false),
10
+ autoFocusFallback: undefined,
11
+ },
12
+ ]);
13
+ uncapture(() => watch(LAYERS, layers => {
14
+ const modal = layers.findLastIndex(l => l.modal);
15
+ for (let i = 0; i < layers.length; i++) {
16
+ layers[i].inert.value = i < modal;
17
+ }
18
+ }));
19
+ export function RootLayer(props) {
20
+ const layer = LAYERS.value[0];
21
+ const root = _jsx("div", { style: { display: "contents" }, inert: layer.inert, children: _jsx(DeriveContext, { children: ctx => {
22
+ ctx.set(LAYER, new Handle(layer));
23
+ return props.children(ctx);
24
+ } }) });
25
+ layer.roots.push(root);
26
+ teardown(() => {
27
+ const index = layer.roots.indexOf(root);
28
+ if (index >= 0) {
29
+ layer.roots.splice(index, 1);
30
+ }
31
+ });
32
+ return root;
33
+ }
34
+ export function Layer(props) {
35
+ const layer = {
36
+ roots: [],
37
+ modal: props.modal ?? false,
38
+ inert: sig(false),
39
+ autoFocusFallback: undefined,
40
+ };
41
+ const enabled = memo(() => Boolean(get(props.enabled) ?? true));
42
+ watch(enabled, enable => {
43
+ if (!enable) {
44
+ return;
45
+ }
46
+ LAYERS.update(layers => {
47
+ layers.push(layer);
48
+ });
49
+ const previous = document.activeElement;
50
+ if (previous && previous !== document.body) {
51
+ previous.blur?.();
52
+ }
53
+ queueMicrotask(() => {
54
+ const layers = LAYERS.value;
55
+ if (layer === layers[layers.length - 1] && root.isConnected) {
56
+ let active = document.activeElement;
57
+ if (active && (root === active || root.contains(active))) {
58
+ return;
59
+ }
60
+ const autoFocus = root.querySelector("[autofocus]");
61
+ if (autoFocus) {
62
+ autoFocus.focus?.();
63
+ active = document.activeElement;
64
+ if (active === autoFocus) {
65
+ return;
66
+ }
67
+ }
68
+ layer.autoFocusFallback?.focus?.();
69
+ }
70
+ });
71
+ teardown(() => {
72
+ let next = undefined;
73
+ LAYERS.update(layers => {
74
+ const index = layers.lastIndexOf(layer);
75
+ if (index >= 0) {
76
+ layers.splice(index, 1);
77
+ next = layers[index - 1];
78
+ }
79
+ });
80
+ queueMicrotask(() => {
81
+ const layers = LAYERS.value;
82
+ if (next === layers[layers.length - 1] && previous?.isConnected && previous !== document.body) {
83
+ previous.focus?.();
84
+ }
85
+ });
86
+ });
87
+ });
88
+ const root = _jsx("div", { style: { display: "contents" }, inert: () => layer.inert.value || !enabled(), children: _jsx(DeriveContext, { children: ctx => {
89
+ ctx.set(LAYER, new Handle(layer));
90
+ return props.children(ctx);
91
+ } }) });
92
+ layer.roots.push(root);
93
+ return root;
94
+ }
95
+ export function isInertLayer() {
96
+ return extract(LAYER)?.inert ?? untrack(() => LAYERS.value[0]).inert.value;
97
+ }
98
+ export function isTopLayer() {
99
+ return extract(LAYER)?.top ?? LAYERS.value.length === 1;
100
+ }
101
+ function instanceContains(instance, node) {
102
+ const roots = instance.roots;
103
+ for (let i = 0; i < roots.length; i++) {
104
+ const root = roots[i];
105
+ if (root === node || root.contains(node)) {
106
+ return true;
107
+ }
108
+ }
109
+ return false;
110
+ }
111
+ class Handle {
112
+ #instance;
113
+ constructor(instance) {
114
+ this.#instance = instance;
115
+ }
116
+ get inert() {
117
+ return this.#instance.inert.value;
118
+ }
119
+ get top() {
120
+ const layers = LAYERS.value;
121
+ return layers[layers.length - 1] === this.#instance;
122
+ }
123
+ useEvent(type, listener, options) {
124
+ const wrapper = wrapContext((event) => {
125
+ if (this.top) {
126
+ listener(event);
127
+ }
128
+ });
129
+ window.addEventListener(type, wrapper, options);
130
+ teardown(() => {
131
+ window.removeEventListener(type, wrapper, options);
132
+ });
133
+ }
134
+ useHotkey(key, action) {
135
+ this.useEvent("keydown", event => {
136
+ if (keyFor(event) === key) {
137
+ handleActionEvent(event, action);
138
+ }
139
+ });
140
+ }
141
+ contains(node) {
142
+ return instanceContains(this.#instance, node);
143
+ }
144
+ stackContains(node, includeModals = false) {
145
+ const layers = untrack(() => LAYERS.value);
146
+ let i = layers.indexOf(this.#instance);
147
+ if (i < 0) {
148
+ return this.contains(node);
149
+ }
150
+ for (;;) {
151
+ if (instanceContains(layers[i], node)) {
152
+ return true;
153
+ }
154
+ i++;
155
+ if (i >= layers.length || (!includeModals && layers[i].modal)) {
156
+ return false;
157
+ }
158
+ }
159
+ }
160
+ useAutoFocusFallback(element) {
161
+ this.#instance.autoFocusFallback = element;
162
+ }
163
+ }
164
+ //# sourceMappingURL=layer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"layer.js","sourceRoot":"","sources":["../../src/components/layer.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,57 @@
1
+ import { ClassValue, Expression, StyleValue } from "rvx";
2
+ import { Action } from "../common/events.js";
3
+ export type LinkReferrerPolicy = "no-referrer" | "no-referrer-when-downgrade" | "origin" | "origin-when-cross-origin" | "same-origin" | "strict-origin" | "strict-origin-when-cross-origin" | "unsafe-url";
4
+ /**
5
+ * Possible values of the `"rel"` attribute that are applicable to `<a>` elements.
6
+ */
7
+ export type LinkAnchorRel = "alternate" | "author" | "bookmark" | "external" | "help" | "license" | "me" | "next" | "nofollow" | "noopener" | "noreferrer" | "opener" | "prev" | "privacy-policy" | "search" | "tag" | "terms-of-service";
8
+ export type LinkAnchorTarget = "_self" | "_blank" | "_parent" | "_top" | "_unfencedTop";
9
+ export declare function Link(props: {
10
+ /**
11
+ * Set when the link is disabled.
12
+ *
13
+ * The link is automatically disabled when there are any pending tasks.
14
+ */
15
+ disabled?: Expression<boolean | undefined>;
16
+ /**
17
+ * The action to run when the link is clicked.
18
+ */
19
+ action?: Action;
20
+ /**
21
+ * Causes the browser to treat the linked url as a download when true or a filename.
22
+ */
23
+ download?: Expression<string | boolean | undefined>;
24
+ /**
25
+ * The url this link points to.
26
+ */
27
+ href?: Expression<string | undefined>;
28
+ /**
29
+ * Hints the human language of the linked url.
30
+ */
31
+ hreflang?: Expression<string | undefined>;
32
+ /**
33
+ * The link target.
34
+ */
35
+ target?: Expression<LinkAnchorTarget | string | undefined>;
36
+ /**
37
+ * How much of the referrer to send when following the link.
38
+ *
39
+ * @default "no-referrer"
40
+ */
41
+ referrerpolicy?: Expression<LinkReferrerPolicy | undefined>;
42
+ /**
43
+ * The link type.
44
+ *
45
+ * @default "noreferrer"
46
+ */
47
+ rel?: Expression<LinkAnchorRel | LinkAnchorRel[] | undefined>;
48
+ class?: ClassValue;
49
+ style?: StyleValue;
50
+ id?: Expression<string | undefined>;
51
+ title?: Expression<string | undefined>;
52
+ autofocus?: Expression<boolean | undefined>;
53
+ "aria-expanded"?: Expression<boolean | undefined>;
54
+ "aria-label"?: Expression<string | undefined>;
55
+ "aria-labelledby"?: Expression<string | undefined>;
56
+ children?: unknown;
57
+ }): unknown;
@@ -0,0 +1,26 @@
1
+ import { jsx as _jsx } from "rvx/jsx-runtime";
2
+ import { extract, get, map, optionalString } from "rvx";
3
+ import { isPending } from "rvx/async";
4
+ import { handleActionEvent, keyFor } from "../common/events.js";
5
+ import { THEME } from "../common/theme.js";
6
+ import { separated } from "../common/types.js";
7
+ export function Link(props) {
8
+ const theme = extract(THEME);
9
+ const disabled = () => isPending() || get(props.disabled);
10
+ function action(event) {
11
+ if (disabled() || !props.action) {
12
+ return;
13
+ }
14
+ handleActionEvent(event, props.action);
15
+ }
16
+ return _jsx("a", { disabled: disabled, class: [
17
+ theme?.link,
18
+ props.class,
19
+ ], style: props.style, id: props.id, "aria-expanded": optionalString(props["aria-expanded"]), "aria-label": props["aria-label"], "aria-labelledby": props["aria-labelledby"], title: props.title, autofocus: props.autofocus, role: props.action === undefined ? undefined : "button", tabindex: "0", download: props.download, href: props.href, hreflang: props.hreflang, target: props.target, referrerpolicy: map(props.referrerpolicy, v => v ?? "no-referrer"), rel: separated(map(props.rel, v => v ?? "noreferrer"), " "), "on:click": action, "on:keydown": event => {
20
+ const key = keyFor(event);
21
+ if (key === "enter" || key === "space") {
22
+ action(event);
23
+ }
24
+ }, children: props.children });
25
+ }
26
+ //# sourceMappingURL=link.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"link.js","sourceRoot":"","sources":["../../src/components/link.tsx"],"names":[],"mappings":";AAAA,OAAO,EAA0B,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,cAAc,EAAc,MAAM,KAAK,CAAC;AAC5F,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAEtC,OAAO,EAAU,iBAAiB,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AACxE,OAAO,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAC3C,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAW/C,MAAM,UAAU,IAAI,CAAC,KAyDpB;IACA,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC;IAC7B,MAAM,QAAQ,GAAG,GAAG,EAAE,CAAC,SAAS,EAAE,IAAI,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;IAE1D,SAAS,MAAM,CAAC,KAAY;QAC3B,IAAI,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;YACjC,OAAO;QACR,CAAC;QACD,iBAAiB,CAAC,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IACxC,CAAC;IAED,OAAO,YACN,QAAQ,EAAE,QAAQ,EAClB,KAAK,EAAE;YACN,KAAK,EAAE,IAAI;YACX,KAAK,CAAC,KAAK;SACX,EACD,KAAK,EAAE,KAAK,CAAC,KAAK,EAClB,EAAE,EAAE,KAAK,CAAC,EAAE,mBACG,cAAc,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,gBACzC,KAAK,CAAC,YAAY,CAAC,qBACd,KAAK,CAAC,iBAAiB,CAAC,EACzC,KAAK,EAAE,KAAK,CAAC,KAAK,EAClB,SAAS,EAAE,KAAK,CAAC,SAAS,EAC1B,IAAI,EAAE,KAAK,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,EACvD,QAAQ,EAAC,GAAG,EAEZ,QAAQ,EAAE,KAAK,CAAC,QAAQ,EACxB,IAAI,EAAE,KAAK,CAAC,IAAI,EAChB,QAAQ,EAAE,KAAK,CAAC,QAAQ,EACxB,MAAM,EAAE,KAAK,CAAC,MAAM,EACpB,cAAc,EAAE,GAAG,CAAC,KAAK,CAAC,cAAc,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,aAAa,CAAC,EAClE,GAAG,EAAE,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,YAAY,CAAC,EAAE,GAAG,CAAC,cAEjD,MAAM,gBACJ,KAAK,CAAC,EAAE;YACnB,MAAM,GAAG,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;YAC1B,IAAI,GAAG,KAAK,OAAO,IAAI,GAAG,KAAK,OAAO,EAAE,CAAC;gBACxC,MAAM,CAAC,KAAK,CAAC,CAAC;YACf,CAAC;QACF,CAAC,YAEA,KAAK,CAAC,QAAQ,GACZ,CAAC;AACN,CAAC"}
@@ -0,0 +1,9 @@
1
+ import { ClassValue, Expression, StyleValue } from "rvx";
2
+ export declare function Page(props: {
3
+ inlineSize?: Expression<string | undefined>;
4
+ role?: Expression<string | undefined>;
5
+ id?: Expression<string | undefined>;
6
+ class?: ClassValue;
7
+ style?: StyleValue;
8
+ children?: unknown;
9
+ }): unknown;
@@ -0,0 +1,17 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "rvx/jsx-runtime";
2
+ import { extract } from "rvx";
3
+ import { THEME } from "../common/theme.js";
4
+ import { Column } from "./column.js";
5
+ export function Page(props) {
6
+ const theme = extract(THEME);
7
+ return _jsxs("div", { role: props.role, id: props.id, class: [
8
+ props.class,
9
+ theme?.page,
10
+ ], style: [
11
+ props.style,
12
+ {
13
+ "--page-inline-size": props.inlineSize,
14
+ },
15
+ ], children: [_jsx("div", { class: theme?.page_scrollbar_comp }), _jsx("div", { class: theme?.page_content_col, children: _jsx(Column, { class: theme?.page_content, children: props.children }) })] });
16
+ }
17
+ //# sourceMappingURL=page.js.map