@tokis/react 1.0.1 → 1.1.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/README.md +8 -6
- package/dist/__tests__/Accordion.test.d.ts +2 -0
- package/dist/__tests__/Accordion.test.d.ts.map +1 -0
- package/dist/__tests__/Accordion.test.js +144 -0
- package/dist/__tests__/Accordion.test.js.map +1 -0
- package/dist/__tests__/Button.test.d.ts +2 -0
- package/dist/__tests__/Button.test.d.ts.map +1 -0
- package/dist/__tests__/Button.test.js +104 -0
- package/dist/__tests__/Button.test.js.map +1 -0
- package/dist/__tests__/Checkbox.test.d.ts +2 -0
- package/dist/__tests__/Checkbox.test.d.ts.map +1 -0
- package/dist/__tests__/Checkbox.test.js +90 -0
- package/dist/__tests__/Checkbox.test.js.map +1 -0
- package/dist/__tests__/Select.test.d.ts +2 -0
- package/dist/__tests__/Select.test.d.ts.map +1 -0
- package/dist/__tests__/Select.test.js +119 -0
- package/dist/__tests__/Select.test.js.map +1 -0
- package/dist/__tests__/datagrid-utils.test.d.ts +2 -0
- package/dist/__tests__/datagrid-utils.test.d.ts.map +1 -0
- package/dist/__tests__/datagrid-utils.test.js +190 -0
- package/dist/__tests__/datagrid-utils.test.js.map +1 -0
- package/dist/__tests__/date-utils.test.d.ts +2 -0
- package/dist/__tests__/date-utils.test.d.ts.map +1 -0
- package/dist/__tests__/date-utils.test.js +180 -0
- package/dist/__tests__/date-utils.test.js.map +1 -0
- package/dist/cjs/components/accordion/index.js +1 -1
- package/dist/cjs/components/checkbox/index.js +2 -1
- package/dist/cjs/components/datagrid/index.js +161 -0
- package/dist/cjs/components/datagrid/types.js +2 -0
- package/dist/cjs/components/datagrid/utils.js +87 -0
- package/dist/cjs/components/datepicker/Calendar.js +117 -0
- package/dist/cjs/components/datepicker/date-utils.js +121 -0
- package/dist/cjs/components/datepicker/index.js +134 -0
- package/dist/cjs/components/extended/index.js +39 -31
- package/dist/cjs/components/layout/index.js +5 -4
- package/dist/cjs/components/treeview/index.js +1 -1
- package/dist/cjs/hooks/useId.js +18 -5
- package/dist/cjs/index.js +2 -0
- package/dist/components/accordion/index.js +1 -1
- package/dist/components/accordion/index.js.map +1 -1
- package/dist/components/checkbox/index.js +2 -1
- package/dist/components/checkbox/index.js.map +1 -1
- package/dist/components/datagrid/index.d.ts +20 -0
- package/dist/components/datagrid/index.d.ts.map +1 -0
- package/dist/components/datagrid/index.js +159 -0
- package/dist/components/datagrid/index.js.map +1 -0
- package/dist/components/datagrid/types.d.ts +92 -0
- package/dist/components/datagrid/types.d.ts.map +1 -0
- package/dist/components/datagrid/types.js +2 -0
- package/dist/components/datagrid/types.js.map +1 -0
- package/dist/components/datagrid/utils.d.ts +14 -0
- package/dist/components/datagrid/utils.d.ts.map +1 -0
- package/dist/components/datagrid/utils.js +80 -0
- package/dist/components/datagrid/utils.js.map +1 -0
- package/dist/components/datepicker/Calendar.d.ts +30 -0
- package/dist/components/datepicker/Calendar.d.ts.map +1 -0
- package/dist/components/datepicker/Calendar.js +115 -0
- package/dist/components/datepicker/Calendar.js.map +1 -0
- package/dist/components/datepicker/date-utils.d.ts +34 -0
- package/dist/components/datepicker/date-utils.d.ts.map +1 -0
- package/dist/components/datepicker/date-utils.js +107 -0
- package/dist/components/datepicker/date-utils.js.map +1 -0
- package/dist/components/datepicker/index.d.ts +52 -0
- package/dist/components/datepicker/index.d.ts.map +1 -0
- package/dist/components/datepicker/index.js +128 -0
- package/dist/components/datepicker/index.js.map +1 -0
- package/dist/components/extended/index.d.ts +14 -29
- package/dist/components/extended/index.d.ts.map +1 -1
- package/dist/components/extended/index.js +40 -27
- package/dist/components/extended/index.js.map +1 -1
- package/dist/components/layout/index.d.ts.map +1 -1
- package/dist/components/layout/index.js +5 -4
- package/dist/components/layout/index.js.map +1 -1
- package/dist/components/treeview/index.js +1 -1
- package/dist/components/treeview/index.js.map +1 -1
- package/dist/hooks/useId.d.ts +13 -3
- package/dist/hooks/useId.d.ts.map +1 -1
- package/dist/hooks/useId.js +19 -6
- package/dist/hooks/useId.js.map +1 -1
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -1
- package/package.json +7 -7
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* Calendar — standalone month-grid date picker widget.
|
|
4
|
+
*
|
|
5
|
+
* Implements WAI-ARIA Calendar / Date Grid pattern:
|
|
6
|
+
* - role="grid" on the day grid
|
|
7
|
+
* - role="gridcell" on each day
|
|
8
|
+
* - Arrow keys navigate within the grid
|
|
9
|
+
* - Enter/Space selects the focused date
|
|
10
|
+
* - Page Up/Down → prev/next month
|
|
11
|
+
* - Ctrl+Page Up/Down → prev/next year
|
|
12
|
+
* - Home/End → first/last day of current week
|
|
13
|
+
*/
|
|
14
|
+
import { useState, useRef, useCallback } from 'react';
|
|
15
|
+
import { DAYS_OF_WEEK, MONTHS, buildCalendarGrid, daysInMonth, formatDate, isSameDay, isBeforeDay, isAfterDay, today, parseDate, } from './date-utils.js';
|
|
16
|
+
import { cn } from '../../utils/cn.js';
|
|
17
|
+
export function Calendar({ value, onChange, min, max, defaultMonth, className }) {
|
|
18
|
+
const selectedDate = parseDate(value);
|
|
19
|
+
const minDate = parseDate(min);
|
|
20
|
+
const maxDate = parseDate(max);
|
|
21
|
+
const todayDate = today();
|
|
22
|
+
const initialYear = defaultMonth?.year ?? selectedDate?.getFullYear() ?? todayDate.getFullYear();
|
|
23
|
+
const initialMonth = defaultMonth?.month ?? selectedDate?.getMonth() ?? todayDate.getMonth();
|
|
24
|
+
const [viewYear, setViewYear] = useState(initialYear);
|
|
25
|
+
const [viewMonth, setViewMonth] = useState(initialMonth);
|
|
26
|
+
const [focusedDate, setFocusedDate] = useState(selectedDate ?? todayDate);
|
|
27
|
+
const gridRef = useRef(null);
|
|
28
|
+
const grid = buildCalendarGrid(viewYear, viewMonth);
|
|
29
|
+
const navigateMonth = (delta) => {
|
|
30
|
+
setViewMonth((m) => {
|
|
31
|
+
const next = m + delta;
|
|
32
|
+
if (next < 0) {
|
|
33
|
+
setViewYear((y) => y - 1);
|
|
34
|
+
return 11;
|
|
35
|
+
}
|
|
36
|
+
if (next > 11) {
|
|
37
|
+
setViewYear((y) => y + 1);
|
|
38
|
+
return 0;
|
|
39
|
+
}
|
|
40
|
+
return next;
|
|
41
|
+
});
|
|
42
|
+
};
|
|
43
|
+
const navigateYear = (delta) => {
|
|
44
|
+
setViewYear((y) => y + delta);
|
|
45
|
+
};
|
|
46
|
+
const selectDate = useCallback((date) => {
|
|
47
|
+
if (minDate && isBeforeDay(date, minDate))
|
|
48
|
+
return;
|
|
49
|
+
if (maxDate && isAfterDay(date, maxDate))
|
|
50
|
+
return;
|
|
51
|
+
onChange?.(formatDate(date));
|
|
52
|
+
}, [onChange, minDate, maxDate]);
|
|
53
|
+
const handleKeyDown = (e) => {
|
|
54
|
+
let next = new Date(focusedDate);
|
|
55
|
+
switch (e.key) {
|
|
56
|
+
case 'ArrowRight':
|
|
57
|
+
next.setDate(next.getDate() + 1);
|
|
58
|
+
break;
|
|
59
|
+
case 'ArrowLeft':
|
|
60
|
+
next.setDate(next.getDate() - 1);
|
|
61
|
+
break;
|
|
62
|
+
case 'ArrowDown':
|
|
63
|
+
next.setDate(next.getDate() + 7);
|
|
64
|
+
break;
|
|
65
|
+
case 'ArrowUp':
|
|
66
|
+
next.setDate(next.getDate() - 7);
|
|
67
|
+
break;
|
|
68
|
+
case 'Home':
|
|
69
|
+
next = new Date(next.getFullYear(), next.getMonth(), 1);
|
|
70
|
+
break;
|
|
71
|
+
case 'End':
|
|
72
|
+
next = new Date(next.getFullYear(), next.getMonth(), daysInMonth(next.getFullYear(), next.getMonth()));
|
|
73
|
+
break;
|
|
74
|
+
case 'PageUp':
|
|
75
|
+
e.ctrlKey ? navigateYear(-1) : navigateMonth(-1);
|
|
76
|
+
return;
|
|
77
|
+
case 'PageDown':
|
|
78
|
+
e.ctrlKey ? navigateYear(1) : navigateMonth(1);
|
|
79
|
+
return;
|
|
80
|
+
case 'Enter':
|
|
81
|
+
case ' ':
|
|
82
|
+
e.preventDefault();
|
|
83
|
+
selectDate(focusedDate);
|
|
84
|
+
return;
|
|
85
|
+
default: return;
|
|
86
|
+
}
|
|
87
|
+
e.preventDefault();
|
|
88
|
+
setFocusedDate(next);
|
|
89
|
+
// Auto-navigate view if the focused date is outside the current view month
|
|
90
|
+
if (next.getFullYear() !== viewYear || next.getMonth() !== viewMonth) {
|
|
91
|
+
setViewYear(next.getFullYear());
|
|
92
|
+
setViewMonth(next.getMonth());
|
|
93
|
+
}
|
|
94
|
+
// Re-focus the cell after state update
|
|
95
|
+
requestAnimationFrame(() => {
|
|
96
|
+
const cell = gridRef.current?.querySelector('[tabindex="0"]');
|
|
97
|
+
cell?.focus();
|
|
98
|
+
});
|
|
99
|
+
};
|
|
100
|
+
return (_jsxs("div", { className: cn('tokis-calendar', className), role: "group", "aria-label": "Calendar", children: [_jsxs("div", { className: "tokis-calendar-nav", children: [_jsx("button", { type: "button", className: "tokis-calendar-nav-btn", onClick: () => navigateYear(-1), "aria-label": "Previous year", children: "\u00AB" }), _jsx("button", { type: "button", className: "tokis-calendar-nav-btn", onClick: () => navigateMonth(-1), "aria-label": "Previous month", children: "\u2039" }), _jsxs("span", { className: "tokis-calendar-title", "aria-live": "polite", "aria-atomic": "true", children: [MONTHS[viewMonth], " ", viewYear] }), _jsx("button", { type: "button", className: "tokis-calendar-nav-btn", onClick: () => navigateMonth(1), "aria-label": "Next month", children: "\u203A" }), _jsx("button", { type: "button", className: "tokis-calendar-nav-btn", onClick: () => navigateYear(1), "aria-label": "Next year", children: "\u00BB" })] }), _jsxs("table", { ref: gridRef, className: "tokis-calendar-grid", role: "grid", "aria-label": `${MONTHS[viewMonth]} ${viewYear}`, onKeyDown: handleKeyDown, children: [_jsx("thead", { children: _jsx("tr", { role: "row", children: DAYS_OF_WEEK.map((d) => (_jsx("th", { role: "columnheader", abbr: d, className: "tokis-calendar-weekday", scope: "col", children: d }, d))) }) }), _jsx("tbody", { children: grid.map((week, wi) => (_jsx("tr", { role: "row", children: week.map((day) => {
|
|
101
|
+
const isCurrentMonth = day.getMonth() === viewMonth;
|
|
102
|
+
const isSelected = selectedDate ? isSameDay(day, selectedDate) : false;
|
|
103
|
+
const isToday = isSameDay(day, todayDate);
|
|
104
|
+
const isFocused = isSameDay(day, focusedDate);
|
|
105
|
+
const isDisabled = Boolean((minDate && isBeforeDay(day, minDate)) ||
|
|
106
|
+
(maxDate && isAfterDay(day, maxDate)));
|
|
107
|
+
return (_jsx("td", { role: "gridcell", "aria-selected": isSelected, "aria-disabled": isDisabled, "aria-label": day.toLocaleDateString('en-US', { weekday: 'long', month: 'long', day: 'numeric', year: 'numeric' }), "aria-current": isToday ? 'date' : undefined, tabIndex: isFocused ? 0 : -1, className: cn('tokis-calendar-day', !isCurrentMonth && 'tokis-calendar-day--outside', isSelected && 'tokis-calendar-day--selected', isToday && 'tokis-calendar-day--today', isDisabled && 'tokis-calendar-day--disabled', isFocused && 'tokis-calendar-day--focused'), onClick: () => !isDisabled && selectDate(day), onFocus: () => setFocusedDate(day), children: day.getDate() }, day.toISOString()));
|
|
108
|
+
}) }, wi))) })] }), _jsx("div", { className: "tokis-calendar-footer", children: _jsx("button", { type: "button", className: "tokis-calendar-today-btn", onClick: () => {
|
|
109
|
+
setViewYear(todayDate.getFullYear());
|
|
110
|
+
setViewMonth(todayDate.getMonth());
|
|
111
|
+
setFocusedDate(todayDate);
|
|
112
|
+
selectDate(todayDate);
|
|
113
|
+
}, children: "Today" }) })] }));
|
|
114
|
+
}
|
|
115
|
+
//# sourceMappingURL=Calendar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Calendar.js","sourceRoot":"","sources":["../../../src/components/datepicker/Calendar.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Zero-dependency date utilities for the DatePicker calendar.
|
|
3
|
+
* All functions operate on plain JS Date objects or ISO YYYY-MM-DD strings.
|
|
4
|
+
*/
|
|
5
|
+
export declare const DAYS_OF_WEEK: readonly ["Su", "Mo", "Tu", "We", "Th", "Fr", "Sa"];
|
|
6
|
+
export declare const MONTHS: readonly ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"];
|
|
7
|
+
/** Parse a YYYY-MM-DD string → local Date (midnight). Returns null if invalid. */
|
|
8
|
+
export declare function parseDate(iso: string | undefined): Date | null;
|
|
9
|
+
/** Format a Date → YYYY-MM-DD string. */
|
|
10
|
+
export declare function formatDate(date: Date): string;
|
|
11
|
+
/** Format a Date for the input display label (e.g., "Jan 15, 2025"). */
|
|
12
|
+
export declare function formatDisplayDate(date: Date): string;
|
|
13
|
+
/** Return the first day of the month for a given year/month (0-indexed). */
|
|
14
|
+
export declare function startOfMonth(year: number, month: number): Date;
|
|
15
|
+
/** Return the number of days in a month. */
|
|
16
|
+
export declare function daysInMonth(year: number, month: number): number;
|
|
17
|
+
/** Build the 6×7 calendar grid for a given year/month. Returns Date[][] (some days in prev/next month). */
|
|
18
|
+
export declare function buildCalendarGrid(year: number, month: number): Date[][];
|
|
19
|
+
/** Returns true if two dates represent the same calendar day. */
|
|
20
|
+
export declare function isSameDay(a: Date, b: Date): boolean;
|
|
21
|
+
/** Returns true if a date is before the given min date (by day). */
|
|
22
|
+
export declare function isBeforeDay(date: Date, min: Date): boolean;
|
|
23
|
+
/** Returns true if a date is after the given max date (by day). */
|
|
24
|
+
export declare function isAfterDay(date: Date, max: Date): boolean;
|
|
25
|
+
/** Returns today as a local midnight Date. */
|
|
26
|
+
export declare function today(): Date;
|
|
27
|
+
/** Parse a HH:MM string into { hours, minutes }. */
|
|
28
|
+
export declare function parseTime(t: string | undefined): {
|
|
29
|
+
hours: number;
|
|
30
|
+
minutes: number;
|
|
31
|
+
};
|
|
32
|
+
/** Format { hours, minutes } → HH:MM string. */
|
|
33
|
+
export declare function formatTime(hours: number, minutes: number): string;
|
|
34
|
+
//# sourceMappingURL=date-utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"date-utils.d.ts","sourceRoot":"","sources":["../../../src/components/datepicker/date-utils.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,eAAO,MAAM,YAAY,qDAAsD,CAAC;AAChF,eAAO,MAAM,MAAM,qIAGT,CAAC;AAEX,kFAAkF;AAClF,wBAAgB,SAAS,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI,GAAG,IAAI,CAS9D;AAED,yCAAyC;AACzC,wBAAgB,UAAU,CAAC,IAAI,EAAE,IAAI,GAAG,MAAM,CAK7C;AAED,wEAAwE;AACxE,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,IAAI,GAAG,MAAM,CAEpD;AAED,4EAA4E;AAC5E,wBAAgB,YAAY,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI,CAE9D;AAED,4CAA4C;AAC5C,wBAAgB,WAAW,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,MAAM,CAE/D;AAED,2GAA2G;AAC3G,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI,EAAE,EAAE,CAiCvE;AAED,iEAAiE;AACjE,wBAAgB,SAAS,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,GAAG,OAAO,CAInD;AAED,oEAAoE;AACpE,wBAAgB,WAAW,CAAC,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,GAAG,OAAO,CAI1D;AAED,mEAAmE;AACnE,wBAAgB,UAAU,CAAC,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,GAAG,OAAO,CAIzD;AAED,8CAA8C;AAC9C,wBAAgB,KAAK,IAAI,IAAI,CAG5B;AAED,oDAAoD;AACpD,wBAAgB,SAAS,CAAC,CAAC,EAAE,MAAM,GAAG,SAAS,GAAG;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,MAAM,CAAA;CAAE,CAInF;AAED,gDAAgD;AAChD,wBAAgB,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,MAAM,CAEjE"}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Zero-dependency date utilities for the DatePicker calendar.
|
|
3
|
+
* All functions operate on plain JS Date objects or ISO YYYY-MM-DD strings.
|
|
4
|
+
*/
|
|
5
|
+
export const DAYS_OF_WEEK = ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'];
|
|
6
|
+
export const MONTHS = [
|
|
7
|
+
'January', 'February', 'March', 'April', 'May', 'June',
|
|
8
|
+
'July', 'August', 'September', 'October', 'November', 'December',
|
|
9
|
+
];
|
|
10
|
+
/** Parse a YYYY-MM-DD string → local Date (midnight). Returns null if invalid. */
|
|
11
|
+
export function parseDate(iso) {
|
|
12
|
+
if (!iso)
|
|
13
|
+
return null;
|
|
14
|
+
const m = /^(\d{4})-(\d{2})-(\d{2})$/.exec(iso);
|
|
15
|
+
if (!m)
|
|
16
|
+
return null;
|
|
17
|
+
const [, y, mo, d] = m.map(Number);
|
|
18
|
+
const date = new Date(y, mo - 1, d);
|
|
19
|
+
// Guard against e.g. "2024-02-30" auto-rolling to March
|
|
20
|
+
if (date.getFullYear() !== y || date.getMonth() !== mo - 1 || date.getDate() !== d)
|
|
21
|
+
return null;
|
|
22
|
+
return date;
|
|
23
|
+
}
|
|
24
|
+
/** Format a Date → YYYY-MM-DD string. */
|
|
25
|
+
export function formatDate(date) {
|
|
26
|
+
const y = date.getFullYear();
|
|
27
|
+
const m = String(date.getMonth() + 1).padStart(2, '0');
|
|
28
|
+
const d = String(date.getDate()).padStart(2, '0');
|
|
29
|
+
return `${y}-${m}-${d}`;
|
|
30
|
+
}
|
|
31
|
+
/** Format a Date for the input display label (e.g., "Jan 15, 2025"). */
|
|
32
|
+
export function formatDisplayDate(date) {
|
|
33
|
+
return date.toLocaleDateString('en-US', { month: 'short', day: 'numeric', year: 'numeric' });
|
|
34
|
+
}
|
|
35
|
+
/** Return the first day of the month for a given year/month (0-indexed). */
|
|
36
|
+
export function startOfMonth(year, month) {
|
|
37
|
+
return new Date(year, month, 1);
|
|
38
|
+
}
|
|
39
|
+
/** Return the number of days in a month. */
|
|
40
|
+
export function daysInMonth(year, month) {
|
|
41
|
+
return new Date(year, month + 1, 0).getDate();
|
|
42
|
+
}
|
|
43
|
+
/** Build the 6×7 calendar grid for a given year/month. Returns Date[][] (some days in prev/next month). */
|
|
44
|
+
export function buildCalendarGrid(year, month) {
|
|
45
|
+
const firstDay = startOfMonth(year, month).getDay(); // 0=Sun
|
|
46
|
+
const totalDays = daysInMonth(year, month);
|
|
47
|
+
const cells = [];
|
|
48
|
+
// Pad with days from previous month
|
|
49
|
+
const prevMonthDays = daysInMonth(year, month - 1 < 0 ? 11 : month - 1);
|
|
50
|
+
const prevYear = month === 0 ? year - 1 : year;
|
|
51
|
+
const prevMonth = month === 0 ? 11 : month - 1;
|
|
52
|
+
for (let i = firstDay - 1; i >= 0; i--) {
|
|
53
|
+
cells.push(new Date(prevYear, prevMonth, prevMonthDays - i));
|
|
54
|
+
}
|
|
55
|
+
// Current month days
|
|
56
|
+
for (let d = 1; d <= totalDays; d++) {
|
|
57
|
+
cells.push(new Date(year, month, d));
|
|
58
|
+
}
|
|
59
|
+
// Pad to complete 6 rows (42 cells)
|
|
60
|
+
const nextYear = month === 11 ? year + 1 : year;
|
|
61
|
+
const nextMonth = month === 11 ? 0 : month + 1;
|
|
62
|
+
let nextDay = 1;
|
|
63
|
+
while (cells.length < 42) {
|
|
64
|
+
cells.push(new Date(nextYear, nextMonth, nextDay++));
|
|
65
|
+
}
|
|
66
|
+
// Split into 6 rows of 7
|
|
67
|
+
const rows = [];
|
|
68
|
+
for (let r = 0; r < 6; r++) {
|
|
69
|
+
rows.push(cells.slice(r * 7, r * 7 + 7));
|
|
70
|
+
}
|
|
71
|
+
return rows;
|
|
72
|
+
}
|
|
73
|
+
/** Returns true if two dates represent the same calendar day. */
|
|
74
|
+
export function isSameDay(a, b) {
|
|
75
|
+
return a.getFullYear() === b.getFullYear()
|
|
76
|
+
&& a.getMonth() === b.getMonth()
|
|
77
|
+
&& a.getDate() === b.getDate();
|
|
78
|
+
}
|
|
79
|
+
/** Returns true if a date is before the given min date (by day). */
|
|
80
|
+
export function isBeforeDay(date, min) {
|
|
81
|
+
const d = new Date(date.getFullYear(), date.getMonth(), date.getDate());
|
|
82
|
+
const m = new Date(min.getFullYear(), min.getMonth(), min.getDate());
|
|
83
|
+
return d < m;
|
|
84
|
+
}
|
|
85
|
+
/** Returns true if a date is after the given max date (by day). */
|
|
86
|
+
export function isAfterDay(date, max) {
|
|
87
|
+
const d = new Date(date.getFullYear(), date.getMonth(), date.getDate());
|
|
88
|
+
const m = new Date(max.getFullYear(), max.getMonth(), max.getDate());
|
|
89
|
+
return d > m;
|
|
90
|
+
}
|
|
91
|
+
/** Returns today as a local midnight Date. */
|
|
92
|
+
export function today() {
|
|
93
|
+
const t = new Date();
|
|
94
|
+
return new Date(t.getFullYear(), t.getMonth(), t.getDate());
|
|
95
|
+
}
|
|
96
|
+
/** Parse a HH:MM string into { hours, minutes }. */
|
|
97
|
+
export function parseTime(t) {
|
|
98
|
+
if (!t)
|
|
99
|
+
return { hours: 0, minutes: 0 };
|
|
100
|
+
const [h, m] = t.split(':').map(Number);
|
|
101
|
+
return { hours: h ?? 0, minutes: m ?? 0 };
|
|
102
|
+
}
|
|
103
|
+
/** Format { hours, minutes } → HH:MM string. */
|
|
104
|
+
export function formatTime(hours, minutes) {
|
|
105
|
+
return `${String(hours).padStart(2, '0')}:${String(minutes).padStart(2, '0')}`;
|
|
106
|
+
}
|
|
107
|
+
//# sourceMappingURL=date-utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"date-utils.js","sourceRoot":"","sources":["../../../src/components/datepicker/date-utils.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAU,CAAC;AAChF,MAAM,CAAC,MAAM,MAAM,GAAG;IACpB,SAAS,EAAE,UAAU,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM;IACtD,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,SAAS,EAAE,UAAU,EAAE,UAAU;CACxD,CAAC;AAEX,kFAAkF;AAClF,MAAM,UAAU,SAAS,CAAC,GAAuB;IAC/C,IAAI,CAAC,GAAG;QAAE,OAAO,IAAI,CAAC;IACtB,MAAM,CAAC,GAAG,2BAA2B,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAChD,IAAI,CAAC,CAAC;QAAE,OAAO,IAAI,CAAC;IACpB,MAAM,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IACnC,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC,EAAE,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;IACpC,wDAAwD;IACxD,IAAI,IAAI,CAAC,WAAW,EAAE,KAAK,CAAC,IAAI,IAAI,CAAC,QAAQ,EAAE,KAAK,EAAE,GAAG,CAAC,IAAI,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC;QAAE,OAAO,IAAI,CAAC;IAChG,OAAO,IAAI,CAAC;AACd,CAAC;AAED,yCAAyC;AACzC,MAAM,UAAU,UAAU,CAAC,IAAU;IACnC,MAAM,CAAC,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;IAC7B,MAAM,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;IACvD,MAAM,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;IAClD,OAAO,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;AAC1B,CAAC;AAED,wEAAwE;AACxE,MAAM,UAAU,iBAAiB,CAAC,IAAU;IAC1C,OAAO,IAAI,CAAC,kBAAkB,CAAC,OAAO,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC;AAC/F,CAAC;AAED,4EAA4E;AAC5E,MAAM,UAAU,YAAY,CAAC,IAAY,EAAE,KAAa;IACtD,OAAO,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;AAClC,CAAC;AAED,4CAA4C;AAC5C,MAAM,UAAU,WAAW,CAAC,IAAY,EAAE,KAAa;IACrD,OAAO,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;AAChD,CAAC;AAED,2GAA2G;AAC3G,MAAM,UAAU,iBAAiB,CAAC,IAAY,EAAE,KAAa;IAC3D,MAAM,QAAQ,GAAG,YAAY,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,QAAQ;IAC7D,MAAM,SAAS,GAAG,WAAW,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IAE3C,MAAM,KAAK,GAAW,EAAE,CAAC;IAEzB,oCAAoC;IACpC,MAAM,aAAa,GAAG,WAAW,CAAC,IAAI,EAAE,KAAK,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;IACxE,MAAM,QAAQ,GAAG,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC/C,MAAM,SAAS,GAAG,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC;IAC/C,KAAK,IAAI,CAAC,GAAG,QAAQ,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;QACvC,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,QAAQ,EAAE,SAAS,EAAE,aAAa,GAAG,CAAC,CAAC,CAAC,CAAC;IAC/D,CAAC;IAED,qBAAqB;IACrB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,SAAS,EAAE,CAAC,EAAE,EAAE,CAAC;QACpC,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC;IACvC,CAAC;IAED,oCAAoC;IACpC,MAAM,QAAQ,GAAG,KAAK,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAChD,MAAM,SAAS,GAAG,KAAK,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC;IAC/C,IAAI,OAAO,GAAG,CAAC,CAAC;IAChB,OAAO,KAAK,CAAC,MAAM,GAAG,EAAE,EAAE,CAAC;QACzB,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,QAAQ,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC;IACvD,CAAC;IAED,yBAAyB;IACzB,MAAM,IAAI,GAAa,EAAE,CAAC;IAC1B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;QAC3B,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC3C,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AAED,iEAAiE;AACjE,MAAM,UAAU,SAAS,CAAC,CAAO,EAAE,CAAO;IACxC,OAAO,CAAC,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC,WAAW,EAAE;WACrC,CAAC,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC,QAAQ,EAAE;WAC7B,CAAC,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC,OAAO,EAAE,CAAC;AACnC,CAAC;AAED,oEAAoE;AACpE,MAAM,UAAU,WAAW,CAAC,IAAU,EAAE,GAAS;IAC/C,MAAM,CAAC,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;IACxE,MAAM,CAAC,GAAG,IAAI,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,EAAE,GAAG,CAAC,QAAQ,EAAE,EAAE,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;IACrE,OAAO,CAAC,GAAG,CAAC,CAAC;AACf,CAAC;AAED,mEAAmE;AACnE,MAAM,UAAU,UAAU,CAAC,IAAU,EAAE,GAAS;IAC9C,MAAM,CAAC,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;IACxE,MAAM,CAAC,GAAG,IAAI,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,EAAE,GAAG,CAAC,QAAQ,EAAE,EAAE,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;IACrE,OAAO,CAAC,GAAG,CAAC,CAAC;AACf,CAAC;AAED,8CAA8C;AAC9C,MAAM,UAAU,KAAK;IACnB,MAAM,CAAC,GAAG,IAAI,IAAI,EAAE,CAAC;IACrB,OAAO,IAAI,IAAI,CAAC,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;AAC9D,CAAC;AAED,oDAAoD;AACpD,MAAM,UAAU,SAAS,CAAC,CAAqB;IAC7C,IAAI,CAAC,CAAC;QAAE,OAAO,EAAE,KAAK,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC;IACxC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IACxC,OAAO,EAAE,KAAK,EAAE,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;AAC5C,CAAC;AAED,gDAAgD;AAChD,MAAM,UAAU,UAAU,CAAC,KAAa,EAAE,OAAe;IACvD,OAAO,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC;AACjF,CAAC"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* DatePicker, TimePicker, DateTimePicker
|
|
3
|
+
*
|
|
4
|
+
* All three share a pattern: a trigger input that opens a Portal-mounted popup.
|
|
5
|
+
* DatePicker uses the Calendar grid widget.
|
|
6
|
+
* TimePicker uses scroll-select columns for hours/minutes.
|
|
7
|
+
* DateTimePicker combines both.
|
|
8
|
+
*/
|
|
9
|
+
import { type CalendarProps } from './Calendar.js';
|
|
10
|
+
export interface DatePickerProps extends Pick<CalendarProps, 'min' | 'max'> {
|
|
11
|
+
/** Controlled value (YYYY-MM-DD). */
|
|
12
|
+
value?: string;
|
|
13
|
+
/** Default value for uncontrolled usage (YYYY-MM-DD). */
|
|
14
|
+
defaultValue?: string;
|
|
15
|
+
/** Fires with a YYYY-MM-DD string or undefined when cleared. */
|
|
16
|
+
onChange?: (value: string | undefined) => void;
|
|
17
|
+
label?: string;
|
|
18
|
+
placeholder?: string;
|
|
19
|
+
disabled?: boolean;
|
|
20
|
+
required?: boolean;
|
|
21
|
+
error?: boolean;
|
|
22
|
+
/** Additional CSS class on the root element. */
|
|
23
|
+
className?: string;
|
|
24
|
+
}
|
|
25
|
+
export declare function DatePicker({ value: valueProp, defaultValue, onChange, label, placeholder, disabled, required, error, min, max, className, }: DatePickerProps): import("react/jsx-runtime").JSX.Element;
|
|
26
|
+
export interface TimePickerProps {
|
|
27
|
+
/** Controlled value (HH:MM). */
|
|
28
|
+
value?: string;
|
|
29
|
+
defaultValue?: string;
|
|
30
|
+
onChange?: (value: string) => void;
|
|
31
|
+
label?: string;
|
|
32
|
+
disabled?: boolean;
|
|
33
|
+
required?: boolean;
|
|
34
|
+
error?: boolean;
|
|
35
|
+
/** 12 or 24 hour format. @default 24 */
|
|
36
|
+
hourFormat?: 12 | 24;
|
|
37
|
+
/** Minute step increment. @default 1 */
|
|
38
|
+
minuteStep?: number;
|
|
39
|
+
className?: string;
|
|
40
|
+
}
|
|
41
|
+
export declare function TimePicker({ value: valueProp, defaultValue, onChange, label, disabled, required, error, hourFormat, minuteStep, className, }: TimePickerProps): import("react/jsx-runtime").JSX.Element;
|
|
42
|
+
export interface DateTimePickerProps extends DatePickerProps {
|
|
43
|
+
/** Controlled datetime value (YYYY-MM-DDTHH:MM). */
|
|
44
|
+
value?: string;
|
|
45
|
+
defaultValue?: string;
|
|
46
|
+
onChange?: (value: string | undefined) => void;
|
|
47
|
+
minuteStep?: number;
|
|
48
|
+
hourFormat?: 12 | 24;
|
|
49
|
+
}
|
|
50
|
+
export declare function DateTimePicker({ value: valueProp, defaultValue, onChange, minuteStep, hourFormat, ...dateProps }: DateTimePickerProps): import("react/jsx-runtime").JSX.Element;
|
|
51
|
+
export { Calendar, type CalendarProps } from './Calendar.js';
|
|
52
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/datepicker/index.tsx"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAaH,OAAO,EAAY,KAAK,aAAa,EAAE,MAAM,eAAe,CAAC;AAiE7D,MAAM,WAAW,eAAgB,SAAQ,IAAI,CAAC,aAAa,EAAE,KAAK,GAAG,KAAK,CAAC;IACzE,qCAAqC;IACrC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,yDAAyD;IACzD,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,gEAAgE;IAChE,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,KAAK,IAAI,CAAC;IAC/C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,gDAAgD;IAChD,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,wBAAgB,UAAU,CAAC,EACzB,KAAK,EAAE,SAAS,EAChB,YAAY,EACZ,QAAQ,EACR,KAAK,EACL,WAA2B,EAC3B,QAAgB,EAChB,QAAgB,EAChB,KAAa,EACb,GAAG,EACH,GAAG,EACH,SAAS,GACV,EAAE,eAAe,2CAuEjB;AAID,MAAM,WAAW,eAAe;IAC9B,gCAAgC;IAChC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,wCAAwC;IACxC,UAAU,CAAC,EAAE,EAAE,GAAG,EAAE,CAAC;IACrB,wCAAwC;IACxC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,wBAAgB,UAAU,CAAC,EACzB,KAAK,EAAE,SAAS,EAChB,YAAY,EACZ,QAAQ,EACR,KAAK,EACL,QAAgB,EAChB,QAAgB,EAChB,KAAa,EACb,UAAe,EACf,UAAc,EACd,SAAS,GACV,EAAE,eAAe,2CA6EjB;AAID,MAAM,WAAW,mBAAoB,SAAQ,eAAe;IAC1D,oDAAoD;IACpD,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,KAAK,IAAI,CAAC;IAC/C,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,UAAU,CAAC,EAAE,EAAE,GAAG,EAAE,CAAC;CACtB;AAED,wBAAgB,cAAc,CAAC,EAC7B,KAAK,EAAE,SAAS,EAChB,YAAY,EACZ,QAAQ,EACR,UAAc,EACd,UAAe,EACf,GAAG,SAAS,EACb,EAAE,mBAAmB,2CAiCrB;AAGD,OAAO,EAAE,QAAQ,EAAE,KAAK,aAAa,EAAE,MAAM,eAAe,CAAC"}
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* DatePicker, TimePicker, DateTimePicker
|
|
4
|
+
*
|
|
5
|
+
* All three share a pattern: a trigger input that opens a Portal-mounted popup.
|
|
6
|
+
* DatePicker uses the Calendar grid widget.
|
|
7
|
+
* TimePicker uses scroll-select columns for hours/minutes.
|
|
8
|
+
* DateTimePicker combines both.
|
|
9
|
+
*/
|
|
10
|
+
import { useState, useRef, useEffect, useCallback, } from 'react';
|
|
11
|
+
import { Portal } from '../portal/index.js';
|
|
12
|
+
import { useId } from '../../hooks/useId.js';
|
|
13
|
+
import { cn } from '../../utils/cn.js';
|
|
14
|
+
import { Calendar } from './Calendar.js';
|
|
15
|
+
import { parseDate, formatDisplayDate, parseTime, formatTime, } from './date-utils.js';
|
|
16
|
+
// ─── Shared floating panel hook ───────────────────────────────────────────────
|
|
17
|
+
function useFloatingPanel(onClose) {
|
|
18
|
+
const [open, setOpen] = useState(false);
|
|
19
|
+
const triggerRef = useRef(null);
|
|
20
|
+
const panelRef = useRef(null);
|
|
21
|
+
const [pos, setPos] = useState({ top: 0, left: 0 });
|
|
22
|
+
const updatePos = useCallback(() => {
|
|
23
|
+
const el = triggerRef.current;
|
|
24
|
+
if (!el)
|
|
25
|
+
return;
|
|
26
|
+
const rect = el.getBoundingClientRect();
|
|
27
|
+
setPos({
|
|
28
|
+
top: rect.bottom + window.scrollY + 4,
|
|
29
|
+
left: rect.left + window.scrollX,
|
|
30
|
+
});
|
|
31
|
+
}, []);
|
|
32
|
+
const openPanel = () => {
|
|
33
|
+
updatePos();
|
|
34
|
+
setOpen(true);
|
|
35
|
+
};
|
|
36
|
+
const closePanel = useCallback(() => {
|
|
37
|
+
setOpen(false);
|
|
38
|
+
onClose?.();
|
|
39
|
+
triggerRef.current?.focus();
|
|
40
|
+
}, [onClose]);
|
|
41
|
+
// Close on outside click
|
|
42
|
+
useEffect(() => {
|
|
43
|
+
if (!open)
|
|
44
|
+
return;
|
|
45
|
+
const handler = (e) => {
|
|
46
|
+
if (!triggerRef.current?.contains(e.target) &&
|
|
47
|
+
!panelRef.current?.contains(e.target)) {
|
|
48
|
+
closePanel();
|
|
49
|
+
}
|
|
50
|
+
};
|
|
51
|
+
document.addEventListener('mousedown', handler);
|
|
52
|
+
return () => document.removeEventListener('mousedown', handler);
|
|
53
|
+
}, [open, closePanel]);
|
|
54
|
+
// Close on Escape
|
|
55
|
+
useEffect(() => {
|
|
56
|
+
if (!open)
|
|
57
|
+
return;
|
|
58
|
+
const handler = (e) => { if (e.key === 'Escape')
|
|
59
|
+
closePanel(); };
|
|
60
|
+
document.addEventListener('keydown', handler);
|
|
61
|
+
return () => document.removeEventListener('keydown', handler);
|
|
62
|
+
}, [open, closePanel]);
|
|
63
|
+
return { open, openPanel, closePanel, triggerRef, panelRef, pos };
|
|
64
|
+
}
|
|
65
|
+
export function DatePicker({ value: valueProp, defaultValue, onChange, label, placeholder = 'Pick a date', disabled = false, required = false, error = false, min, max, className, }) {
|
|
66
|
+
const [internalValue, setInternalValue] = useState(defaultValue);
|
|
67
|
+
const value = valueProp !== undefined ? valueProp : internalValue;
|
|
68
|
+
const id = useId('datepicker');
|
|
69
|
+
const parsedDate = parseDate(value);
|
|
70
|
+
const { open, openPanel, closePanel, triggerRef, panelRef, pos } = useFloatingPanel();
|
|
71
|
+
const handleSelect = (iso) => {
|
|
72
|
+
if (valueProp === undefined)
|
|
73
|
+
setInternalValue(iso);
|
|
74
|
+
onChange?.(iso);
|
|
75
|
+
closePanel();
|
|
76
|
+
};
|
|
77
|
+
const handleClear = (e) => {
|
|
78
|
+
e.stopPropagation();
|
|
79
|
+
if (valueProp === undefined)
|
|
80
|
+
setInternalValue(undefined);
|
|
81
|
+
onChange?.(undefined);
|
|
82
|
+
};
|
|
83
|
+
return (_jsxs("div", { className: cn('tokis-datepicker', error && 'tokis-datepicker--error', disabled && 'tokis-datepicker--disabled', className), children: [label && (_jsxs("label", { className: "tokis-label", htmlFor: id, children: [label, required && _jsx("span", { className: "tokis-label-required", "aria-hidden": "true", children: " *" })] })), _jsxs("div", { className: "tokis-datepicker-input-wrap", children: [_jsxs("button", { ref: triggerRef, id: id, type: "button", className: cn('tokis-datepicker-trigger', open && 'tokis-datepicker-trigger--open'), disabled: disabled, "aria-haspopup": "dialog", "aria-expanded": open, "aria-label": label ? `${label}: ${parsedDate ? formatDisplayDate(parsedDate) : 'not set'}` : undefined, onClick: () => (open ? closePanel() : openPanel()), children: [_jsx("span", { className: cn('tokis-datepicker-value', !parsedDate && 'tokis-datepicker-placeholder'), children: parsedDate ? formatDisplayDate(parsedDate) : placeholder }), _jsx("span", { className: "tokis-datepicker-icon", "aria-hidden": "true", children: "\uD83D\uDCC5" })] }), parsedDate && !disabled && (_jsx("button", { type: "button", className: "tokis-datepicker-clear", "aria-label": "Clear date", onClick: handleClear, children: "\u2715" }))] }), open && (_jsx(Portal, { children: _jsx("div", { ref: panelRef, className: "tokis-datepicker-panel", role: "dialog", "aria-modal": "false", "aria-label": label ?? 'Date picker', style: { top: pos.top, left: pos.left }, children: _jsx(Calendar, { value: value, onChange: handleSelect, min: min, max: max }) }) }))] }));
|
|
84
|
+
}
|
|
85
|
+
export function TimePicker({ value: valueProp, defaultValue, onChange, label, disabled = false, required = false, error = false, hourFormat = 24, minuteStep = 1, className, }) {
|
|
86
|
+
const [internalValue, setInternalValue] = useState(defaultValue ?? '00:00');
|
|
87
|
+
const value = valueProp !== undefined ? valueProp : internalValue;
|
|
88
|
+
const { hours, minutes } = parseTime(value);
|
|
89
|
+
const id = useId('timepicker');
|
|
90
|
+
const setTime = (h, m) => {
|
|
91
|
+
const next = formatTime(h, m);
|
|
92
|
+
if (valueProp === undefined)
|
|
93
|
+
setInternalValue(next);
|
|
94
|
+
onChange?.(next);
|
|
95
|
+
};
|
|
96
|
+
const hourOptions = Array.from({ length: hourFormat === 12 ? 12 : 24 }, (_, i) => hourFormat === 12 ? i + 1 : i);
|
|
97
|
+
const minuteOptions = [];
|
|
98
|
+
for (let m = 0; m < 60; m += minuteStep)
|
|
99
|
+
minuteOptions.push(m);
|
|
100
|
+
return (_jsxs("div", { className: cn('tokis-timepicker', error && 'tokis-timepicker--error', disabled && 'tokis-timepicker--disabled', className), children: [label && (_jsxs("label", { className: "tokis-label", htmlFor: `${id}-hours`, children: [label, required && _jsx("span", { className: "tokis-label-required", "aria-hidden": "true", children: " *" })] })), _jsxs("div", { className: "tokis-timepicker-inputs", children: [_jsx("select", { id: `${id}-hours`, className: "tokis-timepicker-select", value: hours, disabled: disabled, "aria-label": "Hours", onChange: (e) => setTime(Number(e.target.value), minutes), children: hourOptions.map((h) => (_jsx("option", { value: h, children: String(h).padStart(2, '0') }, h))) }), _jsx("span", { className: "tokis-timepicker-sep", "aria-hidden": "true", children: ":" }), _jsx("select", { id: `${id}-minutes`, className: "tokis-timepicker-select", value: minutes, disabled: disabled, "aria-label": "Minutes", onChange: (e) => setTime(hours, Number(e.target.value)), children: minuteOptions.map((m) => (_jsx("option", { value: m, children: String(m).padStart(2, '0') }, m))) }), hourFormat === 12 && (_jsxs("select", { className: "tokis-timepicker-select tokis-timepicker-ampm", value: hours < 12 ? 'AM' : 'PM', disabled: disabled, "aria-label": "AM/PM", onChange: (e) => {
|
|
101
|
+
const ampm = e.target.value;
|
|
102
|
+
let h = hours % 12;
|
|
103
|
+
if (ampm === 'PM')
|
|
104
|
+
h += 12;
|
|
105
|
+
setTime(h, minutes);
|
|
106
|
+
}, children: [_jsx("option", { value: "AM", children: "AM" }), _jsx("option", { value: "PM", children: "PM" })] }))] })] }));
|
|
107
|
+
}
|
|
108
|
+
export function DateTimePicker({ value: valueProp, defaultValue, onChange, minuteStep = 1, hourFormat = 24, ...dateProps }) {
|
|
109
|
+
const split = (v) => {
|
|
110
|
+
if (!v)
|
|
111
|
+
return { date: undefined, time: '00:00' };
|
|
112
|
+
const [date, time] = v.split('T');
|
|
113
|
+
return { date, time: time ?? '00:00' };
|
|
114
|
+
};
|
|
115
|
+
const [internalValue, setInternalValue] = useState(defaultValue);
|
|
116
|
+
const value = valueProp !== undefined ? valueProp : internalValue;
|
|
117
|
+
const { date, time } = split(value);
|
|
118
|
+
const emit = useCallback((d, t) => {
|
|
119
|
+
const next = d ? `${d}T${t ?? '00:00'}` : undefined;
|
|
120
|
+
if (valueProp === undefined)
|
|
121
|
+
setInternalValue(next);
|
|
122
|
+
onChange?.(next);
|
|
123
|
+
}, [valueProp, onChange]);
|
|
124
|
+
return (_jsxs("div", { className: "tokis-datetimepicker", children: [_jsx(DatePicker, { ...dateProps, value: date, onChange: (d) => emit(d, time) }), _jsx(TimePicker, { value: time, disabled: dateProps.disabled, minuteStep: minuteStep, hourFormat: hourFormat, onChange: (t) => emit(date, t) })] }));
|
|
125
|
+
}
|
|
126
|
+
// Re-export Calendar for standalone use
|
|
127
|
+
export { Calendar } from './Calendar.js';
|
|
128
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/datepicker/index.tsx"],"names":[],"mappings":"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"}
|
|
@@ -46,14 +46,12 @@ export interface TransferListProps {
|
|
|
46
46
|
rightTitle?: string;
|
|
47
47
|
}
|
|
48
48
|
export declare function TransferList({ left, right, onChange, leftTitle, rightTitle }: TransferListProps): import("react/jsx-runtime").JSX.Element;
|
|
49
|
-
|
|
49
|
+
/** @deprecated Import named icons from `@tokis/icons` instead. */
|
|
50
|
+
export interface EmojiIconProps extends React.HTMLAttributes<HTMLSpanElement> {
|
|
50
51
|
name: 'search' | 'close' | 'menu' | 'check' | 'star' | 'arrow-right';
|
|
51
52
|
}
|
|
52
|
-
|
|
53
|
-
export
|
|
54
|
-
icon: string;
|
|
55
|
-
}
|
|
56
|
-
export declare function MaterialIcon({ icon, className, ...props }: MaterialIconProps): import("react/jsx-runtime").JSX.Element;
|
|
53
|
+
/** @deprecated Use named SVG icons from `@tokis/icons`. */
|
|
54
|
+
export declare function Icon({ name, className, ...props }: EmojiIconProps): import("react/jsx-runtime").JSX.Element;
|
|
57
55
|
export interface BackdropProps extends React.HTMLAttributes<HTMLDivElement> {
|
|
58
56
|
open: boolean;
|
|
59
57
|
onClick?: () => void;
|
|
@@ -109,8 +107,16 @@ export interface ModalProps {
|
|
|
109
107
|
open: boolean;
|
|
110
108
|
onClose: () => void;
|
|
111
109
|
children: React.ReactNode;
|
|
112
|
-
|
|
113
|
-
|
|
110
|
+
/** Accessible title for the modal (wired to aria-labelledby). */
|
|
111
|
+
title?: string;
|
|
112
|
+
/** Accessible description (wired to aria-describedby). */
|
|
113
|
+
description?: string;
|
|
114
|
+
/** Close when the backdrop is clicked. @default true */
|
|
115
|
+
closeOnBackdropClick?: boolean;
|
|
116
|
+
/** Close on Escape key. @default true */
|
|
117
|
+
closeOnEscape?: boolean;
|
|
118
|
+
}
|
|
119
|
+
export declare function Modal({ open, onClose, children, title, description, closeOnBackdropClick, closeOnEscape, }: ModalProps): import("react/jsx-runtime").JSX.Element | null;
|
|
114
120
|
export interface NoSsrProps {
|
|
115
121
|
children: React.ReactNode;
|
|
116
122
|
fallback?: React.ReactNode;
|
|
@@ -134,27 +140,6 @@ export interface FadeProps {
|
|
|
134
140
|
}
|
|
135
141
|
export declare function Fade({ in: visible, children }: FadeProps): import("react/jsx-runtime").JSX.Element;
|
|
136
142
|
export declare function useMediaQuery(query: string): boolean;
|
|
137
|
-
export interface DataGridColumn {
|
|
138
|
-
field: string;
|
|
139
|
-
headerName: string;
|
|
140
|
-
}
|
|
141
|
-
export interface DataGridProps {
|
|
142
|
-
columns: DataGridColumn[];
|
|
143
|
-
rows: Array<Record<string, React.ReactNode>>;
|
|
144
|
-
}
|
|
145
|
-
export declare function DataGrid({ columns, rows }: DataGridProps): import("react/jsx-runtime").JSX.Element;
|
|
146
|
-
export interface DatePickerProps extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'type'> {
|
|
147
|
-
label?: string;
|
|
148
|
-
}
|
|
149
|
-
export declare function DatePicker({ label, ...props }: DatePickerProps): import("react/jsx-runtime").JSX.Element;
|
|
150
|
-
export interface TimePickerProps extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'type'> {
|
|
151
|
-
label?: string;
|
|
152
|
-
}
|
|
153
|
-
export declare function TimePicker({ label, ...props }: TimePickerProps): import("react/jsx-runtime").JSX.Element;
|
|
154
|
-
export interface DateTimePickerProps extends Omit<React.InputHTMLAttributes<HTMLInputElement>, 'type'> {
|
|
155
|
-
label?: string;
|
|
156
|
-
}
|
|
157
|
-
export declare function DateTimePicker({ label, ...props }: DateTimePickerProps): import("react/jsx-runtime").JSX.Element;
|
|
158
143
|
export interface ChartsProps {
|
|
159
144
|
data: number[];
|
|
160
145
|
labels?: string[];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/extended/index.tsx"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/extended/index.tsx"],"names":[],"mappings":"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"}
|