@mekari/pixel3-date-picker 0.0.1-dev.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (103) hide show
  1. package/dist/calendar-panel.d.mts +231 -0
  2. package/dist/calendar-panel.d.ts +231 -0
  3. package/dist/calendar-panel.js +1498 -0
  4. package/dist/calendar-panel.mjs +25 -0
  5. package/dist/chunk-26Y3AVJW.mjs +115 -0
  6. package/dist/chunk-3VROFGJH.mjs +34 -0
  7. package/dist/chunk-3YYRUEIF.mjs +257 -0
  8. package/dist/chunk-5PISTT2K.mjs +131 -0
  9. package/dist/chunk-AGAA7XTC.mjs +20 -0
  10. package/dist/chunk-EJCSF5VR.mjs +492 -0
  11. package/dist/chunk-EQWT6VDG.mjs +34 -0
  12. package/dist/chunk-FTR7OMCT.mjs +0 -0
  13. package/dist/chunk-HJ4V3PM6.mjs +125 -0
  14. package/dist/chunk-J5BK7Z2U.mjs +46 -0
  15. package/dist/chunk-JZ2KFYWF.mjs +127 -0
  16. package/dist/chunk-LVCRFE25.mjs +153 -0
  17. package/dist/chunk-NIUQXHGQ.mjs +56 -0
  18. package/dist/chunk-NVULZQVI.mjs +119 -0
  19. package/dist/chunk-OY5PVQH5.mjs +31 -0
  20. package/dist/chunk-Q3Z5ZITX.mjs +155 -0
  21. package/dist/chunk-QZ7VFGWC.mjs +6 -0
  22. package/dist/chunk-V36XV4LV.mjs +129 -0
  23. package/dist/chunk-V6D6W7RO.mjs +0 -0
  24. package/dist/chunk-VACMCDOZ.mjs +8 -0
  25. package/dist/components/calendar/index.d.mts +11 -0
  26. package/dist/components/calendar/index.d.ts +11 -0
  27. package/dist/components/calendar/index.js +548 -0
  28. package/dist/components/calendar/index.mjs +23 -0
  29. package/dist/components/calendar/table-date.d.mts +97 -0
  30. package/dist/components/calendar/table-date.d.ts +97 -0
  31. package/dist/components/calendar/table-date.js +305 -0
  32. package/dist/components/calendar/table-date.mjs +13 -0
  33. package/dist/components/calendar/table-month.d.mts +90 -0
  34. package/dist/components/calendar/table-month.d.ts +90 -0
  35. package/dist/components/calendar/table-month.js +294 -0
  36. package/dist/components/calendar/table-month.mjs +14 -0
  37. package/dist/components/calendar/table-year.d.mts +71 -0
  38. package/dist/components/calendar/table-year.d.ts +71 -0
  39. package/dist/components/calendar/table-year.js +288 -0
  40. package/dist/components/calendar/table-year.mjs +14 -0
  41. package/dist/components/parts/date.d.mts +38 -0
  42. package/dist/components/parts/date.d.ts +38 -0
  43. package/dist/components/parts/date.js +70 -0
  44. package/dist/components/parts/date.mjs +7 -0
  45. package/dist/components/parts/day.d.mts +6 -0
  46. package/dist/components/parts/day.d.ts +6 -0
  47. package/dist/components/parts/day.js +44 -0
  48. package/dist/components/parts/day.mjs +7 -0
  49. package/dist/components/parts/index.d.mts +9 -0
  50. package/dist/components/parts/index.d.ts +9 -0
  51. package/dist/components/parts/index.js +157 -0
  52. package/dist/components/parts/index.mjs +20 -0
  53. package/dist/components/parts/month.d.mts +29 -0
  54. package/dist/components/parts/month.d.ts +29 -0
  55. package/dist/components/parts/month.js +58 -0
  56. package/dist/components/parts/month.mjs +7 -0
  57. package/dist/components/parts/year.d.mts +29 -0
  58. package/dist/components/parts/year.d.ts +29 -0
  59. package/dist/components/parts/year.js +58 -0
  60. package/dist/components/parts/year.mjs +7 -0
  61. package/dist/composables/useCalendar.d.mts +90 -0
  62. package/dist/composables/useCalendar.d.ts +90 -0
  63. package/dist/composables/useCalendar.js +184 -0
  64. package/dist/composables/useCalendar.mjs +8 -0
  65. package/dist/composables/useCalendarRange.d.mts +277 -0
  66. package/dist/composables/useCalendarRange.d.ts +277 -0
  67. package/dist/composables/useCalendarRange.js +160 -0
  68. package/dist/composables/useCalendarRange.mjs +8 -0
  69. package/dist/date-picker.d.mts +237 -0
  70. package/dist/date-picker.d.ts +237 -0
  71. package/dist/date-picker.js +1851 -0
  72. package/dist/date-picker.mjs +25 -0
  73. package/dist/index.d.mts +3 -0
  74. package/dist/index.d.ts +3 -0
  75. package/dist/index.js +1853 -0
  76. package/dist/index.mjs +25 -0
  77. package/dist/metafile-cjs.json +1 -0
  78. package/dist/metafile-esm.json +1 -0
  79. package/dist/modules/date-picker.context.d.mts +20 -0
  80. package/dist/modules/date-picker.context.d.ts +20 -0
  81. package/dist/modules/date-picker.context.js +33 -0
  82. package/dist/modules/date-picker.context.mjs +9 -0
  83. package/dist/modules/date-picker.hooks.d.mts +53 -0
  84. package/dist/modules/date-picker.hooks.d.ts +53 -0
  85. package/dist/modules/date-picker.hooks.js +337 -0
  86. package/dist/modules/date-picker.hooks.mjs +10 -0
  87. package/dist/modules/date-picker.locales.d.mts +27 -0
  88. package/dist/modules/date-picker.locales.d.ts +27 -0
  89. package/dist/modules/date-picker.locales.js +84 -0
  90. package/dist/modules/date-picker.locales.mjs +8 -0
  91. package/dist/modules/date-picker.props.d.mts +217 -0
  92. package/dist/modules/date-picker.props.d.ts +217 -0
  93. package/dist/modules/date-picker.props.js +181 -0
  94. package/dist/modules/date-picker.props.mjs +11 -0
  95. package/dist/utils/base.d.mts +20 -0
  96. package/dist/utils/base.d.ts +20 -0
  97. package/dist/utils/base.js +80 -0
  98. package/dist/utils/base.mjs +13 -0
  99. package/dist/utils/date.d.mts +19 -0
  100. package/dist/utils/date.d.ts +19 -0
  101. package/dist/utils/date.js +147 -0
  102. package/dist/utils/date.mjs +29 -0
  103. package/package.json +49 -0
@@ -0,0 +1,277 @@
1
+ import * as vue from 'vue';
2
+ import { CalendarPanelRangeProps } from '../modules/date-picker.props.js';
3
+ import '../components/parts/date.js';
4
+ import 'vue/jsx-runtime';
5
+ import '@mekari/pixel3-styled-system/types';
6
+ import '@mekari/pixel3-styled-system/css';
7
+ import '@mekari/pixel3-styled-system/recipes';
8
+ import '../components/parts/month.js';
9
+ import '../components/parts/year.js';
10
+
11
+ declare function useCalendarRange(props: CalendarPanelRangeProps): {
12
+ startDate: vue.Ref<{
13
+ toString: () => string;
14
+ toDateString: () => string;
15
+ toTimeString: () => string;
16
+ toLocaleString: {
17
+ (): string;
18
+ (locales?: string | string[] | undefined, options?: Intl.DateTimeFormatOptions | undefined): string;
19
+ (locales?: Intl.LocalesArgument, options?: Intl.DateTimeFormatOptions | undefined): string;
20
+ };
21
+ toLocaleDateString: {
22
+ (): string;
23
+ (locales?: string | string[] | undefined, options?: Intl.DateTimeFormatOptions | undefined): string;
24
+ (locales?: Intl.LocalesArgument, options?: Intl.DateTimeFormatOptions | undefined): string;
25
+ };
26
+ toLocaleTimeString: {
27
+ (): string;
28
+ (locales?: string | string[] | undefined, options?: Intl.DateTimeFormatOptions | undefined): string;
29
+ (locales?: Intl.LocalesArgument, options?: Intl.DateTimeFormatOptions | undefined): string;
30
+ };
31
+ valueOf: () => number;
32
+ getTime: () => number;
33
+ getFullYear: () => number;
34
+ getUTCFullYear: () => number;
35
+ getMonth: () => number;
36
+ getUTCMonth: () => number;
37
+ getDate: () => number;
38
+ getUTCDate: () => number;
39
+ getDay: () => number;
40
+ getUTCDay: () => number;
41
+ getHours: () => number;
42
+ getUTCHours: () => number;
43
+ getMinutes: () => number;
44
+ getUTCMinutes: () => number;
45
+ getSeconds: () => number;
46
+ getUTCSeconds: () => number;
47
+ getMilliseconds: () => number;
48
+ getUTCMilliseconds: () => number;
49
+ getTimezoneOffset: () => number;
50
+ setTime: (time: number) => number;
51
+ setMilliseconds: (ms: number) => number;
52
+ setUTCMilliseconds: (ms: number) => number;
53
+ setSeconds: (sec: number, ms?: number | undefined) => number;
54
+ setUTCSeconds: (sec: number, ms?: number | undefined) => number;
55
+ setMinutes: (min: number, sec?: number | undefined, ms?: number | undefined) => number;
56
+ setUTCMinutes: (min: number, sec?: number | undefined, ms?: number | undefined) => number;
57
+ setHours: (hours: number, min?: number | undefined, sec?: number | undefined, ms?: number | undefined) => number;
58
+ setUTCHours: (hours: number, min?: number | undefined, sec?: number | undefined, ms?: number | undefined) => number;
59
+ setDate: (date: number) => number;
60
+ setUTCDate: (date: number) => number;
61
+ setMonth: (month: number, date?: number | undefined) => number;
62
+ setUTCMonth: (month: number, date?: number | undefined) => number;
63
+ setFullYear: (year: number, month?: number | undefined, date?: number | undefined) => number;
64
+ setUTCFullYear: (year: number, month?: number | undefined, date?: number | undefined) => number;
65
+ toUTCString: () => string;
66
+ toISOString: () => string;
67
+ toJSON: (key?: any) => string;
68
+ [Symbol.toPrimitive]: {
69
+ (hint: "default"): string;
70
+ (hint: "string"): string;
71
+ (hint: "number"): number;
72
+ (hint: string): string | number;
73
+ };
74
+ }>;
75
+ endDate: vue.Ref<{
76
+ toString: () => string;
77
+ toDateString: () => string;
78
+ toTimeString: () => string;
79
+ toLocaleString: {
80
+ (): string;
81
+ (locales?: string | string[] | undefined, options?: Intl.DateTimeFormatOptions | undefined): string;
82
+ (locales?: Intl.LocalesArgument, options?: Intl.DateTimeFormatOptions | undefined): string;
83
+ };
84
+ toLocaleDateString: {
85
+ (): string;
86
+ (locales?: string | string[] | undefined, options?: Intl.DateTimeFormatOptions | undefined): string;
87
+ (locales?: Intl.LocalesArgument, options?: Intl.DateTimeFormatOptions | undefined): string;
88
+ };
89
+ toLocaleTimeString: {
90
+ (): string;
91
+ (locales?: string | string[] | undefined, options?: Intl.DateTimeFormatOptions | undefined): string;
92
+ (locales?: Intl.LocalesArgument, options?: Intl.DateTimeFormatOptions | undefined): string;
93
+ };
94
+ valueOf: () => number;
95
+ getTime: () => number;
96
+ getFullYear: () => number;
97
+ getUTCFullYear: () => number;
98
+ getMonth: () => number;
99
+ getUTCMonth: () => number;
100
+ getDate: () => number;
101
+ getUTCDate: () => number;
102
+ getDay: () => number;
103
+ getUTCDay: () => number;
104
+ getHours: () => number;
105
+ getUTCHours: () => number;
106
+ getMinutes: () => number;
107
+ getUTCMinutes: () => number;
108
+ getSeconds: () => number;
109
+ getUTCSeconds: () => number;
110
+ getMilliseconds: () => number;
111
+ getUTCMilliseconds: () => number;
112
+ getTimezoneOffset: () => number;
113
+ setTime: (time: number) => number;
114
+ setMilliseconds: (ms: number) => number;
115
+ setUTCMilliseconds: (ms: number) => number;
116
+ setSeconds: (sec: number, ms?: number | undefined) => number;
117
+ setUTCSeconds: (sec: number, ms?: number | undefined) => number;
118
+ setMinutes: (min: number, sec?: number | undefined, ms?: number | undefined) => number;
119
+ setUTCMinutes: (min: number, sec?: number | undefined, ms?: number | undefined) => number;
120
+ setHours: (hours: number, min?: number | undefined, sec?: number | undefined, ms?: number | undefined) => number;
121
+ setUTCHours: (hours: number, min?: number | undefined, sec?: number | undefined, ms?: number | undefined) => number;
122
+ setDate: (date: number) => number;
123
+ setUTCDate: (date: number) => number;
124
+ setMonth: (month: number, date?: number | undefined) => number;
125
+ setUTCMonth: (month: number, date?: number | undefined) => number;
126
+ setFullYear: (year: number, month?: number | undefined, date?: number | undefined) => number;
127
+ setUTCFullYear: (year: number, month?: number | undefined, date?: number | undefined) => number;
128
+ toUTCString: () => string;
129
+ toISOString: () => string;
130
+ toJSON: (key?: any) => string;
131
+ [Symbol.toPrimitive]: {
132
+ (hint: "default"): string;
133
+ (hint: "string"): string;
134
+ (hint: "number"): number;
135
+ (hint: string): string | number;
136
+ };
137
+ }>;
138
+ hoveredDate: vue.Ref<any>;
139
+ calendars: vue.Ref<{
140
+ toString: () => string;
141
+ toDateString: () => string;
142
+ toTimeString: () => string;
143
+ toLocaleString: {
144
+ (): string;
145
+ (locales?: string | string[] | undefined, options?: Intl.DateTimeFormatOptions | undefined): string;
146
+ (locales?: Intl.LocalesArgument, options?: Intl.DateTimeFormatOptions | undefined): string;
147
+ };
148
+ toLocaleDateString: {
149
+ (): string;
150
+ (locales?: string | string[] | undefined, options?: Intl.DateTimeFormatOptions | undefined): string;
151
+ (locales?: Intl.LocalesArgument, options?: Intl.DateTimeFormatOptions | undefined): string;
152
+ };
153
+ toLocaleTimeString: {
154
+ (): string;
155
+ (locales?: string | string[] | undefined, options?: Intl.DateTimeFormatOptions | undefined): string;
156
+ (locales?: Intl.LocalesArgument, options?: Intl.DateTimeFormatOptions | undefined): string;
157
+ };
158
+ valueOf: () => number;
159
+ getTime: () => number;
160
+ getFullYear: () => number;
161
+ getUTCFullYear: () => number;
162
+ getMonth: () => number;
163
+ getUTCMonth: () => number;
164
+ getDate: () => number;
165
+ getUTCDate: () => number;
166
+ getDay: () => number;
167
+ getUTCDay: () => number;
168
+ getHours: () => number;
169
+ getUTCHours: () => number;
170
+ getMinutes: () => number;
171
+ getUTCMinutes: () => number;
172
+ getSeconds: () => number;
173
+ getUTCSeconds: () => number;
174
+ getMilliseconds: () => number;
175
+ getUTCMilliseconds: () => number;
176
+ getTimezoneOffset: () => number;
177
+ setTime: (time: number) => number;
178
+ setMilliseconds: (ms: number) => number;
179
+ setUTCMilliseconds: (ms: number) => number;
180
+ setSeconds: (sec: number, ms?: number | undefined) => number;
181
+ setUTCSeconds: (sec: number, ms?: number | undefined) => number;
182
+ setMinutes: (min: number, sec?: number | undefined, ms?: number | undefined) => number;
183
+ setUTCMinutes: (min: number, sec?: number | undefined, ms?: number | undefined) => number;
184
+ setHours: (hours: number, min?: number | undefined, sec?: number | undefined, ms?: number | undefined) => number;
185
+ setUTCHours: (hours: number, min?: number | undefined, sec?: number | undefined, ms?: number | undefined) => number;
186
+ setDate: (date: number) => number;
187
+ setUTCDate: (date: number) => number;
188
+ setMonth: (month: number, date?: number | undefined) => number;
189
+ setUTCMonth: (month: number, date?: number | undefined) => number;
190
+ setFullYear: (year: number, month?: number | undefined, date?: number | undefined) => number;
191
+ setUTCFullYear: (year: number, month?: number | undefined, date?: number | undefined) => number;
192
+ toUTCString: () => string;
193
+ toISOString: () => string;
194
+ toJSON: (key?: any) => string;
195
+ [Symbol.toPrimitive]: {
196
+ (hint: "default"): string;
197
+ (hint: "string"): string;
198
+ (hint: "number"): number;
199
+ (hint: string): string | number;
200
+ };
201
+ }[]>;
202
+ getCurrentDates: vue.ComputedRef<{
203
+ toString: () => string;
204
+ toDateString: () => string;
205
+ toTimeString: () => string;
206
+ toLocaleString: {
207
+ (): string;
208
+ (locales?: string | string[] | undefined, options?: Intl.DateTimeFormatOptions | undefined): string;
209
+ (locales?: Intl.LocalesArgument, options?: Intl.DateTimeFormatOptions | undefined): string;
210
+ };
211
+ toLocaleDateString: {
212
+ (): string;
213
+ (locales?: string | string[] | undefined, options?: Intl.DateTimeFormatOptions | undefined): string;
214
+ (locales?: Intl.LocalesArgument, options?: Intl.DateTimeFormatOptions | undefined): string;
215
+ };
216
+ toLocaleTimeString: {
217
+ (): string;
218
+ (locales?: string | string[] | undefined, options?: Intl.DateTimeFormatOptions | undefined): string;
219
+ (locales?: Intl.LocalesArgument, options?: Intl.DateTimeFormatOptions | undefined): string;
220
+ };
221
+ valueOf: () => number;
222
+ getTime: () => number;
223
+ getFullYear: () => number;
224
+ getUTCFullYear: () => number;
225
+ getMonth: () => number;
226
+ getUTCMonth: () => number;
227
+ getDate: () => number;
228
+ getUTCDate: () => number;
229
+ getDay: () => number;
230
+ getUTCDay: () => number;
231
+ getHours: () => number;
232
+ getUTCHours: () => number;
233
+ getMinutes: () => number;
234
+ getUTCMinutes: () => number;
235
+ getSeconds: () => number;
236
+ getUTCSeconds: () => number;
237
+ getMilliseconds: () => number;
238
+ getUTCMilliseconds: () => number;
239
+ getTimezoneOffset: () => number;
240
+ setTime: (time: number) => number;
241
+ setMilliseconds: (ms: number) => number;
242
+ setUTCMilliseconds: (ms: number) => number;
243
+ setSeconds: (sec: number, ms?: number | undefined) => number;
244
+ setUTCSeconds: (sec: number, ms?: number | undefined) => number;
245
+ setMinutes: (min: number, sec?: number | undefined, ms?: number | undefined) => number;
246
+ setUTCMinutes: (min: number, sec?: number | undefined, ms?: number | undefined) => number;
247
+ setHours: (hours: number, min?: number | undefined, sec?: number | undefined, ms?: number | undefined) => number;
248
+ setUTCHours: (hours: number, min?: number | undefined, sec?: number | undefined, ms?: number | undefined) => number;
249
+ setDate: (date: number) => number;
250
+ setUTCDate: (date: number) => number;
251
+ setMonth: (month: number, date?: number | undefined) => number;
252
+ setUTCMonth: (month: number, date?: number | undefined) => number;
253
+ setFullYear: (year: number, month?: number | undefined, date?: number | undefined) => number;
254
+ setUTCFullYear: (year: number, month?: number | undefined, date?: number | undefined) => number;
255
+ toUTCString: () => string;
256
+ toISOString: () => string;
257
+ toJSON: (key?: any) => string;
258
+ [Symbol.toPrimitive]: {
259
+ (hint: "default"): string;
260
+ (hint: "string"): string;
261
+ (hint: "number"): number;
262
+ (hint: string): string | number;
263
+ };
264
+ }[]>;
265
+ setStartDate: (date: Date | undefined) => void;
266
+ setEndDate: (date: Date | undefined) => void;
267
+ setHoveredDate: (date: Date | undefined) => void;
268
+ getDateRangeStatus: (cellDate: any) => {
269
+ inRange: boolean;
270
+ hoverInRange: boolean;
271
+ activeDragRange: boolean;
272
+ };
273
+ updateStartCalendar: (value: Date) => void;
274
+ updateEndCalendar: (value: Date) => void;
275
+ };
276
+
277
+ export { useCalendarRange };
@@ -0,0 +1,160 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
7
+ var __export = (target, all) => {
8
+ for (var name in all)
9
+ __defProp(target, name, { get: all[name], enumerable: true });
10
+ };
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
+ }
17
+ return to;
18
+ };
19
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
20
+
21
+ // src/composables/useCalendarRange.ts
22
+ var useCalendarRange_exports = {};
23
+ __export(useCalendarRange_exports, {
24
+ useCalendarRange: () => useCalendarRange
25
+ });
26
+ module.exports = __toCommonJS(useCalendarRange_exports);
27
+ var import_vue = require("vue");
28
+
29
+ // src/utils/date.ts
30
+ var import_date_fns = require("date-fns");
31
+ function startOfMonth(value) {
32
+ const date = new Date(value);
33
+ date.setDate(1);
34
+ date.setHours(0, 0, 0, 0);
35
+ return date;
36
+ }
37
+ __name(startOfMonth, "startOfMonth");
38
+ function getNextMonth(date) {
39
+ return (0, import_date_fns.addMonths)(date, 1);
40
+ }
41
+ __name(getNextMonth, "getNextMonth");
42
+
43
+ // src/composables/useCalendarRange.ts
44
+ function useCalendarRange(props) {
45
+ const leftCalendar = startOfMonth(/* @__PURE__ */ new Date());
46
+ const rightCalendar = startOfMonth(getNextMonth(/* @__PURE__ */ new Date()));
47
+ const startDate = (0, import_vue.ref)(props.modelValue[0]);
48
+ const endDate = (0, import_vue.ref)(props.modelValue[1]);
49
+ const hoveredDate = (0, import_vue.ref)();
50
+ const calendars = (0, import_vue.ref)([leftCalendar, rightCalendar]);
51
+ const getCurrentDates = (0, import_vue.computed)(() => {
52
+ if (startDate.value && !endDate.value)
53
+ return [startDate.value];
54
+ if (startDate.value && endDate.value)
55
+ return [startDate.value, endDate.value];
56
+ return [];
57
+ });
58
+ const calendarMinDiff = (0, import_vue.computed)(() => {
59
+ const map = {
60
+ date: 1,
61
+ // type:date min 1 month
62
+ month: 1 * 12,
63
+ // type:month min 1 year
64
+ year: 10 * 12
65
+ // type:year min 10 year
66
+ };
67
+ return map[props.type] || map.date;
68
+ });
69
+ const calendarMaxDiff = (0, import_vue.computed)(() => Infinity);
70
+ function setStartDate(date) {
71
+ startDate.value = date;
72
+ }
73
+ __name(setStartDate, "setStartDate");
74
+ function setEndDate(date) {
75
+ endDate.value = date;
76
+ }
77
+ __name(setEndDate, "setEndDate");
78
+ function setHoveredDate(date) {
79
+ hoveredDate.value = date;
80
+ }
81
+ __name(setHoveredDate, "setHoveredDate");
82
+ function getDateRangeStatus(cellDate) {
83
+ const status = {
84
+ inRange: false,
85
+ hoverInRange: false,
86
+ activeDragRange: false
87
+ };
88
+ const isInRange = /* @__PURE__ */ __name((data, range, fn = (v) => v.getTime()) => {
89
+ const value = fn(data);
90
+ let [min, max] = range.map(fn);
91
+ if (min > max) {
92
+ [min, max] = [max, min];
93
+ }
94
+ return value > min && value < max;
95
+ }, "isInRange");
96
+ if (getCurrentDates.value.length === 2 && isInRange(cellDate, getCurrentDates.value)) {
97
+ status.inRange = true;
98
+ }
99
+ if (getCurrentDates.value.length === 1 && hoveredDate.value && isInRange(cellDate, [getCurrentDates.value[0], hoveredDate.value])) {
100
+ status.hoverInRange = true;
101
+ }
102
+ if (getCurrentDates.value[0]) {
103
+ status.activeDragRange = true;
104
+ }
105
+ return status;
106
+ }
107
+ __name(getDateRangeStatus, "getDateRangeStatus");
108
+ function updateStartCalendar(value) {
109
+ updateCalendars([value, calendars.value[1]], 1);
110
+ }
111
+ __name(updateStartCalendar, "updateStartCalendar");
112
+ function updateEndCalendar(value) {
113
+ updateCalendars([calendars.value[0], value], 0);
114
+ }
115
+ __name(updateEndCalendar, "updateEndCalendar");
116
+ function updateCalendars(value, adjustIndex = 1) {
117
+ const gap = getCalendarGap(value);
118
+ if (gap) {
119
+ const calendar = new Date(value[adjustIndex]);
120
+ calendar.setMonth(calendar.getMonth() + (adjustIndex === 0 ? -gap : gap));
121
+ value[adjustIndex] = calendar;
122
+ }
123
+ calendars.value = value;
124
+ }
125
+ __name(updateCalendars, "updateCalendars");
126
+ function getCalendarGap(calendars2) {
127
+ const [calendarLeft, calendarRight] = calendars2;
128
+ const yearDiff = calendarRight.getFullYear() - calendarLeft.getFullYear();
129
+ const monthDiff = calendarRight.getMonth() - calendarLeft.getMonth();
130
+ const diff = yearDiff * 12 + monthDiff;
131
+ const min = calendarMinDiff.value;
132
+ const max = calendarMaxDiff.value;
133
+ if (diff < min) {
134
+ return min - diff;
135
+ }
136
+ if (diff > max) {
137
+ return max - diff;
138
+ }
139
+ return 0;
140
+ }
141
+ __name(getCalendarGap, "getCalendarGap");
142
+ return {
143
+ startDate,
144
+ endDate,
145
+ hoveredDate,
146
+ calendars,
147
+ getCurrentDates,
148
+ setStartDate,
149
+ setEndDate,
150
+ setHoveredDate,
151
+ getDateRangeStatus,
152
+ updateStartCalendar,
153
+ updateEndCalendar
154
+ };
155
+ }
156
+ __name(useCalendarRange, "useCalendarRange");
157
+ // Annotate the CommonJS export names for ESM import in node:
158
+ 0 && (module.exports = {
159
+ useCalendarRange
160
+ });
@@ -0,0 +1,8 @@
1
+ import {
2
+ useCalendarRange
3
+ } from "../chunk-JZ2KFYWF.mjs";
4
+ import "../chunk-26Y3AVJW.mjs";
5
+ import "../chunk-QZ7VFGWC.mjs";
6
+ export {
7
+ useCalendarRange
8
+ };
@@ -0,0 +1,237 @@
1
+ import * as vue_jsx_runtime from 'vue/jsx-runtime';
2
+ import * as vue from 'vue';
3
+
4
+ declare const MpDatePicker: vue.DefineComponent<{
5
+ id: {
6
+ type: vue.PropType<string>;
7
+ };
8
+ modelValue: {
9
+ type: vue.PropType<string | number | Date | Date[] | string[] | number[]>;
10
+ };
11
+ type: {
12
+ type: vue.PropType<"date" | "month" | "year" | "week" | "biweek">;
13
+ default: string;
14
+ };
15
+ valueType: {
16
+ type: vue.PropType<"string" | "date" | "timestamp">;
17
+ default: string;
18
+ };
19
+ format: {
20
+ type: vue.PropType<string>;
21
+ };
22
+ rangeSeparator: {
23
+ type: vue.PropType<string>;
24
+ default: string;
25
+ };
26
+ placeholder: {
27
+ type: vue.PropType<string>;
28
+ default: string;
29
+ };
30
+ errorMessage: {
31
+ type: vue.PropType<string>;
32
+ default: string;
33
+ };
34
+ disabledMessage: {
35
+ type: vue.PropType<string>;
36
+ default: string;
37
+ };
38
+ lang: {
39
+ type: ObjectConstructor;
40
+ default: () => void;
41
+ };
42
+ inputAttr: {
43
+ type: ObjectConstructor;
44
+ default: () => {};
45
+ };
46
+ contentAttr: {
47
+ type: ObjectConstructor;
48
+ default: () => {};
49
+ };
50
+ isRange: {
51
+ type: vue.PropType<boolean>;
52
+ default: boolean;
53
+ };
54
+ isReadOnly: {
55
+ type: vue.PropType<boolean>;
56
+ default: boolean;
57
+ };
58
+ isDisabled: {
59
+ type: vue.PropType<boolean>;
60
+ default: boolean;
61
+ };
62
+ isClearable: {
63
+ type: vue.PropType<boolean>;
64
+ default: boolean;
65
+ };
66
+ isInvalid: {
67
+ type: vue.PropType<boolean>;
68
+ default: boolean;
69
+ };
70
+ usePortal: {
71
+ type: vue.PropType<boolean>;
72
+ default: boolean;
73
+ };
74
+ isKeepAlive: {
75
+ type: vue.PropType<boolean>;
76
+ default: boolean;
77
+ };
78
+ isInline: {
79
+ type: vue.PropType<boolean>;
80
+ default: boolean;
81
+ };
82
+ isNotClickable: {
83
+ type: vue.PropType<boolean>;
84
+ default: boolean;
85
+ };
86
+ isDisableHeader: {
87
+ type: vue.PropType<boolean>;
88
+ default: boolean;
89
+ };
90
+ isShowShortcut: {
91
+ type: vue.PropType<boolean>;
92
+ default: boolean;
93
+ };
94
+ disabledDate: {
95
+ type: vue.PropType<(date: Date) => boolean>;
96
+ default: () => void;
97
+ };
98
+ disabledMonth: {
99
+ type: vue.PropType<(month: number, year: number) => boolean>;
100
+ default: () => void;
101
+ };
102
+ disabledYear: {
103
+ type: vue.PropType<(year: number) => boolean>;
104
+ default: () => void;
105
+ };
106
+ }, () => vue_jsx_runtime.JSX.Element, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, ("update:modelValue" | "error")[], "update:modelValue" | "error", vue.PublicProps, Readonly<vue.ExtractPropTypes<{
107
+ id: {
108
+ type: vue.PropType<string>;
109
+ };
110
+ modelValue: {
111
+ type: vue.PropType<string | number | Date | Date[] | string[] | number[]>;
112
+ };
113
+ type: {
114
+ type: vue.PropType<"date" | "month" | "year" | "week" | "biweek">;
115
+ default: string;
116
+ };
117
+ valueType: {
118
+ type: vue.PropType<"string" | "date" | "timestamp">;
119
+ default: string;
120
+ };
121
+ format: {
122
+ type: vue.PropType<string>;
123
+ };
124
+ rangeSeparator: {
125
+ type: vue.PropType<string>;
126
+ default: string;
127
+ };
128
+ placeholder: {
129
+ type: vue.PropType<string>;
130
+ default: string;
131
+ };
132
+ errorMessage: {
133
+ type: vue.PropType<string>;
134
+ default: string;
135
+ };
136
+ disabledMessage: {
137
+ type: vue.PropType<string>;
138
+ default: string;
139
+ };
140
+ lang: {
141
+ type: ObjectConstructor;
142
+ default: () => void;
143
+ };
144
+ inputAttr: {
145
+ type: ObjectConstructor;
146
+ default: () => {};
147
+ };
148
+ contentAttr: {
149
+ type: ObjectConstructor;
150
+ default: () => {};
151
+ };
152
+ isRange: {
153
+ type: vue.PropType<boolean>;
154
+ default: boolean;
155
+ };
156
+ isReadOnly: {
157
+ type: vue.PropType<boolean>;
158
+ default: boolean;
159
+ };
160
+ isDisabled: {
161
+ type: vue.PropType<boolean>;
162
+ default: boolean;
163
+ };
164
+ isClearable: {
165
+ type: vue.PropType<boolean>;
166
+ default: boolean;
167
+ };
168
+ isInvalid: {
169
+ type: vue.PropType<boolean>;
170
+ default: boolean;
171
+ };
172
+ usePortal: {
173
+ type: vue.PropType<boolean>;
174
+ default: boolean;
175
+ };
176
+ isKeepAlive: {
177
+ type: vue.PropType<boolean>;
178
+ default: boolean;
179
+ };
180
+ isInline: {
181
+ type: vue.PropType<boolean>;
182
+ default: boolean;
183
+ };
184
+ isNotClickable: {
185
+ type: vue.PropType<boolean>;
186
+ default: boolean;
187
+ };
188
+ isDisableHeader: {
189
+ type: vue.PropType<boolean>;
190
+ default: boolean;
191
+ };
192
+ isShowShortcut: {
193
+ type: vue.PropType<boolean>;
194
+ default: boolean;
195
+ };
196
+ disabledDate: {
197
+ type: vue.PropType<(date: Date) => boolean>;
198
+ default: () => void;
199
+ };
200
+ disabledMonth: {
201
+ type: vue.PropType<(month: number, year: number) => boolean>;
202
+ default: () => void;
203
+ };
204
+ disabledYear: {
205
+ type: vue.PropType<(year: number) => boolean>;
206
+ default: () => void;
207
+ };
208
+ }>> & {
209
+ "onUpdate:modelValue"?: ((...args: any[]) => any) | undefined;
210
+ onError?: ((...args: any[]) => any) | undefined;
211
+ }, {
212
+ type: "date" | "month" | "year" | "week" | "biweek";
213
+ valueType: "string" | "date" | "timestamp";
214
+ rangeSeparator: string;
215
+ placeholder: string;
216
+ errorMessage: string;
217
+ disabledMessage: string;
218
+ lang: Record<string, any>;
219
+ inputAttr: Record<string, any>;
220
+ contentAttr: Record<string, any>;
221
+ isRange: boolean;
222
+ isReadOnly: boolean;
223
+ isDisabled: boolean;
224
+ isClearable: boolean;
225
+ isInvalid: boolean;
226
+ usePortal: boolean;
227
+ isKeepAlive: boolean;
228
+ isInline: boolean;
229
+ isNotClickable: boolean;
230
+ isDisableHeader: boolean;
231
+ isShowShortcut: boolean;
232
+ disabledDate: (date: Date) => boolean;
233
+ disabledMonth: (month: number, year: number) => boolean;
234
+ disabledYear: (year: number) => boolean;
235
+ }, {}>;
236
+
237
+ export { MpDatePicker };