@dreamstack-us/kaal 0.0.1 → 0.0.2
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/lib/module/components/CalendarGrid/CalendarGrid.js +47 -13
- package/lib/module/components/CalendarGrid/CalendarGrid.js.map +1 -1
- package/lib/module/components/CalendarGrid/CalendarGrid.styles.js +22 -17
- package/lib/module/components/CalendarGrid/CalendarGrid.styles.js.map +1 -1
- package/lib/module/components/CalendarGrid/CalendarGrid.web.js +203 -0
- package/lib/module/components/CalendarGrid/CalendarGrid.web.js.map +1 -0
- package/lib/module/components/CalendarGrid/DayCell.js +64 -52
- package/lib/module/components/CalendarGrid/DayCell.js.map +1 -1
- package/lib/module/components/CalendarGrid/DayCell.web.js +112 -0
- package/lib/module/components/CalendarGrid/DayCell.web.js.map +1 -0
- package/lib/module/components/CalendarGrid/index.js +1 -1
- package/lib/module/components/CalendarGrid/index.js.map +1 -1
- package/lib/module/components/DatePicker/DatePicker.android.js +17 -8
- package/lib/module/components/DatePicker/DatePicker.android.js.map +1 -1
- package/lib/module/components/DatePicker/DatePicker.ios.js +17 -8
- package/lib/module/components/DatePicker/DatePicker.ios.js.map +1 -1
- package/lib/module/components/DatePicker/DatePicker.js.map +1 -1
- package/lib/module/components/DatePicker/DatePicker.styles.js +19 -20
- package/lib/module/components/DatePicker/DatePicker.styles.js.map +1 -1
- package/lib/module/components/DatePicker/DatePicker.web.js +26 -12
- package/lib/module/components/DatePicker/DatePicker.web.js.map +1 -1
- package/lib/module/components/TimePicker/ClockFace.js +27 -7
- package/lib/module/components/TimePicker/ClockFace.js.map +1 -1
- package/lib/module/components/TimePicker/ClockFace.web.js +253 -0
- package/lib/module/components/TimePicker/ClockFace.web.js.map +1 -0
- package/lib/module/components/TimePicker/MaterialTimePicker.js +68 -16
- package/lib/module/components/TimePicker/MaterialTimePicker.js.map +1 -1
- package/lib/module/components/TimePicker/MaterialTimePicker.web.js +231 -0
- package/lib/module/components/TimePicker/MaterialTimePicker.web.js.map +1 -0
- package/lib/module/components/TimePicker/TimePicker.android.js +13 -6
- package/lib/module/components/TimePicker/TimePicker.android.js.map +1 -1
- package/lib/module/components/TimePicker/TimePicker.ios.js +14 -7
- package/lib/module/components/TimePicker/TimePicker.ios.js.map +1 -1
- package/lib/module/components/TimePicker/TimePicker.styles.js +53 -45
- package/lib/module/components/TimePicker/TimePicker.styles.js.map +1 -1
- package/lib/module/components/TimePicker/TimePicker.web.js +24 -12
- package/lib/module/components/TimePicker/TimePicker.web.js.map +1 -1
- package/lib/module/components/TimePicker/TimeWheelPicker.js +45 -10
- package/lib/module/components/TimePicker/TimeWheelPicker.js.map +1 -1
- package/lib/module/components/TimePicker/TimeWheelPicker.web.js +339 -0
- package/lib/module/components/TimePicker/TimeWheelPicker.web.js.map +1 -0
- package/lib/module/components/TimePicker/index.js +3 -3
- package/lib/module/components/TimePicker/index.js.map +1 -1
- package/lib/module/components/WheelPicker/WheelPicker.js +21 -2
- package/lib/module/components/WheelPicker/WheelPicker.js.map +1 -1
- package/lib/module/components/WheelPicker/WheelPicker.styles.js +13 -8
- package/lib/module/components/WheelPicker/WheelPicker.styles.js.map +1 -1
- package/lib/module/components/WheelPicker/WheelPicker.web.js +146 -57
- package/lib/module/components/WheelPicker/WheelPicker.web.js.map +1 -1
- package/lib/module/context/ThemeOverrideContext.js +34 -0
- package/lib/module/context/ThemeOverrideContext.js.map +1 -0
- package/lib/module/index.js +3 -0
- package/lib/module/index.js.map +1 -1
- package/lib/module/utils/validation.js +74 -34
- package/lib/module/utils/validation.js.map +1 -1
- package/lib/typescript/components/CalendarGrid/CalendarGrid.d.ts +9 -0
- package/lib/typescript/components/CalendarGrid/CalendarGrid.d.ts.map +1 -1
- package/lib/typescript/components/CalendarGrid/CalendarGrid.styles.d.ts +12 -10
- package/lib/typescript/components/CalendarGrid/CalendarGrid.styles.d.ts.map +1 -1
- package/lib/typescript/components/CalendarGrid/CalendarGrid.web.d.ts +21 -0
- package/lib/typescript/components/CalendarGrid/CalendarGrid.web.d.ts.map +1 -0
- package/lib/typescript/components/CalendarGrid/DayCell.d.ts.map +1 -1
- package/lib/typescript/components/CalendarGrid/DayCell.web.d.ts +12 -0
- package/lib/typescript/components/CalendarGrid/DayCell.web.d.ts.map +1 -0
- package/lib/typescript/components/DatePicker/DatePicker.android.d.ts.map +1 -1
- package/lib/typescript/components/DatePicker/DatePicker.d.ts +12 -1
- package/lib/typescript/components/DatePicker/DatePicker.d.ts.map +1 -1
- package/lib/typescript/components/DatePicker/DatePicker.ios.d.ts.map +1 -1
- package/lib/typescript/components/DatePicker/DatePicker.styles.d.ts +12 -13
- package/lib/typescript/components/DatePicker/DatePicker.styles.d.ts.map +1 -1
- package/lib/typescript/components/DatePicker/DatePicker.web.d.ts.map +1 -1
- package/lib/typescript/components/TimePicker/ClockFace.d.ts.map +1 -1
- package/lib/typescript/components/TimePicker/ClockFace.web.d.ts +12 -0
- package/lib/typescript/components/TimePicker/ClockFace.web.d.ts.map +1 -0
- package/lib/typescript/components/TimePicker/MaterialTimePicker.d.ts.map +1 -1
- package/lib/typescript/components/TimePicker/MaterialTimePicker.web.d.ts +12 -0
- package/lib/typescript/components/TimePicker/MaterialTimePicker.web.d.ts.map +1 -0
- package/lib/typescript/components/TimePicker/TimePicker.android.d.ts.map +1 -1
- package/lib/typescript/components/TimePicker/TimePicker.ios.d.ts.map +1 -1
- package/lib/typescript/components/TimePicker/TimePicker.styles.d.ts +29 -25
- package/lib/typescript/components/TimePicker/TimePicker.styles.d.ts.map +1 -1
- package/lib/typescript/components/TimePicker/TimePicker.web.d.ts.map +1 -1
- package/lib/typescript/components/TimePicker/TimeWheelPicker.d.ts.map +1 -1
- package/lib/typescript/components/TimePicker/TimeWheelPicker.web.d.ts +11 -0
- package/lib/typescript/components/TimePicker/TimeWheelPicker.web.d.ts.map +1 -0
- package/lib/typescript/components/WheelPicker/WheelPicker.d.ts +14 -1
- package/lib/typescript/components/WheelPicker/WheelPicker.d.ts.map +1 -1
- package/lib/typescript/components/WheelPicker/WheelPicker.styles.d.ts +9 -7
- package/lib/typescript/components/WheelPicker/WheelPicker.styles.d.ts.map +1 -1
- package/lib/typescript/components/WheelPicker/WheelPicker.web.d.ts.map +1 -1
- package/lib/typescript/context/ThemeOverrideContext.d.ts +23 -0
- package/lib/typescript/context/ThemeOverrideContext.d.ts.map +1 -0
- package/lib/typescript/index.d.ts +4 -2
- package/lib/typescript/index.d.ts.map +1 -1
- package/lib/typescript/types/datepicker.d.ts +41 -0
- package/lib/typescript/types/datepicker.d.ts.map +1 -1
- package/lib/typescript/types/timepicker.d.ts +62 -0
- package/lib/typescript/types/timepicker.d.ts.map +1 -1
- package/lib/typescript/utils/validation.d.ts +47 -27
- package/lib/typescript/utils/validation.d.ts.map +1 -1
- package/package.json +8 -8
- package/src/components/CalendarGrid/CalendarGrid.styles.ts +21 -17
- package/src/components/CalendarGrid/CalendarGrid.tsx +98 -12
- package/src/components/CalendarGrid/CalendarGrid.web.tsx +305 -0
- package/src/components/CalendarGrid/DayCell.tsx +78 -59
- package/src/components/CalendarGrid/DayCell.web.tsx +129 -0
- package/src/components/DatePicker/DatePicker.android.tsx +14 -8
- package/src/components/DatePicker/DatePicker.ios.tsx +14 -8
- package/src/components/DatePicker/DatePicker.styles.ts +18 -22
- package/src/components/DatePicker/DatePicker.tsx +12 -1
- package/src/components/DatePicker/DatePicker.web.tsx +21 -13
- package/src/components/TimePicker/ClockFace.tsx +34 -8
- package/src/components/TimePicker/ClockFace.web.tsx +303 -0
- package/src/components/TimePicker/MaterialTimePicker.tsx +144 -13
- package/src/components/TimePicker/MaterialTimePicker.web.tsx +271 -0
- package/src/components/TimePicker/TimePicker.android.tsx +9 -1
- package/src/components/TimePicker/TimePicker.ios.tsx +10 -6
- package/src/components/TimePicker/TimePicker.styles.ts +52 -45
- package/src/components/TimePicker/TimePicker.web.tsx +17 -7
- package/src/components/TimePicker/TimeWheelPicker.tsx +60 -6
- package/src/components/TimePicker/TimeWheelPicker.web.tsx +401 -0
- package/src/components/WheelPicker/WheelPicker.styles.ts +12 -8
- package/src/components/WheelPicker/WheelPicker.tsx +24 -2
- package/src/components/WheelPicker/WheelPicker.web.tsx +153 -57
- package/src/context/ThemeOverrideContext.tsx +38 -0
- package/src/index.ts +11 -0
- package/src/types/datepicker.ts +44 -0
- package/src/types/timepicker.ts +74 -0
- package/src/utils/validation.ts +111 -55
- package/lib/module/unistyles.js +0 -9
- package/lib/module/unistyles.js.map +0 -1
- package/lib/typescript/unistyles.d.ts +0 -3
- package/lib/typescript/unistyles.d.ts.map +0 -1
- package/src/unistyles.ts +0 -6
|
@@ -0,0 +1,253 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
/// <reference lib="dom" />
|
|
4
|
+
|
|
5
|
+
import { memo, useCallback, useMemo, useRef } from 'react';
|
|
6
|
+
import { View } from 'react-native';
|
|
7
|
+
import { useTimePickerOverrides } from "../../context/ThemeOverrideContext.js";
|
|
8
|
+
import { to12Hour, to24Hour } from "../../hooks/useTimePicker.js";
|
|
9
|
+
import { styles } from "./TimePicker.styles.js";
|
|
10
|
+
|
|
11
|
+
// Clock dimensions
|
|
12
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
13
|
+
const CLOCK_SIZE = 256;
|
|
14
|
+
const CLOCK_CENTER = CLOCK_SIZE / 2;
|
|
15
|
+
const OUTER_RADIUS = 96;
|
|
16
|
+
const SELECTION_DOT_RADIUS = 20;
|
|
17
|
+
const CENTER_DOT_RADIUS = 4;
|
|
18
|
+
|
|
19
|
+
// Hour positions (12 at top, clockwise)
|
|
20
|
+
const HOURS_12 = [12, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11];
|
|
21
|
+
const MINUTE_LABELS = [0, 5, 10, 15, 20, 25, 30, 35, 40, 45, 50, 55];
|
|
22
|
+
|
|
23
|
+
// Default colors (dark theme)
|
|
24
|
+
const DEFAULT_COLORS = {
|
|
25
|
+
clockBackground: '#3F384C',
|
|
26
|
+
handColor: '#4DA6FF',
|
|
27
|
+
selectionDotColor: '#4DA6FF',
|
|
28
|
+
textColor: '#E6E1E5',
|
|
29
|
+
textSelectedColor: '#FFFFFF'
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
/**
|
|
33
|
+
* Converts clock position (0-11 for hours, 0-59 for minutes) to angle in degrees
|
|
34
|
+
* 12 o'clock is at -90 degrees (top)
|
|
35
|
+
*/
|
|
36
|
+
const positionToAngle = (position, isMinutes = false) => {
|
|
37
|
+
if (isMinutes) {
|
|
38
|
+
return position * 6 - 90; // 360/60 = 6 degrees per minute
|
|
39
|
+
}
|
|
40
|
+
return position * 30 - 90; // 360/12 = 30 degrees per position
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
/**
|
|
44
|
+
* Gets x,y coordinates on circle from angle and radius
|
|
45
|
+
*/
|
|
46
|
+
const getPointOnCircle = (angleDegrees, radius) => {
|
|
47
|
+
const rad = angleDegrees * Math.PI / 180;
|
|
48
|
+
return {
|
|
49
|
+
x: CLOCK_CENTER + radius * Math.cos(rad),
|
|
50
|
+
y: CLOCK_CENTER + radius * Math.sin(rad)
|
|
51
|
+
};
|
|
52
|
+
};
|
|
53
|
+
export const ClockFace = /*#__PURE__*/memo(({
|
|
54
|
+
value,
|
|
55
|
+
onChange,
|
|
56
|
+
mode,
|
|
57
|
+
onModeChange,
|
|
58
|
+
is24Hour = false
|
|
59
|
+
}) => {
|
|
60
|
+
const overrides = useTimePickerOverrides();
|
|
61
|
+
const svgRef = useRef(null);
|
|
62
|
+
const isDragging = useRef(false);
|
|
63
|
+
const {
|
|
64
|
+
hour: hour12,
|
|
65
|
+
period
|
|
66
|
+
} = to12Hour(value.hours);
|
|
67
|
+
|
|
68
|
+
// Build colors from overrides
|
|
69
|
+
const colors = useMemo(() => ({
|
|
70
|
+
clockBackground: overrides?.clockBackground ?? DEFAULT_COLORS.clockBackground,
|
|
71
|
+
handColor: overrides?.clockHandColor ?? DEFAULT_COLORS.handColor,
|
|
72
|
+
selectionDotColor: overrides?.clockSelectionColor ?? DEFAULT_COLORS.selectionDotColor,
|
|
73
|
+
textColor: overrides?.clockTextColor ?? DEFAULT_COLORS.textColor,
|
|
74
|
+
textSelectedColor: overrides?.clockTextSelectedColor ?? DEFAULT_COLORS.textSelectedColor
|
|
75
|
+
}), [overrides]);
|
|
76
|
+
|
|
77
|
+
// Calculate hand end position based on current value
|
|
78
|
+
const handAngle = useMemo(() => {
|
|
79
|
+
if (mode === 'hours') {
|
|
80
|
+
const hourIndex = HOURS_12.indexOf(hour12);
|
|
81
|
+
return positionToAngle(hourIndex >= 0 ? hourIndex : 0);
|
|
82
|
+
}
|
|
83
|
+
return positionToAngle(value.minutes, true);
|
|
84
|
+
}, [mode, hour12, value.minutes]);
|
|
85
|
+
const handEndPos = getPointOnCircle(handAngle, OUTER_RADIUS);
|
|
86
|
+
const handleInteraction = useCallback((clientX, clientY) => {
|
|
87
|
+
if (!svgRef.current) return;
|
|
88
|
+
const rect = svgRef.current.getBoundingClientRect();
|
|
89
|
+
const x = clientX - rect.left;
|
|
90
|
+
const y = clientY - rect.top;
|
|
91
|
+
|
|
92
|
+
// Convert touch coordinates to angle
|
|
93
|
+
const dx = x - CLOCK_CENTER;
|
|
94
|
+
const dy = y - CLOCK_CENTER;
|
|
95
|
+
const angle = Math.atan2(dy, dx) * (180 / Math.PI);
|
|
96
|
+
|
|
97
|
+
// Normalize angle to 0-360, with 0 at top (12 o'clock)
|
|
98
|
+
const normalized = ((angle + 90) % 360 + 360) % 360;
|
|
99
|
+
if (mode === 'hours') {
|
|
100
|
+
// Round to nearest hour position
|
|
101
|
+
const position = Math.round(normalized / 30) % 12;
|
|
102
|
+
const hour = HOURS_12[position];
|
|
103
|
+
if (hour !== undefined) {
|
|
104
|
+
const newHours = to24Hour(hour, period);
|
|
105
|
+
onChange({
|
|
106
|
+
hours: newHours,
|
|
107
|
+
minutes: value.minutes
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
} else {
|
|
111
|
+
// Round to nearest minute
|
|
112
|
+
const minutes = Math.round(normalized / 6) % 60;
|
|
113
|
+
onChange({
|
|
114
|
+
hours: value.hours,
|
|
115
|
+
minutes
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
}, [mode, period, value, onChange]);
|
|
119
|
+
const handleInteractionEnd = useCallback(() => {
|
|
120
|
+
// Switch to minutes mode after selecting hours
|
|
121
|
+
if (mode === 'hours' && onModeChange) {
|
|
122
|
+
// Small delay for visual feedback
|
|
123
|
+
setTimeout(() => onModeChange('minutes'), 200);
|
|
124
|
+
}
|
|
125
|
+
}, [mode, onModeChange]);
|
|
126
|
+
const handleMouseDown = useCallback(e => {
|
|
127
|
+
isDragging.current = true;
|
|
128
|
+
handleInteraction(e.clientX, e.clientY);
|
|
129
|
+
}, [handleInteraction]);
|
|
130
|
+
const handleMouseMove = useCallback(e => {
|
|
131
|
+
if (!isDragging.current) return;
|
|
132
|
+
handleInteraction(e.clientX, e.clientY);
|
|
133
|
+
}, [handleInteraction]);
|
|
134
|
+
const handleMouseUp = useCallback(() => {
|
|
135
|
+
if (isDragging.current) {
|
|
136
|
+
isDragging.current = false;
|
|
137
|
+
handleInteractionEnd();
|
|
138
|
+
}
|
|
139
|
+
}, [handleInteractionEnd]);
|
|
140
|
+
const handleTouchStart = useCallback(e => {
|
|
141
|
+
isDragging.current = true;
|
|
142
|
+
const touch = e.touches[0];
|
|
143
|
+
if (touch) {
|
|
144
|
+
handleInteraction(touch.clientX, touch.clientY);
|
|
145
|
+
}
|
|
146
|
+
}, [handleInteraction]);
|
|
147
|
+
const handleTouchMove = useCallback(e => {
|
|
148
|
+
if (!isDragging.current) return;
|
|
149
|
+
const touch = e.touches[0];
|
|
150
|
+
if (touch) {
|
|
151
|
+
handleInteraction(touch.clientX, touch.clientY);
|
|
152
|
+
}
|
|
153
|
+
}, [handleInteraction]);
|
|
154
|
+
const handleTouchEnd = useCallback(() => {
|
|
155
|
+
if (isDragging.current) {
|
|
156
|
+
isDragging.current = false;
|
|
157
|
+
handleInteractionEnd();
|
|
158
|
+
}
|
|
159
|
+
}, [handleInteractionEnd]);
|
|
160
|
+
|
|
161
|
+
// Render clock numbers
|
|
162
|
+
const numbers = useMemo(() => {
|
|
163
|
+
if (mode === 'hours') {
|
|
164
|
+
return HOURS_12.map((hour, index) => {
|
|
165
|
+
const angle = positionToAngle(index);
|
|
166
|
+
const pos = getPointOnCircle(angle, OUTER_RADIUS);
|
|
167
|
+
const isSelected = hour12 === hour;
|
|
168
|
+
return /*#__PURE__*/_jsx("text", {
|
|
169
|
+
x: pos.x,
|
|
170
|
+
y: pos.y,
|
|
171
|
+
textAnchor: "middle",
|
|
172
|
+
dominantBaseline: "central",
|
|
173
|
+
fontSize: 14,
|
|
174
|
+
fontWeight: isSelected ? '500' : '400',
|
|
175
|
+
fill: isSelected ? colors.textSelectedColor : colors.textColor,
|
|
176
|
+
style: {
|
|
177
|
+
userSelect: 'none'
|
|
178
|
+
},
|
|
179
|
+
children: hour
|
|
180
|
+
}, hour);
|
|
181
|
+
});
|
|
182
|
+
}
|
|
183
|
+
return MINUTE_LABELS.map((minute, index) => {
|
|
184
|
+
const angle = positionToAngle(index);
|
|
185
|
+
const pos = getPointOnCircle(angle, OUTER_RADIUS);
|
|
186
|
+
const isSelected = value.minutes === minute;
|
|
187
|
+
return /*#__PURE__*/_jsx("text", {
|
|
188
|
+
x: pos.x,
|
|
189
|
+
y: pos.y,
|
|
190
|
+
textAnchor: "middle",
|
|
191
|
+
dominantBaseline: "central",
|
|
192
|
+
fontSize: 14,
|
|
193
|
+
fontWeight: isSelected ? '500' : '400',
|
|
194
|
+
fill: isSelected ? colors.textSelectedColor : colors.textColor,
|
|
195
|
+
style: {
|
|
196
|
+
userSelect: 'none'
|
|
197
|
+
},
|
|
198
|
+
children: minute.toString().padStart(2, '0')
|
|
199
|
+
}, minute);
|
|
200
|
+
});
|
|
201
|
+
}, [mode, hour12, value.minutes, colors]);
|
|
202
|
+
return /*#__PURE__*/_jsx(View, {
|
|
203
|
+
style: styles.clockContainer,
|
|
204
|
+
children: /*#__PURE__*/_jsxs("svg", {
|
|
205
|
+
ref: svgRef,
|
|
206
|
+
width: CLOCK_SIZE,
|
|
207
|
+
height: CLOCK_SIZE,
|
|
208
|
+
viewBox: `0 0 ${CLOCK_SIZE} ${CLOCK_SIZE}`,
|
|
209
|
+
onMouseDown: handleMouseDown,
|
|
210
|
+
onMouseMove: handleMouseMove,
|
|
211
|
+
onMouseUp: handleMouseUp,
|
|
212
|
+
onMouseLeave: handleMouseUp,
|
|
213
|
+
onTouchStart: handleTouchStart,
|
|
214
|
+
onTouchMove: handleTouchMove,
|
|
215
|
+
onTouchEnd: handleTouchEnd,
|
|
216
|
+
style: {
|
|
217
|
+
cursor: 'pointer',
|
|
218
|
+
touchAction: 'none'
|
|
219
|
+
},
|
|
220
|
+
role: "img",
|
|
221
|
+
"aria-label": `Clock face for selecting ${mode === 'hours' ? 'hours' : 'minutes'}`,
|
|
222
|
+
children: [/*#__PURE__*/_jsx("title", {
|
|
223
|
+
children: mode === 'hours' ? 'Hour selection clock' : 'Minute selection clock'
|
|
224
|
+
}), /*#__PURE__*/_jsx("circle", {
|
|
225
|
+
cx: CLOCK_CENTER,
|
|
226
|
+
cy: CLOCK_CENTER,
|
|
227
|
+
r: CLOCK_SIZE / 2 - 4,
|
|
228
|
+
fill: colors.clockBackground
|
|
229
|
+
}), /*#__PURE__*/_jsx("circle", {
|
|
230
|
+
cx: handEndPos.x,
|
|
231
|
+
cy: handEndPos.y,
|
|
232
|
+
r: SELECTION_DOT_RADIUS,
|
|
233
|
+
fill: colors.selectionDotColor
|
|
234
|
+
}), /*#__PURE__*/_jsx("line", {
|
|
235
|
+
x1: CLOCK_CENTER,
|
|
236
|
+
y1: CLOCK_CENTER,
|
|
237
|
+
x2: handEndPos.x,
|
|
238
|
+
y2: handEndPos.y,
|
|
239
|
+
stroke: colors.handColor,
|
|
240
|
+
strokeWidth: 2
|
|
241
|
+
}), /*#__PURE__*/_jsx("circle", {
|
|
242
|
+
cx: CLOCK_CENTER,
|
|
243
|
+
cy: CLOCK_CENTER,
|
|
244
|
+
r: CENTER_DOT_RADIUS,
|
|
245
|
+
fill: colors.handColor
|
|
246
|
+
}), /*#__PURE__*/_jsx("g", {
|
|
247
|
+
children: numbers
|
|
248
|
+
})]
|
|
249
|
+
})
|
|
250
|
+
});
|
|
251
|
+
});
|
|
252
|
+
ClockFace.displayName = 'ClockFace';
|
|
253
|
+
//# sourceMappingURL=ClockFace.web.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["memo","useCallback","useMemo","useRef","View","useTimePickerOverrides","to12Hour","to24Hour","styles","jsx","_jsx","jsxs","_jsxs","CLOCK_SIZE","CLOCK_CENTER","OUTER_RADIUS","SELECTION_DOT_RADIUS","CENTER_DOT_RADIUS","HOURS_12","MINUTE_LABELS","DEFAULT_COLORS","clockBackground","handColor","selectionDotColor","textColor","textSelectedColor","positionToAngle","position","isMinutes","getPointOnCircle","angleDegrees","radius","rad","Math","PI","x","cos","y","sin","ClockFace","value","onChange","mode","onModeChange","is24Hour","overrides","svgRef","isDragging","hour","hour12","period","hours","colors","clockHandColor","clockSelectionColor","clockTextColor","clockTextSelectedColor","handAngle","hourIndex","indexOf","minutes","handEndPos","handleInteraction","clientX","clientY","current","rect","getBoundingClientRect","left","top","dx","dy","angle","atan2","normalized","round","undefined","newHours","handleInteractionEnd","setTimeout","handleMouseDown","e","handleMouseMove","handleMouseUp","handleTouchStart","touch","touches","handleTouchMove","handleTouchEnd","numbers","map","index","pos","isSelected","textAnchor","dominantBaseline","fontSize","fontWeight","fill","style","userSelect","children","minute","toString","padStart","clockContainer","ref","width","height","viewBox","onMouseDown","onMouseMove","onMouseUp","onMouseLeave","onTouchStart","onTouchMove","onTouchEnd","cursor","touchAction","role","cx","cy","r","x1","y1","x2","y2","stroke","strokeWidth","displayName"],"sourceRoot":"../../../../src","sources":["components/TimePicker/ClockFace.web.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,11 +1,27 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
import { memo, useCallback, useState } from 'react';
|
|
3
|
+
import { memo, useCallback, useMemo, useState } from 'react';
|
|
4
4
|
import { Pressable, Text, View } from 'react-native';
|
|
5
|
+
import { useTimePickerOverrides } from "../../context/ThemeOverrideContext.js";
|
|
5
6
|
import { to12Hour, to24Hour } from "../../hooks/useTimePicker.js";
|
|
6
|
-
import { ClockFace } from
|
|
7
|
+
import { ClockFace } from './ClockFace';
|
|
7
8
|
import { styles } from "./TimePicker.styles.js";
|
|
9
|
+
|
|
10
|
+
// Default colors (dark theme)
|
|
8
11
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
12
|
+
const DEFAULT_COLORS = {
|
|
13
|
+
containerBackground: '#2C2C2E',
|
|
14
|
+
headerColor: '#8E8E93',
|
|
15
|
+
timeFieldBackground: '#3A3A3C',
|
|
16
|
+
timeFieldActiveBackground: '#4DA6FF',
|
|
17
|
+
textColor: '#FFFFFF',
|
|
18
|
+
separatorColor: '#FFFFFF',
|
|
19
|
+
borderColor: '#48484A',
|
|
20
|
+
periodActiveBackground: 'rgba(77, 166, 255, 0.2)',
|
|
21
|
+
periodTextColor: '#8E8E93',
|
|
22
|
+
periodTextActiveColor: '#4DA6FF',
|
|
23
|
+
actionButtonColor: '#4DA6FF'
|
|
24
|
+
};
|
|
9
25
|
export const MaterialTimePicker = /*#__PURE__*/memo(({
|
|
10
26
|
value,
|
|
11
27
|
onChange,
|
|
@@ -13,6 +29,7 @@ export const MaterialTimePicker = /*#__PURE__*/memo(({
|
|
|
13
29
|
onCancel,
|
|
14
30
|
onConfirm
|
|
15
31
|
}) => {
|
|
32
|
+
const overrides = useTimePickerOverrides();
|
|
16
33
|
const [mode, setMode] = useState('hours');
|
|
17
34
|
const {
|
|
18
35
|
hour: hour12,
|
|
@@ -38,10 +55,45 @@ export const MaterialTimePicker = /*#__PURE__*/memo(({
|
|
|
38
55
|
// Format display values
|
|
39
56
|
const displayHour = is24Hour ? value.hours.toString().padStart(2, '0') : hour12.toString().padStart(2, '0');
|
|
40
57
|
const displayMinute = value.minutes.toString().padStart(2, '0');
|
|
58
|
+
|
|
59
|
+
// Build override styles
|
|
60
|
+
const containerStyle = useMemo(() => ({
|
|
61
|
+
backgroundColor: overrides?.containerBackground ?? DEFAULT_COLORS.containerBackground
|
|
62
|
+
}), [overrides]);
|
|
63
|
+
const headerStyle = useMemo(() => ({
|
|
64
|
+
color: overrides?.headerColor ?? DEFAULT_COLORS.headerColor
|
|
65
|
+
}), [overrides]);
|
|
66
|
+
const timeFieldStyle = useMemo(() => ({
|
|
67
|
+
backgroundColor: overrides?.timeFieldBackground ?? DEFAULT_COLORS.timeFieldBackground
|
|
68
|
+
}), [overrides]);
|
|
69
|
+
const timeFieldActiveStyle = useMemo(() => ({
|
|
70
|
+
backgroundColor: overrides?.timeFieldActiveBackground ?? DEFAULT_COLORS.timeFieldActiveBackground
|
|
71
|
+
}), [overrides]);
|
|
72
|
+
const textStyle = useMemo(() => ({
|
|
73
|
+
color: overrides?.textColor ?? DEFAULT_COLORS.textColor
|
|
74
|
+
}), [overrides]);
|
|
75
|
+
const separatorStyle = useMemo(() => ({
|
|
76
|
+
color: overrides?.separatorColor ?? DEFAULT_COLORS.separatorColor
|
|
77
|
+
}), [overrides]);
|
|
78
|
+
const periodContainerStyle = useMemo(() => ({
|
|
79
|
+
borderColor: overrides?.periodBorderColor ?? DEFAULT_COLORS.borderColor
|
|
80
|
+
}), [overrides]);
|
|
81
|
+
const periodActiveStyle = useMemo(() => ({
|
|
82
|
+
backgroundColor: overrides?.periodActiveBackground ?? DEFAULT_COLORS.periodActiveBackground
|
|
83
|
+
}), [overrides]);
|
|
84
|
+
const periodTextStyle = useMemo(() => ({
|
|
85
|
+
color: overrides?.periodTextColor ?? DEFAULT_COLORS.periodTextColor
|
|
86
|
+
}), [overrides]);
|
|
87
|
+
const periodTextActiveStyle = useMemo(() => ({
|
|
88
|
+
color: overrides?.periodTextActiveColor ?? DEFAULT_COLORS.periodTextActiveColor
|
|
89
|
+
}), [overrides]);
|
|
90
|
+
const actionButtonTextStyle = useMemo(() => ({
|
|
91
|
+
color: overrides?.actionButtonColor ?? DEFAULT_COLORS.actionButtonColor
|
|
92
|
+
}), [overrides]);
|
|
41
93
|
return /*#__PURE__*/_jsxs(View, {
|
|
42
|
-
style: styles.materialContainer,
|
|
94
|
+
style: [styles.materialContainer, containerStyle],
|
|
43
95
|
children: [/*#__PURE__*/_jsx(Text, {
|
|
44
|
-
style: styles.materialHeader,
|
|
96
|
+
style: [styles.materialHeader, headerStyle],
|
|
45
97
|
children: "Select time"
|
|
46
98
|
}), /*#__PURE__*/_jsxs(View, {
|
|
47
99
|
style: styles.timeInputContainer,
|
|
@@ -49,36 +101,36 @@ export const MaterialTimePicker = /*#__PURE__*/memo(({
|
|
|
49
101
|
style: styles.timeFieldsContainer,
|
|
50
102
|
children: [/*#__PURE__*/_jsx(Pressable, {
|
|
51
103
|
onPress: handleHourPress,
|
|
52
|
-
style: [styles.timeField, mode === 'hours' && styles.timeFieldActive],
|
|
104
|
+
style: [styles.timeField, timeFieldStyle, mode === 'hours' && [styles.timeFieldActive, timeFieldActiveStyle]],
|
|
53
105
|
children: /*#__PURE__*/_jsx(Text, {
|
|
54
|
-
style: [styles.timeFieldText, mode === 'hours' && styles.timeFieldTextActive],
|
|
106
|
+
style: [styles.timeFieldText, textStyle, mode === 'hours' && styles.timeFieldTextActive],
|
|
55
107
|
children: displayHour
|
|
56
108
|
})
|
|
57
109
|
}), /*#__PURE__*/_jsx(Text, {
|
|
58
|
-
style: styles.timeSeparator,
|
|
110
|
+
style: [styles.timeSeparator, separatorStyle],
|
|
59
111
|
children: ":"
|
|
60
112
|
}), /*#__PURE__*/_jsx(Pressable, {
|
|
61
113
|
onPress: handleMinutePress,
|
|
62
|
-
style: [styles.timeField, mode === 'minutes' && styles.timeFieldActive],
|
|
114
|
+
style: [styles.timeField, timeFieldStyle, mode === 'minutes' && [styles.timeFieldActive, timeFieldActiveStyle]],
|
|
63
115
|
children: /*#__PURE__*/_jsx(Text, {
|
|
64
|
-
style: [styles.timeFieldText, mode === 'minutes' && styles.timeFieldTextActive],
|
|
116
|
+
style: [styles.timeFieldText, textStyle, mode === 'minutes' && styles.timeFieldTextActive],
|
|
65
117
|
children: displayMinute
|
|
66
118
|
})
|
|
67
119
|
})]
|
|
68
120
|
}), !is24Hour && /*#__PURE__*/_jsxs(View, {
|
|
69
|
-
style: styles.periodToggleContainer,
|
|
121
|
+
style: [styles.periodToggleContainer, periodContainerStyle],
|
|
70
122
|
children: [/*#__PURE__*/_jsx(Pressable, {
|
|
71
123
|
onPress: () => handlePeriodChange('AM'),
|
|
72
|
-
style: [styles.periodButton, styles.periodButtonTop, period === 'AM' && styles.periodButtonActive],
|
|
124
|
+
style: [styles.periodButton, styles.periodButtonTop, period === 'AM' && [styles.periodButtonActive, periodActiveStyle]],
|
|
73
125
|
children: /*#__PURE__*/_jsx(Text, {
|
|
74
|
-
style: [styles.periodButtonText, period === 'AM' && styles.periodButtonTextActive],
|
|
126
|
+
style: [styles.periodButtonText, periodTextStyle, period === 'AM' && [styles.periodButtonTextActive, periodTextActiveStyle]],
|
|
75
127
|
children: "AM"
|
|
76
128
|
})
|
|
77
129
|
}), /*#__PURE__*/_jsx(Pressable, {
|
|
78
130
|
onPress: () => handlePeriodChange('PM'),
|
|
79
|
-
style: [styles.periodButton, period === 'PM' && styles.periodButtonActive],
|
|
131
|
+
style: [styles.periodButton, period === 'PM' && [styles.periodButtonActive, periodActiveStyle]],
|
|
80
132
|
children: /*#__PURE__*/_jsx(Text, {
|
|
81
|
-
style: [styles.periodButtonText, period === 'PM' && styles.periodButtonTextActive],
|
|
133
|
+
style: [styles.periodButtonText, periodTextStyle, period === 'PM' && [styles.periodButtonTextActive, periodTextActiveStyle]],
|
|
82
134
|
children: "PM"
|
|
83
135
|
})
|
|
84
136
|
})]
|
|
@@ -103,14 +155,14 @@ export const MaterialTimePicker = /*#__PURE__*/memo(({
|
|
|
103
155
|
style: styles.actionButton,
|
|
104
156
|
onPress: onCancel,
|
|
105
157
|
children: /*#__PURE__*/_jsx(Text, {
|
|
106
|
-
style: styles.actionButtonText,
|
|
158
|
+
style: [styles.actionButtonText, actionButtonTextStyle],
|
|
107
159
|
children: "Cancel"
|
|
108
160
|
})
|
|
109
161
|
}), onConfirm && /*#__PURE__*/_jsx(Pressable, {
|
|
110
162
|
style: styles.actionButton,
|
|
111
163
|
onPress: onConfirm,
|
|
112
164
|
children: /*#__PURE__*/_jsx(Text, {
|
|
113
|
-
style: styles.actionButtonText,
|
|
165
|
+
style: [styles.actionButtonText, actionButtonTextStyle],
|
|
114
166
|
children: "OK"
|
|
115
167
|
})
|
|
116
168
|
})]
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["memo","useCallback","useState","Pressable","Text","View","to12Hour","to24Hour","ClockFace","styles","jsx","_jsx","jsxs","_jsxs","MaterialTimePicker","value","onChange","is24Hour","onCancel","onConfirm","mode","setMode","hour","hour12","period","hours","handleHourPress","handleMinutePress","handlePeriodChange","newPeriod","newHours","minutes","handleModeChange","newMode","displayHour","toString","padStart","displayMinute","style","materialContainer","children","materialHeader","timeInputContainer","timeFieldsContainer","onPress","timeField","timeFieldActive","timeFieldText","timeFieldTextActive","timeSeparator","periodToggleContainer","periodButton","periodButtonTop","periodButtonActive","periodButtonText","periodButtonTextActive","onModeChange","actionsContainer","keyboardButton","keyboardButtonText","actionButtonsContainer","actionButton","actionButtonText","displayName"],"sourceRoot":"../../../../src","sources":["components/TimePicker/MaterialTimePicker.tsx"],"mappings":";;AACA,SAASA,IAAI,EAAEC,WAAW,EAAEC,QAAQ,QAAQ,OAAO;
|
|
1
|
+
{"version":3,"names":["memo","useCallback","useMemo","useState","Pressable","Text","View","useTimePickerOverrides","to12Hour","to24Hour","ClockFace","styles","jsx","_jsx","jsxs","_jsxs","DEFAULT_COLORS","containerBackground","headerColor","timeFieldBackground","timeFieldActiveBackground","textColor","separatorColor","borderColor","periodActiveBackground","periodTextColor","periodTextActiveColor","actionButtonColor","MaterialTimePicker","value","onChange","is24Hour","onCancel","onConfirm","overrides","mode","setMode","hour","hour12","period","hours","handleHourPress","handleMinutePress","handlePeriodChange","newPeriod","newHours","minutes","handleModeChange","newMode","displayHour","toString","padStart","displayMinute","containerStyle","backgroundColor","headerStyle","color","timeFieldStyle","timeFieldActiveStyle","textStyle","separatorStyle","periodContainerStyle","periodBorderColor","periodActiveStyle","periodTextStyle","periodTextActiveStyle","actionButtonTextStyle","style","materialContainer","children","materialHeader","timeInputContainer","timeFieldsContainer","onPress","timeField","timeFieldActive","timeFieldText","timeFieldTextActive","timeSeparator","periodToggleContainer","periodButton","periodButtonTop","periodButtonActive","periodButtonText","periodButtonTextActive","onModeChange","actionsContainer","keyboardButton","keyboardButtonText","actionButtonsContainer","actionButton","actionButtonText","displayName"],"sourceRoot":"../../../../src","sources":["components/TimePicker/MaterialTimePicker.tsx"],"mappings":"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","ignoreList":[]}
|