@oneluiz/dual-datepicker 2.5.0 → 2.6.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.
- package/README.md +154 -7
- package/dual-datepicker.component.d.ts +7 -1
- package/esm2022/dual-datepicker.component.mjs +22 -5
- package/esm2022/preset-utils.mjs +276 -0
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/oneluiz-dual-datepicker.mjs +298 -5
- package/fesm2022/oneluiz-dual-datepicker.mjs.map +1 -1
- package/package.json +1 -1
- package/preset-utils.d.ts +91 -0
- package/public-api.d.ts +2 -1
|
@@ -0,0 +1,276 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Utility functions for creating common date range presets
|
|
3
|
+
* Perfect for dashboards, reporting, POS, BI apps, and ERP systems
|
|
4
|
+
*/
|
|
5
|
+
/**
|
|
6
|
+
* Format a date as YYYY-MM-DD string
|
|
7
|
+
*/
|
|
8
|
+
function formatDate(date) {
|
|
9
|
+
const year = date.getFullYear();
|
|
10
|
+
const month = String(date.getMonth() + 1).padStart(2, '0');
|
|
11
|
+
const day = String(date.getDate()).padStart(2, '0');
|
|
12
|
+
return `${year}-${month}-${day}`;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Get the start of today
|
|
16
|
+
*/
|
|
17
|
+
export function getToday() {
|
|
18
|
+
const today = new Date();
|
|
19
|
+
return {
|
|
20
|
+
start: formatDate(today),
|
|
21
|
+
end: formatDate(today)
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Get yesterday's date range
|
|
26
|
+
*/
|
|
27
|
+
export function getYesterday() {
|
|
28
|
+
const yesterday = new Date();
|
|
29
|
+
yesterday.setDate(yesterday.getDate() - 1);
|
|
30
|
+
return {
|
|
31
|
+
start: formatDate(yesterday),
|
|
32
|
+
end: formatDate(yesterday)
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Get last N days (including today)
|
|
37
|
+
*/
|
|
38
|
+
export function getLastNDays(days) {
|
|
39
|
+
const end = new Date();
|
|
40
|
+
const start = new Date();
|
|
41
|
+
start.setDate(start.getDate() - days + 1);
|
|
42
|
+
return {
|
|
43
|
+
start: formatDate(start),
|
|
44
|
+
end: formatDate(end)
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Get this week (Monday to Sunday)
|
|
49
|
+
*/
|
|
50
|
+
export function getThisWeek() {
|
|
51
|
+
const today = new Date();
|
|
52
|
+
const dayOfWeek = today.getDay();
|
|
53
|
+
const start = new Date(today);
|
|
54
|
+
// Adjust to Monday (1) as first day of week
|
|
55
|
+
const daysToMonday = dayOfWeek === 0 ? 6 : dayOfWeek - 1;
|
|
56
|
+
start.setDate(start.getDate() - daysToMonday);
|
|
57
|
+
const end = new Date(start);
|
|
58
|
+
end.setDate(end.getDate() + 6);
|
|
59
|
+
return {
|
|
60
|
+
start: formatDate(start),
|
|
61
|
+
end: formatDate(end)
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Get last week (Monday to Sunday)
|
|
66
|
+
*/
|
|
67
|
+
export function getLastWeek() {
|
|
68
|
+
const today = new Date();
|
|
69
|
+
const dayOfWeek = today.getDay();
|
|
70
|
+
const daysToMonday = dayOfWeek === 0 ? 6 : dayOfWeek - 1;
|
|
71
|
+
const lastMonday = new Date(today);
|
|
72
|
+
lastMonday.setDate(lastMonday.getDate() - daysToMonday - 7);
|
|
73
|
+
const lastSunday = new Date(lastMonday);
|
|
74
|
+
lastSunday.setDate(lastSunday.getDate() + 6);
|
|
75
|
+
return {
|
|
76
|
+
start: formatDate(lastMonday),
|
|
77
|
+
end: formatDate(lastSunday)
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Get this month (1st to last day)
|
|
82
|
+
*/
|
|
83
|
+
export function getThisMonth() {
|
|
84
|
+
const today = new Date();
|
|
85
|
+
const start = new Date(today.getFullYear(), today.getMonth(), 1);
|
|
86
|
+
const end = new Date(today.getFullYear(), today.getMonth() + 1, 0);
|
|
87
|
+
return {
|
|
88
|
+
start: formatDate(start),
|
|
89
|
+
end: formatDate(end)
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Get last month (1st to last day)
|
|
94
|
+
*/
|
|
95
|
+
export function getLastMonth() {
|
|
96
|
+
const today = new Date();
|
|
97
|
+
const start = new Date(today.getFullYear(), today.getMonth() - 1, 1);
|
|
98
|
+
const end = new Date(today.getFullYear(), today.getMonth(), 0);
|
|
99
|
+
return {
|
|
100
|
+
start: formatDate(start),
|
|
101
|
+
end: formatDate(end)
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* Get month to date (1st of current month to today)
|
|
106
|
+
*/
|
|
107
|
+
export function getMonthToDate() {
|
|
108
|
+
const today = new Date();
|
|
109
|
+
const start = new Date(today.getFullYear(), today.getMonth(), 1);
|
|
110
|
+
return {
|
|
111
|
+
start: formatDate(start),
|
|
112
|
+
end: formatDate(today)
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* Get this quarter (Q1, Q2, Q3, or Q4)
|
|
117
|
+
*/
|
|
118
|
+
export function getThisQuarter() {
|
|
119
|
+
const today = new Date();
|
|
120
|
+
const currentMonth = today.getMonth();
|
|
121
|
+
const quarterStartMonth = Math.floor(currentMonth / 3) * 3;
|
|
122
|
+
const start = new Date(today.getFullYear(), quarterStartMonth, 1);
|
|
123
|
+
const end = new Date(today.getFullYear(), quarterStartMonth + 3, 0);
|
|
124
|
+
return {
|
|
125
|
+
start: formatDate(start),
|
|
126
|
+
end: formatDate(end)
|
|
127
|
+
};
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* Get last quarter
|
|
131
|
+
*/
|
|
132
|
+
export function getLastQuarter() {
|
|
133
|
+
const today = new Date();
|
|
134
|
+
const currentMonth = today.getMonth();
|
|
135
|
+
const lastQuarterStartMonth = Math.floor(currentMonth / 3) * 3 - 3;
|
|
136
|
+
const start = new Date(today.getFullYear(), lastQuarterStartMonth, 1);
|
|
137
|
+
const end = new Date(today.getFullYear(), lastQuarterStartMonth + 3, 0);
|
|
138
|
+
return {
|
|
139
|
+
start: formatDate(start),
|
|
140
|
+
end: formatDate(end)
|
|
141
|
+
};
|
|
142
|
+
}
|
|
143
|
+
/**
|
|
144
|
+
* Get quarter to date (start of current quarter to today)
|
|
145
|
+
*/
|
|
146
|
+
export function getQuarterToDate() {
|
|
147
|
+
const today = new Date();
|
|
148
|
+
const currentMonth = today.getMonth();
|
|
149
|
+
const quarterStartMonth = Math.floor(currentMonth / 3) * 3;
|
|
150
|
+
const start = new Date(today.getFullYear(), quarterStartMonth, 1);
|
|
151
|
+
return {
|
|
152
|
+
start: formatDate(start),
|
|
153
|
+
end: formatDate(today)
|
|
154
|
+
};
|
|
155
|
+
}
|
|
156
|
+
/**
|
|
157
|
+
* Get this year (January 1 to December 31)
|
|
158
|
+
*/
|
|
159
|
+
export function getThisYear() {
|
|
160
|
+
const today = new Date();
|
|
161
|
+
const start = new Date(today.getFullYear(), 0, 1);
|
|
162
|
+
const end = new Date(today.getFullYear(), 11, 31);
|
|
163
|
+
return {
|
|
164
|
+
start: formatDate(start),
|
|
165
|
+
end: formatDate(end)
|
|
166
|
+
};
|
|
167
|
+
}
|
|
168
|
+
/**
|
|
169
|
+
* Get last year
|
|
170
|
+
*/
|
|
171
|
+
export function getLastYear() {
|
|
172
|
+
const today = new Date();
|
|
173
|
+
const start = new Date(today.getFullYear() - 1, 0, 1);
|
|
174
|
+
const end = new Date(today.getFullYear() - 1, 11, 31);
|
|
175
|
+
return {
|
|
176
|
+
start: formatDate(start),
|
|
177
|
+
end: formatDate(end)
|
|
178
|
+
};
|
|
179
|
+
}
|
|
180
|
+
/**
|
|
181
|
+
* Get year to date (January 1 to today)
|
|
182
|
+
*/
|
|
183
|
+
export function getYearToDate() {
|
|
184
|
+
const today = new Date();
|
|
185
|
+
const start = new Date(today.getFullYear(), 0, 1);
|
|
186
|
+
return {
|
|
187
|
+
start: formatDate(start),
|
|
188
|
+
end: formatDate(today)
|
|
189
|
+
};
|
|
190
|
+
}
|
|
191
|
+
/**
|
|
192
|
+
* Get last N months (including current partial month)
|
|
193
|
+
*/
|
|
194
|
+
export function getLastNMonths(months) {
|
|
195
|
+
const today = new Date();
|
|
196
|
+
const start = new Date(today);
|
|
197
|
+
start.setMonth(start.getMonth() - months);
|
|
198
|
+
return {
|
|
199
|
+
start: formatDate(start),
|
|
200
|
+
end: formatDate(today)
|
|
201
|
+
};
|
|
202
|
+
}
|
|
203
|
+
/**
|
|
204
|
+
* Get last N years
|
|
205
|
+
*/
|
|
206
|
+
export function getLastNYears(years) {
|
|
207
|
+
const today = new Date();
|
|
208
|
+
const start = new Date(today);
|
|
209
|
+
start.setFullYear(start.getFullYear() - years);
|
|
210
|
+
return {
|
|
211
|
+
start: formatDate(start),
|
|
212
|
+
end: formatDate(today)
|
|
213
|
+
};
|
|
214
|
+
}
|
|
215
|
+
/**
|
|
216
|
+
* Pre-built preset configurations for common use cases
|
|
217
|
+
* Import and use these directly in your component
|
|
218
|
+
*/
|
|
219
|
+
export const CommonPresets = {
|
|
220
|
+
/**
|
|
221
|
+
* Dashboard presets - Perfect for analytics dashboards
|
|
222
|
+
*/
|
|
223
|
+
dashboard: [
|
|
224
|
+
{ label: 'Today', getValue: getToday },
|
|
225
|
+
{ label: 'Yesterday', getValue: getYesterday },
|
|
226
|
+
{ label: 'Last 7 days', getValue: () => getLastNDays(7) },
|
|
227
|
+
{ label: 'Last 30 days', getValue: () => getLastNDays(30) },
|
|
228
|
+
{ label: 'This month', getValue: getThisMonth },
|
|
229
|
+
{ label: 'Last month', getValue: getLastMonth }
|
|
230
|
+
],
|
|
231
|
+
/**
|
|
232
|
+
* Reporting presets - Perfect for business reporting
|
|
233
|
+
*/
|
|
234
|
+
reporting: [
|
|
235
|
+
{ label: 'Today', getValue: getToday },
|
|
236
|
+
{ label: 'This week', getValue: getThisWeek },
|
|
237
|
+
{ label: 'Last week', getValue: getLastWeek },
|
|
238
|
+
{ label: 'This month', getValue: getThisMonth },
|
|
239
|
+
{ label: 'Last month', getValue: getLastMonth },
|
|
240
|
+
{ label: 'This quarter', getValue: getThisQuarter },
|
|
241
|
+
{ label: 'Last quarter', getValue: getLastQuarter }
|
|
242
|
+
],
|
|
243
|
+
/**
|
|
244
|
+
* Financial presets - Perfect for ERP and accounting systems
|
|
245
|
+
*/
|
|
246
|
+
financial: [
|
|
247
|
+
{ label: 'Month to date', getValue: getMonthToDate },
|
|
248
|
+
{ label: 'Quarter to date', getValue: getQuarterToDate },
|
|
249
|
+
{ label: 'Year to date', getValue: getYearToDate },
|
|
250
|
+
{ label: 'Last month', getValue: getLastMonth },
|
|
251
|
+
{ label: 'Last quarter', getValue: getLastQuarter },
|
|
252
|
+
{ label: 'Last year', getValue: getLastYear }
|
|
253
|
+
],
|
|
254
|
+
/**
|
|
255
|
+
* Analytics presets - Perfect for BI and data analysis
|
|
256
|
+
*/
|
|
257
|
+
analytics: [
|
|
258
|
+
{ label: 'Last 7 days', getValue: () => getLastNDays(7) },
|
|
259
|
+
{ label: 'Last 14 days', getValue: () => getLastNDays(14) },
|
|
260
|
+
{ label: 'Last 30 days', getValue: () => getLastNDays(30) },
|
|
261
|
+
{ label: 'Last 60 days', getValue: () => getLastNDays(60) },
|
|
262
|
+
{ label: 'Last 90 days', getValue: () => getLastNDays(90) },
|
|
263
|
+
{ label: 'Last 180 days', getValue: () => getLastNDays(180) },
|
|
264
|
+
{ label: 'Last 365 days', getValue: () => getLastNDays(365) }
|
|
265
|
+
],
|
|
266
|
+
/**
|
|
267
|
+
* Simple presets - Basic common ranges
|
|
268
|
+
*/
|
|
269
|
+
simple: [
|
|
270
|
+
{ label: 'Today', getValue: getToday },
|
|
271
|
+
{ label: 'Last 7 days', getValue: () => getLastNDays(7) },
|
|
272
|
+
{ label: 'Last 30 days', getValue: () => getLastNDays(30) },
|
|
273
|
+
{ label: 'This year', getValue: getThisYear }
|
|
274
|
+
]
|
|
275
|
+
};
|
|
276
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"preset-utils.js","sourceRoot":"","sources":["../../src/preset-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { PresetConfig, PresetRange } from './dual-datepicker.component';\n\n/**\n * Utility functions for creating common date range presets\n * Perfect for dashboards, reporting, POS, BI apps, and ERP systems\n */\n\n/**\n * Format a date as YYYY-MM-DD string\n */\nfunction formatDate(date: Date): string {\n  const year = date.getFullYear();\n  const month = String(date.getMonth() + 1).padStart(2, '0');\n  const day = String(date.getDate()).padStart(2, '0');\n  return `${year}-${month}-${day}`;\n}\n\n/**\n * Get the start of today\n */\nexport function getToday(): PresetRange {\n  const today = new Date();\n  return {\n    start: formatDate(today),\n    end: formatDate(today)\n  };\n}\n\n/**\n * Get yesterday's date range\n */\nexport function getYesterday(): PresetRange {\n  const yesterday = new Date();\n  yesterday.setDate(yesterday.getDate() - 1);\n  return {\n    start: formatDate(yesterday),\n    end: formatDate(yesterday)\n  };\n}\n\n/**\n * Get last N days (including today)\n */\nexport function getLastNDays(days: number): PresetRange {\n  const end = new Date();\n  const start = new Date();\n  start.setDate(start.getDate() - days + 1);\n  return {\n    start: formatDate(start),\n    end: formatDate(end)\n  };\n}\n\n/**\n * Get this week (Monday to Sunday)\n */\nexport function getThisWeek(): PresetRange {\n  const today = new Date();\n  const dayOfWeek = today.getDay();\n  const start = new Date(today);\n  // Adjust to Monday (1) as first day of week\n  const daysToMonday = dayOfWeek === 0 ? 6 : dayOfWeek - 1;\n  start.setDate(start.getDate() - daysToMonday);\n  \n  const end = new Date(start);\n  end.setDate(end.getDate() + 6);\n  \n  return {\n    start: formatDate(start),\n    end: formatDate(end)\n  };\n}\n\n/**\n * Get last week (Monday to Sunday)\n */\nexport function getLastWeek(): PresetRange {\n  const today = new Date();\n  const dayOfWeek = today.getDay();\n  const daysToMonday = dayOfWeek === 0 ? 6 : dayOfWeek - 1;\n  \n  const lastMonday = new Date(today);\n  lastMonday.setDate(lastMonday.getDate() - daysToMonday - 7);\n  \n  const lastSunday = new Date(lastMonday);\n  lastSunday.setDate(lastSunday.getDate() + 6);\n  \n  return {\n    start: formatDate(lastMonday),\n    end: formatDate(lastSunday)\n  };\n}\n\n/**\n * Get this month (1st to last day)\n */\nexport function getThisMonth(): PresetRange {\n  const today = new Date();\n  const start = new Date(today.getFullYear(), today.getMonth(), 1);\n  const end = new Date(today.getFullYear(), today.getMonth() + 1, 0);\n  \n  return {\n    start: formatDate(start),\n    end: formatDate(end)\n  };\n}\n\n/**\n * Get last month (1st to last day)\n */\nexport function getLastMonth(): PresetRange {\n  const today = new Date();\n  const start = new Date(today.getFullYear(), today.getMonth() - 1, 1);\n  const end = new Date(today.getFullYear(), today.getMonth(), 0);\n  \n  return {\n    start: formatDate(start),\n    end: formatDate(end)\n  };\n}\n\n/**\n * Get month to date (1st of current month to today)\n */\nexport function getMonthToDate(): PresetRange {\n  const today = new Date();\n  const start = new Date(today.getFullYear(), today.getMonth(), 1);\n  \n  return {\n    start: formatDate(start),\n    end: formatDate(today)\n  };\n}\n\n/**\n * Get this quarter (Q1, Q2, Q3, or Q4)\n */\nexport function getThisQuarter(): PresetRange {\n  const today = new Date();\n  const currentMonth = today.getMonth();\n  const quarterStartMonth = Math.floor(currentMonth / 3) * 3;\n  \n  const start = new Date(today.getFullYear(), quarterStartMonth, 1);\n  const end = new Date(today.getFullYear(), quarterStartMonth + 3, 0);\n  \n  return {\n    start: formatDate(start),\n    end: formatDate(end)\n  };\n}\n\n/**\n * Get last quarter\n */\nexport function getLastQuarter(): PresetRange {\n  const today = new Date();\n  const currentMonth = today.getMonth();\n  const lastQuarterStartMonth = Math.floor(currentMonth / 3) * 3 - 3;\n  \n  const start = new Date(today.getFullYear(), lastQuarterStartMonth, 1);\n  const end = new Date(today.getFullYear(), lastQuarterStartMonth + 3, 0);\n  \n  return {\n    start: formatDate(start),\n    end: formatDate(end)\n  };\n}\n\n/**\n * Get quarter to date (start of current quarter to today)\n */\nexport function getQuarterToDate(): PresetRange {\n  const today = new Date();\n  const currentMonth = today.getMonth();\n  const quarterStartMonth = Math.floor(currentMonth / 3) * 3;\n  \n  const start = new Date(today.getFullYear(), quarterStartMonth, 1);\n  \n  return {\n    start: formatDate(start),\n    end: formatDate(today)\n  };\n}\n\n/**\n * Get this year (January 1 to December 31)\n */\nexport function getThisYear(): PresetRange {\n  const today = new Date();\n  const start = new Date(today.getFullYear(), 0, 1);\n  const end = new Date(today.getFullYear(), 11, 31);\n  \n  return {\n    start: formatDate(start),\n    end: formatDate(end)\n  };\n}\n\n/**\n * Get last year\n */\nexport function getLastYear(): PresetRange {\n  const today = new Date();\n  const start = new Date(today.getFullYear() - 1, 0, 1);\n  const end = new Date(today.getFullYear() - 1, 11, 31);\n  \n  return {\n    start: formatDate(start),\n    end: formatDate(end)\n  };\n}\n\n/**\n * Get year to date (January 1 to today)\n */\nexport function getYearToDate(): PresetRange {\n  const today = new Date();\n  const start = new Date(today.getFullYear(), 0, 1);\n  \n  return {\n    start: formatDate(start),\n    end: formatDate(today)\n  };\n}\n\n/**\n * Get last N months (including current partial month)\n */\nexport function getLastNMonths(months: number): PresetRange {\n  const today = new Date();\n  const start = new Date(today);\n  start.setMonth(start.getMonth() - months);\n  \n  return {\n    start: formatDate(start),\n    end: formatDate(today)\n  };\n}\n\n/**\n * Get last N years\n */\nexport function getLastNYears(years: number): PresetRange {\n  const today = new Date();\n  const start = new Date(today);\n  start.setFullYear(start.getFullYear() - years);\n  \n  return {\n    start: formatDate(start),\n    end: formatDate(today)\n  };\n}\n\n/**\n * Pre-built preset configurations for common use cases\n * Import and use these directly in your component\n */\nexport const CommonPresets = {\n  /**\n   * Dashboard presets - Perfect for analytics dashboards\n   */\n  dashboard: [\n    { label: 'Today', getValue: getToday },\n    { label: 'Yesterday', getValue: getYesterday },\n    { label: 'Last 7 days', getValue: () => getLastNDays(7) },\n    { label: 'Last 30 days', getValue: () => getLastNDays(30) },\n    { label: 'This month', getValue: getThisMonth },\n    { label: 'Last month', getValue: getLastMonth }\n  ] as PresetConfig[],\n\n  /**\n   * Reporting presets - Perfect for business reporting\n   */\n  reporting: [\n    { label: 'Today', getValue: getToday },\n    { label: 'This week', getValue: getThisWeek },\n    { label: 'Last week', getValue: getLastWeek },\n    { label: 'This month', getValue: getThisMonth },\n    { label: 'Last month', getValue: getLastMonth },\n    { label: 'This quarter', getValue: getThisQuarter },\n    { label: 'Last quarter', getValue: getLastQuarter }\n  ] as PresetConfig[],\n\n  /**\n   * Financial presets - Perfect for ERP and accounting systems\n   */\n  financial: [\n    { label: 'Month to date', getValue: getMonthToDate },\n    { label: 'Quarter to date', getValue: getQuarterToDate },\n    { label: 'Year to date', getValue: getYearToDate },\n    { label: 'Last month', getValue: getLastMonth },\n    { label: 'Last quarter', getValue: getLastQuarter },\n    { label: 'Last year', getValue: getLastYear }\n  ] as PresetConfig[],\n\n  /**\n   * Analytics presets - Perfect for BI and data analysis\n   */\n  analytics: [\n    { label: 'Last 7 days', getValue: () => getLastNDays(7) },\n    { label: 'Last 14 days', getValue: () => getLastNDays(14) },\n    { label: 'Last 30 days', getValue: () => getLastNDays(30) },\n    { label: 'Last 60 days', getValue: () => getLastNDays(60) },\n    { label: 'Last 90 days', getValue: () => getLastNDays(90) },\n    { label: 'Last 180 days', getValue: () => getLastNDays(180) },\n    { label: 'Last 365 days', getValue: () => getLastNDays(365) }\n  ] as PresetConfig[],\n\n  /**\n   * Simple presets - Basic common ranges\n   */\n  simple: [\n    { label: 'Today', getValue: getToday },\n    { label: 'Last 7 days', getValue: () => getLastNDays(7) },\n    { label: 'Last 30 days', getValue: () => getLastNDays(30) },\n    { label: 'This year', getValue: getThisYear }\n  ] as PresetConfig[]\n};\n"]}
|
package/esm2022/public-api.mjs
CHANGED
|
@@ -5,4 +5,6 @@ export { DualDatepickerComponent } from './dual-datepicker.component';
|
|
|
5
5
|
// Date Adapter System
|
|
6
6
|
export { DateAdapter, DATE_ADAPTER } from './date-adapter';
|
|
7
7
|
export { NativeDateAdapter } from './native-date-adapter';
|
|
8
|
-
|
|
8
|
+
// Preset Utilities
|
|
9
|
+
export * from './preset-utils';
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFHdEUsc0JBQXNCO0FBQ3RCLE9BQU8sRUFBRSxXQUFXLEVBQUUsWUFBWSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFFMUQsbUJBQW1CO0FBQ25CLGNBQWMsZ0JBQWdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBAb25lbHVpei9kdWFsLWRhdGVwaWNrZXJcbiAqL1xuXG5leHBvcnQgeyBEdWFsRGF0ZXBpY2tlckNvbXBvbmVudCB9IGZyb20gJy4vZHVhbC1kYXRlcGlja2VyLmNvbXBvbmVudCc7XG5leHBvcnQgdHlwZSB7IERhdGVSYW5nZSwgUHJlc2V0Q29uZmlnLCBQcmVzZXRSYW5nZSwgTG9jYWxlQ29uZmlnIH0gZnJvbSAnLi9kdWFsLWRhdGVwaWNrZXIuY29tcG9uZW50JztcblxuLy8gRGF0ZSBBZGFwdGVyIFN5c3RlbVxuZXhwb3J0IHsgRGF0ZUFkYXB0ZXIsIERBVEVfQURBUFRFUiB9IGZyb20gJy4vZGF0ZS1hZGFwdGVyJztcbmV4cG9ydCB7IE5hdGl2ZURhdGVBZGFwdGVyIH0gZnJvbSAnLi9uYXRpdmUtZGF0ZS1hZGFwdGVyJztcblxuLy8gUHJlc2V0IFV0aWxpdGllc1xuZXhwb3J0ICogZnJvbSAnLi9wcmVzZXQtdXRpbHMnO1xuIl19
|
|
@@ -329,10 +329,27 @@ class DualDatepickerComponent {
|
|
|
329
329
|
return this.locale.dayNamesShort || this.defaultDayNamesShort;
|
|
330
330
|
}
|
|
331
331
|
seleccionarRangoPredefinido(preset) {
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
332
|
+
let start;
|
|
333
|
+
let end;
|
|
334
|
+
// New flexible pattern with getValue()
|
|
335
|
+
if (preset.getValue) {
|
|
336
|
+
const range = preset.getValue();
|
|
337
|
+
start = range.start;
|
|
338
|
+
end = range.end;
|
|
339
|
+
}
|
|
340
|
+
// Backward compatibility with daysAgo pattern
|
|
341
|
+
else if (preset.daysAgo !== undefined) {
|
|
342
|
+
const hoy = this.dateAdapter.today();
|
|
343
|
+
const fechaInicio = this.dateAdapter.addDays(hoy, -preset.daysAgo);
|
|
344
|
+
start = this.formatearFecha(fechaInicio);
|
|
345
|
+
end = this.formatearFecha(hoy);
|
|
346
|
+
}
|
|
347
|
+
else {
|
|
348
|
+
console.error('PresetConfig must have either getValue() or daysAgo');
|
|
349
|
+
return;
|
|
350
|
+
}
|
|
351
|
+
this.fechaInicio = start;
|
|
352
|
+
this.fechaFin = end;
|
|
336
353
|
this.actualizarRangoFechasTexto();
|
|
337
354
|
this.generarCalendarios();
|
|
338
355
|
if (this.closeOnPresetSelection) {
|
|
@@ -462,6 +479,282 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
462
479
|
args: ['document:click', ['$event']]
|
|
463
480
|
}] } });
|
|
464
481
|
|
|
482
|
+
/**
|
|
483
|
+
* Utility functions for creating common date range presets
|
|
484
|
+
* Perfect for dashboards, reporting, POS, BI apps, and ERP systems
|
|
485
|
+
*/
|
|
486
|
+
/**
|
|
487
|
+
* Format a date as YYYY-MM-DD string
|
|
488
|
+
*/
|
|
489
|
+
function formatDate(date) {
|
|
490
|
+
const year = date.getFullYear();
|
|
491
|
+
const month = String(date.getMonth() + 1).padStart(2, '0');
|
|
492
|
+
const day = String(date.getDate()).padStart(2, '0');
|
|
493
|
+
return `${year}-${month}-${day}`;
|
|
494
|
+
}
|
|
495
|
+
/**
|
|
496
|
+
* Get the start of today
|
|
497
|
+
*/
|
|
498
|
+
function getToday() {
|
|
499
|
+
const today = new Date();
|
|
500
|
+
return {
|
|
501
|
+
start: formatDate(today),
|
|
502
|
+
end: formatDate(today)
|
|
503
|
+
};
|
|
504
|
+
}
|
|
505
|
+
/**
|
|
506
|
+
* Get yesterday's date range
|
|
507
|
+
*/
|
|
508
|
+
function getYesterday() {
|
|
509
|
+
const yesterday = new Date();
|
|
510
|
+
yesterday.setDate(yesterday.getDate() - 1);
|
|
511
|
+
return {
|
|
512
|
+
start: formatDate(yesterday),
|
|
513
|
+
end: formatDate(yesterday)
|
|
514
|
+
};
|
|
515
|
+
}
|
|
516
|
+
/**
|
|
517
|
+
* Get last N days (including today)
|
|
518
|
+
*/
|
|
519
|
+
function getLastNDays(days) {
|
|
520
|
+
const end = new Date();
|
|
521
|
+
const start = new Date();
|
|
522
|
+
start.setDate(start.getDate() - days + 1);
|
|
523
|
+
return {
|
|
524
|
+
start: formatDate(start),
|
|
525
|
+
end: formatDate(end)
|
|
526
|
+
};
|
|
527
|
+
}
|
|
528
|
+
/**
|
|
529
|
+
* Get this week (Monday to Sunday)
|
|
530
|
+
*/
|
|
531
|
+
function getThisWeek() {
|
|
532
|
+
const today = new Date();
|
|
533
|
+
const dayOfWeek = today.getDay();
|
|
534
|
+
const start = new Date(today);
|
|
535
|
+
// Adjust to Monday (1) as first day of week
|
|
536
|
+
const daysToMonday = dayOfWeek === 0 ? 6 : dayOfWeek - 1;
|
|
537
|
+
start.setDate(start.getDate() - daysToMonday);
|
|
538
|
+
const end = new Date(start);
|
|
539
|
+
end.setDate(end.getDate() + 6);
|
|
540
|
+
return {
|
|
541
|
+
start: formatDate(start),
|
|
542
|
+
end: formatDate(end)
|
|
543
|
+
};
|
|
544
|
+
}
|
|
545
|
+
/**
|
|
546
|
+
* Get last week (Monday to Sunday)
|
|
547
|
+
*/
|
|
548
|
+
function getLastWeek() {
|
|
549
|
+
const today = new Date();
|
|
550
|
+
const dayOfWeek = today.getDay();
|
|
551
|
+
const daysToMonday = dayOfWeek === 0 ? 6 : dayOfWeek - 1;
|
|
552
|
+
const lastMonday = new Date(today);
|
|
553
|
+
lastMonday.setDate(lastMonday.getDate() - daysToMonday - 7);
|
|
554
|
+
const lastSunday = new Date(lastMonday);
|
|
555
|
+
lastSunday.setDate(lastSunday.getDate() + 6);
|
|
556
|
+
return {
|
|
557
|
+
start: formatDate(lastMonday),
|
|
558
|
+
end: formatDate(lastSunday)
|
|
559
|
+
};
|
|
560
|
+
}
|
|
561
|
+
/**
|
|
562
|
+
* Get this month (1st to last day)
|
|
563
|
+
*/
|
|
564
|
+
function getThisMonth() {
|
|
565
|
+
const today = new Date();
|
|
566
|
+
const start = new Date(today.getFullYear(), today.getMonth(), 1);
|
|
567
|
+
const end = new Date(today.getFullYear(), today.getMonth() + 1, 0);
|
|
568
|
+
return {
|
|
569
|
+
start: formatDate(start),
|
|
570
|
+
end: formatDate(end)
|
|
571
|
+
};
|
|
572
|
+
}
|
|
573
|
+
/**
|
|
574
|
+
* Get last month (1st to last day)
|
|
575
|
+
*/
|
|
576
|
+
function getLastMonth() {
|
|
577
|
+
const today = new Date();
|
|
578
|
+
const start = new Date(today.getFullYear(), today.getMonth() - 1, 1);
|
|
579
|
+
const end = new Date(today.getFullYear(), today.getMonth(), 0);
|
|
580
|
+
return {
|
|
581
|
+
start: formatDate(start),
|
|
582
|
+
end: formatDate(end)
|
|
583
|
+
};
|
|
584
|
+
}
|
|
585
|
+
/**
|
|
586
|
+
* Get month to date (1st of current month to today)
|
|
587
|
+
*/
|
|
588
|
+
function getMonthToDate() {
|
|
589
|
+
const today = new Date();
|
|
590
|
+
const start = new Date(today.getFullYear(), today.getMonth(), 1);
|
|
591
|
+
return {
|
|
592
|
+
start: formatDate(start),
|
|
593
|
+
end: formatDate(today)
|
|
594
|
+
};
|
|
595
|
+
}
|
|
596
|
+
/**
|
|
597
|
+
* Get this quarter (Q1, Q2, Q3, or Q4)
|
|
598
|
+
*/
|
|
599
|
+
function getThisQuarter() {
|
|
600
|
+
const today = new Date();
|
|
601
|
+
const currentMonth = today.getMonth();
|
|
602
|
+
const quarterStartMonth = Math.floor(currentMonth / 3) * 3;
|
|
603
|
+
const start = new Date(today.getFullYear(), quarterStartMonth, 1);
|
|
604
|
+
const end = new Date(today.getFullYear(), quarterStartMonth + 3, 0);
|
|
605
|
+
return {
|
|
606
|
+
start: formatDate(start),
|
|
607
|
+
end: formatDate(end)
|
|
608
|
+
};
|
|
609
|
+
}
|
|
610
|
+
/**
|
|
611
|
+
* Get last quarter
|
|
612
|
+
*/
|
|
613
|
+
function getLastQuarter() {
|
|
614
|
+
const today = new Date();
|
|
615
|
+
const currentMonth = today.getMonth();
|
|
616
|
+
const lastQuarterStartMonth = Math.floor(currentMonth / 3) * 3 - 3;
|
|
617
|
+
const start = new Date(today.getFullYear(), lastQuarterStartMonth, 1);
|
|
618
|
+
const end = new Date(today.getFullYear(), lastQuarterStartMonth + 3, 0);
|
|
619
|
+
return {
|
|
620
|
+
start: formatDate(start),
|
|
621
|
+
end: formatDate(end)
|
|
622
|
+
};
|
|
623
|
+
}
|
|
624
|
+
/**
|
|
625
|
+
* Get quarter to date (start of current quarter to today)
|
|
626
|
+
*/
|
|
627
|
+
function getQuarterToDate() {
|
|
628
|
+
const today = new Date();
|
|
629
|
+
const currentMonth = today.getMonth();
|
|
630
|
+
const quarterStartMonth = Math.floor(currentMonth / 3) * 3;
|
|
631
|
+
const start = new Date(today.getFullYear(), quarterStartMonth, 1);
|
|
632
|
+
return {
|
|
633
|
+
start: formatDate(start),
|
|
634
|
+
end: formatDate(today)
|
|
635
|
+
};
|
|
636
|
+
}
|
|
637
|
+
/**
|
|
638
|
+
* Get this year (January 1 to December 31)
|
|
639
|
+
*/
|
|
640
|
+
function getThisYear() {
|
|
641
|
+
const today = new Date();
|
|
642
|
+
const start = new Date(today.getFullYear(), 0, 1);
|
|
643
|
+
const end = new Date(today.getFullYear(), 11, 31);
|
|
644
|
+
return {
|
|
645
|
+
start: formatDate(start),
|
|
646
|
+
end: formatDate(end)
|
|
647
|
+
};
|
|
648
|
+
}
|
|
649
|
+
/**
|
|
650
|
+
* Get last year
|
|
651
|
+
*/
|
|
652
|
+
function getLastYear() {
|
|
653
|
+
const today = new Date();
|
|
654
|
+
const start = new Date(today.getFullYear() - 1, 0, 1);
|
|
655
|
+
const end = new Date(today.getFullYear() - 1, 11, 31);
|
|
656
|
+
return {
|
|
657
|
+
start: formatDate(start),
|
|
658
|
+
end: formatDate(end)
|
|
659
|
+
};
|
|
660
|
+
}
|
|
661
|
+
/**
|
|
662
|
+
* Get year to date (January 1 to today)
|
|
663
|
+
*/
|
|
664
|
+
function getYearToDate() {
|
|
665
|
+
const today = new Date();
|
|
666
|
+
const start = new Date(today.getFullYear(), 0, 1);
|
|
667
|
+
return {
|
|
668
|
+
start: formatDate(start),
|
|
669
|
+
end: formatDate(today)
|
|
670
|
+
};
|
|
671
|
+
}
|
|
672
|
+
/**
|
|
673
|
+
* Get last N months (including current partial month)
|
|
674
|
+
*/
|
|
675
|
+
function getLastNMonths(months) {
|
|
676
|
+
const today = new Date();
|
|
677
|
+
const start = new Date(today);
|
|
678
|
+
start.setMonth(start.getMonth() - months);
|
|
679
|
+
return {
|
|
680
|
+
start: formatDate(start),
|
|
681
|
+
end: formatDate(today)
|
|
682
|
+
};
|
|
683
|
+
}
|
|
684
|
+
/**
|
|
685
|
+
* Get last N years
|
|
686
|
+
*/
|
|
687
|
+
function getLastNYears(years) {
|
|
688
|
+
const today = new Date();
|
|
689
|
+
const start = new Date(today);
|
|
690
|
+
start.setFullYear(start.getFullYear() - years);
|
|
691
|
+
return {
|
|
692
|
+
start: formatDate(start),
|
|
693
|
+
end: formatDate(today)
|
|
694
|
+
};
|
|
695
|
+
}
|
|
696
|
+
/**
|
|
697
|
+
* Pre-built preset configurations for common use cases
|
|
698
|
+
* Import and use these directly in your component
|
|
699
|
+
*/
|
|
700
|
+
const CommonPresets = {
|
|
701
|
+
/**
|
|
702
|
+
* Dashboard presets - Perfect for analytics dashboards
|
|
703
|
+
*/
|
|
704
|
+
dashboard: [
|
|
705
|
+
{ label: 'Today', getValue: getToday },
|
|
706
|
+
{ label: 'Yesterday', getValue: getYesterday },
|
|
707
|
+
{ label: 'Last 7 days', getValue: () => getLastNDays(7) },
|
|
708
|
+
{ label: 'Last 30 days', getValue: () => getLastNDays(30) },
|
|
709
|
+
{ label: 'This month', getValue: getThisMonth },
|
|
710
|
+
{ label: 'Last month', getValue: getLastMonth }
|
|
711
|
+
],
|
|
712
|
+
/**
|
|
713
|
+
* Reporting presets - Perfect for business reporting
|
|
714
|
+
*/
|
|
715
|
+
reporting: [
|
|
716
|
+
{ label: 'Today', getValue: getToday },
|
|
717
|
+
{ label: 'This week', getValue: getThisWeek },
|
|
718
|
+
{ label: 'Last week', getValue: getLastWeek },
|
|
719
|
+
{ label: 'This month', getValue: getThisMonth },
|
|
720
|
+
{ label: 'Last month', getValue: getLastMonth },
|
|
721
|
+
{ label: 'This quarter', getValue: getThisQuarter },
|
|
722
|
+
{ label: 'Last quarter', getValue: getLastQuarter }
|
|
723
|
+
],
|
|
724
|
+
/**
|
|
725
|
+
* Financial presets - Perfect for ERP and accounting systems
|
|
726
|
+
*/
|
|
727
|
+
financial: [
|
|
728
|
+
{ label: 'Month to date', getValue: getMonthToDate },
|
|
729
|
+
{ label: 'Quarter to date', getValue: getQuarterToDate },
|
|
730
|
+
{ label: 'Year to date', getValue: getYearToDate },
|
|
731
|
+
{ label: 'Last month', getValue: getLastMonth },
|
|
732
|
+
{ label: 'Last quarter', getValue: getLastQuarter },
|
|
733
|
+
{ label: 'Last year', getValue: getLastYear }
|
|
734
|
+
],
|
|
735
|
+
/**
|
|
736
|
+
* Analytics presets - Perfect for BI and data analysis
|
|
737
|
+
*/
|
|
738
|
+
analytics: [
|
|
739
|
+
{ label: 'Last 7 days', getValue: () => getLastNDays(7) },
|
|
740
|
+
{ label: 'Last 14 days', getValue: () => getLastNDays(14) },
|
|
741
|
+
{ label: 'Last 30 days', getValue: () => getLastNDays(30) },
|
|
742
|
+
{ label: 'Last 60 days', getValue: () => getLastNDays(60) },
|
|
743
|
+
{ label: 'Last 90 days', getValue: () => getLastNDays(90) },
|
|
744
|
+
{ label: 'Last 180 days', getValue: () => getLastNDays(180) },
|
|
745
|
+
{ label: 'Last 365 days', getValue: () => getLastNDays(365) }
|
|
746
|
+
],
|
|
747
|
+
/**
|
|
748
|
+
* Simple presets - Basic common ranges
|
|
749
|
+
*/
|
|
750
|
+
simple: [
|
|
751
|
+
{ label: 'Today', getValue: getToday },
|
|
752
|
+
{ label: 'Last 7 days', getValue: () => getLastNDays(7) },
|
|
753
|
+
{ label: 'Last 30 days', getValue: () => getLastNDays(30) },
|
|
754
|
+
{ label: 'This year', getValue: getThisYear }
|
|
755
|
+
]
|
|
756
|
+
};
|
|
757
|
+
|
|
465
758
|
/**
|
|
466
759
|
* Public API Surface of @oneluiz/dual-datepicker
|
|
467
760
|
*/
|
|
@@ -470,5 +763,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
470
763
|
* Generated bundle index. Do not edit.
|
|
471
764
|
*/
|
|
472
765
|
|
|
473
|
-
export { DATE_ADAPTER, DateAdapter, DualDatepickerComponent, NativeDateAdapter };
|
|
766
|
+
export { CommonPresets, DATE_ADAPTER, DateAdapter, DualDatepickerComponent, NativeDateAdapter, getLastMonth, getLastNDays, getLastNMonths, getLastNYears, getLastQuarter, getLastWeek, getLastYear, getMonthToDate, getQuarterToDate, getThisMonth, getThisQuarter, getThisWeek, getThisYear, getToday, getYearToDate, getYesterday };
|
|
474
767
|
//# sourceMappingURL=oneluiz-dual-datepicker.mjs.map
|