@dxos/react-ui-calendar 0.8.4-main.548089c → 0.8.4-main.59c2e9b
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/lib/browser/index.mjs +194 -201
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/node-esm/index.mjs +194 -201
- package/dist/lib/node-esm/index.mjs.map +3 -3
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/types/src/components/Calendar/Calendar.d.ts +4 -4
- package/dist/types/src/components/Calendar/Calendar.d.ts.map +1 -1
- package/dist/types/src/components/Calendar/Calendar.stories.d.ts +1 -1
- package/dist/types/src/translations.d.ts +2 -2
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +24 -22
- package/src/components/Calendar/Calendar.stories.tsx +4 -4
- package/src/components/Calendar/Calendar.tsx +41 -17
- package/src/translations.ts +1 -1
|
@@ -1,16 +1,15 @@
|
|
|
1
1
|
// src/components/Calendar/Calendar.tsx
|
|
2
|
-
import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
|
|
3
2
|
import { createContext } from "@radix-ui/react-context";
|
|
4
3
|
import { addDays, differenceInWeeks, format, startOfWeek } from "date-fns";
|
|
5
4
|
import React, { forwardRef, useCallback, useEffect, useImperativeHandle, useMemo, useRef, useState } from "react";
|
|
6
5
|
import { useResizeDetector } from "react-resize-detector";
|
|
7
6
|
import { List } from "react-virtualized";
|
|
8
7
|
import { Event } from "@dxos/async";
|
|
9
|
-
import { IconButton, useTranslation } from "@dxos/react-ui";
|
|
10
|
-
import { mx } from "@dxos/
|
|
8
|
+
import { Icon, IconButton, useTranslation } from "@dxos/react-ui";
|
|
9
|
+
import { mx } from "@dxos/ui-theme";
|
|
11
10
|
|
|
12
11
|
// src/translations.ts
|
|
13
|
-
var translationKey = "react-ui-calendar";
|
|
12
|
+
var translationKey = "@dxos/react-ui-calendar";
|
|
14
13
|
var translations = [
|
|
15
14
|
{
|
|
16
15
|
"en-US": {
|
|
@@ -40,223 +39,217 @@ var size = 48;
|
|
|
40
39
|
var defaultWidth = 7 * size;
|
|
41
40
|
var [CalendarContextProvider, useCalendarContext] = createContext("Calendar");
|
|
42
41
|
var CalendarRoot = /* @__PURE__ */ forwardRef(({ children, weekStartsOn = 1 }, forwardedRef) => {
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
setSelected
|
|
65
|
-
}, children);
|
|
66
|
-
} finally {
|
|
67
|
-
_effect.f();
|
|
68
|
-
}
|
|
42
|
+
const event = useMemo(() => new Event(), []);
|
|
43
|
+
const [selected, setSelected] = useState();
|
|
44
|
+
const [index, setIndex] = useState();
|
|
45
|
+
useImperativeHandle(forwardedRef, () => ({
|
|
46
|
+
scrollTo: (date) => {
|
|
47
|
+
event.emit({
|
|
48
|
+
type: "scroll",
|
|
49
|
+
date
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
}), [
|
|
53
|
+
event
|
|
54
|
+
]);
|
|
55
|
+
return /* @__PURE__ */ React.createElement(CalendarContextProvider, {
|
|
56
|
+
weekStartsOn,
|
|
57
|
+
event,
|
|
58
|
+
index,
|
|
59
|
+
setIndex,
|
|
60
|
+
selected,
|
|
61
|
+
setSelected
|
|
62
|
+
}, children);
|
|
69
63
|
});
|
|
70
64
|
var CalendarViewport = ({ children, classNames }) => {
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
className: mx("flex flex-col items-center overflow-hidden bg-inputSurface", classNames)
|
|
76
|
-
}, children);
|
|
77
|
-
} finally {
|
|
78
|
-
_effect.f();
|
|
79
|
-
}
|
|
65
|
+
return /* @__PURE__ */ React.createElement("div", {
|
|
66
|
+
role: "none",
|
|
67
|
+
className: mx("flex flex-col items-center overflow-hidden bg-inputSurface", classNames)
|
|
68
|
+
}, children);
|
|
80
69
|
};
|
|
81
70
|
CalendarViewport.displayName = "CalendarContent";
|
|
82
|
-
var
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
className: "flex justify-end p-2"
|
|
122
|
-
}, (selected ?? top).getFullYear()));
|
|
123
|
-
} finally {
|
|
124
|
-
_effect.f();
|
|
125
|
-
}
|
|
71
|
+
var CalendarToolbar = ({ classNames }) => {
|
|
72
|
+
const { t } = useTranslation(translationKey);
|
|
73
|
+
const { weekStartsOn, event, index, selected } = useCalendarContext(CalendarToolbar.displayName);
|
|
74
|
+
const top = useMemo(() => getDate(start, index ?? 0, 6, weekStartsOn), [
|
|
75
|
+
index,
|
|
76
|
+
weekStartsOn
|
|
77
|
+
]);
|
|
78
|
+
const today = useMemo(() => /* @__PURE__ */ new Date(), []);
|
|
79
|
+
const handleToday = useCallback(() => {
|
|
80
|
+
event.emit({
|
|
81
|
+
type: "scroll",
|
|
82
|
+
date: today
|
|
83
|
+
});
|
|
84
|
+
}, [
|
|
85
|
+
event,
|
|
86
|
+
start,
|
|
87
|
+
today
|
|
88
|
+
]);
|
|
89
|
+
return /* @__PURE__ */ React.createElement("div", {
|
|
90
|
+
role: "none",
|
|
91
|
+
className: mx("shink-0 is-full grid grid-cols-3 items-center bg-barSurface", classNames),
|
|
92
|
+
style: {
|
|
93
|
+
width: defaultWidth
|
|
94
|
+
}
|
|
95
|
+
}, /* @__PURE__ */ React.createElement("div", {
|
|
96
|
+
className: "flex justify-start"
|
|
97
|
+
}, /* @__PURE__ */ React.createElement(IconButton, {
|
|
98
|
+
variant: "ghost",
|
|
99
|
+
size: 5,
|
|
100
|
+
icon: "ph--calendar--regular",
|
|
101
|
+
iconOnly: true,
|
|
102
|
+
classNames: "aspect-square",
|
|
103
|
+
label: t("today button"),
|
|
104
|
+
onClick: handleToday
|
|
105
|
+
})), /* @__PURE__ */ React.createElement("div", {
|
|
106
|
+
className: "flex justify-center p-2 text-description"
|
|
107
|
+
}, format(selected ?? top, "MMMM")), /* @__PURE__ */ React.createElement("div", {
|
|
108
|
+
className: "flex justify-end p-2 text-description"
|
|
109
|
+
}, (selected ?? top).getFullYear()));
|
|
126
110
|
};
|
|
127
|
-
|
|
111
|
+
CalendarToolbar.displayName = "CalendarHeader";
|
|
128
112
|
var CalendarGrid = ({ classNames, rows, onSelect }) => {
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
const
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
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)`
|
|
113
|
+
const { weekStartsOn, event, setIndex, selected, setSelected } = useCalendarContext(CalendarGrid.displayName);
|
|
114
|
+
const { ref: containerRef, width = 0, height = 0 } = useResizeDetector();
|
|
115
|
+
const maxHeight = rows ? rows * size : void 0;
|
|
116
|
+
const listRef = useRef(null);
|
|
117
|
+
const today = useMemo(() => /* @__PURE__ */ new Date(), []);
|
|
118
|
+
const [initialized, setInitialized] = useState(false);
|
|
119
|
+
useEffect(() => {
|
|
120
|
+
const index = differenceInWeeks(today, start);
|
|
121
|
+
listRef.current?.scrollToRow(index);
|
|
122
|
+
}, [
|
|
123
|
+
initialized,
|
|
124
|
+
start,
|
|
125
|
+
today
|
|
126
|
+
]);
|
|
127
|
+
useEffect(() => {
|
|
128
|
+
return event.on((event2) => {
|
|
129
|
+
switch (event2.type) {
|
|
130
|
+
case "scroll": {
|
|
131
|
+
const index = differenceInWeeks(event2.date, start);
|
|
132
|
+
listRef.current?.scrollToRow(index);
|
|
133
|
+
break;
|
|
192
134
|
}
|
|
193
|
-
}
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
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,
|
|
135
|
+
}
|
|
136
|
+
});
|
|
137
|
+
}, [
|
|
138
|
+
event
|
|
139
|
+
]);
|
|
140
|
+
const days = useMemo(() => {
|
|
141
|
+
const weekStart = startOfWeek(/* @__PURE__ */ new Date(), {
|
|
215
142
|
weekStartsOn
|
|
216
|
-
|
|
143
|
+
});
|
|
144
|
+
return Array.from({
|
|
145
|
+
length: 7
|
|
146
|
+
}, (_, i) => {
|
|
147
|
+
const day = addDays(weekStart, i);
|
|
148
|
+
return format(day, "EEE");
|
|
149
|
+
});
|
|
150
|
+
}, []);
|
|
151
|
+
const getNumAppointments = useCallback((_date) => {
|
|
152
|
+
return 0;
|
|
153
|
+
}, []);
|
|
154
|
+
const handleDaySelect = useCallback((date) => {
|
|
155
|
+
setSelected((current) => isSameDay(date, current) ? void 0 : date);
|
|
156
|
+
onSelect?.({
|
|
157
|
+
date
|
|
158
|
+
});
|
|
159
|
+
}, [
|
|
160
|
+
onSelect
|
|
161
|
+
]);
|
|
162
|
+
const handleScroll = useCallback((info) => {
|
|
163
|
+
setIndex(Math.round(info.scrollTop / size));
|
|
164
|
+
}, []);
|
|
165
|
+
const rowRenderer = useCallback(({ key, index, style }) => {
|
|
166
|
+
const getBgColor = (date) => date.getMonth() % 2 === 0 && "bg-modalSurface";
|
|
217
167
|
return /* @__PURE__ */ React.createElement("div", {
|
|
168
|
+
key,
|
|
218
169
|
role: "none",
|
|
219
|
-
|
|
170
|
+
style,
|
|
171
|
+
className: "is-full grid grid-cols-[1fr_max-content_1fr] snap-center"
|
|
220
172
|
}, /* @__PURE__ */ React.createElement("div", {
|
|
221
173
|
role: "none",
|
|
222
|
-
className:
|
|
223
|
-
}, /* @__PURE__ */ React.createElement("div", {
|
|
174
|
+
className: mx(getBgColor(getDate(start, index, 0, weekStartsOn)))
|
|
175
|
+
}), /* @__PURE__ */ React.createElement("div", {
|
|
224
176
|
role: "none",
|
|
225
|
-
className: "
|
|
177
|
+
className: "grid grid-cols-7",
|
|
226
178
|
style: {
|
|
227
|
-
|
|
179
|
+
gridTemplateColumns: `repeat(7, ${size}px)`
|
|
228
180
|
}
|
|
229
|
-
},
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
181
|
+
}, Array.from({
|
|
182
|
+
length: 7
|
|
183
|
+
}).map((_, i) => {
|
|
184
|
+
const date = getDate(start, index, i, weekStartsOn);
|
|
185
|
+
const num = getNumAppointments(date);
|
|
186
|
+
const border = isSameDay(date, selected) ? "border-primary-500" : isSameDay(date, today) ? "border-amber-500" : void 0;
|
|
187
|
+
return /* @__PURE__ */ React.createElement("div", {
|
|
188
|
+
key: i,
|
|
189
|
+
role: "none",
|
|
190
|
+
className: mx("relative flex justify-center items-center cursor-pointer", getBgColor(date)),
|
|
191
|
+
onClick: () => handleDaySelect(date)
|
|
192
|
+
}, /* @__PURE__ */ React.createElement("span", {
|
|
193
|
+
className: "text-description"
|
|
194
|
+
}, date.getDate()), !border && date.getDate() === 1 && /* @__PURE__ */ React.createElement("span", {
|
|
195
|
+
className: "absolute top-0 text-xs text-description"
|
|
196
|
+
}, format(date, "MMM")), border && /* @__PURE__ */ React.createElement("div", {
|
|
197
|
+
role: "none",
|
|
198
|
+
className: mx("absolute top-0 left-0 is-full bs-full border-2 rounded-full", border)
|
|
199
|
+
}), num > 0 && /* @__PURE__ */ React.createElement(Icon, {
|
|
200
|
+
classNames: "absolute bottom-0",
|
|
201
|
+
icon: num > 3 ? "ph--dots-three--regular" : "ph--dot--regular",
|
|
202
|
+
size: 5
|
|
203
|
+
}));
|
|
204
|
+
})), /* @__PURE__ */ React.createElement("div", {
|
|
205
|
+
className: mx(getBgColor(getDate(start, index, 6, weekStartsOn)))
|
|
206
|
+
}));
|
|
207
|
+
}, [
|
|
208
|
+
handleDaySelect,
|
|
209
|
+
getNumAppointments,
|
|
210
|
+
selected,
|
|
211
|
+
weekStartsOn
|
|
212
|
+
]);
|
|
213
|
+
return /* @__PURE__ */ React.createElement("div", {
|
|
214
|
+
role: "none",
|
|
215
|
+
className: mx("flex flex-col bs-full is-full justify-center overflow-hidden", classNames)
|
|
216
|
+
}, /* @__PURE__ */ React.createElement("div", {
|
|
217
|
+
role: "none",
|
|
218
|
+
className: "flex justify-center bg-groupSurface"
|
|
219
|
+
}, /* @__PURE__ */ React.createElement("div", {
|
|
220
|
+
role: "none",
|
|
221
|
+
className: "flex is-full grid grid-cols-7",
|
|
222
|
+
style: {
|
|
223
|
+
width: defaultWidth
|
|
224
|
+
}
|
|
225
|
+
}, days.map((date, i) => /* @__PURE__ */ React.createElement("div", {
|
|
226
|
+
key: i,
|
|
227
|
+
role: "none",
|
|
228
|
+
className: "flex justify-center p-2 text-sm font-thin"
|
|
229
|
+
}, date)))), /* @__PURE__ */ React.createElement("div", {
|
|
230
|
+
role: "none",
|
|
231
|
+
className: "flex flex-col bs-full is-full justify-center overflow-hidden",
|
|
232
|
+
ref: containerRef
|
|
233
|
+
}, /* @__PURE__ */ React.createElement(List, {
|
|
234
|
+
ref: listRef,
|
|
235
|
+
role: "none",
|
|
236
|
+
// TODO(burdon): Snap isn't working.
|
|
237
|
+
className: "[&>div]:snap-y scrollbar-none outline-none",
|
|
238
|
+
width,
|
|
239
|
+
height: maxHeight ?? height,
|
|
240
|
+
rowCount: maxRows,
|
|
241
|
+
rowHeight: size,
|
|
242
|
+
rowRenderer,
|
|
243
|
+
scrollToAlignment: "start",
|
|
244
|
+
onScroll: handleScroll,
|
|
245
|
+
onRowsRendered: () => setInitialized(true)
|
|
246
|
+
})));
|
|
254
247
|
};
|
|
255
248
|
CalendarGrid.displayName = "CalendarGrid";
|
|
256
249
|
var Calendar = {
|
|
257
250
|
Root: CalendarRoot,
|
|
258
251
|
Viewport: CalendarViewport,
|
|
259
|
-
|
|
252
|
+
Toolbar: CalendarToolbar,
|
|
260
253
|
Grid: CalendarGrid
|
|
261
254
|
};
|
|
262
255
|
export {
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
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": "
|
|
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", "
|
|
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 { Icon, IconButton, type ThemedClassName, useTranslation } from '@dxos/react-ui';\nimport { mx } from '@dxos/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 CalendarToolbarProps = ThemedClassName;\n\nconst CalendarToolbar = ({ classNames }: CalendarToolbarProps) => {\n const { t } = useTranslation(translationKey);\n const { weekStartsOn, event, index, selected } = useCalendarContext(CalendarToolbar.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\n role='none'\n className={mx('shink-0 is-full grid grid-cols-3 items-center bg-barSurface', classNames)}\n style={{ width: defaultWidth }}\n >\n <div className='flex justify-start'>\n <IconButton\n variant='ghost'\n size={5}\n icon='ph--calendar--regular'\n iconOnly\n classNames='aspect-square'\n label={t('today button')}\n onClick={handleToday}\n />\n </div>\n <div className='flex justify-center p-2 text-description'>{format(selected ?? top, 'MMMM')}</div>\n <div className='flex justify-end p-2 text-description'>{(selected ?? top).getFullYear()}</div>\n </div>\n );\n};\n\nCalendarToolbar.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 // TODO(burdon): Get info by range.\n // TODO(burdon): Border marker for \"all day events?\"\n const getNumAppointments = useCallback((_date: Date) => {\n // return Math.floor(Math.random() * 10);\n return 0;\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} role='none' style={style} className='is-full grid grid-cols-[1fr_max-content_1fr] snap-center'>\n <div role='none' className={mx(getBgColor(getDate(start, index, 0, weekStartsOn)))} />\n <div role='none' 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 num = getNumAppointments(date);\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 role='none'\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\n role='none'\n className={mx('absolute top-0 left-0 is-full bs-full border-2 rounded-full', border)}\n />\n )}\n {num > 0 && (\n <Icon\n classNames='absolute bottom-0'\n icon={num > 3 ? 'ph--dots-three--regular' : 'ph--dot--regular'}\n size={5}\n />\n )}\n </div>\n );\n })}\n </div>\n <div className={mx(getBgColor(getDate(start, index, 6, weekStartsOn)))} />\n </div>\n );\n },\n [handleDaySelect, getNumAppointments, 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\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 Toolbar: CalendarToolbar,\n Grid: CalendarGrid,\n};\n\nexport type { CalendarController, CalendarRootProps, CalendarViewportProps, CalendarToolbarProps, CalendarGridProps };\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type Resource } from '@dxos/react-ui';\n\nexport const translationKey = '@dxos/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", "Icon", "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", "CalendarToolbar", "t", "useTranslation", "translationKey", "top", "getDate", "today", "handleToday", "useCallback", "style", "width", "IconButton", "variant", "icon", "iconOnly", "label", "onClick", "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", "getNumAppointments", "_date", "handleDaySelect", "isSameDay", "handleScroll", "info", "Math", "round", "scrollTop", "rowRenderer", "key", "getBgColor", "getMonth", "gridTemplateColumns", "map", "num", "border", "span", "Icon", "List", "rowCount", "rowHeight", "scrollToAlignment", "onScroll", "onRowsRendered", "Calendar", "Root", "Viewport", "Toolbar", "Grid"]
|
|
7
7
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"inputs":{"src/translations.ts":{"bytes":
|
|
1
|
+
{"inputs":{"src/translations.ts":{"bytes":1196,"imports":[],"format":"esm"},"src/components/Calendar/util.ts":{"bytes":2802,"imports":[],"format":"esm"},"src/components/Calendar/Calendar.tsx":{"bytes":30821,"imports":[{"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/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":18558},"dist/lib/browser/index.mjs":{"imports":[{"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/ui-theme","kind":"import-statement","external":true}],"exports":["Calendar"],"entryPoint":"src/index.ts","inputs":{"src/components/Calendar/Calendar.tsx":{"bytesInOutput":7905},"src/translations.ts":{"bytesInOutput":167},"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":8788}}}
|