@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.
Files changed (198) hide show
  1. package/dist/{BaseButton-DuASuVth.js → BaseButton-BNFAYn-S.js} +2 -2
  2. package/dist/{BaseButton-DuASuVth.js.map → BaseButton-BNFAYn-S.js.map} +1 -1
  3. package/dist/BaseInput-14YmcfK7.js +27 -0
  4. package/dist/BaseInput-14YmcfK7.js.map +1 -0
  5. package/dist/banner.js +2 -3
  6. package/dist/banner.js.map +1 -1
  7. package/dist/{button-DouvOfEU.js → button-colors-Ccys3hvS.js} +5 -294
  8. package/dist/button-colors-Ccys3hvS.js.map +1 -0
  9. package/dist/button-group.js +226 -6
  10. package/dist/button-group.js.map +1 -1
  11. package/dist/button.js +294 -8
  12. package/dist/button.js.map +1 -1
  13. package/dist/calendar-column-view.js +634 -0
  14. package/dist/calendar-column-view.js.map +1 -0
  15. package/dist/calendar-event-BrQ_SEKD.js +199 -0
  16. package/dist/calendar-event-BrQ_SEKD.js.map +1 -0
  17. package/dist/calendar-month-view.js +376 -0
  18. package/dist/calendar-month-view.js.map +1 -0
  19. package/dist/calendar.js +339 -0
  20. package/dist/calendar.js.map +1 -0
  21. package/dist/canvas.js +361 -0
  22. package/dist/canvas.js.map +1 -0
  23. package/dist/cb-compound-expression.js +125 -0
  24. package/dist/cb-compound-expression.js.map +1 -0
  25. package/dist/cb-divider.js +150 -0
  26. package/dist/cb-divider.js.map +1 -0
  27. package/dist/cb-expression.js +75 -0
  28. package/dist/cb-expression.js.map +1 -0
  29. package/dist/cb-predicate.js +137 -0
  30. package/dist/cb-predicate.js.map +1 -0
  31. package/dist/code-editor.js +2 -1
  32. package/dist/code-editor.js.map +1 -1
  33. package/dist/condition-builder.js +58 -0
  34. package/dist/condition-builder.js.map +1 -0
  35. package/dist/custom-elements-jsdocs.json +7976 -4294
  36. package/dist/custom-elements.json +14358 -7589
  37. package/dist/dropdown-button.js +216 -0
  38. package/dist/dropdown-button.js.map +1 -0
  39. package/dist/event-manager-D-QCmUgR.js +113 -0
  40. package/dist/event-manager-D-QCmUgR.js.map +1 -0
  41. package/dist/fab.js +1 -1
  42. package/dist/flow-designer-dZnLJOQT.js +1656 -0
  43. package/dist/flow-designer-dZnLJOQT.js.map +1 -0
  44. package/dist/flow-designer-node-XMe-jlKg.js +548 -0
  45. package/dist/flow-designer-node-XMe-jlKg.js.map +1 -0
  46. package/dist/flow-designer-node.js +4 -0
  47. package/dist/flow-designer-node.js.map +1 -0
  48. package/dist/flow-designer.js +16 -0
  49. package/dist/flow-designer.js.map +1 -0
  50. package/dist/html-editor.js +358 -0
  51. package/dist/html-editor.js.map +1 -0
  52. package/dist/icon-button-CK1ZuE-2.js +247 -0
  53. package/dist/icon-button-CK1ZuE-2.js.map +1 -0
  54. package/dist/index.js +29 -6
  55. package/dist/index.js.map +1 -1
  56. package/dist/{is-dark-mode-DicqGkCJ.js → is-dark-mode-DOcaw4Yq.js} +2 -27
  57. package/dist/is-dark-mode-DOcaw4Yq.js.map +1 -0
  58. package/dist/modal.js +418 -0
  59. package/dist/modal.js.map +1 -0
  60. package/dist/{navigation-rail-Lxetd5-Z.js → navigation-rail-DyO0oAZU.js} +306 -2197
  61. package/dist/navigation-rail-DyO0oAZU.js.map +1 -0
  62. package/dist/notification-manager.js +268 -0
  63. package/dist/notification-manager.js.map +1 -0
  64. package/dist/peacock-loader.js +84 -8
  65. package/dist/peacock-loader.js.map +1 -1
  66. package/dist/popover-NC7b1lTq.js +1971 -0
  67. package/dist/popover-NC7b1lTq.js.map +1 -0
  68. package/dist/popover-content.js +125 -0
  69. package/dist/popover-content.js.map +1 -0
  70. package/dist/popover.js +4 -0
  71. package/dist/popover.js.map +1 -0
  72. package/dist/split-button.js +388 -0
  73. package/dist/split-button.js.map +1 -0
  74. package/dist/src/__controllers/floating-controller.d.ts +35 -0
  75. package/dist/src/calendar/base-event.d.ts +10 -0
  76. package/dist/src/calendar/calendar-column-view.d.ts +41 -0
  77. package/dist/src/calendar/calendar-event.d.ts +7 -0
  78. package/dist/src/calendar/calendar-month-view.d.ts +31 -0
  79. package/dist/src/calendar/calendar.d.ts +65 -0
  80. package/dist/src/calendar/event-manager.d.ts +17 -0
  81. package/dist/src/calendar/index.d.ts +4 -0
  82. package/dist/src/calendar/types.d.ts +13 -0
  83. package/dist/src/calendar/utils.d.ts +31 -0
  84. package/dist/src/canvas/canvas.d.ts +92 -0
  85. package/dist/src/canvas/index.d.ts +2 -0
  86. package/dist/src/condition-builder/cb-compound-expression.d.ts +31 -0
  87. package/dist/src/condition-builder/cb-divider.d.ts +26 -0
  88. package/dist/src/condition-builder/cb-expression.d.ts +31 -0
  89. package/dist/src/condition-builder/cb-predicate.d.ts +30 -0
  90. package/dist/src/condition-builder/condition-builder.d.ts +27 -0
  91. package/dist/src/condition-builder/index.d.ts +5 -0
  92. package/dist/src/dropdown-button/dropdown-button.d.ts +68 -0
  93. package/dist/src/dropdown-button/index.d.ts +1 -0
  94. package/dist/src/flow-designer/commands.d.ts +66 -0
  95. package/dist/src/flow-designer/flow-designer-node.d.ts +46 -0
  96. package/dist/src/flow-designer/flow-designer.d.ts +133 -0
  97. package/dist/src/flow-designer/index.d.ts +7 -0
  98. package/dist/src/flow-designer/layout.d.ts +30 -0
  99. package/dist/src/flow-designer/types.d.ts +142 -0
  100. package/dist/src/flow-designer/validation.d.ts +43 -0
  101. package/dist/src/flow-designer/workflow-utils.d.ts +40 -0
  102. package/dist/src/html-editor/html-editor.d.ts +56 -0
  103. package/dist/src/html-editor/index.d.ts +2 -0
  104. package/dist/src/index.d.ts +13 -0
  105. package/dist/src/menu/menu/menu.d.ts +5 -7
  106. package/dist/src/menu/menu-item/menu-item.d.ts +14 -13
  107. package/dist/src/modal/index.d.ts +1 -0
  108. package/dist/src/modal/modal.d.ts +63 -0
  109. package/dist/src/notification-manager/index.d.ts +1 -0
  110. package/dist/src/notification-manager/notification-manager.d.ts +44 -0
  111. package/dist/src/popover/index.d.ts +2 -0
  112. package/dist/src/popover/popover-content.d.ts +29 -0
  113. package/dist/src/popover/popover.d.ts +62 -0
  114. package/dist/src/split-button/index.d.ts +1 -0
  115. package/dist/src/split-button/split-button.d.ts +72 -0
  116. package/dist/src/tooltip/tooltip.d.ts +2 -15
  117. package/dist/test/flow-designer.test.d.ts +1 -0
  118. package/dist/tsconfig.tsbuildinfo +1 -1
  119. package/package.json +4 -2
  120. package/readme.md +2 -2
  121. package/src/__controllers/floating-controller.ts +237 -0
  122. package/src/banner/banner.scss +2 -3
  123. package/src/button/button/button.ts +1 -0
  124. package/src/calendar/base-event.ts +49 -0
  125. package/src/calendar/calendar-column-view.scss +326 -0
  126. package/src/calendar/calendar-column-view.ts +392 -0
  127. package/src/calendar/calendar-event.ts +20 -0
  128. package/src/calendar/calendar-month-view.scss +192 -0
  129. package/src/calendar/calendar-month-view.ts +244 -0
  130. package/src/calendar/calendar.scss +71 -0
  131. package/src/calendar/calendar.ts +298 -0
  132. package/src/calendar/event-manager.ts +117 -0
  133. package/src/calendar/index.ts +4 -0
  134. package/src/calendar/types.ts +14 -0
  135. package/src/calendar/utils.ts +180 -0
  136. package/src/canvas/canvas.scss +60 -0
  137. package/src/canvas/canvas.ts +391 -0
  138. package/src/canvas/index.ts +2 -0
  139. package/src/condition-builder/cb-compound-expression.scss +37 -0
  140. package/src/condition-builder/cb-compound-expression.ts +80 -0
  141. package/src/condition-builder/cb-divider.scss +93 -0
  142. package/src/condition-builder/cb-divider.ts +56 -0
  143. package/src/condition-builder/cb-expression.scss +14 -0
  144. package/src/condition-builder/cb-expression.ts +49 -0
  145. package/src/condition-builder/cb-predicate.scss +35 -0
  146. package/src/condition-builder/cb-predicate.ts +102 -0
  147. package/src/condition-builder/condition-builder.scss +13 -0
  148. package/src/condition-builder/condition-builder.ts +38 -0
  149. package/src/condition-builder/index.ts +5 -0
  150. package/src/dropdown-button/demo/index.html +110 -0
  151. package/src/dropdown-button/dropdown-button.scss +22 -0
  152. package/src/dropdown-button/dropdown-button.ts +206 -0
  153. package/src/dropdown-button/index.ts +1 -0
  154. package/src/flow-designer/DEMO.md +239 -0
  155. package/src/flow-designer/commands.ts +278 -0
  156. package/src/flow-designer/flow-designer-node.ts +172 -0
  157. package/src/flow-designer/flow-designer.scss +457 -0
  158. package/src/flow-designer/flow-designer.ts +611 -0
  159. package/src/flow-designer/index.ts +41 -0
  160. package/src/flow-designer/layout.ts +357 -0
  161. package/src/flow-designer/types.ts +166 -0
  162. package/src/flow-designer/validation.ts +284 -0
  163. package/src/flow-designer/workflow-utils.ts +282 -0
  164. package/src/html-editor/html-editor.scss +146 -0
  165. package/src/html-editor/html-editor.ts +276 -0
  166. package/src/html-editor/index.ts +3 -0
  167. package/src/index.ts +25 -0
  168. package/src/menu/menu/menu.scss +2 -2
  169. package/src/menu/menu/menu.ts +91 -101
  170. package/src/menu/menu-item/menu-item.scss +4 -0
  171. package/src/menu/menu-item/menu-item.ts +82 -78
  172. package/src/modal/index.ts +1 -0
  173. package/src/modal/modal.scss +206 -0
  174. package/src/modal/modal.ts +201 -0
  175. package/src/notification-manager/index.ts +1 -0
  176. package/src/notification-manager/notification-manager.scss +113 -0
  177. package/src/notification-manager/notification-manager.ts +199 -0
  178. package/src/peacock-loader.ts +71 -0
  179. package/src/popover/index.ts +2 -0
  180. package/src/popover/popover-content.scss +69 -0
  181. package/src/popover/popover-content.ts +51 -0
  182. package/src/popover/popover.scss +7 -0
  183. package/src/popover/popover.ts +170 -0
  184. package/src/split-button/index.ts +1 -0
  185. package/src/split-button/split-button-colors.scss +56 -0
  186. package/src/split-button/split-button-sizes.scss +28 -0
  187. package/src/split-button/split-button.scss +79 -0
  188. package/src/split-button/split-button.ts +236 -0
  189. package/src/table/table.ts +2 -2
  190. package/src/tooltip/tooltip.scss +4 -3
  191. package/src/tooltip/tooltip.ts +46 -104
  192. package/dist/button-DouvOfEU.js.map +0 -1
  193. package/dist/button-group-CEdMwvJJ.js +0 -464
  194. package/dist/button-group-CEdMwvJJ.js.map +0 -1
  195. package/dist/is-dark-mode-DicqGkCJ.js.map +0 -1
  196. package/dist/navigation-rail-Lxetd5-Z.js.map +0 -1
  197. package/dist/src/menu/menu/MenuSurfaceController.d.ts +0 -18
  198. 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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"}