@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.
- package/LICENSE +21 -0
- package/dist/common/events.d.ts +72 -0
- package/dist/common/events.js +58 -0
- package/dist/common/events.js.map +1 -0
- package/dist/common/parsers.d.ts +88 -0
- package/dist/common/parsers.js +62 -0
- package/dist/common/parsers.js.map +1 -0
- package/dist/common/theme-test.d.ts +7 -0
- package/dist/common/theme-test.js +14 -0
- package/dist/common/theme-test.js.map +1 -0
- package/dist/common/theme.d.ts +144 -0
- package/dist/common/theme.js +2 -0
- package/dist/common/theme.js.map +1 -0
- package/dist/common/trim.d.ts +12 -0
- package/dist/common/trim.js +16 -0
- package/dist/common/trim.js.map +1 -0
- package/dist/common/types.d.ts +13 -0
- package/dist/common/types.js +10 -0
- package/dist/common/types.js.map +1 -0
- package/dist/common/writing-mode.d.ts +82 -0
- package/dist/common/writing-mode.js +61 -0
- package/dist/common/writing-mode.js.map +1 -0
- package/dist/components/button.d.ts +42 -0
- package/dist/components/button.js +26 -0
- package/dist/components/button.js.map +1 -0
- package/dist/components/checkbox.d.ts +9 -0
- package/dist/components/checkbox.js +32 -0
- package/dist/components/checkbox.js.map +1 -0
- package/dist/components/collapse-test.d.ts +8 -0
- package/dist/components/collapse-test.js +15 -0
- package/dist/components/collapse-test.js.map +1 -0
- package/dist/components/collapse.d.ts +13 -0
- package/dist/components/collapse.js +44 -0
- package/dist/components/collapse.js.map +1 -0
- package/dist/components/column.d.ts +12 -0
- package/dist/components/column.js +12 -0
- package/dist/components/column.js.map +1 -0
- package/dist/components/control-group.d.ts +7 -0
- package/dist/components/control-group.js +11 -0
- package/dist/components/control-group.js.map +1 -0
- package/dist/components/dialog.d.ts +33 -0
- package/dist/components/dialog.js +67 -0
- package/dist/components/dialog.js.map +1 -0
- package/dist/components/dropdown-input.d.ts +27 -0
- package/dist/components/dropdown-input.js +31 -0
- package/dist/components/dropdown-input.js.map +1 -0
- package/dist/components/dropdown.d.ts +123 -0
- package/dist/components/dropdown.js +176 -0
- package/dist/components/dropdown.js.map +1 -0
- package/dist/components/flex-space.d.ts +4 -0
- package/dist/components/flex-space.js +10 -0
- package/dist/components/flex-space.js.map +1 -0
- package/dist/components/heading.d.ts +9 -0
- package/dist/components/heading.js +14 -0
- package/dist/components/heading.js.map +1 -0
- package/dist/components/label.d.ts +14 -0
- package/dist/components/label.js +15 -0
- package/dist/components/label.js.map +1 -0
- package/dist/components/layer.d.ts +81 -0
- package/dist/components/layer.js +164 -0
- package/dist/components/layer.js.map +1 -0
- package/dist/components/link.d.ts +57 -0
- package/dist/components/link.js +26 -0
- package/dist/components/link.js.map +1 -0
- package/dist/components/page.d.ts +9 -0
- package/dist/components/page.js +17 -0
- package/dist/components/page.js.map +1 -0
- package/dist/components/popout.d.ts +134 -0
- package/dist/components/popout.js +259 -0
- package/dist/components/popout.js.map +1 -0
- package/dist/components/popover.d.ts +139 -0
- package/dist/components/popover.js +101 -0
- package/dist/components/popover.js.map +1 -0
- package/dist/components/radio-buttons.d.ts +17 -0
- package/dist/components/radio-buttons.js +26 -0
- package/dist/components/radio-buttons.js.map +1 -0
- package/dist/components/row.d.ts +10 -0
- package/dist/components/row.js +23 -0
- package/dist/components/row.js.map +1 -0
- package/dist/components/scroll-view.d.ts +6 -0
- package/dist/components/scroll-view.js +72 -0
- package/dist/components/scroll-view.js.map +1 -0
- package/dist/components/text-input.d.ts +53 -0
- package/dist/components/text-input.js +35 -0
- package/dist/components/text-input.js.map +1 -0
- package/dist/components/text.d.ts +7 -0
- package/dist/components/text.js +11 -0
- package/dist/components/text.js.map +1 -0
- package/dist/components/validation.d.ts +109 -0
- package/dist/components/validation.js +151 -0
- package/dist/components/validation.js.map +1 -0
- package/dist/components/value.d.ts +7 -0
- package/dist/components/value.js +11 -0
- package/dist/components/value.js.map +1 -0
- package/dist/index.d.ts +29 -0
- package/dist/index.js +30 -0
- package/dist/index.js.map +1 -0
- package/dist/test.d.ts +2 -0
- package/dist/test.js +3 -0
- package/dist/test.js.map +1 -0
- package/dist/theme.module.css +679 -0
- package/dist/theme.module.css.map +1 -0
- package/package.json +29 -0
- package/src/common/events.tsx +130 -0
- package/src/common/parsers.tsx +167 -0
- package/src/common/theme-test.tsx +20 -0
- package/src/common/theme.tsx +165 -0
- package/src/common/trim.tsx +30 -0
- package/src/common/types.tsx +23 -0
- package/src/common/writing-mode.tsx +150 -0
- package/src/components/button.tsx +94 -0
- package/src/components/checkbox.tsx +64 -0
- package/src/components/collapse-test.tsx +23 -0
- package/src/components/collapse.tsx +75 -0
- package/src/components/column.tsx +28 -0
- package/src/components/control-group.tsx +22 -0
- package/src/components/dialog.tsx +137 -0
- package/src/components/dropdown-input.tsx +82 -0
- package/src/components/dropdown.tsx +352 -0
- package/src/components/flex-space.tsx +15 -0
- package/src/components/heading.tsx +23 -0
- package/src/components/label.tsx +37 -0
- package/src/components/layer.tsx +299 -0
- package/src/components/link.tsx +118 -0
- package/src/components/page.tsx +36 -0
- package/src/components/popout.tsx +461 -0
- package/src/components/popover.tsx +292 -0
- package/src/components/radio-buttons.tsx +81 -0
- package/src/components/row.tsx +37 -0
- package/src/components/scroll-view.tsx +97 -0
- package/src/components/text-input.tsx +117 -0
- package/src/components/text.tsx +22 -0
- package/src/components/validation.tsx +272 -0
- package/src/components/value.tsx +22 -0
- package/src/index.tsx +29 -0
- package/src/test.tsx +2 -0
- package/src/theme/base.scss +69 -0
- package/src/theme/common.scss +51 -0
- package/src/theme/components/button.scss +116 -0
- package/src/theme/components/checkbox.scss +25 -0
- package/src/theme/components/collapse.scss +64 -0
- package/src/theme/components/column.scss +28 -0
- package/src/theme/components/control-group.scss +14 -0
- package/src/theme/components/dialog.scss +44 -0
- package/src/theme/components/dropdown.scss +50 -0
- package/src/theme/components/flex-space.scss +6 -0
- package/src/theme/components/heading.scss +39 -0
- package/src/theme/components/label.scss +24 -0
- package/src/theme/components/link.scss +25 -0
- package/src/theme/components/page.scss +22 -0
- package/src/theme/components/popover.scss +58 -0
- package/src/theme/components/radio-buttons.scss +31 -0
- package/src/theme/components/row.scss +17 -0
- package/src/theme/components/scroll-view.scss +51 -0
- package/src/theme/components/text-input.scss +45 -0
- package/src/theme/components/text.scss +12 -0
- package/src/theme/components/validation.scss +15 -0
- package/src/theme/components/value.scss +4 -0
- 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,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
|