@redvars/peacock 3.5.1 → 3.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/dist/{BaseButton-DuASuVth.js → BaseButton-BNFAYn-S.js} +2 -2
- package/dist/{BaseButton-DuASuVth.js.map → BaseButton-BNFAYn-S.js.map} +1 -1
- package/dist/BaseInput-14YmcfK7.js +27 -0
- package/dist/BaseInput-14YmcfK7.js.map +1 -0
- package/dist/banner.js +2 -3
- package/dist/banner.js.map +1 -1
- package/dist/{button-DouvOfEU.js → button-colors-Ccys3hvS.js} +5 -294
- package/dist/button-colors-Ccys3hvS.js.map +1 -0
- package/dist/button-group.js +226 -6
- package/dist/button-group.js.map +1 -1
- package/dist/button.js +294 -8
- package/dist/button.js.map +1 -1
- package/dist/calendar-column-view.js +634 -0
- package/dist/calendar-column-view.js.map +1 -0
- package/dist/calendar-event-BrQ_SEKD.js +199 -0
- package/dist/calendar-event-BrQ_SEKD.js.map +1 -0
- package/dist/calendar-month-view.js +376 -0
- package/dist/calendar-month-view.js.map +1 -0
- package/dist/calendar.js +339 -0
- package/dist/calendar.js.map +1 -0
- package/dist/canvas.js +361 -0
- package/dist/canvas.js.map +1 -0
- package/dist/cb-compound-expression.js +125 -0
- package/dist/cb-compound-expression.js.map +1 -0
- package/dist/cb-divider.js +150 -0
- package/dist/cb-divider.js.map +1 -0
- package/dist/cb-expression.js +75 -0
- package/dist/cb-expression.js.map +1 -0
- package/dist/cb-predicate.js +137 -0
- package/dist/cb-predicate.js.map +1 -0
- package/dist/code-editor.js +2 -1
- package/dist/code-editor.js.map +1 -1
- package/dist/condition-builder.js +58 -0
- package/dist/condition-builder.js.map +1 -0
- package/dist/custom-elements-jsdocs.json +7976 -4294
- package/dist/custom-elements.json +14358 -7589
- package/dist/dropdown-button.js +216 -0
- package/dist/dropdown-button.js.map +1 -0
- package/dist/event-manager-D-QCmUgR.js +113 -0
- package/dist/event-manager-D-QCmUgR.js.map +1 -0
- package/dist/fab.js +1 -1
- package/dist/flow-designer-dZnLJOQT.js +1656 -0
- package/dist/flow-designer-dZnLJOQT.js.map +1 -0
- package/dist/flow-designer-node-XMe-jlKg.js +548 -0
- package/dist/flow-designer-node-XMe-jlKg.js.map +1 -0
- package/dist/flow-designer-node.js +4 -0
- package/dist/flow-designer-node.js.map +1 -0
- package/dist/flow-designer.js +16 -0
- package/dist/flow-designer.js.map +1 -0
- package/dist/html-editor.js +358 -0
- package/dist/html-editor.js.map +1 -0
- package/dist/icon-button-CK1ZuE-2.js +247 -0
- package/dist/icon-button-CK1ZuE-2.js.map +1 -0
- package/dist/index.js +29 -6
- package/dist/index.js.map +1 -1
- package/dist/{is-dark-mode-DicqGkCJ.js → is-dark-mode-DOcaw4Yq.js} +2 -27
- package/dist/is-dark-mode-DOcaw4Yq.js.map +1 -0
- package/dist/modal.js +418 -0
- package/dist/modal.js.map +1 -0
- package/dist/{navigation-rail-Lxetd5-Z.js → navigation-rail-DyO0oAZU.js} +306 -2197
- package/dist/navigation-rail-DyO0oAZU.js.map +1 -0
- package/dist/notification-manager.js +268 -0
- package/dist/notification-manager.js.map +1 -0
- package/dist/peacock-loader.js +84 -8
- package/dist/peacock-loader.js.map +1 -1
- package/dist/popover-NC7b1lTq.js +1971 -0
- package/dist/popover-NC7b1lTq.js.map +1 -0
- package/dist/popover-content.js +125 -0
- package/dist/popover-content.js.map +1 -0
- package/dist/popover.js +4 -0
- package/dist/popover.js.map +1 -0
- package/dist/split-button.js +388 -0
- package/dist/split-button.js.map +1 -0
- package/dist/src/__controllers/floating-controller.d.ts +35 -0
- package/dist/src/calendar/base-event.d.ts +10 -0
- package/dist/src/calendar/calendar-column-view.d.ts +41 -0
- package/dist/src/calendar/calendar-event.d.ts +7 -0
- package/dist/src/calendar/calendar-month-view.d.ts +31 -0
- package/dist/src/calendar/calendar.d.ts +65 -0
- package/dist/src/calendar/event-manager.d.ts +17 -0
- package/dist/src/calendar/index.d.ts +4 -0
- package/dist/src/calendar/types.d.ts +13 -0
- package/dist/src/calendar/utils.d.ts +31 -0
- package/dist/src/canvas/canvas.d.ts +92 -0
- package/dist/src/canvas/index.d.ts +2 -0
- package/dist/src/condition-builder/cb-compound-expression.d.ts +31 -0
- package/dist/src/condition-builder/cb-divider.d.ts +26 -0
- package/dist/src/condition-builder/cb-expression.d.ts +31 -0
- package/dist/src/condition-builder/cb-predicate.d.ts +30 -0
- package/dist/src/condition-builder/condition-builder.d.ts +27 -0
- package/dist/src/condition-builder/index.d.ts +5 -0
- package/dist/src/dropdown-button/dropdown-button.d.ts +68 -0
- package/dist/src/dropdown-button/index.d.ts +1 -0
- package/dist/src/flow-designer/commands.d.ts +66 -0
- package/dist/src/flow-designer/flow-designer-node.d.ts +46 -0
- package/dist/src/flow-designer/flow-designer.d.ts +133 -0
- package/dist/src/flow-designer/index.d.ts +7 -0
- package/dist/src/flow-designer/layout.d.ts +30 -0
- package/dist/src/flow-designer/types.d.ts +142 -0
- package/dist/src/flow-designer/validation.d.ts +43 -0
- package/dist/src/flow-designer/workflow-utils.d.ts +40 -0
- package/dist/src/html-editor/html-editor.d.ts +56 -0
- package/dist/src/html-editor/index.d.ts +2 -0
- package/dist/src/index.d.ts +13 -0
- package/dist/src/menu/menu/menu.d.ts +5 -7
- package/dist/src/menu/menu-item/menu-item.d.ts +14 -13
- package/dist/src/modal/index.d.ts +1 -0
- package/dist/src/modal/modal.d.ts +63 -0
- package/dist/src/notification-manager/index.d.ts +1 -0
- package/dist/src/notification-manager/notification-manager.d.ts +44 -0
- package/dist/src/popover/index.d.ts +2 -0
- package/dist/src/popover/popover-content.d.ts +29 -0
- package/dist/src/popover/popover.d.ts +62 -0
- package/dist/src/split-button/index.d.ts +1 -0
- package/dist/src/split-button/split-button.d.ts +72 -0
- package/dist/src/tooltip/tooltip.d.ts +2 -15
- package/dist/test/flow-designer.test.d.ts +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +4 -2
- package/readme.md +2 -2
- package/src/__controllers/floating-controller.ts +237 -0
- package/src/banner/banner.scss +2 -3
- package/src/button/button/button.ts +1 -0
- package/src/calendar/base-event.ts +49 -0
- package/src/calendar/calendar-column-view.scss +326 -0
- package/src/calendar/calendar-column-view.ts +392 -0
- package/src/calendar/calendar-event.ts +20 -0
- package/src/calendar/calendar-month-view.scss +192 -0
- package/src/calendar/calendar-month-view.ts +244 -0
- package/src/calendar/calendar.scss +71 -0
- package/src/calendar/calendar.ts +298 -0
- package/src/calendar/event-manager.ts +117 -0
- package/src/calendar/index.ts +4 -0
- package/src/calendar/types.ts +14 -0
- package/src/calendar/utils.ts +180 -0
- package/src/canvas/canvas.scss +60 -0
- package/src/canvas/canvas.ts +391 -0
- package/src/canvas/index.ts +2 -0
- package/src/condition-builder/cb-compound-expression.scss +37 -0
- package/src/condition-builder/cb-compound-expression.ts +80 -0
- package/src/condition-builder/cb-divider.scss +93 -0
- package/src/condition-builder/cb-divider.ts +56 -0
- package/src/condition-builder/cb-expression.scss +14 -0
- package/src/condition-builder/cb-expression.ts +49 -0
- package/src/condition-builder/cb-predicate.scss +35 -0
- package/src/condition-builder/cb-predicate.ts +102 -0
- package/src/condition-builder/condition-builder.scss +13 -0
- package/src/condition-builder/condition-builder.ts +38 -0
- package/src/condition-builder/index.ts +5 -0
- package/src/dropdown-button/demo/index.html +110 -0
- package/src/dropdown-button/dropdown-button.scss +22 -0
- package/src/dropdown-button/dropdown-button.ts +206 -0
- package/src/dropdown-button/index.ts +1 -0
- package/src/flow-designer/DEMO.md +239 -0
- package/src/flow-designer/commands.ts +278 -0
- package/src/flow-designer/flow-designer-node.ts +172 -0
- package/src/flow-designer/flow-designer.scss +457 -0
- package/src/flow-designer/flow-designer.ts +611 -0
- package/src/flow-designer/index.ts +41 -0
- package/src/flow-designer/layout.ts +357 -0
- package/src/flow-designer/types.ts +166 -0
- package/src/flow-designer/validation.ts +284 -0
- package/src/flow-designer/workflow-utils.ts +282 -0
- package/src/html-editor/html-editor.scss +146 -0
- package/src/html-editor/html-editor.ts +276 -0
- package/src/html-editor/index.ts +3 -0
- package/src/index.ts +25 -0
- package/src/menu/menu/menu.scss +2 -2
- package/src/menu/menu/menu.ts +91 -101
- package/src/menu/menu-item/menu-item.scss +4 -0
- package/src/menu/menu-item/menu-item.ts +82 -78
- package/src/modal/index.ts +1 -0
- package/src/modal/modal.scss +206 -0
- package/src/modal/modal.ts +201 -0
- package/src/notification-manager/index.ts +1 -0
- package/src/notification-manager/notification-manager.scss +113 -0
- package/src/notification-manager/notification-manager.ts +199 -0
- package/src/peacock-loader.ts +71 -0
- package/src/popover/index.ts +2 -0
- package/src/popover/popover-content.scss +69 -0
- package/src/popover/popover-content.ts +51 -0
- package/src/popover/popover.scss +7 -0
- package/src/popover/popover.ts +170 -0
- package/src/split-button/index.ts +1 -0
- package/src/split-button/split-button-colors.scss +56 -0
- package/src/split-button/split-button-sizes.scss +28 -0
- package/src/split-button/split-button.scss +79 -0
- package/src/split-button/split-button.ts +236 -0
- package/src/table/table.ts +2 -2
- package/src/tooltip/tooltip.scss +4 -3
- package/src/tooltip/tooltip.ts +46 -104
- package/dist/button-DouvOfEU.js.map +0 -1
- package/dist/button-group-CEdMwvJJ.js +0 -464
- package/dist/button-group-CEdMwvJJ.js.map +0 -1
- package/dist/is-dark-mode-DicqGkCJ.js.map +0 -1
- package/dist/navigation-rail-Lxetd5-Z.js.map +0 -1
- package/dist/src/menu/menu/MenuSurfaceController.d.ts +0 -18
- package/src/menu/menu/MenuSurfaceController.ts +0 -61
|
@@ -0,0 +1,199 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Pure date utility functions (no external dependencies).
|
|
3
|
+
*/
|
|
4
|
+
function startOfDay(date) {
|
|
5
|
+
const d = new Date(date);
|
|
6
|
+
d.setHours(0, 0, 0, 0);
|
|
7
|
+
return d;
|
|
8
|
+
}
|
|
9
|
+
function endOfDay(date) {
|
|
10
|
+
const d = new Date(date);
|
|
11
|
+
d.setHours(23, 59, 59, 999);
|
|
12
|
+
return d;
|
|
13
|
+
}
|
|
14
|
+
function addDays(date, days) {
|
|
15
|
+
const d = new Date(date);
|
|
16
|
+
d.setDate(d.getDate() + days);
|
|
17
|
+
return d;
|
|
18
|
+
}
|
|
19
|
+
function addMonths(date, months) {
|
|
20
|
+
const d = new Date(date);
|
|
21
|
+
d.setMonth(d.getMonth() + months);
|
|
22
|
+
return d;
|
|
23
|
+
}
|
|
24
|
+
function addHours(date, hours) {
|
|
25
|
+
const d = new Date(date);
|
|
26
|
+
d.setHours(d.getHours() + hours);
|
|
27
|
+
return d;
|
|
28
|
+
}
|
|
29
|
+
function differenceInDays(dateA, dateB) {
|
|
30
|
+
const a = startOfDay(dateA);
|
|
31
|
+
const b = startOfDay(dateB);
|
|
32
|
+
return Math.round((a.valueOf() - b.valueOf()) / 86400000);
|
|
33
|
+
}
|
|
34
|
+
function startOfWeek(date, weekStartsOn = 1) {
|
|
35
|
+
const d = startOfDay(date);
|
|
36
|
+
const day = d.getDay();
|
|
37
|
+
const diff = (day < weekStartsOn ? 7 : 0) + day - weekStartsOn;
|
|
38
|
+
d.setDate(d.getDate() - diff);
|
|
39
|
+
return d;
|
|
40
|
+
}
|
|
41
|
+
function endOfWeek(date, weekStartsOn = 1) {
|
|
42
|
+
const d = startOfWeek(date, weekStartsOn);
|
|
43
|
+
d.setDate(d.getDate() + 6);
|
|
44
|
+
return endOfDay(d);
|
|
45
|
+
}
|
|
46
|
+
function startOfMonth(date) {
|
|
47
|
+
const d = new Date(date);
|
|
48
|
+
d.setDate(1);
|
|
49
|
+
d.setHours(0, 0, 0, 0);
|
|
50
|
+
return d;
|
|
51
|
+
}
|
|
52
|
+
function endOfMonth(date) {
|
|
53
|
+
const d = new Date(date);
|
|
54
|
+
d.setMonth(d.getMonth() + 1, 0);
|
|
55
|
+
d.setHours(23, 59, 59, 999);
|
|
56
|
+
return d;
|
|
57
|
+
}
|
|
58
|
+
function calculateMonthRange(date, weekStartsOn = 1) {
|
|
59
|
+
const sd = startOfWeek(startOfMonth(date), weekStartsOn);
|
|
60
|
+
const ed = endOfWeek(endOfMonth(date), weekStartsOn);
|
|
61
|
+
return { startDate: sd, endDate: ed, totalDays: 42 };
|
|
62
|
+
}
|
|
63
|
+
function calculateWeekRange(date, weekStartsOn = 1) {
|
|
64
|
+
const sd = startOfWeek(date, weekStartsOn);
|
|
65
|
+
const ed = endOfWeek(date, weekStartsOn);
|
|
66
|
+
return { startDate: sd, endDate: ed, totalDays: 7 };
|
|
67
|
+
}
|
|
68
|
+
function calculateDateRange(view, contextDate, days) {
|
|
69
|
+
if (view === 'week') {
|
|
70
|
+
return calculateWeekRange(contextDate, 1);
|
|
71
|
+
}
|
|
72
|
+
return {
|
|
73
|
+
startDate: startOfDay(contextDate),
|
|
74
|
+
endDate: endOfDay(addDays(contextDate, days - 1)),
|
|
75
|
+
totalDays: days,
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
const LONG_EVENT_PADDING = 0.25;
|
|
79
|
+
const DAY_NAMES_SHORT = ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'];
|
|
80
|
+
const DAY_NAMES_LONG = [
|
|
81
|
+
'Sunday',
|
|
82
|
+
'Monday',
|
|
83
|
+
'Tuesday',
|
|
84
|
+
'Wednesday',
|
|
85
|
+
'Thursday',
|
|
86
|
+
'Friday',
|
|
87
|
+
'Saturday',
|
|
88
|
+
];
|
|
89
|
+
const MONTH_NAMES = [
|
|
90
|
+
'January',
|
|
91
|
+
'February',
|
|
92
|
+
'March',
|
|
93
|
+
'April',
|
|
94
|
+
'May',
|
|
95
|
+
'June',
|
|
96
|
+
'July',
|
|
97
|
+
'August',
|
|
98
|
+
'September',
|
|
99
|
+
'October',
|
|
100
|
+
'November',
|
|
101
|
+
'December',
|
|
102
|
+
];
|
|
103
|
+
function formatDate(date, pattern) {
|
|
104
|
+
const day = date.getDate();
|
|
105
|
+
const dayOfWeek = date.getDay();
|
|
106
|
+
const month = date.getMonth();
|
|
107
|
+
const year = date.getFullYear();
|
|
108
|
+
const hours = date.getHours();
|
|
109
|
+
const minutes = date.getMinutes();
|
|
110
|
+
switch (pattern) {
|
|
111
|
+
case 'MMMM d, yyyy':
|
|
112
|
+
return `${MONTH_NAMES[month]} ${day}, ${year}`;
|
|
113
|
+
case 'EEEE':
|
|
114
|
+
return DAY_NAMES_LONG[dayOfWeek];
|
|
115
|
+
case 'E':
|
|
116
|
+
return DAY_NAMES_SHORT[dayOfWeek];
|
|
117
|
+
case 'd':
|
|
118
|
+
return `${day}`;
|
|
119
|
+
case 'dd':
|
|
120
|
+
return day < 10 ? `0${day}` : `${day}`;
|
|
121
|
+
case 'hh a': {
|
|
122
|
+
const h = hours % 12 || 12;
|
|
123
|
+
const ampm = hours < 12 ? 'AM' : 'PM';
|
|
124
|
+
return `${h < 10 ? '0' : ''}${h} ${ampm}`;
|
|
125
|
+
}
|
|
126
|
+
case 'hh:mm a': {
|
|
127
|
+
const h = hours % 12 || 12;
|
|
128
|
+
const ampm = hours < 12 ? 'AM' : 'PM';
|
|
129
|
+
return `${h < 10 ? '0' : ''}${h}:${minutes < 10 ? '0' : ''}${minutes} ${ampm}`;
|
|
130
|
+
}
|
|
131
|
+
case 'dd-MM-yyyy':
|
|
132
|
+
return `${day < 10 ? '0' : ''}${day}-${month + 1 < 10 ? '0' : ''}${month + 1}-${year}`;
|
|
133
|
+
default:
|
|
134
|
+
return date.toLocaleDateString();
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
function getTimePercent(date, forDay) {
|
|
138
|
+
const day = forDay || date;
|
|
139
|
+
const sd = startOfDay(day);
|
|
140
|
+
const ed = endOfDay(day);
|
|
141
|
+
const percent = ((date.valueOf() - sd.valueOf()) / (ed.valueOf() - sd.valueOf())) * 100;
|
|
142
|
+
if (percent < 0)
|
|
143
|
+
return 0;
|
|
144
|
+
if (percent > 100)
|
|
145
|
+
return 100;
|
|
146
|
+
return percent;
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
class BaseEvent {
|
|
150
|
+
constructor(start, end) {
|
|
151
|
+
this.gid = crypto.randomUUID();
|
|
152
|
+
this.start = start;
|
|
153
|
+
this.end = end;
|
|
154
|
+
}
|
|
155
|
+
length() {
|
|
156
|
+
return this.end.valueOf() - this.start.valueOf();
|
|
157
|
+
}
|
|
158
|
+
isOverlapping(event) {
|
|
159
|
+
let totalLength;
|
|
160
|
+
if (this.start.valueOf() <= event.start.valueOf()) {
|
|
161
|
+
totalLength = event.end.valueOf() - this.start.valueOf();
|
|
162
|
+
}
|
|
163
|
+
else {
|
|
164
|
+
totalLength = this.end.valueOf() - event.start.valueOf();
|
|
165
|
+
}
|
|
166
|
+
return this.length() + event.length() >= totalLength;
|
|
167
|
+
}
|
|
168
|
+
isOverlappingWithoutTime(event) {
|
|
169
|
+
const thisStartDay = startOfDay(this.start);
|
|
170
|
+
const eventStartDay = startOfDay(event.start);
|
|
171
|
+
const thisEndDay = endOfDay(this.end);
|
|
172
|
+
const eventEndDay = endOfDay(event.end);
|
|
173
|
+
let totalLength;
|
|
174
|
+
if (thisStartDay.valueOf() <= eventStartDay.valueOf()) {
|
|
175
|
+
totalLength = eventEndDay.valueOf() - thisStartDay.valueOf();
|
|
176
|
+
}
|
|
177
|
+
else {
|
|
178
|
+
totalLength = thisEndDay.valueOf() - eventStartDay.valueOf();
|
|
179
|
+
}
|
|
180
|
+
return this.length() + event.length() >= totalLength;
|
|
181
|
+
}
|
|
182
|
+
isOverlappingWithDate(date) {
|
|
183
|
+
return (this.start.valueOf() <= date.valueOf() &&
|
|
184
|
+
this.end.valueOf() >= date.valueOf());
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
class CalendarEvent extends BaseEvent {
|
|
189
|
+
constructor(start, end, title, color, data) {
|
|
190
|
+
super(start, end);
|
|
191
|
+
this.data = data;
|
|
192
|
+
if (color)
|
|
193
|
+
this.color = color;
|
|
194
|
+
this.title = title;
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
export { BaseEvent as B, CalendarEvent as C, LONG_EVENT_PADDING as L, addDays as a, addMonths as b, calculateDateRange as c, differenceInDays as d, endOfDay as e, formatDate as f, getTimePercent as g, addHours as h, calculateMonthRange as i, startOfDay as s };
|
|
199
|
+
//# sourceMappingURL=calendar-event-BrQ_SEKD.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"calendar-event-BrQ_SEKD.js","sources":["../../src/calendar/utils.ts","../../src/calendar/base-event.ts","../../src/calendar/calendar-event.ts"],"sourcesContent":["/**\n * Pure date utility functions (no external dependencies).\n */\n\nexport function startOfDay(date: Date): Date {\n const d = new Date(date);\n d.setHours(0, 0, 0, 0);\n return d;\n}\n\nexport function endOfDay(date: Date): Date {\n const d = new Date(date);\n d.setHours(23, 59, 59, 999);\n return d;\n}\n\nexport function addDays(date: Date, days: number): Date {\n const d = new Date(date);\n d.setDate(d.getDate() + days);\n return d;\n}\n\nexport function addMonths(date: Date, months: number): Date {\n const d = new Date(date);\n d.setMonth(d.getMonth() + months);\n return d;\n}\n\nexport function addHours(date: Date, hours: number): Date {\n const d = new Date(date);\n d.setHours(d.getHours() + hours);\n return d;\n}\n\nexport function differenceInDays(dateA: Date, dateB: Date): number {\n const a = startOfDay(dateA);\n const b = startOfDay(dateB);\n return Math.round((a.valueOf() - b.valueOf()) / 86400000);\n}\n\nexport function startOfWeek(\n date: Date,\n weekStartsOn: 0 | 1 | 2 | 3 | 4 | 5 | 6 = 1,\n): Date {\n const d = startOfDay(date);\n const day = d.getDay();\n const diff = (day < weekStartsOn ? 7 : 0) + day - weekStartsOn;\n d.setDate(d.getDate() - diff);\n return d;\n}\n\nexport function endOfWeek(\n date: Date,\n weekStartsOn: 0 | 1 | 2 | 3 | 4 | 5 | 6 = 1,\n): Date {\n const d = startOfWeek(date, weekStartsOn);\n d.setDate(d.getDate() + 6);\n return endOfDay(d);\n}\n\nexport function startOfMonth(date: Date): Date {\n const d = new Date(date);\n d.setDate(1);\n d.setHours(0, 0, 0, 0);\n return d;\n}\n\nexport function endOfMonth(date: Date): Date {\n const d = new Date(date);\n d.setMonth(d.getMonth() + 1, 0);\n d.setHours(23, 59, 59, 999);\n return d;\n}\n\nexport function calculateMonthRange(\n date: Date,\n weekStartsOn: 0 | 1 | 2 | 3 | 4 | 5 | 6 = 1,\n) {\n const sd = startOfWeek(startOfMonth(date), weekStartsOn);\n const ed = endOfWeek(endOfMonth(date), weekStartsOn);\n return { startDate: sd, endDate: ed, totalDays: 42 };\n}\n\nexport function calculateWeekRange(\n date: Date,\n weekStartsOn: 0 | 1 | 2 | 3 | 4 | 5 | 6 = 1,\n) {\n const sd = startOfWeek(date, weekStartsOn);\n const ed = endOfWeek(date, weekStartsOn);\n return { startDate: sd, endDate: ed, totalDays: 7 };\n}\n\nexport function calculateDateRange(\n view: string,\n contextDate: Date,\n days: number,\n) {\n if (view === 'week') {\n return calculateWeekRange(contextDate, 1);\n }\n return {\n startDate: startOfDay(contextDate),\n endDate: endOfDay(addDays(contextDate, days - 1)),\n totalDays: days,\n };\n}\n\nexport const LONG_EVENT_PADDING = 0.25;\n\nconst DAY_NAMES_SHORT = ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'];\nconst DAY_NAMES_LONG = [\n 'Sunday',\n 'Monday',\n 'Tuesday',\n 'Wednesday',\n 'Thursday',\n 'Friday',\n 'Saturday',\n];\nconst MONTH_NAMES = [\n 'January',\n 'February',\n 'March',\n 'April',\n 'May',\n 'June',\n 'July',\n 'August',\n 'September',\n 'October',\n 'November',\n 'December',\n];\n\nexport function formatDate(date: Date, pattern: string): string {\n const day = date.getDate();\n const dayOfWeek = date.getDay();\n const month = date.getMonth();\n const year = date.getFullYear();\n const hours = date.getHours();\n const minutes = date.getMinutes();\n\n switch (pattern) {\n case 'MMMM d, yyyy':\n return `${MONTH_NAMES[month]} ${day}, ${year}`;\n case 'EEEE':\n return DAY_NAMES_LONG[dayOfWeek];\n case 'E':\n return DAY_NAMES_SHORT[dayOfWeek];\n case 'd':\n return `${day}`;\n case 'dd':\n return day < 10 ? `0${day}` : `${day}`;\n case 'hh a': {\n const h = hours % 12 || 12;\n const ampm = hours < 12 ? 'AM' : 'PM';\n return `${h < 10 ? '0' : ''}${h} ${ampm}`;\n }\n case 'hh:mm a': {\n const h = hours % 12 || 12;\n const ampm = hours < 12 ? 'AM' : 'PM';\n return `${h < 10 ? '0' : ''}${h}:${minutes < 10 ? '0' : ''}${minutes} ${ampm}`;\n }\n case 'dd-MM-yyyy':\n return `${day < 10 ? '0' : ''}${day}-${month + 1 < 10 ? '0' : ''}${month + 1}-${year}`;\n default:\n return date.toLocaleDateString();\n }\n}\n\nexport function getTimePercent(date: Date, forDay?: Date): number {\n const day = forDay || date;\n const sd = startOfDay(day);\n const ed = endOfDay(day);\n const percent =\n ((date.valueOf() - sd.valueOf()) / (ed.valueOf() - sd.valueOf())) * 100;\n if (percent < 0) return 0;\n if (percent > 100) return 100;\n return percent;\n}\n","import { startOfDay, endOfDay } from './utils.js';\n\nexport class BaseEvent {\n gid: string;\n start: Date;\n end: Date;\n\n constructor(start: Date, end: Date) {\n this.gid = crypto.randomUUID();\n this.start = start;\n this.end = end;\n }\n\n length(): number {\n return this.end.valueOf() - this.start.valueOf();\n }\n\n isOverlapping(event: BaseEvent): boolean {\n let totalLength: number;\n if (this.start.valueOf() <= event.start.valueOf()) {\n totalLength = event.end.valueOf() - this.start.valueOf();\n } else {\n totalLength = this.end.valueOf() - event.start.valueOf();\n }\n return this.length() + event.length() >= totalLength;\n }\n\n isOverlappingWithoutTime(event: BaseEvent): boolean {\n const thisStartDay = startOfDay(this.start);\n const eventStartDay = startOfDay(event.start);\n const thisEndDay = endOfDay(this.end);\n const eventEndDay = endOfDay(event.end);\n\n let totalLength: number;\n if (thisStartDay.valueOf() <= eventStartDay.valueOf()) {\n totalLength = eventEndDay.valueOf() - thisStartDay.valueOf();\n } else {\n totalLength = thisEndDay.valueOf() - eventStartDay.valueOf();\n }\n return this.length() + event.length() >= totalLength;\n }\n\n isOverlappingWithDate(date: Date): boolean {\n return (\n this.start.valueOf() <= date.valueOf() &&\n this.end.valueOf() >= date.valueOf()\n );\n }\n}\n","import { BaseEvent } from './base-event.js';\n\nexport class CalendarEvent extends BaseEvent {\n data: any;\n title: string;\n color?: string;\n\n constructor(\n start: Date,\n end: Date,\n title: string,\n color: string | undefined,\n data: any,\n ) {\n super(start, end);\n this.data = data;\n if (color) this.color = color;\n this.title = title;\n }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,376 @@
|
|
|
1
|
+
import { a as i, _ as __decorate, I as IndividualComponent, i as i$1, b } from './IndividualComponent-DUINtMGK.js';
|
|
2
|
+
import { n } from './property-1psGvXOq.js';
|
|
3
|
+
import { r } from './state-DwbEjqVk.js';
|
|
4
|
+
import { g as getTimePercent, i as calculateMonthRange, a as addDays, B as BaseEvent, s as startOfDay, e as endOfDay, d as differenceInDays, f as formatDate, L as LONG_EVENT_PADDING } from './calendar-event-BrQ_SEKD.js';
|
|
5
|
+
import { M as MonthEventManager } from './event-manager-D-QCmUgR.js';
|
|
6
|
+
|
|
7
|
+
var css_248z = i`@charset "UTF-8";
|
|
8
|
+
* {
|
|
9
|
+
box-sizing: border-box;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
.screen-reader-only {
|
|
13
|
+
display: none !important;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
:host {
|
|
17
|
+
display: block;
|
|
18
|
+
height: 100%;
|
|
19
|
+
--calendar-border-color: var(--color-outline-variant);
|
|
20
|
+
--calendar-scale-color: var(--color-outline-variant);
|
|
21
|
+
--scale-size: 3rem;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
.scale {
|
|
25
|
+
width: var(--scale-size);
|
|
26
|
+
flex-shrink: 0;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
.calendar-month-view {
|
|
30
|
+
display: flex;
|
|
31
|
+
flex-direction: column;
|
|
32
|
+
height: 100%;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
/* ── Header ── */
|
|
36
|
+
.view-header {
|
|
37
|
+
background: var(--color-surface-container);
|
|
38
|
+
display: flex;
|
|
39
|
+
border-bottom: 1px solid var(--calendar-border-color);
|
|
40
|
+
}
|
|
41
|
+
.view-header .columns {
|
|
42
|
+
display: flex;
|
|
43
|
+
flex: 1;
|
|
44
|
+
}
|
|
45
|
+
.view-header .columns .column {
|
|
46
|
+
flex: 1;
|
|
47
|
+
border-inline-start: 1px solid var(--calendar-border-color);
|
|
48
|
+
}
|
|
49
|
+
.view-header .columns .column:first-child {
|
|
50
|
+
border-inline-start: 0;
|
|
51
|
+
}
|
|
52
|
+
.view-header .columns .column .column-content {
|
|
53
|
+
display: flex;
|
|
54
|
+
align-items: center;
|
|
55
|
+
padding: 0.5rem 0.75rem;
|
|
56
|
+
gap: 0.5rem;
|
|
57
|
+
}
|
|
58
|
+
.view-header .columns .column .day {
|
|
59
|
+
font-size: 0.875rem;
|
|
60
|
+
font-weight: 500;
|
|
61
|
+
color: var(--color-on-surface-variant);
|
|
62
|
+
}
|
|
63
|
+
.view-header .scrollbar-placeholder {
|
|
64
|
+
width: var(--scrollbar-width, 0px);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
/* ── View body ── */
|
|
68
|
+
.view-body {
|
|
69
|
+
height: 100%;
|
|
70
|
+
overflow-y: auto;
|
|
71
|
+
}
|
|
72
|
+
.view-body .view-body-scroll {
|
|
73
|
+
display: flex;
|
|
74
|
+
position: relative;
|
|
75
|
+
min-height: 100%;
|
|
76
|
+
}
|
|
77
|
+
.view-body .view-body-scroll .drawing-area {
|
|
78
|
+
flex: 1;
|
|
79
|
+
}
|
|
80
|
+
.view-body .view-body-scroll .drawing-area .multi-day-section {
|
|
81
|
+
border-bottom: 1px solid var(--calendar-scale-color);
|
|
82
|
+
min-height: 8rem;
|
|
83
|
+
}
|
|
84
|
+
.view-body .view-body-scroll .drawing-area .multi-day-section .multi-day-body-scroll {
|
|
85
|
+
position: relative;
|
|
86
|
+
height: 100%;
|
|
87
|
+
}
|
|
88
|
+
.view-body .view-body-scroll .drawing-area .multi-day-section .multi-day-background {
|
|
89
|
+
display: flex;
|
|
90
|
+
height: 100%;
|
|
91
|
+
position: absolute;
|
|
92
|
+
width: 100%;
|
|
93
|
+
}
|
|
94
|
+
.view-body .view-body-scroll .drawing-area .multi-day-section .multi-day-background .columns {
|
|
95
|
+
display: flex;
|
|
96
|
+
flex: 1;
|
|
97
|
+
}
|
|
98
|
+
.view-body .view-body-scroll .drawing-area .multi-day-section .multi-day-background .columns .column {
|
|
99
|
+
min-height: 8rem;
|
|
100
|
+
flex: 1;
|
|
101
|
+
border-inline-start: 1px solid var(--calendar-scale-color);
|
|
102
|
+
}
|
|
103
|
+
.view-body .view-body-scroll .drawing-area .multi-day-section .multi-day-background .columns .column:first-child {
|
|
104
|
+
border-inline-start: 0;
|
|
105
|
+
}
|
|
106
|
+
.view-body .view-body-scroll .drawing-area .multi-day-section .multi-day-background .columns .column .column-header {
|
|
107
|
+
font-size: 0.75rem;
|
|
108
|
+
color: var(--color-on-surface-variant);
|
|
109
|
+
padding-inline-start: 0.5rem;
|
|
110
|
+
padding-top: 0.375rem;
|
|
111
|
+
border-top: 3px solid transparent;
|
|
112
|
+
}
|
|
113
|
+
.view-body .view-body-scroll .drawing-area .multi-day-section .multi-day-background .columns .column.today {
|
|
114
|
+
background: color-mix(in srgb, var(--color-primary) 6%, transparent);
|
|
115
|
+
}
|
|
116
|
+
.view-body .view-body-scroll .drawing-area .multi-day-section .multi-day-background .columns .column.today .column-header {
|
|
117
|
+
border-top-color: var(--color-primary);
|
|
118
|
+
}
|
|
119
|
+
.view-body .view-body-scroll .drawing-area .multi-day-section .multi-events {
|
|
120
|
+
min-height: 4rem;
|
|
121
|
+
padding-top: 2rem;
|
|
122
|
+
height: 100%;
|
|
123
|
+
}
|
|
124
|
+
.view-body .view-body-scroll .drawing-area .multi-day-section .multi-events .row {
|
|
125
|
+
height: 1.8rem;
|
|
126
|
+
box-sizing: content-box;
|
|
127
|
+
position: relative;
|
|
128
|
+
padding-bottom: 0.25rem;
|
|
129
|
+
}
|
|
130
|
+
.view-body .view-body-scroll .drawing-area .multi-day-section .multi-events .row:last-child {
|
|
131
|
+
padding-bottom: 0;
|
|
132
|
+
}
|
|
133
|
+
.view-body .view-body-scroll .drawing-area .multi-day-section .multi-events .row-spacer {
|
|
134
|
+
height: 0.75rem;
|
|
135
|
+
}
|
|
136
|
+
.view-body .view-body-scroll .drawing-area .multi-day-section .multi-events .event {
|
|
137
|
+
position: absolute;
|
|
138
|
+
height: 1.8rem;
|
|
139
|
+
text-overflow: ellipsis;
|
|
140
|
+
overflow: hidden;
|
|
141
|
+
}
|
|
142
|
+
.view-body .view-body-scroll .drawing-area .multi-day-section .multi-events .event .event-title {
|
|
143
|
+
padding: 0.25rem 0.375rem;
|
|
144
|
+
font-size: 0.75rem;
|
|
145
|
+
font-weight: 500;
|
|
146
|
+
white-space: nowrap;
|
|
147
|
+
overflow: hidden;
|
|
148
|
+
text-overflow: ellipsis;
|
|
149
|
+
}
|
|
150
|
+
.view-body .view-body-scroll .drawing-area .multi-day-section .multi-events .event.clickable {
|
|
151
|
+
cursor: pointer;
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
/* ── Event styles ── */
|
|
155
|
+
.event {
|
|
156
|
+
background: var(--calendar-event-bg-color);
|
|
157
|
+
border-inline-start: 0.25rem solid var(--calendar-event-border-color);
|
|
158
|
+
border-radius: var(--shape-corner-extra-small);
|
|
159
|
+
color: var(--calendar-event-text-color);
|
|
160
|
+
transition: background 150ms ease;
|
|
161
|
+
}
|
|
162
|
+
.event.clickable:hover {
|
|
163
|
+
background: var(--calendar-event-bg-color--hover);
|
|
164
|
+
color: var(--calendar-event-text-color--hover);
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
/* ── Today highlighting ── */
|
|
168
|
+
.calendar-month-view .view-body .view-body-scroll .drawing-area .multi-day-section .multi-day-background .columns .column.today {
|
|
169
|
+
background: color-mix(in srgb, var(--color-primary) 6%, transparent);
|
|
170
|
+
}
|
|
171
|
+
.calendar-month-view .view-body .view-body-scroll .drawing-area .multi-day-section .multi-day-background .columns .column.today .column-header {
|
|
172
|
+
border-top-color: var(--color-primary);
|
|
173
|
+
}`;
|
|
174
|
+
|
|
175
|
+
/**
|
|
176
|
+
* @label Calendar Month View
|
|
177
|
+
* @tag wc-calendar-month-view
|
|
178
|
+
* @rawTag calendar-month-view
|
|
179
|
+
* @parentRawTag calendar
|
|
180
|
+
* @summary Internal month view component for the calendar.
|
|
181
|
+
*/
|
|
182
|
+
let CalendarMonthView = class CalendarMonthView extends i$1 {
|
|
183
|
+
constructor() {
|
|
184
|
+
super(...arguments);
|
|
185
|
+
this.events = [];
|
|
186
|
+
this.eventClickable = true;
|
|
187
|
+
this.currentTime = new Date();
|
|
188
|
+
this.contextDate = new Date();
|
|
189
|
+
this.dateRange = {};
|
|
190
|
+
this.weekDayEvents = [];
|
|
191
|
+
}
|
|
192
|
+
connectedCallback() {
|
|
193
|
+
super.connectedCallback();
|
|
194
|
+
this._processEvents();
|
|
195
|
+
}
|
|
196
|
+
willUpdate(changedProperties) {
|
|
197
|
+
if (changedProperties.has('events') ||
|
|
198
|
+
changedProperties.has('contextDate')) {
|
|
199
|
+
this._processEvents();
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
firstUpdated() {
|
|
203
|
+
const viewBody = this.renderRoot.querySelector('.view-body');
|
|
204
|
+
if (viewBody) {
|
|
205
|
+
const viewBodyHeight = viewBody.scrollHeight;
|
|
206
|
+
viewBody.scrollTo({
|
|
207
|
+
top: (getTimePercent(this.currentTime) / 100) * viewBodyHeight - 150,
|
|
208
|
+
});
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
_processEvents() {
|
|
212
|
+
this.dateRange = calculateMonthRange(this.contextDate, 1);
|
|
213
|
+
this.weekDayEvents = [];
|
|
214
|
+
for (let i = new Date(this.dateRange.startDate), j = 0; j < 6; i = addDays(i, 7), j++) {
|
|
215
|
+
const manager = new MonthEventManager();
|
|
216
|
+
manager.addEvents(this.events.filter(event => event.isOverlapping(new BaseEvent(startOfDay(i), endOfDay(addDays(i, 6))))));
|
|
217
|
+
manager.process();
|
|
218
|
+
this.weekDayEvents.push(manager.columns);
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
_getDatePercent(date, dateRangeStartDate) {
|
|
222
|
+
const currentDay = differenceInDays(startOfDay(date), dateRangeStartDate);
|
|
223
|
+
const percent = (currentDay / 7) * 100;
|
|
224
|
+
if (percent < 0)
|
|
225
|
+
return 0;
|
|
226
|
+
if (percent > 100)
|
|
227
|
+
return 100;
|
|
228
|
+
return percent;
|
|
229
|
+
}
|
|
230
|
+
_getDayClass(date) {
|
|
231
|
+
const diff = differenceInDays(startOfDay(date), startOfDay(this.currentTime));
|
|
232
|
+
if (diff === 0)
|
|
233
|
+
return 'column today';
|
|
234
|
+
if (diff < 0)
|
|
235
|
+
return 'column past';
|
|
236
|
+
return 'column future';
|
|
237
|
+
}
|
|
238
|
+
_populateColorVars(styles, color) {
|
|
239
|
+
styles['--calendar-event-bg-color'] = `var(--color-${color}-container)`;
|
|
240
|
+
styles['--calendar-event-bg-color--hover'] = `var(--color-inverse-${color})`;
|
|
241
|
+
styles['--calendar-event-border-color'] = `var(--color-${color})`;
|
|
242
|
+
styles['--calendar-event-text-color'] = `var(--color-on-${color}-container)`;
|
|
243
|
+
styles['--calendar-event-text-color--hover'] = `var(--color-on-${color})`;
|
|
244
|
+
}
|
|
245
|
+
_emitEventClick(event) {
|
|
246
|
+
this.dispatchEvent(new CustomEvent('month-view-event-click', {
|
|
247
|
+
detail: { event },
|
|
248
|
+
bubbles: true,
|
|
249
|
+
composed: true,
|
|
250
|
+
}));
|
|
251
|
+
}
|
|
252
|
+
_renderHeader() {
|
|
253
|
+
const columns = [];
|
|
254
|
+
for (let i = new Date(this.dateRange.startDate), j = 0; j < 7; i = addDays(i, 1), j++) {
|
|
255
|
+
columns.push(b `
|
|
256
|
+
<div class="column">
|
|
257
|
+
<div class="column-content">
|
|
258
|
+
<div class="day">${formatDate(i, 'EEEE')}</div>
|
|
259
|
+
</div>
|
|
260
|
+
</div>
|
|
261
|
+
`);
|
|
262
|
+
}
|
|
263
|
+
return columns;
|
|
264
|
+
}
|
|
265
|
+
_renderMultiDayBackground(sd) {
|
|
266
|
+
const columns = [];
|
|
267
|
+
for (let i = new Date(sd), j = 0; j < 7; i = addDays(i, 1), j++) {
|
|
268
|
+
columns.push(b `
|
|
269
|
+
<div class=${this._getDayClass(i)}>
|
|
270
|
+
<div class="column-content">
|
|
271
|
+
<div class="column-header">
|
|
272
|
+
<div class="day">${formatDate(i, 'd')}</div>
|
|
273
|
+
</div>
|
|
274
|
+
</div>
|
|
275
|
+
</div>
|
|
276
|
+
`);
|
|
277
|
+
}
|
|
278
|
+
return columns;
|
|
279
|
+
}
|
|
280
|
+
_renderEvents() {
|
|
281
|
+
return this.weekDayEvents.map((eventDay, index) => {
|
|
282
|
+
const weekStartDate = addDays(this.dateRange.startDate, index * 7);
|
|
283
|
+
return b `
|
|
284
|
+
<div class="multi-day-section">
|
|
285
|
+
<div class="multi-day-body-scroll">
|
|
286
|
+
<div class="multi-day-background">
|
|
287
|
+
<div class="columns">
|
|
288
|
+
${this._renderMultiDayBackground(weekStartDate)}
|
|
289
|
+
</div>
|
|
290
|
+
</div>
|
|
291
|
+
<div class="multi-events">
|
|
292
|
+
<div class="row-content">
|
|
293
|
+
${eventDay.map(nodes => b `
|
|
294
|
+
<div class="row">
|
|
295
|
+
${nodes.map(node => {
|
|
296
|
+
const evtCls = this.eventClickable
|
|
297
|
+
? 'event clickable'
|
|
298
|
+
: 'event';
|
|
299
|
+
const evtStyles = {
|
|
300
|
+
left: `${this._getDatePercent(node.start, weekStartDate) + LONG_EVENT_PADDING}%`,
|
|
301
|
+
width: `${this._getDatePercent(addDays(node.end, 1), weekStartDate) - this._getDatePercent(node.start, weekStartDate) - 2 * LONG_EVENT_PADDING}%`,
|
|
302
|
+
};
|
|
303
|
+
if (node.color) {
|
|
304
|
+
this._populateColorVars(evtStyles, node.color);
|
|
305
|
+
}
|
|
306
|
+
return b `
|
|
307
|
+
<div
|
|
308
|
+
class=${evtCls}
|
|
309
|
+
style=${this._styleMap(evtStyles)}
|
|
310
|
+
@click=${() => {
|
|
311
|
+
if (this.eventClickable)
|
|
312
|
+
this._emitEventClick(node.data);
|
|
313
|
+
}}
|
|
314
|
+
>
|
|
315
|
+
<div class="event-title">
|
|
316
|
+
${node.title || '(no title)'}
|
|
317
|
+
</div>
|
|
318
|
+
</div>
|
|
319
|
+
`;
|
|
320
|
+
})}
|
|
321
|
+
</div>
|
|
322
|
+
`)}
|
|
323
|
+
<div class="row-spacer"></div>
|
|
324
|
+
</div>
|
|
325
|
+
</div>
|
|
326
|
+
</div>
|
|
327
|
+
</div>
|
|
328
|
+
`;
|
|
329
|
+
});
|
|
330
|
+
}
|
|
331
|
+
_styleMap(styles) {
|
|
332
|
+
return Object.entries(styles)
|
|
333
|
+
.map(([k, v]) => `${k}:${v}`)
|
|
334
|
+
.join(';');
|
|
335
|
+
}
|
|
336
|
+
render() {
|
|
337
|
+
return b `
|
|
338
|
+
<div class="calendar-month-view">
|
|
339
|
+
<div class="view-header">
|
|
340
|
+
<div class="columns">${this._renderHeader()}</div>
|
|
341
|
+
<div class="scrollbar-placeholder"></div>
|
|
342
|
+
</div>
|
|
343
|
+
<div class="view-body">
|
|
344
|
+
<div class="view-body-scroll">
|
|
345
|
+
<div class="drawing-area">${this._renderEvents()}</div>
|
|
346
|
+
</div>
|
|
347
|
+
</div>
|
|
348
|
+
</div>
|
|
349
|
+
`;
|
|
350
|
+
}
|
|
351
|
+
};
|
|
352
|
+
CalendarMonthView.styles = [css_248z];
|
|
353
|
+
__decorate([
|
|
354
|
+
n({ type: Array })
|
|
355
|
+
], CalendarMonthView.prototype, "events", void 0);
|
|
356
|
+
__decorate([
|
|
357
|
+
n({ type: Boolean, attribute: 'event-clickable' })
|
|
358
|
+
], CalendarMonthView.prototype, "eventClickable", void 0);
|
|
359
|
+
__decorate([
|
|
360
|
+
n({ type: Object, attribute: false })
|
|
361
|
+
], CalendarMonthView.prototype, "currentTime", void 0);
|
|
362
|
+
__decorate([
|
|
363
|
+
n({ type: Object, attribute: false })
|
|
364
|
+
], CalendarMonthView.prototype, "contextDate", void 0);
|
|
365
|
+
__decorate([
|
|
366
|
+
r()
|
|
367
|
+
], CalendarMonthView.prototype, "dateRange", void 0);
|
|
368
|
+
__decorate([
|
|
369
|
+
r()
|
|
370
|
+
], CalendarMonthView.prototype, "weekDayEvents", void 0);
|
|
371
|
+
CalendarMonthView = __decorate([
|
|
372
|
+
IndividualComponent
|
|
373
|
+
], CalendarMonthView);
|
|
374
|
+
|
|
375
|
+
export { CalendarMonthView };
|
|
376
|
+
//# sourceMappingURL=calendar-month-view.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"calendar-month-view.js","sources":["../../src/calendar/calendar-month-view.ts"],"sourcesContent":["import { LitElement, html, nothing } from 'lit';\nimport { property, state } from 'lit/decorators.js';\nimport {\n addDays,\n differenceInDays,\n startOfDay,\n endOfDay,\n calculateMonthRange,\n formatDate,\n getTimePercent,\n LONG_EVENT_PADDING,\n} from './utils.js';\nimport { BaseEvent } from './base-event.js';\nimport { CalendarEvent } from './calendar-event.js';\nimport { MonthEventManager } from './event-manager.js';\nimport type { ColumnEvent } from './event-manager.js';\nimport IndividualComponent from '@/IndividualComponent.js';\nimport styles from './calendar-month-view.scss';\n\n/**\n * @label Calendar Month View\n * @tag wc-calendar-month-view\n * @rawTag calendar-month-view\n * @parentRawTag calendar\n * @summary Internal month view component for the calendar.\n */\n@IndividualComponent\nexport class CalendarMonthView extends LitElement {\n static styles = [styles];\n\n @property({ type: Array })\n events: CalendarEvent[] = [];\n\n @property({ type: Boolean, attribute: 'event-clickable' })\n eventClickable: boolean = true;\n\n @property({ type: Object, attribute: false })\n currentTime: Date = new Date();\n\n @property({ type: Object, attribute: false })\n contextDate: Date = new Date();\n\n @state()\n private dateRange: any = {};\n\n @state()\n private weekDayEvents: ColumnEvent[][][] = [];\n\n override connectedCallback() {\n super.connectedCallback();\n this._processEvents();\n }\n\n override willUpdate(changedProperties: Map<string, unknown>) {\n if (\n changedProperties.has('events') ||\n changedProperties.has('contextDate')\n ) {\n this._processEvents();\n }\n }\n\n override firstUpdated() {\n const viewBody = this.renderRoot.querySelector('.view-body');\n if (viewBody) {\n const viewBodyHeight = viewBody.scrollHeight;\n viewBody.scrollTo({\n top:\n (getTimePercent(this.currentTime) / 100) * viewBodyHeight - 150,\n });\n }\n }\n\n private _processEvents() {\n this.dateRange = calculateMonthRange(this.contextDate, 1);\n this.weekDayEvents = [];\n\n for (\n let i = new Date(this.dateRange.startDate), j = 0;\n j < 6;\n i = addDays(i, 7), j++\n ) {\n const manager = new MonthEventManager();\n manager.addEvents(\n this.events.filter(event =>\n event.isOverlapping(\n new BaseEvent(startOfDay(i), endOfDay(addDays(i, 6))),\n ),\n ),\n );\n manager.process();\n this.weekDayEvents.push(manager.columns);\n }\n }\n\n private _getDatePercent(date: Date, dateRangeStartDate: Date): number {\n const currentDay = differenceInDays(startOfDay(date), dateRangeStartDate);\n const percent = (currentDay / 7) * 100;\n if (percent < 0) return 0;\n if (percent > 100) return 100;\n return percent;\n }\n\n private _getDayClass(date: Date): string {\n const diff = differenceInDays(\n startOfDay(date),\n startOfDay(this.currentTime),\n );\n if (diff === 0) return 'column today';\n if (diff < 0) return 'column past';\n return 'column future';\n }\n\n private _populateColorVars(\n styles: Record<string, string>,\n color: string,\n ) {\n styles['--calendar-event-bg-color'] = `var(--color-${color}-container)`;\n styles['--calendar-event-bg-color--hover'] = `var(--color-inverse-${color})`;\n styles['--calendar-event-border-color'] = `var(--color-${color})`;\n styles['--calendar-event-text-color'] = `var(--color-on-${color}-container)`;\n styles['--calendar-event-text-color--hover'] = `var(--color-on-${color})`;\n }\n\n private _emitEventClick(event: any) {\n this.dispatchEvent(\n new CustomEvent('month-view-event-click', {\n detail: { event },\n bubbles: true,\n composed: true,\n }),\n );\n }\n\n private _renderHeader() {\n const columns: any[] = [];\n for (\n let i = new Date(this.dateRange.startDate), j = 0;\n j < 7;\n i = addDays(i, 1), j++\n ) {\n columns.push(html`\n <div class=\"column\">\n <div class=\"column-content\">\n <div class=\"day\">${formatDate(i, 'EEEE')}</div>\n </div>\n </div>\n `);\n }\n return columns;\n }\n\n private _renderMultiDayBackground(sd: Date) {\n const columns: any[] = [];\n for (let i = new Date(sd), j = 0; j < 7; i = addDays(i, 1), j++) {\n columns.push(html`\n <div class=${this._getDayClass(i)}>\n <div class=\"column-content\">\n <div class=\"column-header\">\n <div class=\"day\">${formatDate(i, 'd')}</div>\n </div>\n </div>\n </div>\n `);\n }\n return columns;\n }\n\n private _renderEvents() {\n return this.weekDayEvents.map((eventDay, index) => {\n const weekStartDate = addDays(this.dateRange.startDate, index * 7);\n return html`\n <div class=\"multi-day-section\">\n <div class=\"multi-day-body-scroll\">\n <div class=\"multi-day-background\">\n <div class=\"columns\">\n ${this._renderMultiDayBackground(weekStartDate)}\n </div>\n </div>\n <div class=\"multi-events\">\n <div class=\"row-content\">\n ${eventDay.map(\n nodes => html`\n <div class=\"row\">\n ${nodes.map(node => {\n const evtCls = this.eventClickable\n ? 'event clickable'\n : 'event';\n const evtStyles: Record<string, string> = {\n left: `${this._getDatePercent(node.start, weekStartDate) + LONG_EVENT_PADDING}%`,\n width: `${this._getDatePercent(addDays(node.end, 1), weekStartDate) - this._getDatePercent(node.start, weekStartDate) - 2 * LONG_EVENT_PADDING}%`,\n };\n if (node.color) {\n this._populateColorVars(evtStyles, node.color);\n }\n return html`\n <div\n class=${evtCls}\n style=${this._styleMap(evtStyles)}\n @click=${() => {\n if (this.eventClickable)\n this._emitEventClick(node.data);\n }}\n >\n <div class=\"event-title\">\n ${node.title || '(no title)'}\n </div>\n </div>\n `;\n })}\n </div>\n `,\n )}\n <div class=\"row-spacer\"></div>\n </div>\n </div>\n </div>\n </div>\n `;\n });\n }\n\n private _styleMap(styles: Record<string, string>): string {\n return Object.entries(styles)\n .map(([k, v]) => `${k}:${v}`)\n .join(';');\n }\n\n render() {\n return html`\n <div class=\"calendar-month-view\">\n <div class=\"view-header\">\n <div class=\"columns\">${this._renderHeader()}</div>\n <div class=\"scrollbar-placeholder\"></div>\n </div>\n <div class=\"view-body\">\n <div class=\"view-body-scroll\">\n <div class=\"drawing-area\">${this._renderEvents()}</div>\n </div>\n </div>\n </div>\n `;\n }\n}\n"],"names":["LitElement","html","styles","property","state"],"mappings":"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"}
|