@teach-in/react 0.3.0 → 0.4.0
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/dist/chunk-3YOW5DEZ.mjs +45 -0
- package/dist/chunk-4N3FFVKQ.mjs +14 -0
- package/dist/{chunk-QCLLPJMB.mjs → chunk-544SDU73.mjs} +2 -2
- package/dist/chunk-7BTEKEON.mjs +11 -0
- package/dist/{chunk-2CEZXLZR.mjs → chunk-AFVGHUW2.mjs} +1 -1
- package/dist/chunk-EEGPGLDC.mjs +26 -0
- package/dist/{chunk-GEJLG5RP.mjs → chunk-NLHQDWUK.mjs} +3 -2
- package/dist/chunk-PSK7I7V4.mjs +30 -0
- package/dist/chunk-Q2ILWL7L.mjs +1 -0
- package/dist/chunk-TSD6GU35.mjs +16 -0
- package/dist/chunk-UON5ACST.mjs +1 -0
- package/dist/chunk-UT5RUCAT.mjs +1 -0
- package/dist/{chunk-2ASQXBDD.mjs → chunk-WFNNN6WU.mjs} +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.js +290 -234
- package/dist/index.mjs +148 -133
- package/dist/ui/data/image/image.d.ts +6 -0
- package/dist/ui/data/image/image.js +47 -0
- package/dist/ui/data/image/image.mjs +7 -0
- package/dist/ui/data/image/index.d.ts +1 -0
- package/dist/ui/data/image/index.js +49 -0
- package/dist/ui/data/image/index.mjs +8 -0
- package/dist/ui/data/index.d.ts +1 -0
- package/dist/ui/data/index.js +11 -0
- package/dist/ui/data/index.mjs +10 -5
- package/dist/ui/feedback/chip/chip.js +18 -1
- package/dist/ui/feedback/chip/chip.mjs +3 -1
- package/dist/ui/feedback/chip/index.js +18 -1
- package/dist/ui/feedback/chip/index.mjs +3 -1
- package/dist/ui/feedback/index.js +18 -1
- package/dist/ui/feedback/index.mjs +6 -4
- package/dist/ui/form/index.js +23 -10
- package/dist/ui/form/index.mjs +14 -14
- package/dist/ui/form/rhf/fields/autocomplete-field.mjs +10 -10
- package/dist/ui/form/rhf/fields/checkbox-field.mjs +10 -10
- package/dist/ui/form/rhf/fields/date-picker-field.mjs +10 -10
- package/dist/ui/form/rhf/fields/email-field.mjs +10 -10
- package/dist/ui/form/rhf/fields/index.js +23 -10
- package/dist/ui/form/rhf/fields/index.mjs +11 -11
- package/dist/ui/form/rhf/fields/input-field.mjs +10 -10
- package/dist/ui/form/rhf/fields/radio-field.mjs +10 -10
- package/dist/ui/form/rhf/fields/select-field.d.ts +8 -3
- package/dist/ui/form/rhf/fields/select-field.js +23 -10
- package/dist/ui/form/rhf/fields/select-field.mjs +11 -11
- package/dist/ui/form/rhf/fields/switch-field.mjs +10 -10
- package/dist/ui/form/rhf/fields/text-field.mjs +10 -10
- package/dist/ui/form/rhf/fields/textarea-field.mjs +10 -10
- package/dist/ui/form/rhf/index.js +23 -10
- package/dist/ui/form/rhf/index.mjs +11 -11
- package/dist/ui/format/index.mjs +12 -12
- package/dist/ui/index.js +288 -234
- package/dist/ui/index.mjs +145 -133
- package/dist/ui/inputs/index.js +21 -9
- package/dist/ui/inputs/index.mjs +18 -18
- package/dist/ui/inputs/select/index.js +21 -9
- package/dist/ui/inputs/select/index.mjs +1 -1
- package/dist/ui/inputs/select/select.d.ts +18 -5
- package/dist/ui/inputs/select/select.js +21 -9
- package/dist/ui/inputs/select/select.mjs +1 -1
- package/dist/ui/layout/container/container.mjs +73 -67
- package/dist/ui/layout/container/index.mjs +73 -67
- package/dist/ui/layout/index.mjs +76 -70
- package/dist/ui/layout/page/index.mjs +4 -2
- package/dist/ui/layout/page/page-loading.mjs +4 -2
- package/dist/ui/layout/page/section-loading.mjs +4 -2
- package/dist/ui/navigation/breadcrumbs/breadcrumbs.d.ts +10 -6
- package/dist/ui/navigation/breadcrumbs/breadcrumbs.js +4 -24
- package/dist/ui/navigation/breadcrumbs/breadcrumbs.mjs +1 -1
- package/dist/ui/navigation/breadcrumbs/index.js +4 -24
- package/dist/ui/navigation/breadcrumbs/index.mjs +1 -1
- package/dist/ui/navigation/index.js +4 -14
- package/dist/ui/navigation/index.mjs +9 -9
- package/dist/ui/overlays/index.d.ts +1 -0
- package/dist/ui/overlays/index.js +25 -2
- package/dist/ui/overlays/index.mjs +11 -6
- package/dist/ui/overlays/popover/index.d.ts +1 -0
- package/dist/ui/overlays/popover/index.js +51 -0
- package/dist/ui/overlays/popover/index.mjs +8 -0
- package/dist/ui/overlays/popover/popover.d.ts +10 -0
- package/dist/ui/overlays/popover/popover.js +49 -0
- package/dist/ui/overlays/popover/popover.mjs +7 -0
- package/dist/ui/provider/index.mjs +4 -2
- package/dist/ui/provider/ui-provider.mjs +4 -2
- package/dist/ui/surface/index.mjs +4 -4
- package/dist/ui/theme/colors/common.mjs +3 -3
- package/dist/ui/theme/colors/index.mjs +5 -5
- package/dist/ui/theme/colors/semantic.mjs +4 -4
- package/dist/ui/theme/colors.mjs +5 -5
- package/dist/ui/theme/index.mjs +6 -6
- package/dist/ui/theme/theme.mjs +6 -6
- package/dist/utils/extend-variants.d.ts +41 -0
- package/dist/utils/extend-variants.js +34 -0
- package/dist/utils/extend-variants.mjs +7 -0
- package/dist/utils/index.d.ts +1 -0
- package/dist/utils/index.js +36 -0
- package/dist/utils/index.mjs +8 -0
- package/package.json +5 -3
- package/dist/chunk-4KPEPEPC.mjs +0 -26
- package/dist/chunk-GQ3LBZ2Q.mjs +0 -33
- package/dist/chunk-ONQIPN3G.mjs +0 -14
- package/dist/{chunk-CYSW4N3T.mjs → chunk-3C4DPNCD.mjs} +0 -0
- package/dist/{chunk-IXPMUODA.mjs → chunk-5WDV3PDI.mjs} +6 -6
- /package/dist/{chunk-NMMWGIQE.mjs → chunk-DRZAPJZH.mjs} +0 -0
|
@@ -3,29 +3,29 @@ import {
|
|
|
3
3
|
SwitchField
|
|
4
4
|
} from "../../../../chunk-EC3NSPHR.mjs";
|
|
5
5
|
import "../../../../chunk-CZEO3U25.mjs";
|
|
6
|
-
import "../../../../chunk-
|
|
7
|
-
import "../../../../chunk-
|
|
8
|
-
import "../../../../chunk-N3EAW6UO.mjs";
|
|
6
|
+
import "../../../../chunk-DUQFM3QS.mjs";
|
|
7
|
+
import "../../../../chunk-KTUGFQWJ.mjs";
|
|
9
8
|
import "../../../../chunk-RRA7GWP2.mjs";
|
|
10
9
|
import "../../../../chunk-NOXFF2KJ.mjs";
|
|
11
10
|
import "../../../../chunk-2SNKT7I4.mjs";
|
|
12
|
-
import "../../../../chunk-
|
|
13
|
-
import "../../../../chunk-
|
|
11
|
+
import "../../../../chunk-LLP2PTPK.mjs";
|
|
12
|
+
import "../../../../chunk-E5QSNLSR.mjs";
|
|
13
|
+
import "../../../../chunk-N3EAW6UO.mjs";
|
|
14
14
|
import "../../../../chunk-5HK7HRTR.mjs";
|
|
15
15
|
import "../../../../chunk-HJUZTISD.mjs";
|
|
16
|
-
import "../../../../chunk-V3KKDSQP.mjs";
|
|
17
16
|
import "../../../../chunk-V2HNFTTX.mjs";
|
|
18
17
|
import "../../../../chunk-IAJ6G633.mjs";
|
|
18
|
+
import "../../../../chunk-V3KKDSQP.mjs";
|
|
19
|
+
import "../../../../chunk-LJIVY6GU.mjs";
|
|
20
|
+
import "../../../../chunk-ZRHEFEFS.mjs";
|
|
21
|
+
import "../../../../chunk-V2G5QHZZ.mjs";
|
|
19
22
|
import "../../../../chunk-AQ3ISJKU.mjs";
|
|
20
|
-
import "../../../../chunk-
|
|
23
|
+
import "../../../../chunk-3YOW5DEZ.mjs";
|
|
21
24
|
import "../../../../chunk-WYJW5NNA.mjs";
|
|
22
25
|
import "../../../../chunk-C3MURCMZ.mjs";
|
|
23
26
|
import "../../../../chunk-UUKS7JYX.mjs";
|
|
24
27
|
import "../../../../chunk-C4PCTOGM.mjs";
|
|
25
28
|
import "../../../../chunk-N3QOXWJI.mjs";
|
|
26
|
-
import "../../../../chunk-LJIVY6GU.mjs";
|
|
27
|
-
import "../../../../chunk-ZRHEFEFS.mjs";
|
|
28
|
-
import "../../../../chunk-V2G5QHZZ.mjs";
|
|
29
29
|
export {
|
|
30
30
|
SwitchField
|
|
31
31
|
};
|
|
@@ -3,29 +3,29 @@ import {
|
|
|
3
3
|
TextField
|
|
4
4
|
} from "../../../../chunk-CETCW7DS.mjs";
|
|
5
5
|
import "../../../../chunk-CZEO3U25.mjs";
|
|
6
|
-
import "../../../../chunk-
|
|
7
|
-
import "../../../../chunk-
|
|
8
|
-
import "../../../../chunk-N3EAW6UO.mjs";
|
|
6
|
+
import "../../../../chunk-DUQFM3QS.mjs";
|
|
7
|
+
import "../../../../chunk-KTUGFQWJ.mjs";
|
|
9
8
|
import "../../../../chunk-RRA7GWP2.mjs";
|
|
10
9
|
import "../../../../chunk-NOXFF2KJ.mjs";
|
|
11
10
|
import "../../../../chunk-2SNKT7I4.mjs";
|
|
12
|
-
import "../../../../chunk-
|
|
13
|
-
import "../../../../chunk-
|
|
11
|
+
import "../../../../chunk-LLP2PTPK.mjs";
|
|
12
|
+
import "../../../../chunk-E5QSNLSR.mjs";
|
|
13
|
+
import "../../../../chunk-N3EAW6UO.mjs";
|
|
14
14
|
import "../../../../chunk-5HK7HRTR.mjs";
|
|
15
15
|
import "../../../../chunk-HJUZTISD.mjs";
|
|
16
|
-
import "../../../../chunk-V3KKDSQP.mjs";
|
|
17
16
|
import "../../../../chunk-V2HNFTTX.mjs";
|
|
18
17
|
import "../../../../chunk-IAJ6G633.mjs";
|
|
18
|
+
import "../../../../chunk-V3KKDSQP.mjs";
|
|
19
|
+
import "../../../../chunk-LJIVY6GU.mjs";
|
|
20
|
+
import "../../../../chunk-ZRHEFEFS.mjs";
|
|
21
|
+
import "../../../../chunk-V2G5QHZZ.mjs";
|
|
19
22
|
import "../../../../chunk-AQ3ISJKU.mjs";
|
|
20
|
-
import "../../../../chunk-
|
|
23
|
+
import "../../../../chunk-3YOW5DEZ.mjs";
|
|
21
24
|
import "../../../../chunk-WYJW5NNA.mjs";
|
|
22
25
|
import "../../../../chunk-C3MURCMZ.mjs";
|
|
23
26
|
import "../../../../chunk-UUKS7JYX.mjs";
|
|
24
27
|
import "../../../../chunk-C4PCTOGM.mjs";
|
|
25
28
|
import "../../../../chunk-N3QOXWJI.mjs";
|
|
26
|
-
import "../../../../chunk-LJIVY6GU.mjs";
|
|
27
|
-
import "../../../../chunk-ZRHEFEFS.mjs";
|
|
28
|
-
import "../../../../chunk-V2G5QHZZ.mjs";
|
|
29
29
|
export {
|
|
30
30
|
TextField
|
|
31
31
|
};
|
|
@@ -3,29 +3,29 @@ import {
|
|
|
3
3
|
TextareaField
|
|
4
4
|
} from "../../../../chunk-V4HKGJYK.mjs";
|
|
5
5
|
import "../../../../chunk-CZEO3U25.mjs";
|
|
6
|
-
import "../../../../chunk-
|
|
7
|
-
import "../../../../chunk-
|
|
8
|
-
import "../../../../chunk-N3EAW6UO.mjs";
|
|
6
|
+
import "../../../../chunk-DUQFM3QS.mjs";
|
|
7
|
+
import "../../../../chunk-KTUGFQWJ.mjs";
|
|
9
8
|
import "../../../../chunk-RRA7GWP2.mjs";
|
|
10
9
|
import "../../../../chunk-NOXFF2KJ.mjs";
|
|
11
10
|
import "../../../../chunk-2SNKT7I4.mjs";
|
|
12
|
-
import "../../../../chunk-
|
|
13
|
-
import "../../../../chunk-
|
|
11
|
+
import "../../../../chunk-LLP2PTPK.mjs";
|
|
12
|
+
import "../../../../chunk-E5QSNLSR.mjs";
|
|
13
|
+
import "../../../../chunk-N3EAW6UO.mjs";
|
|
14
14
|
import "../../../../chunk-5HK7HRTR.mjs";
|
|
15
15
|
import "../../../../chunk-HJUZTISD.mjs";
|
|
16
|
-
import "../../../../chunk-V3KKDSQP.mjs";
|
|
17
16
|
import "../../../../chunk-V2HNFTTX.mjs";
|
|
18
17
|
import "../../../../chunk-IAJ6G633.mjs";
|
|
18
|
+
import "../../../../chunk-V3KKDSQP.mjs";
|
|
19
|
+
import "../../../../chunk-LJIVY6GU.mjs";
|
|
20
|
+
import "../../../../chunk-ZRHEFEFS.mjs";
|
|
21
|
+
import "../../../../chunk-V2G5QHZZ.mjs";
|
|
19
22
|
import "../../../../chunk-AQ3ISJKU.mjs";
|
|
20
|
-
import "../../../../chunk-
|
|
23
|
+
import "../../../../chunk-3YOW5DEZ.mjs";
|
|
21
24
|
import "../../../../chunk-WYJW5NNA.mjs";
|
|
22
25
|
import "../../../../chunk-C3MURCMZ.mjs";
|
|
23
26
|
import "../../../../chunk-UUKS7JYX.mjs";
|
|
24
27
|
import "../../../../chunk-C4PCTOGM.mjs";
|
|
25
28
|
import "../../../../chunk-N3QOXWJI.mjs";
|
|
26
|
-
import "../../../../chunk-LJIVY6GU.mjs";
|
|
27
|
-
import "../../../../chunk-ZRHEFEFS.mjs";
|
|
28
|
-
import "../../../../chunk-V2G5QHZZ.mjs";
|
|
29
29
|
export {
|
|
30
30
|
TextareaField
|
|
31
31
|
};
|
|
@@ -105,21 +105,33 @@ var import_react6 = __toESM(require("react"));
|
|
|
105
105
|
var import_select = require("@heroui/select");
|
|
106
106
|
var import_jsx_runtime6 = require("react/jsx-runtime");
|
|
107
107
|
var Select = import_react6.default.forwardRef(
|
|
108
|
-
({ value, items, onChange, ...props }, ref) => {
|
|
109
|
-
const
|
|
108
|
+
({ value, items, onChange, selectionMode, ...props }, ref) => {
|
|
109
|
+
const isMultiple = selectionMode === "multiple";
|
|
110
|
+
const selectedKeys = import_react6.default.useMemo(() => {
|
|
111
|
+
if (value == null) return /* @__PURE__ */ new Set();
|
|
112
|
+
return new Set(Array.isArray(value) ? value : [value]);
|
|
113
|
+
}, [value]);
|
|
114
|
+
const handleSelectionChange = import_react6.default.useCallback(
|
|
115
|
+
(keys) => {
|
|
116
|
+
var _a;
|
|
117
|
+
if (keys === "all") return;
|
|
118
|
+
const selected = Array.from(keys).filter((key) => typeof key === "string");
|
|
119
|
+
if (isMultiple) {
|
|
120
|
+
onChange == null ? void 0 : onChange(selected);
|
|
121
|
+
} else {
|
|
122
|
+
onChange == null ? void 0 : onChange((_a = selected[0]) != null ? _a : null);
|
|
123
|
+
}
|
|
124
|
+
},
|
|
125
|
+
[onChange, isMultiple]
|
|
126
|
+
);
|
|
110
127
|
return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(
|
|
111
128
|
import_select.Select,
|
|
112
129
|
{
|
|
113
130
|
ref,
|
|
114
131
|
items,
|
|
115
|
-
placeholder: " ",
|
|
116
132
|
selectedKeys,
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
if (typeof selected === "string") {
|
|
120
|
-
onChange == null ? void 0 : onChange(selected);
|
|
121
|
-
}
|
|
122
|
-
},
|
|
133
|
+
selectionMode,
|
|
134
|
+
onSelectionChange: handleSelectionChange,
|
|
123
135
|
...props,
|
|
124
136
|
children: (item) => /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(import_select.SelectItem, { children: item.label }, item.key)
|
|
125
137
|
}
|
|
@@ -242,7 +254,7 @@ TextareaField.displayName = "TeachInUI.TextareaField";
|
|
|
242
254
|
// src/ui/form/rhf/fields/select-field.tsx
|
|
243
255
|
var import_react_hook_form5 = require("react-hook-form");
|
|
244
256
|
var import_jsx_runtime15 = require("react/jsx-runtime");
|
|
245
|
-
function SelectField({ name, ...props }) {
|
|
257
|
+
function SelectField({ name, selectionMode, ...props }) {
|
|
246
258
|
const { control } = (0, import_react_hook_form5.useFormContext)();
|
|
247
259
|
return /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(
|
|
248
260
|
import_react_hook_form5.Controller,
|
|
@@ -252,6 +264,7 @@ function SelectField({ name, ...props }) {
|
|
|
252
264
|
render: ({ field, fieldState: { error } }) => /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(
|
|
253
265
|
Select,
|
|
254
266
|
{
|
|
267
|
+
selectionMode,
|
|
255
268
|
value: field.value,
|
|
256
269
|
onChange: (value) => field.onChange(value),
|
|
257
270
|
...props,
|
|
@@ -9,7 +9,7 @@ import {
|
|
|
9
9
|
} from "../../../chunk-W2A6C27Y.mjs";
|
|
10
10
|
import {
|
|
11
11
|
SelectField
|
|
12
|
-
} from "../../../chunk-
|
|
12
|
+
} from "../../../chunk-NLHQDWUK.mjs";
|
|
13
13
|
import {
|
|
14
14
|
SwitchField
|
|
15
15
|
} from "../../../chunk-EC3NSPHR.mjs";
|
|
@@ -32,29 +32,29 @@ import {
|
|
|
32
32
|
EmailField
|
|
33
33
|
} from "../../../chunk-R7LDL5CU.mjs";
|
|
34
34
|
import "../../../chunk-CZEO3U25.mjs";
|
|
35
|
-
import "../../../chunk-
|
|
36
|
-
import "../../../chunk-
|
|
37
|
-
import "../../../chunk-N3EAW6UO.mjs";
|
|
35
|
+
import "../../../chunk-DUQFM3QS.mjs";
|
|
36
|
+
import "../../../chunk-KTUGFQWJ.mjs";
|
|
38
37
|
import "../../../chunk-RRA7GWP2.mjs";
|
|
39
38
|
import "../../../chunk-NOXFF2KJ.mjs";
|
|
40
39
|
import "../../../chunk-2SNKT7I4.mjs";
|
|
41
|
-
import "../../../chunk-
|
|
42
|
-
import "../../../chunk-
|
|
40
|
+
import "../../../chunk-LLP2PTPK.mjs";
|
|
41
|
+
import "../../../chunk-E5QSNLSR.mjs";
|
|
42
|
+
import "../../../chunk-N3EAW6UO.mjs";
|
|
43
43
|
import "../../../chunk-5HK7HRTR.mjs";
|
|
44
44
|
import "../../../chunk-HJUZTISD.mjs";
|
|
45
|
-
import "../../../chunk-V3KKDSQP.mjs";
|
|
46
45
|
import "../../../chunk-V2HNFTTX.mjs";
|
|
47
46
|
import "../../../chunk-IAJ6G633.mjs";
|
|
47
|
+
import "../../../chunk-V3KKDSQP.mjs";
|
|
48
|
+
import "../../../chunk-LJIVY6GU.mjs";
|
|
49
|
+
import "../../../chunk-ZRHEFEFS.mjs";
|
|
50
|
+
import "../../../chunk-V2G5QHZZ.mjs";
|
|
48
51
|
import "../../../chunk-AQ3ISJKU.mjs";
|
|
49
|
-
import "../../../chunk-
|
|
52
|
+
import "../../../chunk-3YOW5DEZ.mjs";
|
|
50
53
|
import "../../../chunk-WYJW5NNA.mjs";
|
|
51
54
|
import "../../../chunk-C3MURCMZ.mjs";
|
|
52
55
|
import "../../../chunk-UUKS7JYX.mjs";
|
|
53
56
|
import "../../../chunk-C4PCTOGM.mjs";
|
|
54
57
|
import "../../../chunk-N3QOXWJI.mjs";
|
|
55
|
-
import "../../../chunk-LJIVY6GU.mjs";
|
|
56
|
-
import "../../../chunk-ZRHEFEFS.mjs";
|
|
57
|
-
import "../../../chunk-V2G5QHZZ.mjs";
|
|
58
58
|
export {
|
|
59
59
|
AutocompleteField,
|
|
60
60
|
CheckboxField,
|
package/dist/ui/format/index.mjs
CHANGED
|
@@ -1,17 +1,5 @@
|
|
|
1
1
|
"use client";
|
|
2
2
|
import "../../chunk-5IHVMMCK.mjs";
|
|
3
|
-
import {
|
|
4
|
-
Plural
|
|
5
|
-
} from "../../chunk-UHLC7GOU.mjs";
|
|
6
|
-
import {
|
|
7
|
-
Time
|
|
8
|
-
} from "../../chunk-3ZTXXJSO.mjs";
|
|
9
|
-
import {
|
|
10
|
-
Boolean
|
|
11
|
-
} from "../../chunk-26RHRVH2.mjs";
|
|
12
|
-
import {
|
|
13
|
-
Currency
|
|
14
|
-
} from "../../chunk-LN7WH3OB.mjs";
|
|
15
3
|
import {
|
|
16
4
|
DateFormat
|
|
17
5
|
} from "../../chunk-BUVPBB4J.mjs";
|
|
@@ -27,6 +15,18 @@ import {
|
|
|
27
15
|
import {
|
|
28
16
|
Percent
|
|
29
17
|
} from "../../chunk-CXAZBWS4.mjs";
|
|
18
|
+
import {
|
|
19
|
+
Plural
|
|
20
|
+
} from "../../chunk-UHLC7GOU.mjs";
|
|
21
|
+
import {
|
|
22
|
+
Time
|
|
23
|
+
} from "../../chunk-3ZTXXJSO.mjs";
|
|
24
|
+
import {
|
|
25
|
+
Boolean
|
|
26
|
+
} from "../../chunk-26RHRVH2.mjs";
|
|
27
|
+
import {
|
|
28
|
+
Currency
|
|
29
|
+
} from "../../chunk-LN7WH3OB.mjs";
|
|
30
30
|
export {
|
|
31
31
|
Boolean as FormatBoolean,
|
|
32
32
|
Currency as FormatCurrency,
|