sa2kit 1.6.2 → 1.6.5

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 (128) hide show
  1. package/dist/audioDetection/index.js.map +1 -1
  2. package/dist/audioDetection/index.mjs.map +1 -1
  3. package/dist/auth/index.d.mts +16 -1
  4. package/dist/auth/index.d.ts +16 -1
  5. package/dist/auth/index.js +42 -23
  6. package/dist/auth/index.js.map +1 -1
  7. package/dist/auth/index.mjs +26 -3
  8. package/dist/auth/index.mjs.map +1 -1
  9. package/dist/auth/middleware/index.js +3 -3
  10. package/dist/auth/middleware/index.mjs +2 -2
  11. package/dist/auth/routes/index.js +14 -14
  12. package/dist/auth/routes/index.mjs +2 -2
  13. package/dist/auth/services/index.d.mts +1 -0
  14. package/dist/auth/services/index.d.ts +1 -0
  15. package/dist/auth/services/index.js +7 -7
  16. package/dist/auth/services/index.mjs +1 -1
  17. package/dist/calendar/index.d.mts +1311 -0
  18. package/dist/calendar/index.d.ts +1311 -0
  19. package/dist/calendar/index.js +5360 -0
  20. package/dist/calendar/index.js.map +1 -0
  21. package/dist/calendar/index.mjs +5294 -0
  22. package/dist/calendar/index.mjs.map +1 -0
  23. package/dist/calendar/routes/index.d.mts +118 -0
  24. package/dist/calendar/routes/index.d.ts +118 -0
  25. package/dist/calendar/routes/index.js +335 -0
  26. package/dist/calendar/routes/index.js.map +1 -0
  27. package/dist/calendar/routes/index.mjs +327 -0
  28. package/dist/calendar/routes/index.mjs.map +1 -0
  29. package/dist/calendar/server.d.mts +1189 -0
  30. package/dist/calendar/server.d.ts +1189 -0
  31. package/dist/calendar/server.js +219 -0
  32. package/dist/calendar/server.js.map +1 -0
  33. package/dist/calendar/server.mjs +165 -0
  34. package/dist/calendar/server.mjs.map +1 -0
  35. package/dist/chunk-2ODO4HEI.js +195 -0
  36. package/dist/chunk-2ODO4HEI.js.map +1 -0
  37. package/dist/{chunk-RCNNVNLT.mjs → chunk-3BGPZN4X.mjs} +8 -3
  38. package/dist/chunk-3BGPZN4X.mjs.map +1 -0
  39. package/dist/{chunk-FV3FNHQY.js → chunk-6W5BMXJG.js} +4 -4
  40. package/dist/{chunk-FV3FNHQY.js.map → chunk-6W5BMXJG.js.map} +1 -1
  41. package/dist/{chunk-NMF4ANIC.js → chunk-7Z5LLJ3A.js} +8 -2
  42. package/dist/chunk-7Z5LLJ3A.js.map +1 -0
  43. package/dist/{chunk-42IJ7HEI.js → chunk-CD77U7LZ.js} +5 -5
  44. package/dist/{chunk-42IJ7HEI.js.map → chunk-CD77U7LZ.js.map} +1 -1
  45. package/dist/{chunk-6BL3AZGD.js → chunk-DUHZ7VZP.js} +2 -2
  46. package/dist/chunk-DUHZ7VZP.js.map +1 -0
  47. package/dist/{chunk-6VHWOPRR.mjs → chunk-ESRCX5TQ.mjs} +3 -3
  48. package/dist/{chunk-6VHWOPRR.mjs.map → chunk-ESRCX5TQ.mjs.map} +1 -1
  49. package/dist/chunk-FJU3NA6B.js +318 -0
  50. package/dist/chunk-FJU3NA6B.js.map +1 -0
  51. package/dist/{chunk-DQVPZTVC.js → chunk-G4AMEDO5.js} +2 -2
  52. package/dist/{chunk-DQVPZTVC.js.map → chunk-G4AMEDO5.js.map} +1 -1
  53. package/dist/chunk-GAC4J5GX.js +228 -0
  54. package/dist/chunk-GAC4J5GX.js.map +1 -0
  55. package/dist/chunk-KFDEOLDH.mjs +100 -0
  56. package/dist/chunk-KFDEOLDH.mjs.map +1 -0
  57. package/dist/chunk-NRYHBGU6.js +106 -0
  58. package/dist/chunk-NRYHBGU6.js.map +1 -0
  59. package/dist/chunk-OCIJT5VO.mjs +306 -0
  60. package/dist/chunk-OCIJT5VO.mjs.map +1 -0
  61. package/dist/{chunk-U2L6V7KD.mjs → chunk-OCR5DS4C.mjs} +2 -2
  62. package/dist/chunk-OCR5DS4C.mjs.map +1 -0
  63. package/dist/{chunk-IBLB7ARJ.mjs → chunk-QAT2RWAO.mjs} +3 -3
  64. package/dist/{chunk-IBLB7ARJ.mjs.map → chunk-QAT2RWAO.mjs.map} +1 -1
  65. package/dist/chunk-T6TE7GTY.mjs +218 -0
  66. package/dist/chunk-T6TE7GTY.mjs.map +1 -0
  67. package/dist/chunk-ZCLAF3XN.mjs +182 -0
  68. package/dist/chunk-ZCLAF3XN.mjs.map +1 -0
  69. package/dist/{chunk-5XUE72Y3.mjs → chunk-ZYXF3L6T.mjs} +2 -2
  70. package/dist/{chunk-5XUE72Y3.mjs.map → chunk-ZYXF3L6T.mjs.map} +1 -1
  71. package/dist/imageCrop/index.js.map +1 -1
  72. package/dist/imageCrop/index.mjs.map +1 -1
  73. package/dist/index-DSel44Ke.d.mts +93 -0
  74. package/dist/index-DSel44Ke.d.ts +93 -0
  75. package/dist/index.d.mts +433 -3
  76. package/dist/index.d.ts +433 -3
  77. package/dist/index.js +2148 -64
  78. package/dist/index.js.map +1 -1
  79. package/dist/index.mjs +1980 -33
  80. package/dist/index.mjs.map +1 -1
  81. package/dist/mmd/admin/index.d.mts +1 -1
  82. package/dist/mmd/admin/index.d.ts +1 -1
  83. package/dist/mmd/index.d.mts +94 -3
  84. package/dist/mmd/index.d.ts +94 -3
  85. package/dist/mmd/index.js +677 -180
  86. package/dist/mmd/index.js.map +1 -1
  87. package/dist/mmd/index.mjs +679 -183
  88. package/dist/mmd/index.mjs.map +1 -1
  89. package/dist/mmd/server/index.d.mts +1 -1
  90. package/dist/mmd/server/index.d.ts +1 -1
  91. package/dist/music/index.d.mts +79 -0
  92. package/dist/music/index.d.ts +79 -0
  93. package/dist/music/index.js +58 -0
  94. package/dist/music/index.js.map +1 -0
  95. package/dist/music/index.mjs +5 -0
  96. package/dist/music/index.mjs.map +1 -0
  97. package/dist/music/server/index.d.mts +1 -0
  98. package/dist/music/server/index.d.ts +1 -0
  99. package/dist/music/server/index.js +37 -0
  100. package/dist/music/server/index.js.map +1 -0
  101. package/dist/music/server/index.mjs +4 -0
  102. package/dist/music/server/index.mjs.map +1 -0
  103. package/dist/testYourself/admin/index.js +3 -3
  104. package/dist/testYourself/admin/index.mjs +1 -1
  105. package/dist/testYourself/index.js +7 -7
  106. package/dist/testYourself/index.js.map +1 -1
  107. package/dist/testYourself/index.mjs +2 -2
  108. package/dist/testYourself/index.mjs.map +1 -1
  109. package/dist/{types-DxYJqqes.d.mts → types-B60F7EZZ.d.mts} +16 -1
  110. package/dist/{types-DxYJqqes.d.ts → types-B60F7EZZ.d.ts} +16 -1
  111. package/dist/universalFile/index.d.mts +125 -7
  112. package/dist/universalFile/index.d.ts +125 -7
  113. package/dist/universalFile/index.js +1253 -30
  114. package/dist/universalFile/index.js.map +1 -1
  115. package/dist/universalFile/index.mjs +1244 -23
  116. package/dist/universalFile/index.mjs.map +1 -1
  117. package/dist/universalFile/server/index.js +5 -5
  118. package/dist/universalFile/server/index.mjs +1 -1
  119. package/dist/utils/index.d.mts +5 -1
  120. package/dist/utils/index.d.ts +5 -1
  121. package/dist/utils/index.js +13 -9
  122. package/dist/utils/index.mjs +1 -1
  123. package/package.json +47 -19
  124. package/tailwind.animations.js +5 -0
  125. package/dist/chunk-6BL3AZGD.js.map +0 -1
  126. package/dist/chunk-NMF4ANIC.js.map +0 -1
  127. package/dist/chunk-RCNNVNLT.mjs.map +0 -1
  128. package/dist/chunk-U2L6V7KD.mjs.map +0 -1
@@ -0,0 +1,1311 @@
1
+ import { DragStartEvent, DragOverEvent, DragEndEvent } from '@dnd-kit/core';
2
+ import React__default from 'react';
3
+
4
+ /**
5
+ * 日历模块类型定义
6
+ *
7
+ * 定义了日历模块中使用的所有TypeScript类型,包括:
8
+ * - 事件相关类型
9
+ * - 日历视图类型
10
+ * - 重复规则类型
11
+ * - 提醒类型
12
+ * - API响应类型
13
+ * - 组件Props类型
14
+ */
15
+ /**
16
+ * 日历事件
17
+ */
18
+ interface CalendarEvent {
19
+ id: number;
20
+ title: string;
21
+ description?: string;
22
+ startTime: Date;
23
+ endTime: Date;
24
+ allDay: boolean;
25
+ location?: string;
26
+ color: string;
27
+ priority: EventPriority;
28
+ userId: number;
29
+ createdAt: Date;
30
+ updatedAt: Date;
31
+ recurrenceRule?: RecurrenceRule$1;
32
+ reminders?: Reminder[];
33
+ }
34
+ /**
35
+ * 重复规则
36
+ */
37
+ interface RecurrenceRule$1 {
38
+ id: number;
39
+ eventId: number;
40
+ ruleType: RecurrenceType;
41
+ interval: number;
42
+ endDate?: Date;
43
+ count?: number;
44
+ byWeekday?: number[];
45
+ byMonthday?: number[];
46
+ byMonth?: number[];
47
+ }
48
+ /**
49
+ * 提醒
50
+ */
51
+ interface Reminder {
52
+ id: number;
53
+ eventId: number;
54
+ reminderTime: Date;
55
+ reminderType: ReminderType;
56
+ status: ReminderStatus;
57
+ createdAt: Date;
58
+ }
59
+ /**
60
+ * 重复类型
61
+ */
62
+ declare enum RecurrenceType {
63
+ DAILY = "daily",
64
+ WEEKLY = "weekly",
65
+ MONTHLY = "monthly",
66
+ YEARLY = "yearly",
67
+ CUSTOM = "custom"
68
+ }
69
+ /**
70
+ * 提醒类型
71
+ */
72
+ declare enum ReminderType {
73
+ NOTIFICATION = "notification",
74
+ EMAIL = "email",
75
+ SMS = "sms"
76
+ }
77
+ /**
78
+ * 提醒状态
79
+ */
80
+ declare enum ReminderStatus {
81
+ PENDING = "pending",
82
+ SENT = "sent",
83
+ FAILED = "failed"
84
+ }
85
+ /**
86
+ * 日历视图类型
87
+ */
88
+ declare enum CalendarViewType {
89
+ MONTH = "month",
90
+ WEEK = "week",
91
+ DAY = "day",
92
+ AGENDA = "agenda"
93
+ }
94
+ /**
95
+ * 事件颜色预设
96
+ */
97
+ declare enum EventColor {
98
+ BLUE = "#3B82F6",
99
+ GREEN = "#10B981",
100
+ PURPLE = "#8B5CF6",
101
+ RED = "#EF4444",
102
+ YELLOW = "#F59E0B",
103
+ PINK = "#EC4899",
104
+ INDIGO = "#6366F1",
105
+ GRAY = "#6B7280"
106
+ }
107
+ /**
108
+ * 事件优先级
109
+ */
110
+ declare enum EventPriority {
111
+ LOW = "low",
112
+ NORMAL = "normal",
113
+ HIGH = "high",
114
+ URGENT = "urgent"
115
+ }
116
+ /**
117
+ * 事件表单数据
118
+ */
119
+ interface EventFormData {
120
+ title: string;
121
+ description?: string;
122
+ startTime: Date;
123
+ endTime: Date;
124
+ allDay: boolean;
125
+ location?: string;
126
+ color: string;
127
+ priority: EventPriority;
128
+ recurrence?: RecurrenceFormData;
129
+ reminders?: ReminderFormData[];
130
+ }
131
+ /**
132
+ * 重复规则表单数据
133
+ */
134
+ interface RecurrenceFormData {
135
+ ruleType: RecurrenceType;
136
+ interval: number;
137
+ endDate?: Date;
138
+ count?: number;
139
+ byWeekday?: number[];
140
+ byMonthday?: number[];
141
+ byMonth?: number[];
142
+ }
143
+ /**
144
+ * 提醒表单数据
145
+ */
146
+ interface ReminderFormData {
147
+ reminderTime: Date;
148
+ reminderType: ReminderType;
149
+ }
150
+ /**
151
+ * API提醒数据
152
+ */
153
+ interface ReminderApiData {
154
+ reminderTime: string;
155
+ reminderType: ReminderType;
156
+ }
157
+ /**
158
+ * 创建事件请求
159
+ */
160
+ interface CreateEventRequest {
161
+ title: string;
162
+ description?: string;
163
+ startTime: string;
164
+ endTime: string;
165
+ allDay: boolean;
166
+ location?: string;
167
+ color: string;
168
+ priority: EventPriority;
169
+ recurrence?: RecurrenceFormData;
170
+ reminders?: ReminderApiData[];
171
+ }
172
+ /**
173
+ * 更新事件请求
174
+ */
175
+ interface UpdateEventRequest {
176
+ title?: string;
177
+ description?: string;
178
+ startTime?: string;
179
+ endTime?: string;
180
+ allDay?: boolean;
181
+ location?: string;
182
+ color?: string;
183
+ priority?: EventPriority;
184
+ recurrence?: RecurrenceFormData;
185
+ reminders?: ReminderApiData[];
186
+ }
187
+ /**
188
+ * 删除事件请求
189
+ */
190
+ interface DeleteEventRequest {
191
+ id: number;
192
+ deleteAll?: boolean;
193
+ }
194
+ /**
195
+ * 获取事件请求参数
196
+ */
197
+ interface GetEventsRequest {
198
+ startDate: string;
199
+ endDate: string;
200
+ viewType?: CalendarViewType;
201
+ userId?: number;
202
+ }
203
+ /**
204
+ * API响应基础类型
205
+ */
206
+ interface ApiResponse<T = any> {
207
+ success: boolean;
208
+ data?: T;
209
+ error?: string;
210
+ message?: string;
211
+ }
212
+ /**
213
+ * 事件列表响应
214
+ */
215
+ interface EventsResponse extends ApiResponse<CalendarEvent[]> {
216
+ }
217
+ /**
218
+ * 单个事件响应
219
+ */
220
+ interface EventResponse extends ApiResponse<CalendarEvent> {
221
+ }
222
+ /**
223
+ * 日历视图组件Props
224
+ */
225
+ interface CalendarViewProps {
226
+ events: CalendarEvent[];
227
+ viewType: CalendarViewType;
228
+ currentDate: Date;
229
+ onDateChange: (date: Date) => void;
230
+ onViewTypeChange: (viewType: CalendarViewType) => void;
231
+ onEventClick: (event: CalendarEvent) => void;
232
+ onEventCreate: (event: EventFormData) => void;
233
+ onEventUpdate: (event: CalendarEvent) => void;
234
+ onEventDelete: (eventId: number) => void;
235
+ loading?: boolean;
236
+ className?: string;
237
+ }
238
+ /**
239
+ * 事件卡片组件Props
240
+ */
241
+ interface EventCardProps {
242
+ event: CalendarEvent;
243
+ onClick?: (event: CalendarEvent) => void;
244
+ onEdit?: (event: CalendarEvent) => void;
245
+ onDelete?: (eventId: number) => void;
246
+ compact?: boolean;
247
+ className?: string;
248
+ }
249
+ /**
250
+ * 事件表单组件Props
251
+ */
252
+ interface EventFormProps$1 {
253
+ event?: CalendarEvent;
254
+ onSubmit: (eventData: EventFormData) => void;
255
+ onCancel: () => void;
256
+ loading?: boolean;
257
+ className?: string;
258
+ }
259
+ /**
260
+ * 事件弹窗组件Props
261
+ */
262
+ interface EventModalProps$1 {
263
+ isOpen: boolean;
264
+ event?: CalendarEvent;
265
+ onClose: () => void;
266
+ onSave: (eventData: EventFormData) => void;
267
+ onDelete?: (eventId: number) => void;
268
+ loading?: boolean;
269
+ }
270
+ /**
271
+ * 迷你日历组件Props
272
+ */
273
+ interface MiniCalendarProps {
274
+ selectedDate: Date;
275
+ onDateSelect: (date: Date) => void;
276
+ events?: CalendarEvent[];
277
+ highlightDatesWithEvents?: boolean;
278
+ className?: string;
279
+ }
280
+ /**
281
+ * 日历状态
282
+ */
283
+ interface CalendarState {
284
+ events: CalendarEvent[];
285
+ currentDate: Date;
286
+ viewType: CalendarViewType;
287
+ selectedEvent?: CalendarEvent;
288
+ loading: boolean;
289
+ error?: string;
290
+ }
291
+ /**
292
+ * 日历操作类型
293
+ */
294
+ interface CalendarActions {
295
+ setEvents: (events: CalendarEvent[]) => void;
296
+ addEvent: (event: CalendarEvent) => void;
297
+ updateEvent: (event: CalendarEvent) => void;
298
+ deleteEvent: (eventId: number) => void;
299
+ setCurrentDate: (date: Date) => void;
300
+ setViewType: (viewType: CalendarViewType) => void;
301
+ setSelectedEvent: (event?: CalendarEvent) => void;
302
+ setLoading: (loading: boolean) => void;
303
+ setError: (error?: string) => void;
304
+ }
305
+ /**
306
+ * useCalendar Hook返回类型
307
+ */
308
+ interface UseCalendarReturn {
309
+ state: CalendarState;
310
+ actions: CalendarActions;
311
+ loadEvents: (startDate: Date, endDate: Date) => Promise<void>;
312
+ createEvent: (eventData: EventFormData) => Promise<CalendarEvent>;
313
+ updateEvent: (eventId: number, eventData: Partial<EventFormData>) => Promise<CalendarEvent>;
314
+ deleteEvent: (eventId: number, deleteAll?: boolean) => Promise<void>;
315
+ refreshEvents: () => Promise<void>;
316
+ }
317
+ /**
318
+ * useEvents Hook返回类型
319
+ */
320
+ interface UseEventsReturn$1 {
321
+ events: CalendarEvent[];
322
+ loading: boolean;
323
+ error?: string;
324
+ createEvent: (eventData: EventFormData) => Promise<CalendarEvent>;
325
+ updateEvent: (eventId: number, eventData: Partial<EventFormData>) => Promise<CalendarEvent>;
326
+ deleteEvent: (eventId: number, deleteAll?: boolean) => Promise<void>;
327
+ loadEvents: (startDate: Date, endDate: Date) => Promise<void>;
328
+ refreshEvents: () => Promise<void>;
329
+ }
330
+ /**
331
+ * 日期范围
332
+ */
333
+ interface DateRange {
334
+ startDate: Date;
335
+ endDate: Date;
336
+ }
337
+ /**
338
+ * 日历单元格数据
339
+ */
340
+ interface CalendarCell {
341
+ date: Date;
342
+ isCurrentMonth: boolean;
343
+ isToday: boolean;
344
+ isSelected: boolean;
345
+ events: CalendarEvent[];
346
+ }
347
+ /**
348
+ * 时间槽数据
349
+ */
350
+ interface TimeSlot {
351
+ time: Date;
352
+ events: CalendarEvent[];
353
+ isWorkingHour: boolean;
354
+ }
355
+ /**
356
+ * 日历配置
357
+ */
358
+ interface CalendarConfig {
359
+ firstDayOfWeek: number;
360
+ workingHours: {
361
+ start: string;
362
+ end: string;
363
+ };
364
+ timeZone: string;
365
+ dateFormat: string;
366
+ timeFormat: string;
367
+ defaultView: CalendarViewType;
368
+ defaultEventColor: string;
369
+ weekends: boolean;
370
+ eventColors: Record<string, string>;
371
+ }
372
+ /**
373
+ * 服务接口
374
+ */
375
+ interface CalendarService {
376
+ getEvents(params: GetEventsRequest): Promise<CalendarEvent[]>;
377
+ createEvent(eventData: CreateEventRequest): Promise<CalendarEvent>;
378
+ updateEvent(eventId: number, eventData: UpdateEventRequest): Promise<CalendarEvent>;
379
+ deleteEvent(eventId: number, deleteAll?: boolean): Promise<void>;
380
+ getEvent(eventId: number): Promise<CalendarEvent>;
381
+ }
382
+ /**
383
+ * 数据库服务接口
384
+ */
385
+ interface CalendarDbService {
386
+ getAllEvents(userId: number, startDate?: Date, endDate?: Date): Promise<CalendarEvent[]>;
387
+ getEventById(eventId: number): Promise<CalendarEvent | null>;
388
+ createEvent(eventData: Omit<CalendarEvent, 'id' | 'createdAt' | 'updatedAt'>): Promise<CalendarEvent>;
389
+ updateEvent(eventId: number, eventData: Partial<CalendarEvent>): Promise<CalendarEvent>;
390
+ deleteEvent(eventId: number): Promise<void>;
391
+ createRecurrenceRule(ruleData: Omit<RecurrenceRule$1, 'id'>): Promise<RecurrenceRule$1>;
392
+ updateRecurrenceRule(ruleId: number, ruleData: Partial<RecurrenceRule$1>): Promise<RecurrenceRule$1>;
393
+ deleteRecurrenceRule(ruleId: number): Promise<void>;
394
+ createReminder(reminderData: Omit<Reminder, 'id' | 'createdAt'>): Promise<Reminder>;
395
+ updateReminder(reminderId: number, reminderData: Partial<Reminder>): Promise<Reminder>;
396
+ deleteReminder(reminderId: number): Promise<void>;
397
+ }
398
+ /**
399
+ * 事件排序字段
400
+ */
401
+ declare enum EventSortField {
402
+ START_TIME = "startTime",
403
+ TITLE = "title",
404
+ PRIORITY = "priority",
405
+ CREATED_AT = "createdAt",
406
+ UPDATED_AT = "updatedAt"
407
+ }
408
+ /**
409
+ * 排序方向
410
+ */
411
+ declare enum SortDirection {
412
+ ASC = "asc",
413
+ DESC = "desc"
414
+ }
415
+ /**
416
+ * 事件列表显示模式
417
+ */
418
+ declare enum EventListDisplayMode {
419
+ LIST = "list",
420
+ GRID = "grid"
421
+ }
422
+ /**
423
+ * 事件列表排序配置
424
+ */
425
+ interface EventListSort {
426
+ field: EventSortField;
427
+ direction: SortDirection;
428
+ }
429
+ /**
430
+ * 事件列表过滤配置
431
+ */
432
+ interface EventListFilter {
433
+ priority?: EventPriority;
434
+ color?: string;
435
+ dateRange?: DateRange;
436
+ searchText?: string;
437
+ }
438
+ /**
439
+ * 事件列表配置
440
+ */
441
+ interface EventListConfig {
442
+ displayMode: EventListDisplayMode;
443
+ sort: EventListSort;
444
+ filter: EventListFilter;
445
+ pageSize: number;
446
+ currentPage: number;
447
+ }
448
+ /**
449
+ * 事件列表Props
450
+ */
451
+ interface EventListProps {
452
+ events: CalendarEvent[];
453
+ config: EventListConfig;
454
+ onConfigChange: (config: EventListConfig) => void;
455
+ onEventClick: (event: CalendarEvent) => void;
456
+ onEventEdit: (event: CalendarEvent) => void;
457
+ onEventDelete: (eventId: number) => void;
458
+ onBatchDelete?: (eventIds: number[]) => Promise<void>;
459
+ enableBatchActions?: boolean;
460
+ loading?: boolean;
461
+ className?: string;
462
+ }
463
+
464
+ interface UseEventsReturn {
465
+ events: CalendarEvent[];
466
+ loading: boolean;
467
+ error?: string;
468
+ createEvent: (eventData: EventFormData) => Promise<CalendarEvent>;
469
+ updateEvent: (eventId: number, eventData: Partial<EventFormData>) => Promise<CalendarEvent>;
470
+ deleteEvent: (eventId: number, deleteAll?: boolean) => Promise<void>;
471
+ batchDeleteEvents: (eventIds: number[]) => Promise<void>;
472
+ fetchEvents: (startDate: Date, endDate: Date) => Promise<void>;
473
+ clearError: () => void;
474
+ }
475
+ /**
476
+ * 事件管理 Hook
477
+ *
478
+ * 提供事件的状态管理和CRUD操作
479
+ */
480
+ declare function useEvents(): UseEventsReturn;
481
+
482
+ /**
483
+ * 事件类型服务
484
+ *
485
+ * 负责处理不同类型事件的创建逻辑:
486
+ * 1. 单次事件 (Single Event)
487
+ * 2. 多天事件 (Multi-day Event)
488
+ * 3. 重复事件 (Recurring Event)
489
+ */
490
+ declare enum EventType {
491
+ SINGLE = "single",// 单次事件
492
+ MULTI_DAY = "multi_day",// 多天事件(跨越多个日期的单个事件)
493
+ RECURRING = "recurring"
494
+ }
495
+ declare enum RecurrencePattern {
496
+ DAILY = "daily",
497
+ WEEKLY = "weekly",
498
+ MONTHLY = "monthly",
499
+ YEARLY = "yearly",
500
+ CUSTOM = "custom"
501
+ }
502
+ interface BaseEventData {
503
+ title: string;
504
+ description?: string;
505
+ location?: string;
506
+ color: string;
507
+ priority: string;
508
+ allDay: boolean;
509
+ }
510
+ interface SingleEventData extends BaseEventData {
511
+ type: EventType.SINGLE;
512
+ startTime: Date;
513
+ endTime: Date;
514
+ }
515
+ interface MultiDayEventData extends BaseEventData {
516
+ type: EventType.MULTI_DAY;
517
+ startDate: Date;
518
+ endDate: Date;
519
+ startTime?: string;
520
+ endTime?: string;
521
+ }
522
+ interface RecurringEventData extends BaseEventData {
523
+ type: EventType.RECURRING;
524
+ startDate: Date;
525
+ startTime: Date;
526
+ endTime: Date;
527
+ recurrence: {
528
+ pattern: RecurrencePattern;
529
+ interval: number;
530
+ endDate?: Date;
531
+ count?: number;
532
+ daysOfWeek?: number[];
533
+ };
534
+ }
535
+ type EventData = SingleEventData | MultiDayEventData | RecurringEventData;
536
+ interface GeneratedEvent {
537
+ title: string;
538
+ description?: string;
539
+ startTime: Date;
540
+ endTime: Date;
541
+ location?: string;
542
+ color: string;
543
+ priority: string;
544
+ allDay: boolean;
545
+ eventType: EventType;
546
+ parentEventId?: string;
547
+ instanceDate?: string;
548
+ isMultiDayPart?: boolean;
549
+ isRecurringInstance?: boolean;
550
+ }
551
+ declare class EventTypeService {
552
+ /**
553
+ * 根据事件数据生成实际的事件实例
554
+ */
555
+ static generateEventInstances(eventData: EventData, viewStartDate: Date, viewEndDate: Date, parentEventId?: string): GeneratedEvent[];
556
+ /**
557
+ * 生成单次事件
558
+ */
559
+ private static generateSingleEvent;
560
+ /**
561
+ * 生成多天事件实例
562
+ * 例:21-23号的会议 -> 创建3个事件实例,每个代表一天
563
+ */
564
+ private static generateMultiDayEvents;
565
+ /**
566
+ * 生成重复事件实例
567
+ */
568
+ private static generateRecurringEvents;
569
+ /**
570
+ * 计算下一次重复的日期
571
+ */
572
+ private static getNextRecurrenceDate;
573
+ /**
574
+ * 格式化日期为字符串 (YYYY-MM-DD)
575
+ */
576
+ private static formatDateString;
577
+ /**
578
+ * 验证事件数据
579
+ */
580
+ static validateEventData(eventData: EventData): string[];
581
+ private static validateSingleEvent;
582
+ private static validateMultiDayEvent;
583
+ private static validateRecurringEvent;
584
+ /**
585
+ * 获取事件类型的描述文本
586
+ */
587
+ static getEventTypeDescription(eventData: EventData): string;
588
+ }
589
+
590
+ interface UseEnhancedEventsReturn {
591
+ events: CalendarEvent[];
592
+ loading: boolean;
593
+ error?: string;
594
+ createEvent: (eventData: EventFormData) => Promise<CalendarEvent>;
595
+ createEnhancedEvent: (eventData: EventData) => Promise<CalendarEvent[]>;
596
+ updateEvent: (eventId: number, eventData: Partial<EventFormData>) => Promise<CalendarEvent>;
597
+ updateEventTime: (eventId: number, newStartTime: Date, newEndTime: Date) => Promise<void>;
598
+ deleteEvent: (eventId: number, deleteAll?: boolean) => Promise<void>;
599
+ batchDeleteEvents: (eventIds: number[]) => Promise<void>;
600
+ fetchEvents: (startDate: Date, endDate: Date) => Promise<void>;
601
+ clearError: () => void;
602
+ }
603
+ /**
604
+ * 增强版事件管理 Hook
605
+ *
606
+ * 支持新的事件类型系统:单次事件、多天事件、重复事件
607
+ */
608
+ declare function useEnhancedEvents(): UseEnhancedEventsReturn;
609
+
610
+ interface DragState {
611
+ isDragging: boolean;
612
+ draggedEvent: CalendarEvent | null;
613
+ dragOverDate: Date | null;
614
+ previewTime: string | null;
615
+ }
616
+ interface UseEventDragReturn {
617
+ dragState: DragState;
618
+ handleDragStart: (event: DragStartEvent) => void;
619
+ handleDragOver: (event: DragOverEvent) => void;
620
+ handleDragEnd: (event: DragEndEvent) => void;
621
+ resetDragState: () => void;
622
+ }
623
+ /**
624
+ * 事件拖拽Hook
625
+ *
626
+ * 提供事件拖拽功能,支持:
627
+ * - 拖拽事件到不同日期
628
+ * - 拖拽时显示预览信息
629
+ * - 拖拽状态管理
630
+ */
631
+ declare function useEventDrag(events: CalendarEvent[], onEventUpdate: (eventId: number, newStartTime: Date, newEndTime: Date) => Promise<void>): UseEventDragReturn;
632
+
633
+ /**
634
+ * 日历日期工具函数
635
+ *
636
+ * 提供日历模块中常用的日期处理功能,包括:
637
+ * - 日期格式化
638
+ * - 日期计算
639
+ * - 日历视图相关的日期逻辑
640
+ * - 重复事件计算
641
+ */
642
+ /**
643
+ * 格式化日期为 YYYY-MM-DD 格式
644
+ * 使用本地时区,避免时区转换问题
645
+ */
646
+ declare function formatDate(date: Date): string;
647
+ /**
648
+ * 格式化时间为 HH:mm 格式
649
+ */
650
+ declare function formatTime(date: Date): string;
651
+ /**
652
+ * 格式化日期时间为本地字符串
653
+ */
654
+ declare function formatDateTime(date: Date, options?: Intl.DateTimeFormatOptions): string;
655
+ /**
656
+ * 将日期时间转换为ISO字符串,但保持本地时区
657
+ * 避免时区转换导致的日期偏移问题
658
+ */
659
+ declare function toLocalISOString(date: Date): string;
660
+ /**
661
+ * 获取月份的第一天
662
+ */
663
+ declare function getMonthStart(date: Date): Date;
664
+ /**
665
+ * 获取月份的最后一天
666
+ */
667
+ declare function getMonthEnd(date: Date): Date;
668
+ /**
669
+ * 获取周的第一天(基于指定的一周开始日)
670
+ */
671
+ declare function getWeekStart(date: Date, firstDayOfWeek?: number): Date;
672
+ /**
673
+ * 获取周的最后一天
674
+ */
675
+ declare function getWeekEnd(date: Date, firstDayOfWeek?: number): Date;
676
+ /**
677
+ * 获取当天的开始时间
678
+ */
679
+ declare function getDayStart(date: Date): Date;
680
+ /**
681
+ * 获取当天的结束时间
682
+ */
683
+ declare function getDayEnd(date: Date): Date;
684
+ /**
685
+ * 检查两个日期是否在同一天
686
+ */
687
+ declare function isSameDay(date1: Date, date2: Date): boolean;
688
+ /**
689
+ * 检查两个日期是否在同一周
690
+ */
691
+ declare function isSameWeek(date1: Date, date2: Date, firstDayOfWeek?: number): boolean;
692
+ /**
693
+ * 检查两个日期是否在同一月
694
+ */
695
+ declare function isSameMonth(date1: Date, date2: Date): boolean;
696
+ /**
697
+ * 检查日期是否是今天
698
+ */
699
+ declare function isToday(date: Date): boolean;
700
+ /**
701
+ * 检查日期是否是周末
702
+ */
703
+ declare function isWeekend(date: Date): boolean;
704
+ /**
705
+ * 添加天数
706
+ */
707
+ declare function addDays(date: Date, days: number): Date;
708
+ /**
709
+ * 添加周数
710
+ */
711
+ declare function addWeeks(date: Date, weeks: number): Date;
712
+ /**
713
+ * 添加月数
714
+ */
715
+ declare function addMonths(date: Date, months: number): Date;
716
+ /**
717
+ * 添加年数
718
+ */
719
+ declare function addYears(date: Date, years: number): Date;
720
+ /**
721
+ * 获取月视图的日期网格
722
+ */
723
+ declare function getMonthViewDates(date: Date, firstDayOfWeek?: number): Date[];
724
+ /**
725
+ * 获取周视图的日期
726
+ */
727
+ declare function getWeekViewDates(date: Date, firstDayOfWeek?: number): Date[];
728
+ /**
729
+ * 生成时间槽(用于日视图和周视图)
730
+ */
731
+ declare function generateTimeSlots(startHour?: number, endHour?: number, interval?: number): Date[];
732
+ /**
733
+ * 解析日期字符串为Date对象
734
+ */
735
+ declare function parseDate(dateString: string): Date;
736
+ /**
737
+ * 获取两个日期之间的天数差
738
+ */
739
+ declare function getDaysDifference(date1: Date, date2: Date): number;
740
+ /**
741
+ * 检查时间是否在工作时间内
742
+ */
743
+ declare function isWorkingHour(date: Date, workingStart?: string, workingEnd?: string): boolean;
744
+ /**
745
+ * 获取月份名称
746
+ */
747
+ declare function getMonthName(date: Date, locale?: string): string;
748
+ /**
749
+ * 获取星期名称
750
+ */
751
+ declare function getWeekdayName(date: Date, locale?: string, format?: 'long' | 'short' | 'narrow'): string;
752
+ /**
753
+ * 获取相对时间描述(如"2小时前"、"明天")
754
+ */
755
+ declare function getRelativeTime(date: Date, locale?: string): string;
756
+ /**
757
+ * 验证日期是否有效
758
+ */
759
+ declare function isValidDate(date: any): date is Date;
760
+ /**
761
+ * 克隆日期对象
762
+ */
763
+ declare function cloneDate(date: Date): Date;
764
+
765
+ /**
766
+ * 检测是否为移动端设备
767
+ */
768
+ declare const isMobileDevice: () => boolean;
769
+ /**
770
+ * 检测是否支持拖拽
771
+ */
772
+ declare const isDragSupported: () => boolean;
773
+ declare const useDeviceType: () => {
774
+ isMobile: boolean;
775
+ dragSupported: boolean;
776
+ };
777
+
778
+ interface RecurrenceRule {
779
+ type: 'daily' | 'weekly' | 'monthly' | 'yearly';
780
+ interval: number;
781
+ endDate?: string;
782
+ count?: number;
783
+ daysOfWeek?: number[];
784
+ dayOfMonth?: number;
785
+ weekOfMonth?: number;
786
+ }
787
+ interface RecurringEventInstance {
788
+ startTime: string;
789
+ endTime: string;
790
+ title: string;
791
+ description?: string;
792
+ location?: string;
793
+ color?: string;
794
+ priority?: string;
795
+ allDay: boolean;
796
+ isRecurringInstance: boolean;
797
+ recurrenceId?: string;
798
+ instanceDate: string;
799
+ }
800
+ declare class RecurrenceService {
801
+ /**
802
+ * 根据重复规则生成事件实例
803
+ */
804
+ static generateRecurringInstances(baseEvent: {
805
+ title: string;
806
+ description?: string;
807
+ startTime: string;
808
+ endTime: string;
809
+ location?: string;
810
+ color?: string;
811
+ priority?: string;
812
+ allDay: boolean;
813
+ }, rule: RecurrenceRule, startDate: Date, endDate: Date, eventId?: string): RecurringEventInstance[];
814
+ /**
815
+ * 判断是否应该在指定日期生成实例
816
+ */
817
+ private static shouldGenerateInstance;
818
+ /**
819
+ * 获取下一个重复事件的日期
820
+ */
821
+ private static getNextOccurrence;
822
+ /**
823
+ * 验证重复规则
824
+ */
825
+ static validateRecurrenceRule(rule: RecurrenceRule): string[];
826
+ /**
827
+ * 将表单数据转换为重复规则
828
+ */
829
+ static formDataToRecurrenceRule(formData: {
830
+ recurrenceType?: 'daily' | 'weekly' | 'monthly' | 'yearly';
831
+ recurrenceInterval?: number;
832
+ recurrenceEndDate?: string;
833
+ recurrenceCount?: number;
834
+ }): RecurrenceRule | null;
835
+ /**
836
+ * 描述重复规则的文本
837
+ */
838
+ static describeRecurrenceRule(rule: RecurrenceRule): string;
839
+ }
840
+
841
+ interface ReminderConfig {
842
+ minutes: number;
843
+ type: 'browser' | 'email' | 'sms' | 'sound';
844
+ enabled: boolean;
845
+ }
846
+ interface ScheduledReminder {
847
+ id: string;
848
+ eventId: number;
849
+ eventTitle: string;
850
+ reminderTime: Date;
851
+ config: ReminderConfig;
852
+ status: 'pending' | 'sent' | 'failed';
853
+ }
854
+ declare class ReminderService {
855
+ private static reminders;
856
+ private static notificationPermission;
857
+ /**
858
+ * 初始化提醒服务
859
+ */
860
+ static initialize(): Promise<void>;
861
+ /**
862
+ * 为事件创建提醒
863
+ */
864
+ static createReminder(event: CalendarEvent, reminderMinutes: number, reminderType?: 'browser' | 'email' | 'sms' | 'sound'): string;
865
+ /**
866
+ * 删除提醒
867
+ */
868
+ static deleteReminder(reminderId: string): boolean;
869
+ /**
870
+ * 删除事件的所有提醒
871
+ */
872
+ static deleteEventReminders(eventId: number): void;
873
+ /**
874
+ * 检查并触发到期的提醒
875
+ */
876
+ private static checkPendingReminders;
877
+ /**
878
+ * 触发提醒
879
+ */
880
+ private static triggerReminder;
881
+ /**
882
+ * 发送浏览器通知
883
+ */
884
+ private static sendBrowserNotification;
885
+ /**
886
+ * 发送邮件提醒
887
+ */
888
+ private static sendEmailReminder;
889
+ /**
890
+ * 发送短信提醒
891
+ */
892
+ private static sendSmsReminder;
893
+ /**
894
+ * 播放声音提醒
895
+ */
896
+ private static playSoundReminder;
897
+ /**
898
+ * 显示视觉提醒
899
+ */
900
+ private static showVisualAlert;
901
+ /**
902
+ * 获取时间描述文本
903
+ */
904
+ private static getTimeText;
905
+ /**
906
+ * 获取所有提醒
907
+ */
908
+ static getAllReminders(): ScheduledReminder[];
909
+ /**
910
+ * 获取事件的提醒
911
+ */
912
+ static getEventReminders(eventId: number): ScheduledReminder[];
913
+ /**
914
+ * 智能推荐提醒时间
915
+ */
916
+ static getSmartReminderSuggestions(event: CalendarEvent): number[];
917
+ /**
918
+ * 批量创建智能提醒
919
+ */
920
+ static createSmartReminders(event: CalendarEvent): string[];
921
+ }
922
+
923
+ /**
924
+ * 日历导出服务
925
+ *
926
+ * 提供日历事件的导出功能,支持多种格式:
927
+ * - iCal (.ics) 格式
928
+ * - JSON 格式
929
+ * - CSV 格式
930
+ */
931
+
932
+ interface ExportOptions {
933
+ format: 'ical' | 'json' | 'csv';
934
+ dateRange?: {
935
+ start: Date;
936
+ end: Date;
937
+ };
938
+ includeCompleted?: boolean;
939
+ }
940
+ declare class CalendarExportService {
941
+ /**
942
+ * 导出事件到指定格式
943
+ */
944
+ static exportEvents(events: CalendarEvent[], options: ExportOptions): Promise<string>;
945
+ /**
946
+ * 导出为 iCal (.ics) 格式
947
+ */
948
+ private static exportToICal;
949
+ /**
950
+ * 导出为 JSON 格式
951
+ */
952
+ private static exportToJSON;
953
+ /**
954
+ * 导出为 CSV 格式
955
+ */
956
+ private static exportToCSV;
957
+ /**
958
+ * 下载导出的文件
959
+ */
960
+ static downloadFile(content: string, filename: string, mimeType: string): void;
961
+ /**
962
+ * 获导出方法的便捷函数
963
+ */
964
+ static exportAndDownload(events: CalendarEvent[], options: ExportOptions, filename?: string): Promise<void>;
965
+ /**
966
+ * 格式化日期时间为 iCal 格式
967
+ */
968
+ private static formatDateTimeToICal;
969
+ /**
970
+ * 转义 iCal 文本
971
+ */
972
+ private static escapeICalText;
973
+ /**
974
+ * 转义 CSV 字段
975
+ */
976
+ private static escapeCSVField;
977
+ }
978
+
979
+ /**
980
+ * 日历导入服务
981
+ *
982
+ * 提供日历事件的导入功能,支持多种格式:
983
+ * - iCal (.ics) 格式
984
+ * - JSON 格式
985
+ * - CSV 格式
986
+ */
987
+
988
+ interface ImportOptions {
989
+ format: 'ical' | 'json' | 'csv';
990
+ overwriteExisting?: boolean;
991
+ validateEvents?: boolean;
992
+ }
993
+ interface ImportResult {
994
+ success: boolean;
995
+ importedCount: number;
996
+ errors: string[];
997
+ events: CreateEventRequest[];
998
+ }
999
+ declare class CalendarImportService {
1000
+ /**
1001
+ * 从文件导入事件
1002
+ */
1003
+ static importFromFile(file: File, options: ImportOptions): Promise<ImportResult>;
1004
+ /**
1005
+ * 从内容字符串导入事件
1006
+ */
1007
+ static importFromContent(content: string, options: ImportOptions): Promise<ImportResult>;
1008
+ /**
1009
+ * 读取文件内容
1010
+ */
1011
+ private static readFileContent;
1012
+ /**
1013
+ * 解析 iCal 内容
1014
+ */
1015
+ private static parseICalContent;
1016
+ /**
1017
+ * 解析 JSON 内容
1018
+ */
1019
+ private static parseJSONContent;
1020
+ /**
1021
+ * 解析 CSV 内容
1022
+ */
1023
+ private static parseCSVContent;
1024
+ /**
1025
+ * 解析 CSV 行
1026
+ */
1027
+ private static parseCSVLine;
1028
+ /**
1029
+ * 验证和过滤事件
1030
+ */
1031
+ private static validateAndFilterEvents;
1032
+ /**
1033
+ * 解析 iCal 日期时间
1034
+ */
1035
+ private static parseICalDateTime;
1036
+ /**
1037
+ * 反转义 iCal 文本
1038
+ */
1039
+ private static unescapeICalText;
1040
+ /**
1041
+ * 映射 iCal 优先级
1042
+ */
1043
+ private static mapICalPriority;
1044
+ }
1045
+
1046
+ interface CalendarPageProps {
1047
+ /** 当前登录用户信息 */
1048
+ user?: {
1049
+ id: number;
1050
+ name?: string;
1051
+ [key: string]: any;
1052
+ } | null;
1053
+ /** 是否已认证 */
1054
+ isAuthenticated?: boolean;
1055
+ /** 触发登录的回调 */
1056
+ onShowLogin?: () => void;
1057
+ /** 自定义页头操作区域(例如用户菜单) */
1058
+ headerActions?: React__default.ReactNode;
1059
+ }
1060
+ /**
1061
+ * 基础日历页面组件
1062
+ *
1063
+ * 这是一个简化版本的日历页面,用于在实验田中展示基本功能
1064
+ * 包含了基本的月历视图和事件显示
1065
+ */
1066
+ declare function CalendarPage({ user: propUser, isAuthenticated: propIsAuthenticated, onShowLogin, headerActions }: CalendarPageProps): React__default.JSX.Element;
1067
+
1068
+ interface EventDetailPageProps {
1069
+ eventId: number;
1070
+ onBack?: () => void;
1071
+ onEdit?: (event: CalendarEvent) => void;
1072
+ onDelete?: (eventId: number) => void;
1073
+ }
1074
+ declare const EventDetailPage: React__default.FC<EventDetailPageProps>;
1075
+
1076
+ interface EventFormProps {
1077
+ /** 初始事件数据(编辑模式) */
1078
+ initialData?: Partial<EventFormData>;
1079
+ /** 是否为编辑模式 */
1080
+ isEdit?: boolean;
1081
+ /** 表单提交回调 */
1082
+ onSubmit: (data: EventFormData) => void;
1083
+ /** 取消回调 */
1084
+ onCancel: () => void;
1085
+ /** 是否正在加载 */
1086
+ loading?: boolean;
1087
+ }
1088
+ /**
1089
+ * 事件表单组件
1090
+ *
1091
+ * 用于创建和编辑日历事件的表单组件
1092
+ * 支持基本信息、重复规则、提醒设置等功能
1093
+ */
1094
+ declare function EventForm({ initialData, isEdit, onSubmit, onCancel, loading }: EventFormProps): React__default.JSX.Element;
1095
+
1096
+ /**
1097
+ * 事件列表组件
1098
+ * 支持列表/网格显示模式、排序、批量选择和批量删除
1099
+ */
1100
+ declare function EventList({ events, config, onConfigChange, onEventClick, onEventEdit, onEventDelete, onBatchDelete, enableBatchActions, loading, className }: EventListProps): React__default.JSX.Element;
1101
+
1102
+ interface EventModalProps {
1103
+ isOpen: boolean;
1104
+ onClose: () => void;
1105
+ onSave: (eventData: CreateEventRequest | UpdateEventRequest) => Promise<void>;
1106
+ onDelete?: (eventId: number) => Promise<void>;
1107
+ event?: CalendarEvent | null;
1108
+ initialDate?: Date;
1109
+ }
1110
+ declare const EventModal: React__default.FC<EventModalProps>;
1111
+
1112
+ declare const COLOR_THEMES: {
1113
+ default: {
1114
+ name: string;
1115
+ colors: {
1116
+ primary: string;
1117
+ secondary: string;
1118
+ accent: string;
1119
+ danger: string;
1120
+ purple: string;
1121
+ pink: string;
1122
+ indigo: string;
1123
+ teal: string;
1124
+ };
1125
+ background: {
1126
+ calendar: string;
1127
+ cell: string;
1128
+ today: string;
1129
+ weekend: string;
1130
+ otherMonth: string;
1131
+ };
1132
+ border: {
1133
+ calendar: string;
1134
+ cell: string;
1135
+ today: string;
1136
+ };
1137
+ text: {
1138
+ primary: string;
1139
+ secondary: string;
1140
+ today: string;
1141
+ weekend: string;
1142
+ otherMonth: string;
1143
+ };
1144
+ };
1145
+ dark: {
1146
+ name: string;
1147
+ colors: {
1148
+ primary: string;
1149
+ secondary: string;
1150
+ accent: string;
1151
+ danger: string;
1152
+ purple: string;
1153
+ pink: string;
1154
+ indigo: string;
1155
+ teal: string;
1156
+ };
1157
+ background: {
1158
+ calendar: string;
1159
+ cell: string;
1160
+ today: string;
1161
+ weekend: string;
1162
+ otherMonth: string;
1163
+ };
1164
+ border: {
1165
+ calendar: string;
1166
+ cell: string;
1167
+ today: string;
1168
+ };
1169
+ text: {
1170
+ primary: string;
1171
+ secondary: string;
1172
+ today: string;
1173
+ weekend: string;
1174
+ otherMonth: string;
1175
+ };
1176
+ };
1177
+ colorful: {
1178
+ name: string;
1179
+ colors: {
1180
+ primary: string;
1181
+ secondary: string;
1182
+ accent: string;
1183
+ danger: string;
1184
+ purple: string;
1185
+ pink: string;
1186
+ indigo: string;
1187
+ teal: string;
1188
+ };
1189
+ background: {
1190
+ calendar: string;
1191
+ cell: string;
1192
+ today: string;
1193
+ weekend: string;
1194
+ otherMonth: string;
1195
+ };
1196
+ border: {
1197
+ calendar: string;
1198
+ cell: string;
1199
+ today: string;
1200
+ };
1201
+ text: {
1202
+ primary: string;
1203
+ secondary: string;
1204
+ today: string;
1205
+ weekend: string;
1206
+ otherMonth: string;
1207
+ };
1208
+ };
1209
+ };
1210
+ interface CalendarSettingsProps {
1211
+ onSettingsChange?: (settings: CalendarSettingsData) => void;
1212
+ }
1213
+ interface CalendarSettingsData {
1214
+ theme: keyof typeof COLOR_THEMES;
1215
+ customColors?: {
1216
+ [key: string]: string;
1217
+ };
1218
+ weekStartsOn: number;
1219
+ timeFormat: '12h' | '24h';
1220
+ language: string;
1221
+ showWeekNumbers: boolean;
1222
+ showLunarCalendar: boolean;
1223
+ defaultEventDuration: number;
1224
+ workingHours: {
1225
+ start: string;
1226
+ end: string;
1227
+ };
1228
+ }
1229
+ declare function CalendarSettings({ onSettingsChange }: CalendarSettingsProps): React__default.JSX.Element;
1230
+
1231
+ interface ImprovedEventModalProps {
1232
+ isOpen: boolean;
1233
+ onClose: () => void;
1234
+ onSave: (eventData: EventData) => Promise<void>;
1235
+ onDelete?: (eventId: number) => Promise<void>;
1236
+ event?: CalendarEvent | null;
1237
+ initialDate?: Date;
1238
+ }
1239
+ declare const ImprovedEventModal: React__default.FC<ImprovedEventModalProps>;
1240
+
1241
+ interface EventSearchProps {
1242
+ events: CalendarEvent[];
1243
+ onFiltered: (filteredEvents: CalendarEvent[]) => void;
1244
+ className?: string;
1245
+ }
1246
+ declare const EventSearch: React__default.FC<EventSearchProps>;
1247
+
1248
+ interface DraggableMonthViewProps {
1249
+ events: CalendarEvent[];
1250
+ currentDate: Date;
1251
+ onDateChange: (date: Date) => void;
1252
+ onEventClick?: (event: CalendarEvent) => void;
1253
+ onDateClick?: (date: Date) => void;
1254
+ onEventUpdate: (eventId: number, newStartTime: Date, newEndTime: Date) => Promise<void>;
1255
+ className?: string;
1256
+ }
1257
+ /**
1258
+ * 支持拖拽的月视图组件
1259
+ *
1260
+ * 功能特性:
1261
+ * - 完整的月视图日历
1262
+ * - 事件拖拽功能(桌面端)
1263
+ * - 移动端禁用拖拽,优化触摸体验
1264
+ * - 拖拽预览和反馈
1265
+ * - 月份导航
1266
+ * - 响应式设计
1267
+ */
1268
+ declare const DraggableMonthView: React__default.FC<DraggableMonthViewProps>;
1269
+
1270
+ interface DraggableEventProps {
1271
+ event: CalendarEvent;
1272
+ isDragging?: boolean;
1273
+ className?: string;
1274
+ onClick?: () => void;
1275
+ children?: React__default.ReactNode;
1276
+ }
1277
+ /**
1278
+ * 可拖拽的事件组件
1279
+ *
1280
+ * 功能特性:
1281
+ * - 支持拖拽移动事件(桌面端)
1282
+ * - 移动端禁用拖拽功能
1283
+ * - 拖拽时显示半透明效果
1284
+ * - 保持原有的点击功能
1285
+ * - 响应式设计
1286
+ */
1287
+ declare const DraggableEvent: React__default.FC<DraggableEventProps>;
1288
+
1289
+ interface DroppableCalendarCellProps {
1290
+ date: Date;
1291
+ events: CalendarEvent[];
1292
+ isCurrentMonth: boolean;
1293
+ isSelected?: boolean;
1294
+ dragOverPreview?: string | null;
1295
+ onEventClick?: (event: CalendarEvent) => void;
1296
+ onDateClick?: (date: Date) => void;
1297
+ className?: string;
1298
+ disableDrop?: boolean;
1299
+ }
1300
+ /**
1301
+ * 可放置的日历单元格组件
1302
+ *
1303
+ * 功能特性:
1304
+ * - 支持拖拽事件到此日期
1305
+ * - 显示当前日期的所有事件
1306
+ * - 拖拽悬停时显示预览
1307
+ * - 响应式设计
1308
+ */
1309
+ declare const DroppableCalendarCell: React__default.FC<DroppableCalendarCellProps>;
1310
+
1311
+ export { type ApiResponse, type CalendarActions, type CalendarCell, type CalendarConfig, type CalendarDbService, type CalendarEvent, CalendarExportService, CalendarImportService, CalendarPage, type CalendarService, CalendarSettings, type CalendarState, type CalendarViewProps, CalendarViewType, type CreateEventRequest, type DateRange, type DeleteEventRequest, DraggableEvent, DraggableMonthView, DroppableCalendarCell, type EventCardProps, EventColor, EventDetailPage, EventForm, type EventFormData, type EventFormProps$1 as EventFormProps, EventList, type EventListConfig, EventListDisplayMode, type EventListFilter, type EventListProps, type EventListSort, EventModal, type EventModalProps$1 as EventModalProps, EventPriority, type EventResponse, EventSearch, EventSortField, EventTypeService, type EventsResponse, type GetEventsRequest, ImprovedEventModal, type MiniCalendarProps, type RecurrenceFormData, type RecurrenceRule$1 as RecurrenceRule, RecurrenceService, RecurrenceType, type Reminder, type ReminderApiData, type ReminderFormData, ReminderService, ReminderStatus, ReminderType, SortDirection, type TimeSlot, type UpdateEventRequest, type UseCalendarReturn, type UseEventsReturn$1 as UseEventsReturn, addDays, addMonths, addWeeks, addYears, cloneDate, formatDate, formatDateTime, formatTime, generateTimeSlots, getDayEnd, getDayStart, getDaysDifference, getMonthEnd, getMonthName, getMonthStart, getMonthViewDates, getRelativeTime, getWeekEnd, getWeekStart, getWeekViewDates, getWeekdayName, isDragSupported, isMobileDevice, isSameDay, isSameMonth, isSameWeek, isToday, isValidDate, isWeekend, isWorkingHour, parseDate, toLocalISOString, useDeviceType, useEnhancedEvents, useEventDrag, useEvents };