@dxos/react-ui-calendar 0.8.4-main.548089c

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (34) hide show
  1. package/LICENSE +8 -0
  2. package/README.md +1 -0
  3. package/dist/lib/browser/index.mjs +265 -0
  4. package/dist/lib/browser/index.mjs.map +7 -0
  5. package/dist/lib/browser/meta.json +1 -0
  6. package/dist/lib/node-esm/index.mjs +267 -0
  7. package/dist/lib/node-esm/index.mjs.map +7 -0
  8. package/dist/lib/node-esm/meta.json +1 -0
  9. package/dist/types/src/components/Calendar/Calendar.d.ts +47 -0
  10. package/dist/types/src/components/Calendar/Calendar.d.ts.map +1 -0
  11. package/dist/types/src/components/Calendar/Calendar.stories.d.ts +27 -0
  12. package/dist/types/src/components/Calendar/Calendar.stories.d.ts.map +1 -0
  13. package/dist/types/src/components/Calendar/index.d.ts +2 -0
  14. package/dist/types/src/components/Calendar/index.d.ts.map +1 -0
  15. package/dist/types/src/components/Calendar/util.d.ts +4 -0
  16. package/dist/types/src/components/Calendar/util.d.ts.map +1 -0
  17. package/dist/types/src/components/index.d.ts +2 -0
  18. package/dist/types/src/components/index.d.ts.map +1 -0
  19. package/dist/types/src/index.d.ts +2 -0
  20. package/dist/types/src/index.d.ts.map +1 -0
  21. package/dist/types/src/translations.d.ts +9 -0
  22. package/dist/types/src/translations.d.ts.map +1 -0
  23. package/dist/types/src/types.d.ts +175 -0
  24. package/dist/types/src/types.d.ts.map +1 -0
  25. package/dist/types/tsconfig.tsbuildinfo +1 -0
  26. package/package.json +64 -0
  27. package/src/components/Calendar/Calendar.stories.tsx +76 -0
  28. package/src/components/Calendar/Calendar.tsx +294 -0
  29. package/src/components/Calendar/index.ts +5 -0
  30. package/src/components/Calendar/util.ts +22 -0
  31. package/src/components/index.ts +5 -0
  32. package/src/index.ts +5 -0
  33. package/src/translations.ts +17 -0
  34. package/src/types.ts +193 -0
package/LICENSE ADDED
@@ -0,0 +1,8 @@
1
+ MIT License
2
+ Copyright (c) 2022 DXOS
3
+
4
+ Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
5
+
6
+ The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
7
+
8
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
package/README.md ADDED
@@ -0,0 +1 @@
1
+ # @dxos/react-ui-calendar
@@ -0,0 +1,265 @@
1
+ // src/components/Calendar/Calendar.tsx
2
+ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
3
+ import { createContext } from "@radix-ui/react-context";
4
+ import { addDays, differenceInWeeks, format, startOfWeek } from "date-fns";
5
+ import React, { forwardRef, useCallback, useEffect, useImperativeHandle, useMemo, useRef, useState } from "react";
6
+ import { useResizeDetector } from "react-resize-detector";
7
+ import { List } from "react-virtualized";
8
+ import { Event } from "@dxos/async";
9
+ import { IconButton, useTranslation } from "@dxos/react-ui";
10
+ import { mx } from "@dxos/react-ui-theme";
11
+
12
+ // src/translations.ts
13
+ var translationKey = "react-ui-calendar";
14
+ var translations = [
15
+ {
16
+ "en-US": {
17
+ [translationKey]: {
18
+ "today button": "Today"
19
+ }
20
+ }
21
+ }
22
+ ];
23
+
24
+ // src/components/Calendar/util.ts
25
+ var getDate = (start2, weekNumber, dayOfWeek, weekStartsOn) => {
26
+ const result = new Date(start2);
27
+ const startDayOfWeek = start2.getDay();
28
+ const adjustedStartDay = (startDayOfWeek === 0 ? 7 : startDayOfWeek) - weekStartsOn;
29
+ result.setDate(start2.getDate() - adjustedStartDay + weekNumber * 7 + dayOfWeek);
30
+ return result;
31
+ };
32
+ var isSameDay = (date1, date2) => {
33
+ return !!date2 && date1.getFullYear() === date2.getFullYear() && date1.getMonth() === date2.getMonth() && date1.getDate() === date2.getDate();
34
+ };
35
+
36
+ // src/components/Calendar/Calendar.tsx
37
+ var maxRows = 50 * 100;
38
+ var start = /* @__PURE__ */ new Date("1970-01-01");
39
+ var size = 48;
40
+ var defaultWidth = 7 * size;
41
+ var [CalendarContextProvider, useCalendarContext] = createContext("Calendar");
42
+ var CalendarRoot = /* @__PURE__ */ forwardRef(({ children, weekStartsOn = 1 }, forwardedRef) => {
43
+ var _effect = _useSignals();
44
+ try {
45
+ const event = useMemo(() => new Event(), []);
46
+ const [selected, setSelected] = useState();
47
+ const [index, setIndex] = useState();
48
+ useImperativeHandle(forwardedRef, () => ({
49
+ scrollTo: (date) => {
50
+ event.emit({
51
+ type: "scroll",
52
+ date
53
+ });
54
+ }
55
+ }), [
56
+ event
57
+ ]);
58
+ return /* @__PURE__ */ React.createElement(CalendarContextProvider, {
59
+ weekStartsOn,
60
+ event,
61
+ index,
62
+ setIndex,
63
+ selected,
64
+ setSelected
65
+ }, children);
66
+ } finally {
67
+ _effect.f();
68
+ }
69
+ });
70
+ var CalendarViewport = ({ children, classNames }) => {
71
+ var _effect = _useSignals();
72
+ try {
73
+ return /* @__PURE__ */ React.createElement("div", {
74
+ role: "none",
75
+ className: mx("flex flex-col items-center overflow-hidden bg-inputSurface", classNames)
76
+ }, children);
77
+ } finally {
78
+ _effect.f();
79
+ }
80
+ };
81
+ CalendarViewport.displayName = "CalendarContent";
82
+ var CalendarHeader = ({ classNames }) => {
83
+ var _effect = _useSignals();
84
+ try {
85
+ const { t } = useTranslation(translationKey);
86
+ const { weekStartsOn, event, index, selected } = useCalendarContext(CalendarHeader.displayName);
87
+ const top = useMemo(() => getDate(start, index ?? 0, 6, weekStartsOn), [
88
+ index,
89
+ weekStartsOn
90
+ ]);
91
+ const today = useMemo(() => /* @__PURE__ */ new Date(), []);
92
+ const handleToday = useCallback(() => {
93
+ event.emit({
94
+ type: "scroll",
95
+ date: today
96
+ });
97
+ }, [
98
+ event,
99
+ start,
100
+ today
101
+ ]);
102
+ return /* @__PURE__ */ React.createElement("div", {
103
+ role: "none",
104
+ className: mx("shink-0 is-full grid grid-cols-3", classNames),
105
+ style: {
106
+ width: defaultWidth
107
+ }
108
+ }, /* @__PURE__ */ React.createElement("div", {
109
+ className: "flex justify-start"
110
+ }, /* @__PURE__ */ React.createElement(IconButton, {
111
+ variant: "ghost",
112
+ size: 6,
113
+ icon: "ph--calendar--regular",
114
+ iconOnly: true,
115
+ classNames: "aspect-square",
116
+ label: t("today button"),
117
+ onClick: handleToday
118
+ })), /* @__PURE__ */ React.createElement("span", {
119
+ className: "flex justify-center p-2"
120
+ }, format(selected ?? top, "MMMM")), /* @__PURE__ */ React.createElement("span", {
121
+ className: "flex justify-end p-2"
122
+ }, (selected ?? top).getFullYear()));
123
+ } finally {
124
+ _effect.f();
125
+ }
126
+ };
127
+ CalendarHeader.displayName = "CalendarHeader";
128
+ var CalendarGrid = ({ classNames, rows, onSelect }) => {
129
+ var _effect = _useSignals();
130
+ try {
131
+ const { weekStartsOn, event, setIndex, selected, setSelected } = useCalendarContext(CalendarGrid.displayName);
132
+ const { ref: containerRef, width = 0, height = 0 } = useResizeDetector();
133
+ const maxHeight = rows ? rows * size : void 0;
134
+ const listRef = useRef(null);
135
+ const today = useMemo(() => /* @__PURE__ */ new Date(), []);
136
+ const [initialized, setInitialized] = useState(false);
137
+ useEffect(() => {
138
+ const index = differenceInWeeks(today, start);
139
+ listRef.current?.scrollToRow(index);
140
+ }, [
141
+ initialized,
142
+ start,
143
+ today
144
+ ]);
145
+ useEffect(() => {
146
+ return event.on((event2) => {
147
+ switch (event2.type) {
148
+ case "scroll": {
149
+ const index = differenceInWeeks(event2.date, start);
150
+ listRef.current?.scrollToRow(index);
151
+ break;
152
+ }
153
+ }
154
+ });
155
+ }, [
156
+ event
157
+ ]);
158
+ const days = useMemo(() => {
159
+ const weekStart = startOfWeek(/* @__PURE__ */ new Date(), {
160
+ weekStartsOn
161
+ });
162
+ return Array.from({
163
+ length: 7
164
+ }, (_, i) => {
165
+ const day = addDays(weekStart, i);
166
+ return format(day, "EEE");
167
+ });
168
+ }, []);
169
+ const handleDaySelect = useCallback((date) => {
170
+ setSelected((current) => isSameDay(date, current) ? void 0 : date);
171
+ onSelect?.({
172
+ date
173
+ });
174
+ }, [
175
+ onSelect
176
+ ]);
177
+ const handleScroll = useCallback((info) => {
178
+ setIndex(Math.round(info.scrollTop / size));
179
+ }, []);
180
+ const rowRenderer = useCallback(({ key, index, style }) => {
181
+ const getBgColor = (date) => date.getMonth() % 2 === 0 && "bg-modalSurface";
182
+ return /* @__PURE__ */ React.createElement("div", {
183
+ key,
184
+ style,
185
+ className: "is-full grid grid-cols-[1fr_max-content_1fr] snap-center"
186
+ }, /* @__PURE__ */ React.createElement("div", {
187
+ className: mx(getBgColor(getDate(start, index, 0, weekStartsOn)))
188
+ }), /* @__PURE__ */ React.createElement("div", {
189
+ className: "grid grid-cols-7",
190
+ style: {
191
+ gridTemplateColumns: `repeat(7, ${size}px)`
192
+ }
193
+ }, Array.from({
194
+ length: 7
195
+ }).map((_, i) => {
196
+ const date = getDate(start, index, i, weekStartsOn);
197
+ const border = isSameDay(date, selected) ? "border-primary-500" : isSameDay(date, today) ? "border-amber-500" : void 0;
198
+ return /* @__PURE__ */ React.createElement("div", {
199
+ key: i,
200
+ className: mx("relative flex justify-center items-center cursor-pointer", getBgColor(date)),
201
+ onClick: () => handleDaySelect(date)
202
+ }, /* @__PURE__ */ React.createElement("span", {
203
+ className: "text-description"
204
+ }, date.getDate()), !border && date.getDate() === 1 && /* @__PURE__ */ React.createElement("span", {
205
+ className: "absolute top-0 text-xs text-description"
206
+ }, format(date, "MMM")), border && /* @__PURE__ */ React.createElement("div", {
207
+ className: mx("absolute top-0 left-0 is-full bs-full border-2 rounded-full", border)
208
+ }));
209
+ })), /* @__PURE__ */ React.createElement("div", {
210
+ className: mx(getBgColor(getDate(start, index, 6, weekStartsOn)))
211
+ }));
212
+ }, [
213
+ handleDaySelect,
214
+ selected,
215
+ weekStartsOn
216
+ ]);
217
+ return /* @__PURE__ */ React.createElement("div", {
218
+ role: "none",
219
+ className: mx("flex flex-col bs-full is-full justify-center overflow-hidden", classNames)
220
+ }, /* @__PURE__ */ React.createElement("div", {
221
+ role: "none",
222
+ className: "flex justify-center bg-groupSurface"
223
+ }, /* @__PURE__ */ React.createElement("div", {
224
+ role: "none",
225
+ className: "flex is-full grid grid-cols-7",
226
+ style: {
227
+ width: defaultWidth
228
+ }
229
+ }, days.map((date, i) => /* @__PURE__ */ React.createElement("div", {
230
+ key: i,
231
+ role: "none",
232
+ className: "flex justify-center p-2 text-sm font-thin"
233
+ }, date)))), /* @__PURE__ */ React.createElement("div", {
234
+ role: "none",
235
+ className: "flex flex-col bs-full is-full justify-center overflow-hidden",
236
+ ref: containerRef
237
+ }, /* @__PURE__ */ React.createElement(List, {
238
+ ref: listRef,
239
+ role: "none",
240
+ // TODO(burdon): Snap isn't working.
241
+ className: "[&>div]:snap-y scrollbar-none outline-none",
242
+ width,
243
+ height: maxHeight ?? height,
244
+ rowCount: maxRows,
245
+ rowHeight: size,
246
+ rowRenderer,
247
+ scrollToAlignment: "start",
248
+ onScroll: handleScroll,
249
+ onRowsRendered: () => setInitialized(true)
250
+ })));
251
+ } finally {
252
+ _effect.f();
253
+ }
254
+ };
255
+ CalendarGrid.displayName = "CalendarGrid";
256
+ var Calendar = {
257
+ Root: CalendarRoot,
258
+ Viewport: CalendarViewport,
259
+ Header: CalendarHeader,
260
+ Grid: CalendarGrid
261
+ };
262
+ export {
263
+ Calendar
264
+ };
265
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/Calendar/Calendar.tsx", "../../../src/translations.ts", "../../../src/components/Calendar/util.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { createContext } from '@radix-ui/react-context';\nimport { type Day, addDays, differenceInWeeks, format, startOfWeek } from 'date-fns';\nimport React, {\n type Dispatch,\n type PropsWithChildren,\n type SetStateAction,\n forwardRef,\n useCallback,\n useEffect,\n useImperativeHandle,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport { useResizeDetector } from 'react-resize-detector';\nimport { List, type ListProps, type ListRowRenderer } from 'react-virtualized';\n\nimport { Event } from '@dxos/async';\nimport { IconButton, type ThemedClassName, useTranslation } from '@dxos/react-ui';\nimport { mx } from '@dxos/react-ui-theme';\n\nimport { translationKey } from '../../translations';\n\nimport { getDate, isSameDay } from './util';\n\nconst maxRows = 50 * 100;\nconst start = new Date('1970-01-01');\nconst size = 48;\nconst defaultWidth = 7 * size;\n\n//\n// Context\n//\n\ntype CalendarEvent = {\n type: 'scroll';\n date: Date;\n};\n\ntype CalendarContextValue = {\n weekStartsOn: Day;\n event: Event<CalendarEvent>;\n index: number | undefined;\n setIndex: Dispatch<SetStateAction<number | undefined>>;\n selected: Date | undefined;\n setSelected: Dispatch<SetStateAction<Date | undefined>>;\n};\n\nconst [CalendarContextProvider, useCalendarContext] = createContext<CalendarContextValue>('Calendar');\n\n//\n// Controller\n//\n\ntype CalendarController = {\n scrollTo: (date: Date) => void;\n};\n\n//\n// Root\n//\n\ntype CalendarRootProps = PropsWithChildren<Partial<Pick<CalendarContextValue, 'weekStartsOn'>>>;\n\nconst CalendarRoot = forwardRef<CalendarController, CalendarRootProps>(\n ({ children, weekStartsOn = 1 }, forwardedRef) => {\n const event = useMemo(() => new Event<CalendarEvent>(), []);\n const [selected, setSelected] = useState<Date | undefined>();\n const [index, setIndex] = useState<number | undefined>();\n\n useImperativeHandle(\n forwardedRef,\n () => ({\n scrollTo: (date: Date) => {\n event.emit({ type: 'scroll', date });\n },\n }),\n [event],\n );\n\n return (\n <CalendarContextProvider\n weekStartsOn={weekStartsOn}\n event={event}\n index={index}\n setIndex={setIndex}\n selected={selected}\n setSelected={setSelected}\n >\n {children}\n </CalendarContextProvider>\n );\n },\n);\n\n//\n// Viewport\n//\n\ntype CalendarViewportProps = PropsWithChildren<ThemedClassName>;\n\nconst CalendarViewport = ({ children, classNames }: CalendarViewportProps) => {\n return (\n <div role='none' className={mx('flex flex-col items-center overflow-hidden bg-inputSurface', classNames)}>\n {children}\n </div>\n );\n};\n\nCalendarViewport.displayName = 'CalendarContent';\n\n//\n// Header\n//\n\ntype CalendarHeaderProps = ThemedClassName;\n\nconst CalendarHeader = ({ classNames }: CalendarHeaderProps) => {\n const { t } = useTranslation(translationKey);\n const { weekStartsOn, event, index, selected } = useCalendarContext(CalendarHeader.displayName);\n const top = useMemo(() => getDate(start, index ?? 0, 6, weekStartsOn), [index, weekStartsOn]);\n const today = useMemo(() => new Date(), []);\n\n const handleToday = useCallback(() => {\n event.emit({ type: 'scroll', date: today });\n }, [event, start, today]);\n\n return (\n <div role='none' className={mx('shink-0 is-full grid grid-cols-3', classNames)} style={{ width: defaultWidth }}>\n <div className='flex justify-start'>\n <IconButton\n variant='ghost'\n size={6}\n icon='ph--calendar--regular'\n iconOnly\n classNames='aspect-square'\n label={t('today button')}\n onClick={handleToday}\n />\n </div>\n <span className='flex justify-center p-2'>{format(selected ?? top, 'MMMM')}</span>\n <span className='flex justify-end p-2'>{(selected ?? top).getFullYear()}</span>\n </div>\n );\n};\n\nCalendarHeader.displayName = 'CalendarHeader';\n\n//\n// Grid\n// TODO(burdon): Key nav.\n// TODO(burdon): Drag range.\n//\n\ntype CalendarGridProps = ThemedClassName<{\n rows?: number;\n onSelect?: (event: { date: Date }) => void;\n}>;\n\nconst CalendarGrid = ({ classNames, rows, onSelect }: CalendarGridProps) => {\n const { weekStartsOn, event, setIndex, selected, setSelected } = useCalendarContext(CalendarGrid.displayName);\n const { ref: containerRef, width = 0, height = 0 } = useResizeDetector();\n const maxHeight = rows ? rows * size : undefined;\n const listRef = useRef<List>(null);\n const today = useMemo(() => new Date(), []);\n\n const [initialized, setInitialized] = useState(false);\n useEffect(() => {\n const index = differenceInWeeks(today, start);\n listRef.current?.scrollToRow(index);\n }, [initialized, start, today]);\n\n useEffect(() => {\n return event.on((event) => {\n switch (event.type) {\n case 'scroll': {\n const index = differenceInWeeks(event.date, start);\n listRef.current?.scrollToRow(index);\n break;\n }\n }\n });\n }, [event]);\n\n const days = useMemo(() => {\n const weekStart = startOfWeek(new Date(), { weekStartsOn });\n return Array.from({ length: 7 }, (_, i) => {\n const day = addDays(weekStart, i);\n return format(day, 'EEE'); // Short day name (Mon, Tue, etc.)\n });\n }, []);\n\n const handleDaySelect = useCallback(\n (date: Date) => {\n setSelected((current) => (isSameDay(date, current) ? undefined : date));\n onSelect?.({ date });\n },\n [onSelect],\n );\n\n const handleScroll = useCallback<NonNullable<ListProps['onScroll']>>((info) => {\n setIndex(Math.round(info.scrollTop / size));\n }, []);\n\n const rowRenderer = useCallback<ListRowRenderer>(\n ({ key, index, style }) => {\n const getBgColor = (date: Date) => date.getMonth() % 2 === 0 && 'bg-modalSurface';\n return (\n <div key={key} style={style} className='is-full grid grid-cols-[1fr_max-content_1fr] snap-center'>\n <div className={mx(getBgColor(getDate(start, index, 0, weekStartsOn)))} />\n <div className='grid grid-cols-7' style={{ gridTemplateColumns: `repeat(7, ${size}px)` }}>\n {Array.from({ length: 7 }).map((_, i) => {\n const date = getDate(start, index, i, weekStartsOn);\n const border = isSameDay(date, selected)\n ? 'border-primary-500'\n : isSameDay(date, today)\n ? 'border-amber-500'\n : undefined;\n\n return (\n <div\n key={i}\n className={mx('relative flex justify-center items-center cursor-pointer', getBgColor(date))}\n onClick={() => handleDaySelect(date)}\n >\n <span className='text-description'>{date.getDate()}</span>\n {!border && date.getDate() === 1 && (\n <span className='absolute top-0 text-xs text-description'>{format(date, 'MMM')}</span>\n )}\n {border && (\n <div className={mx('absolute top-0 left-0 is-full bs-full border-2 rounded-full', border)} />\n )}\n </div>\n );\n })}\n </div>\n <div className={mx(getBgColor(getDate(start, index, 6, weekStartsOn)))} />\n </div>\n );\n },\n [handleDaySelect, selected, weekStartsOn],\n );\n\n return (\n <div role='none' className={mx('flex flex-col bs-full is-full justify-center overflow-hidden', classNames)}>\n {/* Day labels */}\n <div role='none' className='flex justify-center bg-groupSurface'>\n <div role='none' className='flex is-full grid grid-cols-7' style={{ width: defaultWidth }}>\n {days.map((date, i) => (\n <div key={i} role='none' className='flex justify-center p-2 text-sm font-thin'>\n {date}\n </div>\n ))}\n </div>\n </div>\n {/* Grid */}\n <div role='none' className='flex flex-col bs-full is-full justify-center overflow-hidden' ref={containerRef}>\n <List\n ref={listRef}\n role='none'\n // TODO(burdon): Snap isn't working.\n className='[&>div]:snap-y scrollbar-none outline-none'\n width={width}\n height={maxHeight ?? height}\n rowCount={maxRows}\n rowHeight={size}\n rowRenderer={rowRenderer}\n scrollToAlignment='start'\n onScroll={handleScroll}\n onRowsRendered={() => setInitialized(true)}\n />\n </div>\n </div>\n );\n};\n\nCalendarGrid.displayName = 'CalendarGrid';\n\n//\n// Calendar\n//\n\nexport const Calendar = {\n Root: CalendarRoot,\n Viewport: CalendarViewport,\n Header: CalendarHeader,\n Grid: CalendarGrid,\n};\n\nexport type { CalendarController, CalendarRootProps, CalendarViewportProps, CalendarHeaderProps, CalendarGridProps };\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type Resource } from '@dxos/react-ui';\n\nexport const translationKey = 'react-ui-calendar';\n\nexport const translations = [\n {\n 'en-US': {\n [translationKey]: {\n 'today button': 'Today',\n },\n },\n },\n] as const satisfies Resource[];\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type Day } from 'date-fns';\n\nexport const getDate = (start: Date, weekNumber: number, dayOfWeek: number, weekStartsOn: Day): Date => {\n const result = new Date(start);\n const startDayOfWeek = start.getDay(); // 0 = Sunday, 1 = Monday, etc.\n const adjustedStartDay = (startDayOfWeek === 0 ? 7 : startDayOfWeek) - weekStartsOn; // Adjust for weekStartsOn.\n result.setDate(start.getDate() - adjustedStartDay + weekNumber * 7 + dayOfWeek);\n return result;\n};\n\nexport const isSameDay = (date1: Date, date2: Date | undefined): boolean => {\n return (\n !!date2 &&\n date1.getFullYear() === date2.getFullYear() &&\n date1.getMonth() === date2.getMonth() &&\n date1.getDate() === date2.getDate()\n );\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["createContext", "addDays", "differenceInWeeks", "format", "startOfWeek", "React", "forwardRef", "useCallback", "useEffect", "useImperativeHandle", "useMemo", "useRef", "useState", "useResizeDetector", "List", "Event", "IconButton", "useTranslation", "mx", "translationKey", "translations", "getDate", "start", "weekNumber", "dayOfWeek", "weekStartsOn", "result", "Date", "startDayOfWeek", "getDay", "adjustedStartDay", "setDate", "isSameDay", "date1", "date2", "getFullYear", "getMonth", "maxRows", "start", "Date", "size", "defaultWidth", "CalendarContextProvider", "useCalendarContext", "createContext", "CalendarRoot", "forwardRef", "children", "weekStartsOn", "forwardedRef", "event", "useMemo", "Event", "selected", "setSelected", "useState", "index", "setIndex", "useImperativeHandle", "scrollTo", "date", "emit", "type", "CalendarViewport", "classNames", "div", "role", "className", "mx", "displayName", "CalendarHeader", "t", "useTranslation", "translationKey", "top", "getDate", "today", "handleToday", "useCallback", "style", "width", "IconButton", "variant", "icon", "iconOnly", "label", "onClick", "span", "format", "getFullYear", "CalendarGrid", "rows", "onSelect", "ref", "containerRef", "height", "useResizeDetector", "maxHeight", "undefined", "listRef", "useRef", "initialized", "setInitialized", "useEffect", "differenceInWeeks", "current", "scrollToRow", "on", "days", "weekStart", "startOfWeek", "Array", "from", "length", "_", "i", "day", "addDays", "handleDaySelect", "isSameDay", "handleScroll", "info", "Math", "round", "scrollTop", "rowRenderer", "key", "getBgColor", "getMonth", "gridTemplateColumns", "map", "border", "List", "rowCount", "rowHeight", "scrollToAlignment", "onScroll", "onRowsRendered", "Calendar", "Root", "Viewport", "Header", "Grid"]
7
+ }
@@ -0,0 +1 @@
1
+ {"inputs":{"src/translations.ts":{"bytes":1182,"imports":[],"format":"esm"},"src/components/Calendar/util.ts":{"bytes":2802,"imports":[],"format":"esm"},"src/components/Calendar/Calendar.tsx":{"bytes":29761,"imports":[{"path":"@preact-signals/safe-react/tracking","kind":"import-statement","external":true},{"path":"@radix-ui/react-context","kind":"import-statement","external":true},{"path":"date-fns","kind":"import-statement","external":true},{"path":"react","kind":"import-statement","external":true},{"path":"react-resize-detector","kind":"import-statement","external":true},{"path":"react-virtualized","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/react-ui","kind":"import-statement","external":true},{"path":"@dxos/react-ui-theme","kind":"import-statement","external":true},{"path":"src/translations.ts","kind":"import-statement","original":"../../translations"},{"path":"src/components/Calendar/util.ts","kind":"import-statement","original":"./util"}],"format":"esm"},"src/components/Calendar/index.ts":{"bytes":476,"imports":[{"path":"src/components/Calendar/Calendar.tsx","kind":"import-statement","original":"./Calendar"}],"format":"esm"},"src/components/index.ts":{"bytes":467,"imports":[{"path":"src/components/Calendar/index.ts","kind":"import-statement","original":"./Calendar"}],"format":"esm"},"src/index.ts":{"bytes":462,"imports":[{"path":"src/components/index.ts","kind":"import-statement","original":"./components"}],"format":"esm"}},"outputs":{"dist/lib/browser/index.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":17427},"dist/lib/browser/index.mjs":{"imports":[{"path":"@preact-signals/safe-react/tracking","kind":"import-statement","external":true},{"path":"@radix-ui/react-context","kind":"import-statement","external":true},{"path":"date-fns","kind":"import-statement","external":true},{"path":"react","kind":"import-statement","external":true},{"path":"react-resize-detector","kind":"import-statement","external":true},{"path":"react-virtualized","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/react-ui","kind":"import-statement","external":true},{"path":"@dxos/react-ui-theme","kind":"import-statement","external":true}],"exports":["Calendar"],"entryPoint":"src/index.ts","inputs":{"src/components/Calendar/Calendar.tsx":{"bytesInOutput":8140},"src/translations.ts":{"bytesInOutput":161},"src/components/Calendar/util.ts":{"bytesInOutput":517},"src/components/Calendar/index.ts":{"bytesInOutput":0},"src/components/index.ts":{"bytesInOutput":0},"src/index.ts":{"bytesInOutput":0}},"bytes":9017}}}
@@ -0,0 +1,267 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+
3
+ // src/components/Calendar/Calendar.tsx
4
+ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
5
+ import { createContext } from "@radix-ui/react-context";
6
+ import { addDays, differenceInWeeks, format, startOfWeek } from "date-fns";
7
+ import React, { forwardRef, useCallback, useEffect, useImperativeHandle, useMemo, useRef, useState } from "react";
8
+ import { useResizeDetector } from "react-resize-detector";
9
+ import { List } from "react-virtualized";
10
+ import { Event } from "@dxos/async";
11
+ import { IconButton, useTranslation } from "@dxos/react-ui";
12
+ import { mx } from "@dxos/react-ui-theme";
13
+
14
+ // src/translations.ts
15
+ var translationKey = "react-ui-calendar";
16
+ var translations = [
17
+ {
18
+ "en-US": {
19
+ [translationKey]: {
20
+ "today button": "Today"
21
+ }
22
+ }
23
+ }
24
+ ];
25
+
26
+ // src/components/Calendar/util.ts
27
+ var getDate = (start2, weekNumber, dayOfWeek, weekStartsOn) => {
28
+ const result = new Date(start2);
29
+ const startDayOfWeek = start2.getDay();
30
+ const adjustedStartDay = (startDayOfWeek === 0 ? 7 : startDayOfWeek) - weekStartsOn;
31
+ result.setDate(start2.getDate() - adjustedStartDay + weekNumber * 7 + dayOfWeek);
32
+ return result;
33
+ };
34
+ var isSameDay = (date1, date2) => {
35
+ return !!date2 && date1.getFullYear() === date2.getFullYear() && date1.getMonth() === date2.getMonth() && date1.getDate() === date2.getDate();
36
+ };
37
+
38
+ // src/components/Calendar/Calendar.tsx
39
+ var maxRows = 50 * 100;
40
+ var start = /* @__PURE__ */ new Date("1970-01-01");
41
+ var size = 48;
42
+ var defaultWidth = 7 * size;
43
+ var [CalendarContextProvider, useCalendarContext] = createContext("Calendar");
44
+ var CalendarRoot = /* @__PURE__ */ forwardRef(({ children, weekStartsOn = 1 }, forwardedRef) => {
45
+ var _effect = _useSignals();
46
+ try {
47
+ const event = useMemo(() => new Event(), []);
48
+ const [selected, setSelected] = useState();
49
+ const [index, setIndex] = useState();
50
+ useImperativeHandle(forwardedRef, () => ({
51
+ scrollTo: (date) => {
52
+ event.emit({
53
+ type: "scroll",
54
+ date
55
+ });
56
+ }
57
+ }), [
58
+ event
59
+ ]);
60
+ return /* @__PURE__ */ React.createElement(CalendarContextProvider, {
61
+ weekStartsOn,
62
+ event,
63
+ index,
64
+ setIndex,
65
+ selected,
66
+ setSelected
67
+ }, children);
68
+ } finally {
69
+ _effect.f();
70
+ }
71
+ });
72
+ var CalendarViewport = ({ children, classNames }) => {
73
+ var _effect = _useSignals();
74
+ try {
75
+ return /* @__PURE__ */ React.createElement("div", {
76
+ role: "none",
77
+ className: mx("flex flex-col items-center overflow-hidden bg-inputSurface", classNames)
78
+ }, children);
79
+ } finally {
80
+ _effect.f();
81
+ }
82
+ };
83
+ CalendarViewport.displayName = "CalendarContent";
84
+ var CalendarHeader = ({ classNames }) => {
85
+ var _effect = _useSignals();
86
+ try {
87
+ const { t } = useTranslation(translationKey);
88
+ const { weekStartsOn, event, index, selected } = useCalendarContext(CalendarHeader.displayName);
89
+ const top = useMemo(() => getDate(start, index ?? 0, 6, weekStartsOn), [
90
+ index,
91
+ weekStartsOn
92
+ ]);
93
+ const today = useMemo(() => /* @__PURE__ */ new Date(), []);
94
+ const handleToday = useCallback(() => {
95
+ event.emit({
96
+ type: "scroll",
97
+ date: today
98
+ });
99
+ }, [
100
+ event,
101
+ start,
102
+ today
103
+ ]);
104
+ return /* @__PURE__ */ React.createElement("div", {
105
+ role: "none",
106
+ className: mx("shink-0 is-full grid grid-cols-3", classNames),
107
+ style: {
108
+ width: defaultWidth
109
+ }
110
+ }, /* @__PURE__ */ React.createElement("div", {
111
+ className: "flex justify-start"
112
+ }, /* @__PURE__ */ React.createElement(IconButton, {
113
+ variant: "ghost",
114
+ size: 6,
115
+ icon: "ph--calendar--regular",
116
+ iconOnly: true,
117
+ classNames: "aspect-square",
118
+ label: t("today button"),
119
+ onClick: handleToday
120
+ })), /* @__PURE__ */ React.createElement("span", {
121
+ className: "flex justify-center p-2"
122
+ }, format(selected ?? top, "MMMM")), /* @__PURE__ */ React.createElement("span", {
123
+ className: "flex justify-end p-2"
124
+ }, (selected ?? top).getFullYear()));
125
+ } finally {
126
+ _effect.f();
127
+ }
128
+ };
129
+ CalendarHeader.displayName = "CalendarHeader";
130
+ var CalendarGrid = ({ classNames, rows, onSelect }) => {
131
+ var _effect = _useSignals();
132
+ try {
133
+ const { weekStartsOn, event, setIndex, selected, setSelected } = useCalendarContext(CalendarGrid.displayName);
134
+ const { ref: containerRef, width = 0, height = 0 } = useResizeDetector();
135
+ const maxHeight = rows ? rows * size : void 0;
136
+ const listRef = useRef(null);
137
+ const today = useMemo(() => /* @__PURE__ */ new Date(), []);
138
+ const [initialized, setInitialized] = useState(false);
139
+ useEffect(() => {
140
+ const index = differenceInWeeks(today, start);
141
+ listRef.current?.scrollToRow(index);
142
+ }, [
143
+ initialized,
144
+ start,
145
+ today
146
+ ]);
147
+ useEffect(() => {
148
+ return event.on((event2) => {
149
+ switch (event2.type) {
150
+ case "scroll": {
151
+ const index = differenceInWeeks(event2.date, start);
152
+ listRef.current?.scrollToRow(index);
153
+ break;
154
+ }
155
+ }
156
+ });
157
+ }, [
158
+ event
159
+ ]);
160
+ const days = useMemo(() => {
161
+ const weekStart = startOfWeek(/* @__PURE__ */ new Date(), {
162
+ weekStartsOn
163
+ });
164
+ return Array.from({
165
+ length: 7
166
+ }, (_, i) => {
167
+ const day = addDays(weekStart, i);
168
+ return format(day, "EEE");
169
+ });
170
+ }, []);
171
+ const handleDaySelect = useCallback((date) => {
172
+ setSelected((current) => isSameDay(date, current) ? void 0 : date);
173
+ onSelect?.({
174
+ date
175
+ });
176
+ }, [
177
+ onSelect
178
+ ]);
179
+ const handleScroll = useCallback((info) => {
180
+ setIndex(Math.round(info.scrollTop / size));
181
+ }, []);
182
+ const rowRenderer = useCallback(({ key, index, style }) => {
183
+ const getBgColor = (date) => date.getMonth() % 2 === 0 && "bg-modalSurface";
184
+ return /* @__PURE__ */ React.createElement("div", {
185
+ key,
186
+ style,
187
+ className: "is-full grid grid-cols-[1fr_max-content_1fr] snap-center"
188
+ }, /* @__PURE__ */ React.createElement("div", {
189
+ className: mx(getBgColor(getDate(start, index, 0, weekStartsOn)))
190
+ }), /* @__PURE__ */ React.createElement("div", {
191
+ className: "grid grid-cols-7",
192
+ style: {
193
+ gridTemplateColumns: `repeat(7, ${size}px)`
194
+ }
195
+ }, Array.from({
196
+ length: 7
197
+ }).map((_, i) => {
198
+ const date = getDate(start, index, i, weekStartsOn);
199
+ const border = isSameDay(date, selected) ? "border-primary-500" : isSameDay(date, today) ? "border-amber-500" : void 0;
200
+ return /* @__PURE__ */ React.createElement("div", {
201
+ key: i,
202
+ className: mx("relative flex justify-center items-center cursor-pointer", getBgColor(date)),
203
+ onClick: () => handleDaySelect(date)
204
+ }, /* @__PURE__ */ React.createElement("span", {
205
+ className: "text-description"
206
+ }, date.getDate()), !border && date.getDate() === 1 && /* @__PURE__ */ React.createElement("span", {
207
+ className: "absolute top-0 text-xs text-description"
208
+ }, format(date, "MMM")), border && /* @__PURE__ */ React.createElement("div", {
209
+ className: mx("absolute top-0 left-0 is-full bs-full border-2 rounded-full", border)
210
+ }));
211
+ })), /* @__PURE__ */ React.createElement("div", {
212
+ className: mx(getBgColor(getDate(start, index, 6, weekStartsOn)))
213
+ }));
214
+ }, [
215
+ handleDaySelect,
216
+ selected,
217
+ weekStartsOn
218
+ ]);
219
+ return /* @__PURE__ */ React.createElement("div", {
220
+ role: "none",
221
+ className: mx("flex flex-col bs-full is-full justify-center overflow-hidden", classNames)
222
+ }, /* @__PURE__ */ React.createElement("div", {
223
+ role: "none",
224
+ className: "flex justify-center bg-groupSurface"
225
+ }, /* @__PURE__ */ React.createElement("div", {
226
+ role: "none",
227
+ className: "flex is-full grid grid-cols-7",
228
+ style: {
229
+ width: defaultWidth
230
+ }
231
+ }, days.map((date, i) => /* @__PURE__ */ React.createElement("div", {
232
+ key: i,
233
+ role: "none",
234
+ className: "flex justify-center p-2 text-sm font-thin"
235
+ }, date)))), /* @__PURE__ */ React.createElement("div", {
236
+ role: "none",
237
+ className: "flex flex-col bs-full is-full justify-center overflow-hidden",
238
+ ref: containerRef
239
+ }, /* @__PURE__ */ React.createElement(List, {
240
+ ref: listRef,
241
+ role: "none",
242
+ // TODO(burdon): Snap isn't working.
243
+ className: "[&>div]:snap-y scrollbar-none outline-none",
244
+ width,
245
+ height: maxHeight ?? height,
246
+ rowCount: maxRows,
247
+ rowHeight: size,
248
+ rowRenderer,
249
+ scrollToAlignment: "start",
250
+ onScroll: handleScroll,
251
+ onRowsRendered: () => setInitialized(true)
252
+ })));
253
+ } finally {
254
+ _effect.f();
255
+ }
256
+ };
257
+ CalendarGrid.displayName = "CalendarGrid";
258
+ var Calendar = {
259
+ Root: CalendarRoot,
260
+ Viewport: CalendarViewport,
261
+ Header: CalendarHeader,
262
+ Grid: CalendarGrid
263
+ };
264
+ export {
265
+ Calendar
266
+ };
267
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/Calendar/Calendar.tsx", "../../../src/translations.ts", "../../../src/components/Calendar/util.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { createContext } from '@radix-ui/react-context';\nimport { type Day, addDays, differenceInWeeks, format, startOfWeek } from 'date-fns';\nimport React, {\n type Dispatch,\n type PropsWithChildren,\n type SetStateAction,\n forwardRef,\n useCallback,\n useEffect,\n useImperativeHandle,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport { useResizeDetector } from 'react-resize-detector';\nimport { List, type ListProps, type ListRowRenderer } from 'react-virtualized';\n\nimport { Event } from '@dxos/async';\nimport { IconButton, type ThemedClassName, useTranslation } from '@dxos/react-ui';\nimport { mx } from '@dxos/react-ui-theme';\n\nimport { translationKey } from '../../translations';\n\nimport { getDate, isSameDay } from './util';\n\nconst maxRows = 50 * 100;\nconst start = new Date('1970-01-01');\nconst size = 48;\nconst defaultWidth = 7 * size;\n\n//\n// Context\n//\n\ntype CalendarEvent = {\n type: 'scroll';\n date: Date;\n};\n\ntype CalendarContextValue = {\n weekStartsOn: Day;\n event: Event<CalendarEvent>;\n index: number | undefined;\n setIndex: Dispatch<SetStateAction<number | undefined>>;\n selected: Date | undefined;\n setSelected: Dispatch<SetStateAction<Date | undefined>>;\n};\n\nconst [CalendarContextProvider, useCalendarContext] = createContext<CalendarContextValue>('Calendar');\n\n//\n// Controller\n//\n\ntype CalendarController = {\n scrollTo: (date: Date) => void;\n};\n\n//\n// Root\n//\n\ntype CalendarRootProps = PropsWithChildren<Partial<Pick<CalendarContextValue, 'weekStartsOn'>>>;\n\nconst CalendarRoot = forwardRef<CalendarController, CalendarRootProps>(\n ({ children, weekStartsOn = 1 }, forwardedRef) => {\n const event = useMemo(() => new Event<CalendarEvent>(), []);\n const [selected, setSelected] = useState<Date | undefined>();\n const [index, setIndex] = useState<number | undefined>();\n\n useImperativeHandle(\n forwardedRef,\n () => ({\n scrollTo: (date: Date) => {\n event.emit({ type: 'scroll', date });\n },\n }),\n [event],\n );\n\n return (\n <CalendarContextProvider\n weekStartsOn={weekStartsOn}\n event={event}\n index={index}\n setIndex={setIndex}\n selected={selected}\n setSelected={setSelected}\n >\n {children}\n </CalendarContextProvider>\n );\n },\n);\n\n//\n// Viewport\n//\n\ntype CalendarViewportProps = PropsWithChildren<ThemedClassName>;\n\nconst CalendarViewport = ({ children, classNames }: CalendarViewportProps) => {\n return (\n <div role='none' className={mx('flex flex-col items-center overflow-hidden bg-inputSurface', classNames)}>\n {children}\n </div>\n );\n};\n\nCalendarViewport.displayName = 'CalendarContent';\n\n//\n// Header\n//\n\ntype CalendarHeaderProps = ThemedClassName;\n\nconst CalendarHeader = ({ classNames }: CalendarHeaderProps) => {\n const { t } = useTranslation(translationKey);\n const { weekStartsOn, event, index, selected } = useCalendarContext(CalendarHeader.displayName);\n const top = useMemo(() => getDate(start, index ?? 0, 6, weekStartsOn), [index, weekStartsOn]);\n const today = useMemo(() => new Date(), []);\n\n const handleToday = useCallback(() => {\n event.emit({ type: 'scroll', date: today });\n }, [event, start, today]);\n\n return (\n <div role='none' className={mx('shink-0 is-full grid grid-cols-3', classNames)} style={{ width: defaultWidth }}>\n <div className='flex justify-start'>\n <IconButton\n variant='ghost'\n size={6}\n icon='ph--calendar--regular'\n iconOnly\n classNames='aspect-square'\n label={t('today button')}\n onClick={handleToday}\n />\n </div>\n <span className='flex justify-center p-2'>{format(selected ?? top, 'MMMM')}</span>\n <span className='flex justify-end p-2'>{(selected ?? top).getFullYear()}</span>\n </div>\n );\n};\n\nCalendarHeader.displayName = 'CalendarHeader';\n\n//\n// Grid\n// TODO(burdon): Key nav.\n// TODO(burdon): Drag range.\n//\n\ntype CalendarGridProps = ThemedClassName<{\n rows?: number;\n onSelect?: (event: { date: Date }) => void;\n}>;\n\nconst CalendarGrid = ({ classNames, rows, onSelect }: CalendarGridProps) => {\n const { weekStartsOn, event, setIndex, selected, setSelected } = useCalendarContext(CalendarGrid.displayName);\n const { ref: containerRef, width = 0, height = 0 } = useResizeDetector();\n const maxHeight = rows ? rows * size : undefined;\n const listRef = useRef<List>(null);\n const today = useMemo(() => new Date(), []);\n\n const [initialized, setInitialized] = useState(false);\n useEffect(() => {\n const index = differenceInWeeks(today, start);\n listRef.current?.scrollToRow(index);\n }, [initialized, start, today]);\n\n useEffect(() => {\n return event.on((event) => {\n switch (event.type) {\n case 'scroll': {\n const index = differenceInWeeks(event.date, start);\n listRef.current?.scrollToRow(index);\n break;\n }\n }\n });\n }, [event]);\n\n const days = useMemo(() => {\n const weekStart = startOfWeek(new Date(), { weekStartsOn });\n return Array.from({ length: 7 }, (_, i) => {\n const day = addDays(weekStart, i);\n return format(day, 'EEE'); // Short day name (Mon, Tue, etc.)\n });\n }, []);\n\n const handleDaySelect = useCallback(\n (date: Date) => {\n setSelected((current) => (isSameDay(date, current) ? undefined : date));\n onSelect?.({ date });\n },\n [onSelect],\n );\n\n const handleScroll = useCallback<NonNullable<ListProps['onScroll']>>((info) => {\n setIndex(Math.round(info.scrollTop / size));\n }, []);\n\n const rowRenderer = useCallback<ListRowRenderer>(\n ({ key, index, style }) => {\n const getBgColor = (date: Date) => date.getMonth() % 2 === 0 && 'bg-modalSurface';\n return (\n <div key={key} style={style} className='is-full grid grid-cols-[1fr_max-content_1fr] snap-center'>\n <div className={mx(getBgColor(getDate(start, index, 0, weekStartsOn)))} />\n <div className='grid grid-cols-7' style={{ gridTemplateColumns: `repeat(7, ${size}px)` }}>\n {Array.from({ length: 7 }).map((_, i) => {\n const date = getDate(start, index, i, weekStartsOn);\n const border = isSameDay(date, selected)\n ? 'border-primary-500'\n : isSameDay(date, today)\n ? 'border-amber-500'\n : undefined;\n\n return (\n <div\n key={i}\n className={mx('relative flex justify-center items-center cursor-pointer', getBgColor(date))}\n onClick={() => handleDaySelect(date)}\n >\n <span className='text-description'>{date.getDate()}</span>\n {!border && date.getDate() === 1 && (\n <span className='absolute top-0 text-xs text-description'>{format(date, 'MMM')}</span>\n )}\n {border && (\n <div className={mx('absolute top-0 left-0 is-full bs-full border-2 rounded-full', border)} />\n )}\n </div>\n );\n })}\n </div>\n <div className={mx(getBgColor(getDate(start, index, 6, weekStartsOn)))} />\n </div>\n );\n },\n [handleDaySelect, selected, weekStartsOn],\n );\n\n return (\n <div role='none' className={mx('flex flex-col bs-full is-full justify-center overflow-hidden', classNames)}>\n {/* Day labels */}\n <div role='none' className='flex justify-center bg-groupSurface'>\n <div role='none' className='flex is-full grid grid-cols-7' style={{ width: defaultWidth }}>\n {days.map((date, i) => (\n <div key={i} role='none' className='flex justify-center p-2 text-sm font-thin'>\n {date}\n </div>\n ))}\n </div>\n </div>\n {/* Grid */}\n <div role='none' className='flex flex-col bs-full is-full justify-center overflow-hidden' ref={containerRef}>\n <List\n ref={listRef}\n role='none'\n // TODO(burdon): Snap isn't working.\n className='[&>div]:snap-y scrollbar-none outline-none'\n width={width}\n height={maxHeight ?? height}\n rowCount={maxRows}\n rowHeight={size}\n rowRenderer={rowRenderer}\n scrollToAlignment='start'\n onScroll={handleScroll}\n onRowsRendered={() => setInitialized(true)}\n />\n </div>\n </div>\n );\n};\n\nCalendarGrid.displayName = 'CalendarGrid';\n\n//\n// Calendar\n//\n\nexport const Calendar = {\n Root: CalendarRoot,\n Viewport: CalendarViewport,\n Header: CalendarHeader,\n Grid: CalendarGrid,\n};\n\nexport type { CalendarController, CalendarRootProps, CalendarViewportProps, CalendarHeaderProps, CalendarGridProps };\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type Resource } from '@dxos/react-ui';\n\nexport const translationKey = 'react-ui-calendar';\n\nexport const translations = [\n {\n 'en-US': {\n [translationKey]: {\n 'today button': 'Today',\n },\n },\n },\n] as const satisfies Resource[];\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type Day } from 'date-fns';\n\nexport const getDate = (start: Date, weekNumber: number, dayOfWeek: number, weekStartsOn: Day): Date => {\n const result = new Date(start);\n const startDayOfWeek = start.getDay(); // 0 = Sunday, 1 = Monday, etc.\n const adjustedStartDay = (startDayOfWeek === 0 ? 7 : startDayOfWeek) - weekStartsOn; // Adjust for weekStartsOn.\n result.setDate(start.getDate() - adjustedStartDay + weekNumber * 7 + dayOfWeek);\n return result;\n};\n\nexport const isSameDay = (date1: Date, date2: Date | undefined): boolean => {\n return (\n !!date2 &&\n date1.getFullYear() === date2.getFullYear() &&\n date1.getMonth() === date2.getMonth() &&\n date1.getDate() === date2.getDate()\n );\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["createContext", "addDays", "differenceInWeeks", "format", "startOfWeek", "React", "forwardRef", "useCallback", "useEffect", "useImperativeHandle", "useMemo", "useRef", "useState", "useResizeDetector", "List", "Event", "IconButton", "useTranslation", "mx", "translationKey", "translations", "getDate", "start", "weekNumber", "dayOfWeek", "weekStartsOn", "result", "Date", "startDayOfWeek", "getDay", "adjustedStartDay", "setDate", "isSameDay", "date1", "date2", "getFullYear", "getMonth", "maxRows", "start", "Date", "size", "defaultWidth", "CalendarContextProvider", "useCalendarContext", "createContext", "CalendarRoot", "forwardRef", "children", "weekStartsOn", "forwardedRef", "event", "useMemo", "Event", "selected", "setSelected", "useState", "index", "setIndex", "useImperativeHandle", "scrollTo", "date", "emit", "type", "CalendarViewport", "classNames", "div", "role", "className", "mx", "displayName", "CalendarHeader", "t", "useTranslation", "translationKey", "top", "getDate", "today", "handleToday", "useCallback", "style", "width", "IconButton", "variant", "icon", "iconOnly", "label", "onClick", "span", "format", "getFullYear", "CalendarGrid", "rows", "onSelect", "ref", "containerRef", "height", "useResizeDetector", "maxHeight", "undefined", "listRef", "useRef", "initialized", "setInitialized", "useEffect", "differenceInWeeks", "current", "scrollToRow", "on", "days", "weekStart", "startOfWeek", "Array", "from", "length", "_", "i", "day", "addDays", "handleDaySelect", "isSameDay", "handleScroll", "info", "Math", "round", "scrollTop", "rowRenderer", "key", "getBgColor", "getMonth", "gridTemplateColumns", "map", "border", "List", "rowCount", "rowHeight", "scrollToAlignment", "onScroll", "onRowsRendered", "Calendar", "Root", "Viewport", "Header", "Grid"]
7
+ }