@ya-accelerators/nextjs-framework 0.0.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/@types/general.d.ts +1 -0
- package/@types/image.d.ts +8 -0
- package/@types/next-auth.d.ts +18 -0
- package/dist/env.client.d.ts +3 -0
- package/dist/env.client.js +9 -0
- package/dist/env.client.js.map +1 -0
- package/dist/env.d.ts +6 -0
- package/dist/env.js +18 -0
- package/dist/env.js.map +1 -0
- package/dist/hooks/date/index.d.ts +11 -0
- package/dist/hooks/date/index.js +14 -0
- package/dist/hooks/date/index.js.map +1 -0
- package/dist/hooks/dispatch/index.d.ts +9 -0
- package/dist/hooks/dispatch/index.jsx +25 -0
- package/dist/hooks/dispatch/index.jsx.map +1 -0
- package/dist/hooks/index.d.ts +6 -0
- package/dist/hooks/index.js +7 -0
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/loading/index.d.ts +10 -0
- package/dist/hooks/loading/index.jsx +22 -0
- package/dist/hooks/loading/index.jsx.map +1 -0
- package/dist/hooks/localStorage/index.d.ts +1 -0
- package/dist/hooks/localStorage/index.js +53 -0
- package/dist/hooks/localStorage/index.js.map +1 -0
- package/dist/hooks/modal/index.d.ts +26 -0
- package/dist/hooks/modal/index.jsx +63 -0
- package/dist/hooks/modal/index.jsx.map +1 -0
- package/dist/hooks/toast/index.d.ts +15 -0
- package/dist/hooks/toast/index.jsx +39 -0
- package/dist/hooks/toast/index.jsx.map +1 -0
- package/dist/i18n/index.d.ts +3 -0
- package/dist/i18n/index.js +40 -0
- package/dist/i18n/index.js.map +1 -0
- package/dist/i18n/strings/en-US.json +18 -0
- package/dist/i18n/strings/ja-JP.json +37 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.js +8 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/cookie/index.d.ts +9 -0
- package/dist/lib/cookie/index.js +66 -0
- package/dist/lib/cookie/index.js.map +1 -0
- package/dist/lib/index.d.ts +10 -0
- package/dist/lib/index.js +11 -0
- package/dist/lib/index.js.map +1 -0
- package/dist/lib/next-auth/index.d.ts +2 -0
- package/dist/lib/next-auth/index.js +62 -0
- package/dist/lib/next-auth/index.js.map +1 -0
- package/dist/lib/s3/index.d.ts +2 -0
- package/dist/lib/s3/index.js +17 -0
- package/dist/lib/s3/index.js.map +1 -0
- package/dist/lib/trpc/index.d.ts +8 -0
- package/dist/lib/trpc/index.js +32 -0
- package/dist/lib/trpc/index.js.map +1 -0
- package/dist/styles/globals.css +26 -0
- package/dist/styles/tailwind.config.d.ts +577 -0
- package/dist/styles/tailwind.config.js +671 -0
- package/dist/styles/tailwind.config.js.map +1 -0
- package/dist/styles/tailwind.config.ts +672 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/dist/ui/component/button/base.d.ts +27 -0
- package/dist/ui/component/button/base.jsx +54 -0
- package/dist/ui/component/button/base.jsx.map +1 -0
- package/dist/ui/component/button/colored/index.d.ts +11 -0
- package/dist/ui/component/button/colored/index.jsx +7 -0
- package/dist/ui/component/button/colored/index.jsx.map +1 -0
- package/dist/ui/component/button/image/index.d.ts +4 -0
- package/dist/ui/component/button/image/index.jsx +5 -0
- package/dist/ui/component/button/image/index.jsx.map +1 -0
- package/dist/ui/component/button/index.d.ts +18 -0
- package/dist/ui/component/button/index.jsx +25 -0
- package/dist/ui/component/button/index.jsx.map +1 -0
- package/dist/ui/component/button/text/index.d.ts +11 -0
- package/dist/ui/component/button/text/index.jsx +8 -0
- package/dist/ui/component/button/text/index.jsx.map +1 -0
- package/dist/ui/component/card/index.d.ts +12 -0
- package/dist/ui/component/card/index.jsx +20 -0
- package/dist/ui/component/card/index.jsx.map +1 -0
- package/dist/ui/component/icon/index.d.ts +7 -0
- package/dist/ui/component/icon/index.jsx +3 -0
- package/dist/ui/component/icon/index.jsx.map +1 -0
- package/dist/ui/component/index.d.ts +95 -0
- package/dist/ui/component/index.js +15 -0
- package/dist/ui/component/index.js.map +1 -0
- package/dist/ui/component/loading/index.d.ts +5 -0
- package/dist/ui/component/loading/index.jsx +27 -0
- package/dist/ui/component/loading/index.jsx.map +1 -0
- package/dist/ui/component/ssr/index.d.ts +5 -0
- package/dist/ui/component/ssr/index.jsx +11 -0
- package/dist/ui/component/ssr/index.jsx.map +1 -0
- package/dist/ui/component/typography/H1/index.d.ts +7 -0
- package/dist/ui/component/typography/H1/index.jsx +13 -0
- package/dist/ui/component/typography/H1/index.jsx.map +1 -0
- package/dist/ui/component/typography/H2/index.d.ts +7 -0
- package/dist/ui/component/typography/H2/index.jsx +13 -0
- package/dist/ui/component/typography/H2/index.jsx.map +1 -0
- package/dist/ui/component/typography/H3/index.d.ts +7 -0
- package/dist/ui/component/typography/H3/index.jsx +13 -0
- package/dist/ui/component/typography/H3/index.jsx.map +1 -0
- package/dist/ui/component/typography/H4/index.d.ts +7 -0
- package/dist/ui/component/typography/H4/index.jsx +13 -0
- package/dist/ui/component/typography/H4/index.jsx.map +1 -0
- package/dist/ui/component/typography/H5/index.d.ts +7 -0
- package/dist/ui/component/typography/H5/index.jsx +13 -0
- package/dist/ui/component/typography/H5/index.jsx.map +1 -0
- package/dist/ui/component/typography/H6/index.d.ts +7 -0
- package/dist/ui/component/typography/H6/index.jsx +13 -0
- package/dist/ui/component/typography/H6/index.jsx.map +1 -0
- package/dist/ui/component/typography/Label/index.d.ts +7 -0
- package/dist/ui/component/typography/Label/index.jsx +13 -0
- package/dist/ui/component/typography/Label/index.jsx.map +1 -0
- package/dist/ui/component/typography/LinkText/index.d.ts +8 -0
- package/dist/ui/component/typography/LinkText/index.jsx +14 -0
- package/dist/ui/component/typography/LinkText/index.jsx.map +1 -0
- package/dist/ui/component/typography/P/index.d.ts +7 -0
- package/dist/ui/component/typography/P/index.jsx +13 -0
- package/dist/ui/component/typography/P/index.jsx.map +1 -0
- package/dist/ui/component/typography/Pre/index.d.ts +7 -0
- package/dist/ui/component/typography/Pre/index.jsx +13 -0
- package/dist/ui/component/typography/Pre/index.jsx.map +1 -0
- package/dist/ui/component/typography/index.d.ts +54 -0
- package/dist/ui/component/typography/index.jsx +23 -0
- package/dist/ui/component/typography/index.jsx.map +1 -0
- package/dist/ui/composite/button/index.d.ts +8 -0
- package/dist/ui/composite/button/index.jsx +45 -0
- package/dist/ui/composite/button/index.jsx.map +1 -0
- package/dist/ui/composite/dropdown/index.d.ts +12 -0
- package/dist/ui/composite/dropdown/index.jsx +102 -0
- package/dist/ui/composite/dropdown/index.jsx.map +1 -0
- package/dist/ui/composite/index.d.ts +342 -0
- package/dist/ui/composite/index.js +13 -0
- package/dist/ui/composite/index.js.map +1 -0
- package/dist/ui/composite/input/address/index.d.ts +33 -0
- package/dist/ui/composite/input/address/index.jsx +132 -0
- package/dist/ui/composite/input/address/index.jsx.map +1 -0
- package/dist/ui/composite/input/address/map.d.ts +64 -0
- package/dist/ui/composite/input/address/map.jsx +111 -0
- package/dist/ui/composite/input/address/map.jsx.map +1 -0
- package/dist/ui/composite/input/address/utils.d.ts +23 -0
- package/dist/ui/composite/input/address/utils.js +63 -0
- package/dist/ui/composite/input/address/utils.js.map +1 -0
- package/dist/ui/composite/input/checkbox/index.d.ts +22 -0
- package/dist/ui/composite/input/checkbox/index.jsx +38 -0
- package/dist/ui/composite/input/checkbox/index.jsx.map +1 -0
- package/dist/ui/composite/input/datePicker/index.d.ts +19 -0
- package/dist/ui/composite/input/datePicker/index.jsx +100 -0
- package/dist/ui/composite/input/datePicker/index.jsx.map +1 -0
- package/dist/ui/composite/input/dateRange/index.d.ts +14 -0
- package/dist/ui/composite/input/dateRange/index.jsx +46 -0
- package/dist/ui/composite/input/dateRange/index.jsx.map +1 -0
- package/dist/ui/composite/input/dateTimePicker/index.d.ts +15 -0
- package/dist/ui/composite/input/dateTimePicker/index.jsx +74 -0
- package/dist/ui/composite/input/dateTimePicker/index.jsx.map +1 -0
- package/dist/ui/composite/input/dateTimeRange/index.d.ts +14 -0
- package/dist/ui/composite/input/dateTimeRange/index.jsx +88 -0
- package/dist/ui/composite/input/dateTimeRange/index.jsx.map +1 -0
- package/dist/ui/composite/input/index.d.ts +216 -0
- package/dist/ui/composite/input/index.js +35 -0
- package/dist/ui/composite/input/index.js.map +1 -0
- package/dist/ui/composite/input/list/index.d.ts +20 -0
- package/dist/ui/composite/input/list/index.jsx +30 -0
- package/dist/ui/composite/input/list/index.jsx.map +1 -0
- package/dist/ui/composite/input/radio/index.d.ts +14 -0
- package/dist/ui/composite/input/radio/index.jsx +34 -0
- package/dist/ui/composite/input/radio/index.jsx.map +1 -0
- package/dist/ui/composite/input/search/index.d.ts +5 -0
- package/dist/ui/composite/input/search/index.jsx +38 -0
- package/dist/ui/composite/input/search/index.jsx.map +1 -0
- package/dist/ui/composite/input/select/ClearIndicator/index.d.ts +4 -0
- package/dist/ui/composite/input/select/ClearIndicator/index.jsx +8 -0
- package/dist/ui/composite/input/select/ClearIndicator/index.jsx.map +1 -0
- package/dist/ui/composite/input/select/Control/index.d.ts +4 -0
- package/dist/ui/composite/input/select/Control/index.jsx +23 -0
- package/dist/ui/composite/input/select/Control/index.jsx.map +1 -0
- package/dist/ui/composite/input/select/DropdownIndicator/index.d.ts +4 -0
- package/dist/ui/composite/input/select/DropdownIndicator/index.jsx +8 -0
- package/dist/ui/composite/input/select/DropdownIndicator/index.jsx.map +1 -0
- package/dist/ui/composite/input/select/GroupHeading/index.d.ts +4 -0
- package/dist/ui/composite/input/select/GroupHeading/index.jsx +9 -0
- package/dist/ui/composite/input/select/GroupHeading/index.jsx.map +1 -0
- package/dist/ui/composite/input/select/Input/index.d.ts +4 -0
- package/dist/ui/composite/input/select/Input/index.jsx +7 -0
- package/dist/ui/composite/input/select/Input/index.jsx.map +1 -0
- package/dist/ui/composite/input/select/Menu/index.d.ts +4 -0
- package/dist/ui/composite/input/select/Menu/index.jsx +19 -0
- package/dist/ui/composite/input/select/Menu/index.jsx.map +1 -0
- package/dist/ui/composite/input/select/MultiValue/index.d.ts +4 -0
- package/dist/ui/composite/input/select/MultiValue/index.jsx +15 -0
- package/dist/ui/composite/input/select/MultiValue/index.jsx.map +1 -0
- package/dist/ui/composite/input/select/Option/index.d.ts +4 -0
- package/dist/ui/composite/input/select/Option/index.jsx +79 -0
- package/dist/ui/composite/input/select/Option/index.jsx.map +1 -0
- package/dist/ui/composite/input/select/Placeholder/index.d.ts +4 -0
- package/dist/ui/composite/input/select/Placeholder/index.jsx +7 -0
- package/dist/ui/composite/input/select/Placeholder/index.jsx.map +1 -0
- package/dist/ui/composite/input/select/SelectContainer/index.d.ts +4 -0
- package/dist/ui/composite/input/select/SelectContainer/index.jsx +40 -0
- package/dist/ui/composite/input/select/SelectContainer/index.jsx.map +1 -0
- package/dist/ui/composite/input/select/SingleValue/index.d.ts +4 -0
- package/dist/ui/composite/input/select/SingleValue/index.jsx +17 -0
- package/dist/ui/composite/input/select/SingleValue/index.jsx.map +1 -0
- package/dist/ui/composite/input/select/index.d.ts +37 -0
- package/dist/ui/composite/input/select/index.jsx +242 -0
- package/dist/ui/composite/input/select/index.jsx.map +1 -0
- package/dist/ui/composite/input/select/types.d.ts +16 -0
- package/dist/ui/composite/input/select/types.js +6 -0
- package/dist/ui/composite/input/select/types.js.map +1 -0
- package/dist/ui/composite/input/text/index.d.ts +15 -0
- package/dist/ui/composite/input/text/index.jsx +40 -0
- package/dist/ui/composite/input/text/index.jsx.map +1 -0
- package/dist/ui/composite/input/textarea/index.d.ts +11 -0
- package/dist/ui/composite/input/textarea/index.jsx +62 -0
- package/dist/ui/composite/input/textarea/index.jsx.map +1 -0
- package/dist/ui/composite/input/timePicker/index.d.ts +13 -0
- package/dist/ui/composite/input/timePicker/index.jsx +36 -0
- package/dist/ui/composite/input/timePicker/index.jsx.map +1 -0
- package/dist/ui/composite/input/timeRange/index.d.ts +16 -0
- package/dist/ui/composite/input/timeRange/index.jsx +54 -0
- package/dist/ui/composite/input/timeRange/index.jsx.map +1 -0
- package/dist/ui/composite/input/weekDaysSelector/index.d.ts +11 -0
- package/dist/ui/composite/input/weekDaysSelector/index.jsx +39 -0
- package/dist/ui/composite/input/weekDaysSelector/index.jsx.map +1 -0
- package/dist/ui/composite/input/weekdayPicker/index.d.ts +13 -0
- package/dist/ui/composite/input/weekdayPicker/index.jsx +49 -0
- package/dist/ui/composite/input/weekdayPicker/index.jsx.map +1 -0
- package/dist/ui/composite/label/index.d.ts +11 -0
- package/dist/ui/composite/label/index.jsx +18 -0
- package/dist/ui/composite/label/index.jsx.map +1 -0
- package/dist/ui/composite/pageTitle/index.d.ts +18 -0
- package/dist/ui/composite/pageTitle/index.jsx +62 -0
- package/dist/ui/composite/pageTitle/index.jsx.map +1 -0
- package/dist/ui/functional/index.d.ts +10 -0
- package/dist/ui/functional/index.js +9 -0
- package/dist/ui/functional/index.js.map +1 -0
- package/dist/ui/functional/notFound/index.d.ts +1 -0
- package/dist/ui/functional/notFound/index.jsx +13 -0
- package/dist/ui/functional/notFound/index.jsx.map +1 -0
- package/dist/ui/functional/signInForm/index.d.ts +4 -0
- package/dist/ui/functional/signInForm/index.jsx +45 -0
- package/dist/ui/functional/signInForm/index.jsx.map +1 -0
- package/dist/ui/functional/signOutForm/index.d.ts +3 -0
- package/dist/ui/functional/signOutForm/index.jsx +29 -0
- package/dist/ui/functional/signOutForm/index.jsx.map +1 -0
- package/dist/ui/index.d.ts +6 -0
- package/dist/ui/index.js +7 -0
- package/dist/ui/index.js.map +1 -0
- package/dist/ui/layout/app/component.d.ts +59 -0
- package/dist/ui/layout/app/component.jsx +224 -0
- package/dist/ui/layout/app/component.jsx.map +1 -0
- package/dist/ui/layout/app/content/index.d.ts +9 -0
- package/dist/ui/layout/app/content/index.jsx +18 -0
- package/dist/ui/layout/app/content/index.jsx.map +1 -0
- package/dist/ui/layout/app/index.d.ts +18 -0
- package/dist/ui/layout/app/index.jsx +40 -0
- package/dist/ui/layout/app/index.jsx.map +1 -0
- package/dist/ui/layout/form/index.d.ts +68 -0
- package/dist/ui/layout/form/index.jsx +558 -0
- package/dist/ui/layout/form/index.jsx.map +1 -0
- package/dist/ui/layout/index.d.ts +356 -0
- package/dist/ui/layout/index.js +19 -0
- package/dist/ui/layout/index.js.map +1 -0
- package/dist/ui/layout/modal/index.d.ts +7 -0
- package/dist/ui/layout/modal/index.jsx +11 -0
- package/dist/ui/layout/modal/index.jsx.map +1 -0
- package/dist/ui/layout/object/index.d.ts +30 -0
- package/dist/ui/layout/object/index.jsx +145 -0
- package/dist/ui/layout/object/index.jsx.map +1 -0
- package/dist/ui/layout/root/index.d.ts +10 -0
- package/dist/ui/layout/root/index.jsx +31 -0
- package/dist/ui/layout/root/index.jsx.map +1 -0
- package/dist/ui/layout/root/provider/index.d.ts +7 -0
- package/dist/ui/layout/root/provider/index.jsx +26 -0
- package/dist/ui/layout/root/provider/index.jsx.map +1 -0
- package/dist/ui/layout/tab/component.d.ts +4 -0
- package/dist/ui/layout/tab/component.jsx +16 -0
- package/dist/ui/layout/tab/component.jsx.map +1 -0
- package/dist/ui/layout/tab/content/index.d.ts +8 -0
- package/dist/ui/layout/tab/content/index.jsx +8 -0
- package/dist/ui/layout/tab/content/index.jsx.map +1 -0
- package/dist/ui/layout/tab/index.d.ts +11 -0
- package/dist/ui/layout/tab/index.jsx +25 -0
- package/dist/ui/layout/tab/index.jsx.map +1 -0
- package/dist/ui/layout/table/index.d.ts +33 -0
- package/dist/ui/layout/table/index.jsx +283 -0
- package/dist/ui/layout/table/index.jsx.map +1 -0
- package/dist/ui/layout/toast/index.d.ts +7 -0
- package/dist/ui/layout/toast/index.jsx +18 -0
- package/dist/ui/layout/toast/index.jsx.map +1 -0
- package/dist/ui/theme/border/index.d.ts +28 -0
- package/dist/ui/theme/border/index.js +67 -0
- package/dist/ui/theme/border/index.js.map +1 -0
- package/dist/ui/theme/color/index.d.ts +32 -0
- package/dist/ui/theme/color/index.js +106 -0
- package/dist/ui/theme/color/index.js.map +1 -0
- package/dist/ui/theme/index.d.ts +4 -0
- package/dist/ui/theme/index.js +5 -0
- package/dist/ui/theme/index.js.map +1 -0
- package/dist/ui/theme/rounded/index.d.ts +9 -0
- package/dist/ui/theme/rounded/index.js +14 -0
- package/dist/ui/theme/rounded/index.js.map +1 -0
- package/dist/ui/theme/size/index.d.ts +15 -0
- package/dist/ui/theme/size/index.js +55 -0
- package/dist/ui/theme/size/index.js.map +1 -0
- package/dist/ui/types/index.d.ts +113 -0
- package/dist/ui/types/index.js +33 -0
- package/dist/ui/types/index.js.map +1 -0
- package/dist/util/client.d.ts +2 -0
- package/dist/util/client.js +4 -0
- package/dist/util/client.js.map +1 -0
- package/dist/util/date/impl.d.ts +7 -0
- package/dist/util/date/impl.js +22 -0
- package/dist/util/date/impl.js.map +1 -0
- package/dist/util/date/index.d.ts +17 -0
- package/dist/util/date/index.js +16 -0
- package/dist/util/date/index.js.map +1 -0
- package/dist/util/index.d.ts +17 -0
- package/dist/util/index.js +143 -0
- package/dist/util/index.js.map +1 -0
- package/package.json +62 -0
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { useCallback, useEffect, useRef, useState } from 'react';
|
|
3
|
+
import { Component } from '../../../component';
|
|
4
|
+
import { DateTimePicker } from '../dateTimePicker';
|
|
5
|
+
const normalizeDateTime = (value, stepMinutes) => {
|
|
6
|
+
if (!value) {
|
|
7
|
+
return undefined;
|
|
8
|
+
}
|
|
9
|
+
const ret = new Date(value);
|
|
10
|
+
ret.setSeconds(0);
|
|
11
|
+
ret.setMilliseconds(0);
|
|
12
|
+
if (stepMinutes > 0) {
|
|
13
|
+
const rounded = Math.round(ret.getMinutes() / stepMinutes) * stepMinutes;
|
|
14
|
+
ret.setMinutes(rounded);
|
|
15
|
+
}
|
|
16
|
+
return ret;
|
|
17
|
+
};
|
|
18
|
+
export const DateTimeRange = ({ defaultValue, name, disabled, error, stepMinutes = 30, // Default to 30 minutes (in seconds)
|
|
19
|
+
onChange, ...props }) => {
|
|
20
|
+
const [startDateTime, setStartDateTime] = useState(() => normalizeDateTime(defaultValue?.start, stepMinutes));
|
|
21
|
+
const [endDateTime, setEndDateTime] = useState(() => normalizeDateTime(defaultValue?.end, stepMinutes));
|
|
22
|
+
useEffect(() => {
|
|
23
|
+
const normalizedStart = normalizeDateTime(defaultValue?.start, stepMinutes);
|
|
24
|
+
const normalizedEnd = normalizeDateTime(defaultValue?.end, stepMinutes);
|
|
25
|
+
if (normalizedStart) {
|
|
26
|
+
// eslint-disable-next-line react-hooks/set-state-in-effect
|
|
27
|
+
setStartDateTime(normalizedStart);
|
|
28
|
+
const minEndTime = new Date(normalizedStart.getTime() + stepMinutes * 60 * 1000);
|
|
29
|
+
setEndDateTime((prevEndDateTime) => {
|
|
30
|
+
const endToUse = normalizedEnd ?? prevEndDateTime;
|
|
31
|
+
if (!endToUse || endToUse.getTime() < minEndTime.getTime()) {
|
|
32
|
+
return minEndTime;
|
|
33
|
+
}
|
|
34
|
+
return endToUse;
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
else if (normalizedEnd) {
|
|
38
|
+
setEndDateTime((prevEndDateTime) => {
|
|
39
|
+
return normalizedEnd ?? prevEndDateTime;
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
}, [defaultValue?.start, defaultValue?.end, stepMinutes]);
|
|
43
|
+
const startTimeRef = useRef(null);
|
|
44
|
+
const endTimeRef = useRef(null);
|
|
45
|
+
const handleStartDateTimeChange = useCallback((newStartDateTime) => {
|
|
46
|
+
const normalizedStart = normalizeDateTime(newStartDateTime, stepMinutes);
|
|
47
|
+
setStartDateTime(normalizedStart);
|
|
48
|
+
if (!normalizedStart) {
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
const minEndTime = new Date(normalizedStart.getTime() + stepMinutes * 60 * 1000);
|
|
52
|
+
setEndDateTime((prevEndDateTime) => {
|
|
53
|
+
if (!prevEndDateTime || prevEndDateTime.getTime() < minEndTime.getTime()) {
|
|
54
|
+
return minEndTime;
|
|
55
|
+
}
|
|
56
|
+
return prevEndDateTime;
|
|
57
|
+
});
|
|
58
|
+
}, [stepMinutes]);
|
|
59
|
+
const handleEndDateTimeChange = useCallback((newEndDateTime) => {
|
|
60
|
+
const normalizedEnd = normalizeDateTime(newEndDateTime, stepMinutes);
|
|
61
|
+
if (startDateTime) {
|
|
62
|
+
const minEndTime = new Date(startDateTime.getTime() + stepMinutes * 60 * 1000);
|
|
63
|
+
if (!normalizedEnd || normalizedEnd.getTime() <= minEndTime.getTime()) {
|
|
64
|
+
setEndDateTime(minEndTime);
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
setEndDateTime(normalizedEnd);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
setEndDateTime(normalizedEnd);
|
|
72
|
+
}
|
|
73
|
+
}, [startDateTime, stepMinutes]);
|
|
74
|
+
return (<div className='gap-control-padding-base flex w-full items-center'>
|
|
75
|
+
<DateTimePicker key={`${name}StartAt-${startDateTime?.toISOString() ?? 'start'}`} {...props} name={`${name}StartAt`} value={startDateTime} onChange={(e) => {
|
|
76
|
+
handleStartDateTimeChange(e);
|
|
77
|
+
onChange?.({ start: e });
|
|
78
|
+
}} disabled={disabled} error={error} stepMinutes={stepMinutes} timeSelectRef={startTimeRef}/>
|
|
79
|
+
<Component.Typography.P container={true} disabled={disabled} className='text-sm'>
|
|
80
|
+
〜
|
|
81
|
+
</Component.Typography.P>
|
|
82
|
+
<DateTimePicker key={`${name}EndAt-${endDateTime?.toISOString() ?? 'end'}`} {...props} name={`${name}EndAt`} value={endDateTime} min={startDateTime ? new Date(startDateTime.getTime() + stepMinutes * 60 * 1000) : undefined} onChange={(e) => {
|
|
83
|
+
handleEndDateTimeChange(e);
|
|
84
|
+
onChange?.({ end: e });
|
|
85
|
+
}} disabled={disabled} error={error} stepMinutes={stepMinutes} timeSelectRef={endTimeRef}/>
|
|
86
|
+
</div>);
|
|
87
|
+
};
|
|
88
|
+
//# sourceMappingURL=index.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.jsx","sourceRoot":"","sources":["../../../../../../src/ui/composite/input/dateTimeRange/index.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,216 @@
|
|
|
1
|
+
import * as address from './address';
|
|
2
|
+
import * as datePicker from './datePicker';
|
|
3
|
+
import * as dateTimePicker from './dateTimePicker';
|
|
4
|
+
import * as select from './select';
|
|
5
|
+
import * as timePicker from './timePicker';
|
|
6
|
+
export declare const Input: {
|
|
7
|
+
WeekDaysSelector: ({ name, short, defaultValue, onChange, disabled, className, error, }: {
|
|
8
|
+
name: string;
|
|
9
|
+
short?: boolean;
|
|
10
|
+
defaultValue?: import("../../..").Weekday | import("../../..").Weekday[] | null;
|
|
11
|
+
onChange?: (value: import("../../..").Weekday | import("../../..").Weekday[]) => void;
|
|
12
|
+
disabled?: boolean;
|
|
13
|
+
className?: string;
|
|
14
|
+
error?: boolean;
|
|
15
|
+
}) => import("react").JSX.Element;
|
|
16
|
+
WeekdayPicker: ({ name, short, defaultValue, onChange, disabled, className, required, multiSelect, error, ...props }: {
|
|
17
|
+
name: string;
|
|
18
|
+
short?: boolean;
|
|
19
|
+
defaultValue?: import("../../..").Weekday | import("../../..").Weekday[] | null;
|
|
20
|
+
onChange?: (value: import("../../..").Weekday | import("../../..").Weekday[]) => void;
|
|
21
|
+
disabled?: boolean;
|
|
22
|
+
className?: string;
|
|
23
|
+
required?: boolean;
|
|
24
|
+
multiSelect?: boolean;
|
|
25
|
+
error?: boolean;
|
|
26
|
+
}) => import("react").JSX.Element;
|
|
27
|
+
TimeRange: ({ defaultValue, name, disabled, error, required, stepMinutes, onChange, ...props }: Omit<import("react").ComponentProps<typeof timePicker.TimePicker>, "defaultValue" | "onChange"> & {
|
|
28
|
+
defaultValue?: {
|
|
29
|
+
start?: string | null;
|
|
30
|
+
end?: string | null;
|
|
31
|
+
};
|
|
32
|
+
error?: boolean;
|
|
33
|
+
required?: boolean;
|
|
34
|
+
disabled?: boolean;
|
|
35
|
+
stepMinutes?: number;
|
|
36
|
+
onChange?: (value: {
|
|
37
|
+
start?: string | null;
|
|
38
|
+
end?: string | null;
|
|
39
|
+
}) => void;
|
|
40
|
+
}) => import("react").JSX.Element;
|
|
41
|
+
TimePicker: ({ min, max, stepMinutes, defaultValue, value, selectRef, ...props }: {
|
|
42
|
+
min?: string | null;
|
|
43
|
+
max?: string | null;
|
|
44
|
+
stepMinutes?: number;
|
|
45
|
+
defaultValue?: string | null;
|
|
46
|
+
value?: string | null;
|
|
47
|
+
selectRef?: React.RefObject<import("react-select").SelectInstance<import("./select/types").SelectOption, boolean> | null>;
|
|
48
|
+
} & Omit<import("react").ComponentProps<typeof select.Select>, "options" | "defaultValue">) => import("react").JSX.Element;
|
|
49
|
+
TextArea: ({ name, color, rounded, disabled, className, required, defaultValue, error, rows, ...props }: {
|
|
50
|
+
name: string;
|
|
51
|
+
color?: import("../..").TextColorTypes;
|
|
52
|
+
rounded?: import("../..").Rounded;
|
|
53
|
+
required?: boolean;
|
|
54
|
+
defaultValue?: string | number | readonly string[] | undefined | null;
|
|
55
|
+
error?: boolean;
|
|
56
|
+
} & Omit<import("react").ComponentProps<"textarea">, "name" | "color" | "defaultValue">) => import("react").JSX.Element;
|
|
57
|
+
Text: ({ name, rounded, focused, color, icon, className, defaultValue, error, inputClassName, isClearable, ...props }: {
|
|
58
|
+
name: string;
|
|
59
|
+
rounded?: import("../..").Rounded;
|
|
60
|
+
focused?: boolean;
|
|
61
|
+
color?: import("../..").TextColorTypes;
|
|
62
|
+
icon?: import("../..").IconType;
|
|
63
|
+
defaultValue?: string | number | readonly string[] | undefined | null;
|
|
64
|
+
error?: boolean;
|
|
65
|
+
inputClassName?: string;
|
|
66
|
+
isClearable?: boolean;
|
|
67
|
+
} & Omit<import("react").ComponentProps<"input">, "name" | "color" | "defaultValue">) => import("react").JSX.Element;
|
|
68
|
+
useScrollToSelectedOnOpen: (args: {
|
|
69
|
+
menuOpen: boolean;
|
|
70
|
+
portalEl?: HTMLElement;
|
|
71
|
+
instanceId: string;
|
|
72
|
+
}) => void;
|
|
73
|
+
Select: import("react").ForwardRefExoticComponent<{
|
|
74
|
+
name: string;
|
|
75
|
+
className?: string;
|
|
76
|
+
options: import("react-select").OptionsOrGroups<import("./select/types").SelectOption, import("react-select").GroupBase<import("./select/types").SelectOption>>;
|
|
77
|
+
defaultValue?: string | number | readonly string[] | undefined | null;
|
|
78
|
+
value?: string;
|
|
79
|
+
onChange?: (value: string) => void;
|
|
80
|
+
disabled?: boolean;
|
|
81
|
+
required?: boolean;
|
|
82
|
+
isMulti?: boolean;
|
|
83
|
+
isSearchable?: boolean;
|
|
84
|
+
isClearable?: boolean;
|
|
85
|
+
placeholder?: string;
|
|
86
|
+
noOptionsMessage?: string;
|
|
87
|
+
showDividerBetweenOptions?: boolean;
|
|
88
|
+
indentPadding?: number;
|
|
89
|
+
autoFocus?: boolean;
|
|
90
|
+
rounded?: import("../..").Rounded;
|
|
91
|
+
error?: boolean;
|
|
92
|
+
} & import("react").RefAttributes<import("react-select").SelectInstance<import("./select/types").SelectOption, boolean>>>;
|
|
93
|
+
Search: ({ value, onUpdate, className, }: {
|
|
94
|
+
value?: string;
|
|
95
|
+
onUpdate: (value: string) => void;
|
|
96
|
+
className?: string;
|
|
97
|
+
}) => import("react").JSX.Element;
|
|
98
|
+
Radio: ({ orientation, name, options, value, defaultValue, onChange, disabled, required, }: {
|
|
99
|
+
orientation: "horizontal" | "vertical";
|
|
100
|
+
name: string;
|
|
101
|
+
options: {
|
|
102
|
+
value: string;
|
|
103
|
+
label: string;
|
|
104
|
+
disabled?: boolean;
|
|
105
|
+
}[];
|
|
106
|
+
value?: string;
|
|
107
|
+
defaultValue?: string | null;
|
|
108
|
+
onChange?: (value: string) => void;
|
|
109
|
+
disabled?: boolean;
|
|
110
|
+
required?: boolean;
|
|
111
|
+
}) => import("react").JSX.Element;
|
|
112
|
+
List: ({ name, rounded, defaultList, minListLength, maxListLength, valueLength, isFirstItem, input, }: {
|
|
113
|
+
name: string;
|
|
114
|
+
rounded?: import("../..").Rounded;
|
|
115
|
+
defaultList: string[][];
|
|
116
|
+
minListLength?: number;
|
|
117
|
+
maxListLength?: number;
|
|
118
|
+
valueLength: number;
|
|
119
|
+
isFirstItem: boolean;
|
|
120
|
+
input: (props: {
|
|
121
|
+
name: string;
|
|
122
|
+
autoFocus: boolean;
|
|
123
|
+
values: string[];
|
|
124
|
+
onChange: (index: number, value: string) => void;
|
|
125
|
+
}) => {
|
|
126
|
+
node: import("react").ReactNode;
|
|
127
|
+
disabled?: boolean;
|
|
128
|
+
};
|
|
129
|
+
}) => import("react").JSX.Element;
|
|
130
|
+
DateTimeRange: ({ defaultValue, name, disabled, error, stepMinutes, onChange, ...props }: Omit<import("react").ComponentProps<typeof dateTimePicker.DateTimePicker>, "defaultValue" | "onChange"> & {
|
|
131
|
+
defaultValue?: {
|
|
132
|
+
start?: Date;
|
|
133
|
+
end?: Date;
|
|
134
|
+
};
|
|
135
|
+
error?: boolean;
|
|
136
|
+
stepMinutes?: number;
|
|
137
|
+
onChange?: (value: {
|
|
138
|
+
start?: Date;
|
|
139
|
+
end?: Date;
|
|
140
|
+
}) => void;
|
|
141
|
+
}) => import("react").JSX.Element;
|
|
142
|
+
DateTimePicker: ({ name, defaultValue, value, min, max, onChange, disabled, required, error, stepMinutes, timeSelectRef, }: {
|
|
143
|
+
name: string;
|
|
144
|
+
defaultValue?: Date;
|
|
145
|
+
value?: Date;
|
|
146
|
+
min?: Date;
|
|
147
|
+
max?: Date;
|
|
148
|
+
onChange?: (value: Date) => void;
|
|
149
|
+
disabled?: boolean;
|
|
150
|
+
required?: boolean;
|
|
151
|
+
error?: boolean;
|
|
152
|
+
stepMinutes?: number;
|
|
153
|
+
timeSelectRef?: React.RefObject<import("react-select").SelectInstance<import("./select/types").SelectOption, boolean> | null>;
|
|
154
|
+
}) => import("react").JSX.Element;
|
|
155
|
+
DateRange: ({ defaultValue, name, disabled, error, stepDays, onChange, ...props }: Omit<import("react").ComponentProps<typeof datePicker.DatePicker>, "defaultValue" | "onChange"> & {
|
|
156
|
+
defaultValue?: {
|
|
157
|
+
start?: Date;
|
|
158
|
+
end?: Date;
|
|
159
|
+
};
|
|
160
|
+
error?: boolean;
|
|
161
|
+
stepDays?: number;
|
|
162
|
+
onChange?: (value: {
|
|
163
|
+
start?: Date;
|
|
164
|
+
end?: Date;
|
|
165
|
+
}) => void;
|
|
166
|
+
}) => import("react").JSX.Element;
|
|
167
|
+
DatePicker: (props: Parameters<({ name, rounded, placement, defaultValue, value, min, max, onChange, disabled, className, required, error, autoFocus, }: {
|
|
168
|
+
name: string;
|
|
169
|
+
rounded?: import("../..").Rounded;
|
|
170
|
+
placement?: "top" | "right" | "bottom" | "left" | "top-start" | "top-end" | "right-start" | "right-end" | "bottom-start" | "bottom-end" | "left-start" | "left-end";
|
|
171
|
+
defaultValue?: Date;
|
|
172
|
+
value?: Date;
|
|
173
|
+
min?: Date;
|
|
174
|
+
max?: Date;
|
|
175
|
+
onChange?: (value?: Date) => void;
|
|
176
|
+
disabled?: boolean;
|
|
177
|
+
className?: string;
|
|
178
|
+
required?: boolean;
|
|
179
|
+
error?: boolean;
|
|
180
|
+
autoFocus?: boolean;
|
|
181
|
+
}) => import("react").JSX.Element>[0]) => import("react").JSX.Element;
|
|
182
|
+
Checkbox: ({ orientation, name, options, defaultValue, onChange, disabled, error, }: {
|
|
183
|
+
orientation: "horizontal" | "vertical";
|
|
184
|
+
name: string;
|
|
185
|
+
options: {
|
|
186
|
+
value: string;
|
|
187
|
+
label: string;
|
|
188
|
+
disabled?: boolean;
|
|
189
|
+
}[];
|
|
190
|
+
defaultValue?: string[] | null;
|
|
191
|
+
onChange?: (values: string[]) => void;
|
|
192
|
+
disabled?: boolean;
|
|
193
|
+
error?: boolean;
|
|
194
|
+
}) => import("react").JSX.Element;
|
|
195
|
+
CheckboxItem: ({ name, checked, onClick, value, label, disabled, error, }: {
|
|
196
|
+
name: string;
|
|
197
|
+
checked: boolean;
|
|
198
|
+
onClick: () => void;
|
|
199
|
+
value: string;
|
|
200
|
+
label: string;
|
|
201
|
+
disabled?: boolean;
|
|
202
|
+
error?: boolean;
|
|
203
|
+
}) => import("react").JSX.Element;
|
|
204
|
+
Address: ({ name, rounded, defaultValue, countryCode, onSearch, onChange, disabled, required, className, googleMapsApiKey, }: {
|
|
205
|
+
name: string;
|
|
206
|
+
rounded?: import("../..").Rounded;
|
|
207
|
+
defaultValue?: address.AddressValue | null;
|
|
208
|
+
countryCode?: string;
|
|
209
|
+
onSearch?: (result: address.AddressValue | null) => void;
|
|
210
|
+
onChange?: (value: address.AddressValue) => void;
|
|
211
|
+
disabled?: boolean;
|
|
212
|
+
required?: boolean;
|
|
213
|
+
className?: string;
|
|
214
|
+
googleMapsApiKey?: string;
|
|
215
|
+
}) => import("react").JSX.Element;
|
|
216
|
+
};
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import * as address from './address';
|
|
2
|
+
import * as checkbox from './checkbox';
|
|
3
|
+
import * as datePicker from './datePicker';
|
|
4
|
+
import * as dateRange from './dateRange';
|
|
5
|
+
import * as dateTimePicker from './dateTimePicker';
|
|
6
|
+
import * as dateTimeRange from './dateTimeRange';
|
|
7
|
+
import * as list from './list';
|
|
8
|
+
import * as radio from './radio';
|
|
9
|
+
import * as search from './search';
|
|
10
|
+
import * as select from './select';
|
|
11
|
+
import * as text from './text';
|
|
12
|
+
import * as textarea from './textarea';
|
|
13
|
+
import * as timePicker from './timePicker';
|
|
14
|
+
import * as timeRange from './timeRange';
|
|
15
|
+
import * as weekdayPicker from './weekdayPicker';
|
|
16
|
+
import * as weekDaysSelector from './weekDaysSelector';
|
|
17
|
+
export const Input = {
|
|
18
|
+
...address,
|
|
19
|
+
...checkbox,
|
|
20
|
+
...datePicker,
|
|
21
|
+
...dateRange,
|
|
22
|
+
...dateTimePicker,
|
|
23
|
+
...dateTimeRange,
|
|
24
|
+
...list,
|
|
25
|
+
...radio,
|
|
26
|
+
...search,
|
|
27
|
+
...select,
|
|
28
|
+
...text,
|
|
29
|
+
...textarea,
|
|
30
|
+
...timePicker,
|
|
31
|
+
...timeRange,
|
|
32
|
+
...weekdayPicker,
|
|
33
|
+
...weekDaysSelector,
|
|
34
|
+
};
|
|
35
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/ui/composite/input/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,WAAW,CAAA;AACpC,OAAO,KAAK,QAAQ,MAAM,YAAY,CAAA;AACtC,OAAO,KAAK,UAAU,MAAM,cAAc,CAAA;AAC1C,OAAO,KAAK,SAAS,MAAM,aAAa,CAAA;AACxC,OAAO,KAAK,cAAc,MAAM,kBAAkB,CAAA;AAClD,OAAO,KAAK,aAAa,MAAM,iBAAiB,CAAA;AAChD,OAAO,KAAK,IAAI,MAAM,QAAQ,CAAA;AAC9B,OAAO,KAAK,KAAK,MAAM,SAAS,CAAA;AAChC,OAAO,KAAK,MAAM,MAAM,UAAU,CAAA;AAClC,OAAO,KAAK,MAAM,MAAM,UAAU,CAAA;AAClC,OAAO,KAAK,IAAI,MAAM,QAAQ,CAAA;AAC9B,OAAO,KAAK,QAAQ,MAAM,YAAY,CAAA;AACtC,OAAO,KAAK,UAAU,MAAM,cAAc,CAAA;AAC1C,OAAO,KAAK,SAAS,MAAM,aAAa,CAAA;AACxC,OAAO,KAAK,aAAa,MAAM,iBAAiB,CAAA;AAChD,OAAO,KAAK,gBAAgB,MAAM,oBAAoB,CAAA;AAEtD,MAAM,CAAC,MAAM,KAAK,GAAG;IACnB,GAAG,OAAO;IACV,GAAG,QAAQ;IACX,GAAG,UAAU;IACb,GAAG,SAAS;IACZ,GAAG,cAAc;IACjB,GAAG,aAAa;IAChB,GAAG,IAAI;IACP,GAAG,KAAK;IACR,GAAG,MAAM;IACT,GAAG,MAAM;IACT,GAAG,IAAI;IACP,GAAG,QAAQ;IACX,GAAG,UAAU;IACb,GAAG,SAAS;IACZ,GAAG,aAAa;IAChB,GAAG,gBAAgB;CACpB,CAAA"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { ReactNode } from 'react';
|
|
2
|
+
import { Rounded } from '../../../theme';
|
|
3
|
+
export declare const List: ({ name, rounded, defaultList, minListLength, maxListLength, valueLength, isFirstItem, input, }: {
|
|
4
|
+
name: string;
|
|
5
|
+
rounded?: Rounded;
|
|
6
|
+
defaultList: string[][];
|
|
7
|
+
minListLength?: number;
|
|
8
|
+
maxListLength?: number;
|
|
9
|
+
valueLength: number;
|
|
10
|
+
isFirstItem: boolean;
|
|
11
|
+
input: (props: {
|
|
12
|
+
name: string;
|
|
13
|
+
autoFocus: boolean;
|
|
14
|
+
values: string[];
|
|
15
|
+
onChange: (index: number, value: string) => void;
|
|
16
|
+
}) => {
|
|
17
|
+
node: ReactNode;
|
|
18
|
+
disabled?: boolean;
|
|
19
|
+
};
|
|
20
|
+
}) => import("react").JSX.Element;
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import AddIcon from '@mui/icons-material/Add';
|
|
3
|
+
import DeleteIcon from '@mui/icons-material/Delete';
|
|
4
|
+
import { useState } from 'react';
|
|
5
|
+
import { Component } from '../../../component';
|
|
6
|
+
import { ColorTypes, ControlSize, Rounded } from '../../../theme';
|
|
7
|
+
export const List = ({ name, rounded = Rounded.m, defaultList, minListLength = 1, maxListLength, valueLength, isFirstItem, input, }) => {
|
|
8
|
+
const [list, setList] = useState(defaultList.length === 0 ? [[...Array(valueLength)].map(() => '')] : defaultList);
|
|
9
|
+
return (<div className='gap-control-padding-base flex w-full flex-col'>
|
|
10
|
+
{list.map((values, i) => {
|
|
11
|
+
const ret = input({
|
|
12
|
+
name: `${name}[${i}]`,
|
|
13
|
+
autoFocus: isFirstItem && i === 0,
|
|
14
|
+
values,
|
|
15
|
+
onChange: (valueIndex, value) => setList((item) => item.map((y, j) => (j === i ? y.map((z, k) => (k === valueIndex ? value : z)) : y))),
|
|
16
|
+
});
|
|
17
|
+
return (<div key={i} className='gap-control-padding-base flex w-full'>
|
|
18
|
+
<div className='gap-control-padding-base flex w-full items-center'>{ret.node}</div>
|
|
19
|
+
<Component.Button variant='colored' size={ControlSize.md} rounded={rounded} color={ColorTypes.secondary} container={true} icon={DeleteIcon} onClick={() => setList((x) => x.filter((_, j) => j !== i))} disabled={list.length === minListLength || ret.disabled === true}/>
|
|
20
|
+
</div>);
|
|
21
|
+
})}
|
|
22
|
+
<Component.Button variant='colored' size={ControlSize.md} rounded={rounded} color={ColorTypes.primary} container={true} icon={AddIcon} onClick={() => {
|
|
23
|
+
if (list.length === maxListLength) {
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
setList([...list, [...Array(valueLength)].map(() => '')]);
|
|
27
|
+
}}/>
|
|
28
|
+
</div>);
|
|
29
|
+
};
|
|
30
|
+
//# sourceMappingURL=index.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.jsx","sourceRoot":"","sources":["../../../../../../src/ui/composite/input/list/index.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export declare const Radio: ({ orientation, name, options, value, defaultValue, onChange, disabled, required, }: {
|
|
2
|
+
orientation: "horizontal" | "vertical";
|
|
3
|
+
name: string;
|
|
4
|
+
options: {
|
|
5
|
+
value: string;
|
|
6
|
+
label: string;
|
|
7
|
+
disabled?: boolean;
|
|
8
|
+
}[];
|
|
9
|
+
value?: string;
|
|
10
|
+
defaultValue?: string | null;
|
|
11
|
+
onChange?: (value: string) => void;
|
|
12
|
+
disabled?: boolean;
|
|
13
|
+
required?: boolean;
|
|
14
|
+
}) => import("react").JSX.Element;
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import RadioButtonCheckedIcon from '@mui/icons-material/RadioButtonChecked';
|
|
3
|
+
import RadioButtonUncheckedIcon from '@mui/icons-material/RadioButtonUnchecked';
|
|
4
|
+
import classNames from 'classnames';
|
|
5
|
+
import { useTranslations } from 'next-intl';
|
|
6
|
+
import { useState } from 'react';
|
|
7
|
+
import { Component } from '../../../component';
|
|
8
|
+
import { getTextColorTypeClassName, TextColorTypes } from '../../../theme';
|
|
9
|
+
export const Radio = ({ orientation, name, options, value, defaultValue, onChange, disabled, required, }) => {
|
|
10
|
+
const isControlled = value !== undefined;
|
|
11
|
+
const [internalValue, setInternalValue] = useState(() => defaultValue ?? (options.length === 0 ? undefined : options[0].value));
|
|
12
|
+
const currentValue = isControlled ? value : internalValue;
|
|
13
|
+
return (<div className={classNames('flex flex-wrap', orientation === 'vertical'
|
|
14
|
+
? 'gap-control-padding-md flex-col'
|
|
15
|
+
: 'gap-control-padding-xl gap-y-control-padding-sm')}>
|
|
16
|
+
{options.map((x, i) => (<RadioItem key={i} name={name} checked={currentValue === x.value} onClick={() => {
|
|
17
|
+
if (!isControlled) {
|
|
18
|
+
setInternalValue(x.value);
|
|
19
|
+
}
|
|
20
|
+
onChange?.(x.value);
|
|
21
|
+
}} disabled={disabled === true || x.disabled === true} required={required} {...x}/>))}
|
|
22
|
+
</div>);
|
|
23
|
+
};
|
|
24
|
+
const RadioItem = ({ name, checked, onClick, value, label, disabled, required, }) => {
|
|
25
|
+
const t = useTranslations();
|
|
26
|
+
return (<fieldset data-disabled={disabled} className={classNames('gap-control-padding-md flex w-fit items-center justify-center whitespace-nowrap', disabled ? 'clickable-disabled' : 'clickable-enabled')} onClick={checked || disabled ? undefined : onClick}>
|
|
27
|
+
<input type='radio' checked={checked} onChange={() => { }} name={name} value={value} className='hidden' required={required && !checked}/>
|
|
28
|
+
{checked ? (<RadioButtonCheckedIcon className={classNames('size-control-base!', getTextColorTypeClassName(TextColorTypes.primary, true))}/>) : (<RadioButtonUncheckedIcon className={classNames('size-control-base!', getTextColorTypeClassName(TextColorTypes.disabled, true))}/>)}
|
|
29
|
+
<Component.Typography.Label container={true} className={classNames('text-xs', disabled ? 'cursor-default' : 'cursor-pointer')}>
|
|
30
|
+
{t(label)}
|
|
31
|
+
</Component.Typography.Label>
|
|
32
|
+
</fieldset>);
|
|
33
|
+
};
|
|
34
|
+
//# sourceMappingURL=index.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.jsx","sourceRoot":"","sources":["../../../../../../src/ui/composite/input/radio/index.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import SearchIcon from '@mui/icons-material/Search';
|
|
3
|
+
import classNames from 'classnames';
|
|
4
|
+
import { useEffect, useRef, useState } from 'react';
|
|
5
|
+
import { Text } from '../text';
|
|
6
|
+
export const Search = ({ value, onUpdate, className, }) => {
|
|
7
|
+
const [localQuery, setLocalQuery] = useState(value ?? '');
|
|
8
|
+
const debounceTimerRef = useRef(null);
|
|
9
|
+
useEffect(() => () => {
|
|
10
|
+
if (debounceTimerRef.current) {
|
|
11
|
+
clearTimeout(debounceTimerRef.current);
|
|
12
|
+
}
|
|
13
|
+
}, []);
|
|
14
|
+
const isComposingRef = useRef(false);
|
|
15
|
+
return (<Text name='search' placeholder='Search' icon={SearchIcon} className={classNames('w-full', className)} value={localQuery} onChange={(e) => {
|
|
16
|
+
setLocalQuery(e.target.value);
|
|
17
|
+
if (isComposingRef.current) {
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
20
|
+
if (debounceTimerRef.current) {
|
|
21
|
+
clearTimeout(debounceTimerRef.current);
|
|
22
|
+
}
|
|
23
|
+
debounceTimerRef.current = setTimeout(() => onUpdate(e.target.value), 400);
|
|
24
|
+
}} onCompositionStart={() => {
|
|
25
|
+
isComposingRef.current = true;
|
|
26
|
+
if (debounceTimerRef.current) {
|
|
27
|
+
clearTimeout(debounceTimerRef.current);
|
|
28
|
+
}
|
|
29
|
+
}} onCompositionEnd={(e) => {
|
|
30
|
+
isComposingRef.current = false;
|
|
31
|
+
const newValue = e.currentTarget.value;
|
|
32
|
+
if (debounceTimerRef.current) {
|
|
33
|
+
clearTimeout(debounceTimerRef.current);
|
|
34
|
+
}
|
|
35
|
+
debounceTimerRef.current = setTimeout(() => onUpdate(newValue), 400);
|
|
36
|
+
}}/>);
|
|
37
|
+
};
|
|
38
|
+
//# sourceMappingURL=index.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.jsx","sourceRoot":"","sources":["../../../../../../src/ui/composite/input/search/index.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAA;AAEZ,OAAO,UAAU,MAAM,4BAA4B,CAAA;AACnD,OAAO,UAAU,MAAM,YAAY,CAAA;AACnC,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAEnD,OAAO,EAAE,IAAI,EAAE,MAAM,SAAS,CAAA;AAE9B,MAAM,CAAC,MAAM,MAAM,GAAG,CAAC,EACrB,KAAK,EACL,QAAQ,EACR,SAAS,GAKV,EAAE,EAAE;IACH,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAC,KAAK,IAAI,EAAE,CAAC,CAAA;IAEzD,MAAM,gBAAgB,GAAG,MAAM,CAAwB,IAAI,CAAC,CAAA;IAC5D,SAAS,CACP,GAAG,EAAE,CAAC,GAAG,EAAE;QACT,IAAI,gBAAgB,CAAC,OAAO,EAAE,CAAC;YAC7B,YAAY,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAA;QACxC,CAAC;IACH,CAAC,EACD,EAAE,CACH,CAAA;IAED,MAAM,cAAc,GAAG,MAAM,CAAC,KAAK,CAAC,CAAA;IACpC,OAAO,CACL,CAAC,IAAI,CACH,IAAI,CAAC,QAAQ,CACb,WAAW,CAAC,QAAQ,CACpB,IAAI,CAAC,CAAC,UAAU,CAAC,CACjB,SAAS,CAAC,CAAC,UAAU,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC,CAC3C,KAAK,CAAC,CAAC,UAAU,CAAC,CAClB,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE;YACd,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;YAC7B,IAAI,cAAc,CAAC,OAAO,EAAE,CAAC;gBAC3B,OAAM;YACR,CAAC;YACD,IAAI,gBAAgB,CAAC,OAAO,EAAE,CAAC;gBAC7B,YAAY,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAA;YACxC,CAAC;YACD,gBAAgB,CAAC,OAAO,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,GAAG,CAAC,CAAA;QAC5E,CAAC,CAAC,CACF,kBAAkB,CAAC,CAAC,GAAG,EAAE;YACvB,cAAc,CAAC,OAAO,GAAG,IAAI,CAAA;YAC7B,IAAI,gBAAgB,CAAC,OAAO,EAAE,CAAC;gBAC7B,YAAY,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAA;YACxC,CAAC;QACH,CAAC,CAAC,CACF,gBAAgB,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE;YACtB,cAAc,CAAC,OAAO,GAAG,KAAK,CAAA;YAC9B,MAAM,QAAQ,GAAG,CAAC,CAAC,aAAa,CAAC,KAAK,CAAA;YAEtC,IAAI,gBAAgB,CAAC,OAAO,EAAE,CAAC;gBAC7B,YAAY,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAA;YACxC,CAAC;YACD,gBAAgB,CAAC,OAAO,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,GAAG,CAAC,CAAA;QACtE,CAAC,CAAC,EACF,CACH,CAAA;AACH,CAAC,CAAA"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import ClearIcon from '@mui/icons-material/Clear';
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import { components } from 'react-select';
|
|
5
|
+
export const ClearIndicator = (props) => props.selectProps.required === null ? null : (<components.ClearIndicator {...props}>
|
|
6
|
+
<ClearIcon className='size-control-sm!'/>
|
|
7
|
+
</components.ClearIndicator>);
|
|
8
|
+
//# sourceMappingURL=index.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.jsx","sourceRoot":"","sources":["../../../../../../../src/ui/composite/input/select/ClearIndicator/index.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAA;AAEZ,OAAO,SAAS,MAAM,2BAA2B,CAAA;AACjD,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAA4B,UAAU,EAAkB,MAAM,cAAc,CAAA;AAInF,MAAM,CAAC,MAAM,cAAc,GAAkF,CAC3G,KAA0E,EAC1E,EAAE,CACF,KAAK,CAAC,WAAW,CAAC,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAC3C,CAAC,UAAU,CAAC,cAAc,CAAC,IAAI,KAAK,CAAC,CACnC;MAAA,CAAC,SAAS,CAAC,SAAS,CAAC,kBAAkB,EACzC;IAAA,EAAE,UAAU,CAAC,cAAc,CAAC,CAC7B,CAAA"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import classNames from 'classnames';
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import { components } from 'react-select';
|
|
5
|
+
import { BackgroundColorTypes, BorderColorTypes, BorderWidth, getBackgroundColorTypeClassName, getBorderColorTypeClassName, getRoundedClassName, Rounded, } from '../../../../theme';
|
|
6
|
+
export const Control = (props) => {
|
|
7
|
+
const { children, ...rest } = props;
|
|
8
|
+
return (<components.Control {...rest}>
|
|
9
|
+
<div className={classNames('flex items-center w-full pl-control-padding-base pr-control-padding-md', getBackgroundColorTypeClassName(BackgroundColorTypes.default), getRoundedClassName(props.selectProps.rounded || Rounded.m), getBorderColorTypeClassName({
|
|
10
|
+
color: props.selectProps.error
|
|
11
|
+
? BorderColorTypes.error
|
|
12
|
+
: props.isFocused
|
|
13
|
+
? BorderColorTypes.primary
|
|
14
|
+
: BorderColorTypes.default,
|
|
15
|
+
container: true,
|
|
16
|
+
width: BorderWidth.base,
|
|
17
|
+
type: 'outline',
|
|
18
|
+
}))}>
|
|
19
|
+
{children}
|
|
20
|
+
</div>
|
|
21
|
+
</components.Control>);
|
|
22
|
+
};
|
|
23
|
+
//# sourceMappingURL=index.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.jsx","sourceRoot":"","sources":["../../../../../../../src/ui/composite/input/select/Control/index.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAA;AAEZ,OAAO,UAAU,MAAM,YAAY,CAAA;AACnC,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,UAAU,EAAqC,MAAM,cAAc,CAAA;AAE5E,OAAO,EACL,oBAAoB,EACpB,gBAAgB,EAChB,WAAW,EACX,+BAA+B,EAC/B,2BAA2B,EAC3B,mBAAmB,EACnB,OAAO,GACR,MAAM,mBAAmB,CAAA;AAG1B,MAAM,CAAC,MAAM,OAAO,GAA2E,CAC7F,KAAmE,EACnE,EAAE;IACF,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAI,EAAE,GAAG,KAAK,CAAA;IACnC,OAAO,CACL,CAAC,UAAU,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,CAC3B;MAAA,CAAC,GAAG,CACF,SAAS,CAAC,CAAC,UAAU,CACnB,wEAAwE,EACxE,+BAA+B,CAAC,oBAAoB,CAAC,OAAO,CAAC,EAC7D,mBAAmB,CAAC,KAAK,CAAC,WAAW,CAAC,OAAO,IAAI,OAAO,CAAC,CAAC,CAAC,EAC3D,2BAA2B,CAAC;YAC1B,KAAK,EAAE,KAAK,CAAC,WAAW,CAAC,KAAK;gBAC5B,CAAC,CAAC,gBAAgB,CAAC,KAAK;gBACxB,CAAC,CAAC,KAAK,CAAC,SAAS;oBACf,CAAC,CAAC,gBAAgB,CAAC,OAAO;oBAC1B,CAAC,CAAC,gBAAgB,CAAC,OAAO;YAC9B,SAAS,EAAE,IAAI;YACf,KAAK,EAAE,WAAW,CAAC,IAAI;YACvB,IAAI,EAAE,SAAS;SAChB,CAAC,CACH,CAAC,CAEF;QAAA,CAAC,QAAQ,CACX;MAAA,EAAE,GAAG,CACP;IAAA,EAAE,UAAU,CAAC,OAAO,CAAC,CACtB,CAAA;AACH,CAAC,CAAA"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { type DropdownIndicatorProps, type GroupBase } from 'react-select';
|
|
3
|
+
import type { SelectOption } from '../types';
|
|
4
|
+
export declare const DropdownIndicator: React.FC<DropdownIndicatorProps<SelectOption, boolean, GroupBase<SelectOption>>>;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import ArrowDropDownIcon from '@mui/icons-material/ArrowDropDown';
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import { components } from 'react-select';
|
|
5
|
+
export const DropdownIndicator = (props) => (<components.DropdownIndicator {...props}>
|
|
6
|
+
<ArrowDropDownIcon className='size-control-md!'/>
|
|
7
|
+
</components.DropdownIndicator>);
|
|
8
|
+
//# sourceMappingURL=index.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.jsx","sourceRoot":"","sources":["../../../../../../../src/ui/composite/input/select/DropdownIndicator/index.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAA;AAEZ,OAAO,iBAAiB,MAAM,mCAAmC,CAAA;AACjE,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,UAAU,EAA+C,MAAM,cAAc,CAAA;AAItF,MAAM,CAAC,MAAM,iBAAiB,GAAqF,CACjH,KAA6E,EAC7E,EAAE,CAAC,CACH,CAAC,UAAU,CAAC,iBAAiB,CAAC,IAAI,KAAK,CAAC,CACtC;IAAA,CAAC,iBAAiB,CAAC,SAAS,CAAC,kBAAkB,EACjD;EAAA,EAAE,UAAU,CAAC,iBAAiB,CAAC,CAChC,CAAA"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import classNames from 'classnames';
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import { components } from 'react-select';
|
|
5
|
+
import { getTextColorTypeClassName, TextColorTypes } from '../../../../theme';
|
|
6
|
+
export const GroupHeading = (props) => (<div className={classNames('font-semibold text-sm', getTextColorTypeClassName(TextColorTypes.main, false))}>
|
|
7
|
+
<components.GroupHeading {...props} className='cursor-default px-control-padding-base py-control-padding-md'/>
|
|
8
|
+
</div>);
|
|
9
|
+
//# sourceMappingURL=index.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.jsx","sourceRoot":"","sources":["../../../../../../../src/ui/composite/input/select/GroupHeading/index.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAA;AAEZ,OAAO,UAAU,MAAM,YAAY,CAAA;AACnC,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,UAAU,EAA0C,MAAM,cAAc,CAAA;AAEjF,OAAO,EAAE,yBAAyB,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAA;AAG7E,MAAM,CAAC,MAAM,YAAY,GAAgF,CACvG,KAAwE,EACxE,EAAE,CAAC,CACH,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,UAAU,CAAC,uBAAuB,EAAE,yBAAyB,CAAC,cAAc,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,CACzG;IAAA,CAAC,UAAU,CAAC,YAAY,CAAC,IAAI,KAAK,CAAC,CAAC,SAAS,CAAC,8DAA8D,EAC9G;EAAA,EAAE,GAAG,CAAC,CACP,CAAA"}
|