nuxt-ui-elements-pro 0.1.8 → 0.1.9
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/module.json +1 -1
- package/dist/module.mjs +2 -2
- package/dist/runtime/components/EventCalendar.d.vue.ts +7 -7
- package/dist/runtime/components/EventCalendar.vue +12 -12
- package/dist/runtime/components/EventCalendar.vue.d.ts +7 -7
- package/dist/runtime/components/event-calendar/EventCalendarListView.d.vue.ts +1 -1
- package/dist/runtime/components/event-calendar/EventCalendarListView.vue +1 -1
- package/dist/runtime/components/event-calendar/EventCalendarListView.vue.d.ts +1 -1
- package/dist/runtime/components/event-calendar/EventCalendarMonthView.d.vue.ts +3 -3
- package/dist/runtime/components/event-calendar/EventCalendarMonthView.vue +7 -9
- package/dist/runtime/components/event-calendar/EventCalendarMonthView.vue.d.ts +3 -3
- package/dist/runtime/components/event-calendar/EventCalendarTimeGrid.d.vue.ts +2 -2
- package/dist/runtime/components/event-calendar/EventCalendarTimeGrid.vue +2 -2
- package/dist/runtime/components/event-calendar/EventCalendarTimeGrid.vue.d.ts +2 -2
- package/package.json +1 -1
package/dist/module.json
CHANGED
package/dist/module.mjs
CHANGED
|
@@ -14,7 +14,7 @@ const eventCalendar = (options) => ({
|
|
|
14
14
|
weekdayRow: "grid grid-cols-7 border-b border-default",
|
|
15
15
|
weekdayCell: "py-2 text-center text-xs font-medium text-muted uppercase tracking-wider",
|
|
16
16
|
monthBody: "flex flex-col select-none",
|
|
17
|
-
monthWeekRow: "",
|
|
17
|
+
monthWeekRow: "relative",
|
|
18
18
|
dayCell: "border-b border-r border-default hover:bg-elevated/50 cursor-pointer",
|
|
19
19
|
dayCellOutside: "bg-muted/20",
|
|
20
20
|
monthDayNumber: "relative z-[1] p-1",
|
|
@@ -33,7 +33,7 @@ const eventCalendar = (options) => ({
|
|
|
33
33
|
eventTime: "font-medium mr-1",
|
|
34
34
|
recurringIcon: "size-3 shrink-0 opacity-60 align-middle mr-0.5",
|
|
35
35
|
moreEvents: "relative z-[2] text-xs text-muted px-1.5 py-0.5 cursor-pointer hover:text-highlighted",
|
|
36
|
-
expandedOverlay: "bg-default border border-default rounded-lg p-1.5 shadow-xl z-20 animate-expand-overlay",
|
|
36
|
+
expandedOverlay: "absolute top-1/2 -translate-x-1/2 -translate-y-1/2 bg-default border border-default rounded-lg p-1.5 shadow-xl z-20 animate-expand-overlay",
|
|
37
37
|
// Week/Day view
|
|
38
38
|
timeGridRoot: "flex-1 flex flex-col min-h-0 overflow-hidden",
|
|
39
39
|
columnHeaders: "flex border-b border-default shrink-0",
|
|
@@ -100,32 +100,32 @@ export interface EventCalendarSlots {
|
|
|
100
100
|
view: CalendarView;
|
|
101
101
|
}) => any;
|
|
102
102
|
/** Customize weekday header labels (month view) */
|
|
103
|
-
"
|
|
103
|
+
"month-weekday-header"?: (props: {
|
|
104
104
|
day: string;
|
|
105
105
|
index: number;
|
|
106
106
|
}) => any;
|
|
107
|
-
/** Customize day cell
|
|
108
|
-
day?: (props: {
|
|
107
|
+
/** Customize the day header area in each month cell (month view) */
|
|
108
|
+
"month-day-header"?: (props: {
|
|
109
109
|
day: CalendarDay;
|
|
110
110
|
}) => any;
|
|
111
111
|
/** Customize "+N more" indicator (month view) */
|
|
112
|
-
"more-events"?: (props: {
|
|
112
|
+
"month-more-events"?: (props: {
|
|
113
113
|
events: CalendarEvent[];
|
|
114
114
|
count: number;
|
|
115
115
|
day: CalendarDay;
|
|
116
116
|
}) => any;
|
|
117
117
|
/** Customize time labels (week/day view) */
|
|
118
|
-
"time-label"?: (props: {
|
|
118
|
+
"time-grid-label"?: (props: {
|
|
119
119
|
hour: number;
|
|
120
120
|
label: string;
|
|
121
121
|
}) => any;
|
|
122
122
|
/** Customize all-day event area (week/day view) */
|
|
123
|
-
"all-day"?: (props: {
|
|
123
|
+
"time-grid-all-day"?: (props: {
|
|
124
124
|
events: CalendarEvent[];
|
|
125
125
|
date: CalendarDate;
|
|
126
126
|
}) => any;
|
|
127
127
|
/** Customize date group headers (list view) */
|
|
128
|
-
"date-header"?: (props: {
|
|
128
|
+
"list-date-header"?: (props: {
|
|
129
129
|
day: CalendarDay;
|
|
130
130
|
weekday: string;
|
|
131
131
|
dateLabel: string;
|
|
@@ -223,14 +223,14 @@ defineExpose({
|
|
|
223
223
|
<template v-if="slots.event" #event="eventProps">
|
|
224
224
|
<slot name="event" v-bind="eventProps" />
|
|
225
225
|
</template>
|
|
226
|
-
<template v-if="slots['
|
|
227
|
-
<slot name="
|
|
226
|
+
<template v-if="slots['month-weekday-header']" #month-weekday-header="dayHeaderProps">
|
|
227
|
+
<slot name="month-weekday-header" v-bind="dayHeaderProps" />
|
|
228
228
|
</template>
|
|
229
|
-
<template v-if="slots
|
|
230
|
-
<slot name="day" v-bind="dayProps" />
|
|
229
|
+
<template v-if="slots['month-day-header']" #month-day-header="dayProps">
|
|
230
|
+
<slot name="month-day-header" v-bind="dayProps" />
|
|
231
231
|
</template>
|
|
232
|
-
<template v-if="slots['more-events']" #more-events="moreProps">
|
|
233
|
-
<slot name="more-events" v-bind="moreProps" />
|
|
232
|
+
<template v-if="slots['month-more-events']" #month-more-events="moreProps">
|
|
233
|
+
<slot name="month-more-events" v-bind="moreProps" />
|
|
234
234
|
</template>
|
|
235
235
|
<template v-if="slots.loading" #loading>
|
|
236
236
|
<slot name="loading" />
|
|
@@ -242,11 +242,11 @@ defineExpose({
|
|
|
242
242
|
<template v-if="slots.event" #event="eventProps">
|
|
243
243
|
<slot name="event" v-bind="eventProps" />
|
|
244
244
|
</template>
|
|
245
|
-
<template v-if="slots['time-label']" #time-label="timeLabelProps">
|
|
246
|
-
<slot name="time-label" v-bind="timeLabelProps" />
|
|
245
|
+
<template v-if="slots['time-grid-label']" #time-grid-label="timeLabelProps">
|
|
246
|
+
<slot name="time-grid-label" v-bind="timeLabelProps" />
|
|
247
247
|
</template>
|
|
248
|
-
<template v-if="slots['all-day']" #all-day="allDayProps">
|
|
249
|
-
<slot name="all-day" v-bind="allDayProps" />
|
|
248
|
+
<template v-if="slots['time-grid-all-day']" #time-grid-all-day="allDayProps">
|
|
249
|
+
<slot name="time-grid-all-day" v-bind="allDayProps" />
|
|
250
250
|
</template>
|
|
251
251
|
<template v-if="slots.loading" #loading>
|
|
252
252
|
<slot name="loading" />
|
|
@@ -258,8 +258,8 @@ defineExpose({
|
|
|
258
258
|
<template v-if="slots.event" #event="eventProps">
|
|
259
259
|
<slot name="event" v-bind="eventProps" />
|
|
260
260
|
</template>
|
|
261
|
-
<template v-if="slots['date-header']" #date-header="dateHeaderProps">
|
|
262
|
-
<slot name="date-header" v-bind="dateHeaderProps" />
|
|
261
|
+
<template v-if="slots['list-date-header']" #list-date-header="dateHeaderProps">
|
|
262
|
+
<slot name="list-date-header" v-bind="dateHeaderProps" />
|
|
263
263
|
</template>
|
|
264
264
|
</EventCalendarListView>
|
|
265
265
|
</template>
|
|
@@ -100,32 +100,32 @@ export interface EventCalendarSlots {
|
|
|
100
100
|
view: CalendarView;
|
|
101
101
|
}) => any;
|
|
102
102
|
/** Customize weekday header labels (month view) */
|
|
103
|
-
"
|
|
103
|
+
"month-weekday-header"?: (props: {
|
|
104
104
|
day: string;
|
|
105
105
|
index: number;
|
|
106
106
|
}) => any;
|
|
107
|
-
/** Customize day cell
|
|
108
|
-
day?: (props: {
|
|
107
|
+
/** Customize the day header area in each month cell (month view) */
|
|
108
|
+
"month-day-header"?: (props: {
|
|
109
109
|
day: CalendarDay;
|
|
110
110
|
}) => any;
|
|
111
111
|
/** Customize "+N more" indicator (month view) */
|
|
112
|
-
"more-events"?: (props: {
|
|
112
|
+
"month-more-events"?: (props: {
|
|
113
113
|
events: CalendarEvent[];
|
|
114
114
|
count: number;
|
|
115
115
|
day: CalendarDay;
|
|
116
116
|
}) => any;
|
|
117
117
|
/** Customize time labels (week/day view) */
|
|
118
|
-
"time-label"?: (props: {
|
|
118
|
+
"time-grid-label"?: (props: {
|
|
119
119
|
hour: number;
|
|
120
120
|
label: string;
|
|
121
121
|
}) => any;
|
|
122
122
|
/** Customize all-day event area (week/day view) */
|
|
123
|
-
"all-day"?: (props: {
|
|
123
|
+
"time-grid-all-day"?: (props: {
|
|
124
124
|
events: CalendarEvent[];
|
|
125
125
|
date: CalendarDate;
|
|
126
126
|
}) => any;
|
|
127
127
|
/** Customize date group headers (list view) */
|
|
128
|
-
"date-header"?: (props: {
|
|
128
|
+
"list-date-header"?: (props: {
|
|
129
129
|
day: CalendarDay;
|
|
130
130
|
weekday: string;
|
|
131
131
|
dateLabel: string;
|
|
@@ -31,7 +31,7 @@ function formatDateLabel(day) {
|
|
|
31
31
|
<div
|
|
32
32
|
data-slot="listDateHeader"
|
|
33
33
|
:class="ctx.ui.value.listDateHeader({ class: ctx.propUi.value?.listDateHeader })">
|
|
34
|
-
<slot name="date-header" :day="day" :weekday="formatWeekday(day)" :date-label="formatDateLabel(day)">
|
|
34
|
+
<slot name="list-date-header" :day="day" :weekday="formatWeekday(day)" :date-label="formatDateLabel(day)">
|
|
35
35
|
<span
|
|
36
36
|
data-slot="listDateWeekday"
|
|
37
37
|
:class="ctx.ui.value.listDateWeekday({ class: ctx.propUi.value?.listDateWeekday })">
|
|
@@ -5,18 +5,18 @@ export interface EventCalendarMonthViewProps {
|
|
|
5
5
|
as?: string | Component;
|
|
6
6
|
}
|
|
7
7
|
export interface EventCalendarMonthViewSlots {
|
|
8
|
-
"
|
|
8
|
+
"month-weekday-header": (props: {
|
|
9
9
|
day: string;
|
|
10
10
|
index: number;
|
|
11
11
|
}) => any;
|
|
12
|
-
day: (props: {
|
|
12
|
+
"month-day-header": (props: {
|
|
13
13
|
day: CalendarDay;
|
|
14
14
|
}) => any;
|
|
15
15
|
event: (props: {
|
|
16
16
|
event: CalendarEvent;
|
|
17
17
|
view: CalendarView;
|
|
18
18
|
}) => any;
|
|
19
|
-
"more-events": (props: {
|
|
19
|
+
"month-more-events": (props: {
|
|
20
20
|
events: CalendarEvent[];
|
|
21
21
|
count: number;
|
|
22
22
|
day: CalendarDay;
|
|
@@ -38,7 +38,7 @@ onKeyStroke("Escape", () => {
|
|
|
38
38
|
data-slot="weekdayCell"
|
|
39
39
|
role="columnheader"
|
|
40
40
|
:class="ctx.ui.value.weekdayCell({ class: ctx.propUi.value?.weekdayCell })">
|
|
41
|
-
<slot name="
|
|
41
|
+
<slot name="month-weekday-header" :day="day" :index="index">
|
|
42
42
|
{{ day }}
|
|
43
43
|
</slot>
|
|
44
44
|
</div>
|
|
@@ -83,7 +83,7 @@ onKeyStroke("Escape", () => {
|
|
|
83
83
|
ctx.dropTargetKey.value === `month-${day.date.toString()}` && ctx.ui.value.dropTarget({ class: ctx.propUi.value?.dropTarget }),
|
|
84
84
|
colIdx === 6 && 'border-r-0!',
|
|
85
85
|
ctx.isDateInSelection(day.date) && ctx.ui.value.selectionOverlay({ class: ctx.propUi.value?.selectionOverlay }),
|
|
86
|
-
isExpanded(day.date.toString()) && '
|
|
86
|
+
isExpanded(day.date.toString()) && 'z-10'
|
|
87
87
|
]"
|
|
88
88
|
:style="{
|
|
89
89
|
gridColumn: `${colIdx + 1}`,
|
|
@@ -106,10 +106,9 @@ onKeyStroke("Escape", () => {
|
|
|
106
106
|
:class="ctx.ui.value.monthDayNumber({ class: ctx.propUi.value?.monthDayNumber })"
|
|
107
107
|
:style="{
|
|
108
108
|
gridColumn: `${colIdx + 1}`,
|
|
109
|
-
gridRow: '1'
|
|
110
|
-
pointerEvents: 'none'
|
|
109
|
+
gridRow: '1'
|
|
111
110
|
}">
|
|
112
|
-
<slot name="day" :day="day">
|
|
111
|
+
<slot name="month-day-header" :day="day">
|
|
113
112
|
<div
|
|
114
113
|
:class="[
|
|
115
114
|
!day.isToday && ctx.ui.value.dayNumber({ class: ctx.propUi.value?.dayNumber }),
|
|
@@ -225,7 +224,7 @@ onKeyStroke("Escape", () => {
|
|
|
225
224
|
@keydown.enter.stop="openExpandDay(layout.week.days[overflowItem.col].date.toString(), $event)"
|
|
226
225
|
@keydown.space.prevent.stop="openExpandDay(layout.week.days[overflowItem.col].date.toString(), $event)">
|
|
227
226
|
<slot
|
|
228
|
-
name="more-events"
|
|
227
|
+
name="month-more-events"
|
|
229
228
|
:events="overflowItem.hiddenEvents.map((e) => e.original)"
|
|
230
229
|
:count="overflowItem.hiddenCount"
|
|
231
230
|
:day="layout.week.days[overflowItem.col]">
|
|
@@ -243,9 +242,8 @@ onKeyStroke("Escape", () => {
|
|
|
243
242
|
:aria-label="`Events for ${ctx.formatDateAriaLabel(day.date)}`"
|
|
244
243
|
:class="ctx.ui.value.expandedOverlay({ class: ctx.propUi.value?.expandedOverlay })"
|
|
245
244
|
:style="{
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
zIndex: 20
|
|
245
|
+
left: `calc(${colIdx} / 7 * 100% + 100% / 14)`,
|
|
246
|
+
width: 'calc(100% / 7 + 16px)'
|
|
249
247
|
}"
|
|
250
248
|
@click.stop>
|
|
251
249
|
<div
|
|
@@ -5,18 +5,18 @@ export interface EventCalendarMonthViewProps {
|
|
|
5
5
|
as?: string | Component;
|
|
6
6
|
}
|
|
7
7
|
export interface EventCalendarMonthViewSlots {
|
|
8
|
-
"
|
|
8
|
+
"month-weekday-header": (props: {
|
|
9
9
|
day: string;
|
|
10
10
|
index: number;
|
|
11
11
|
}) => any;
|
|
12
|
-
day: (props: {
|
|
12
|
+
"month-day-header": (props: {
|
|
13
13
|
day: CalendarDay;
|
|
14
14
|
}) => any;
|
|
15
15
|
event: (props: {
|
|
16
16
|
event: CalendarEvent;
|
|
17
17
|
view: CalendarView;
|
|
18
18
|
}) => any;
|
|
19
|
-
"more-events": (props: {
|
|
19
|
+
"month-more-events": (props: {
|
|
20
20
|
events: CalendarEvent[];
|
|
21
21
|
count: number;
|
|
22
22
|
day: CalendarDay;
|
|
@@ -10,11 +10,11 @@ export interface EventCalendarTimeGridSlots {
|
|
|
10
10
|
event: CalendarEvent;
|
|
11
11
|
view: CalendarView;
|
|
12
12
|
}) => any;
|
|
13
|
-
"time-label": (props: {
|
|
13
|
+
"time-grid-label": (props: {
|
|
14
14
|
hour: number;
|
|
15
15
|
label: string;
|
|
16
16
|
}) => any;
|
|
17
|
-
"all-day": (props: {
|
|
17
|
+
"time-grid-all-day": (props: {
|
|
18
18
|
events: CalendarEvent[];
|
|
19
19
|
date: CalendarDate;
|
|
20
20
|
}) => any;
|
|
@@ -62,7 +62,7 @@ const ctx = useEventCalendarContext();
|
|
|
62
62
|
@dragover="ctx.onDragOver(`allday-${day.dateKey}`, $event)"
|
|
63
63
|
@dragleave="ctx.onDragLeave"
|
|
64
64
|
@drop="ctx.onDropMonthCell(day.date, $event)">
|
|
65
|
-
<slot name="all-day" :events="day.allDayEvents.map((e) => e.original)" :date="day.date">
|
|
65
|
+
<slot name="time-grid-all-day" :events="day.allDayEvents.map((e) => e.original)" :date="day.date">
|
|
66
66
|
<div
|
|
67
67
|
v-for="event in day.allDayEvents"
|
|
68
68
|
:key="event.id"
|
|
@@ -174,7 +174,7 @@ const ctx = useEventCalendarContext();
|
|
|
174
174
|
:class="ctx.ui.value.timeGutterSlot({ class: ctx.propUi.value?.timeGutterSlot })"
|
|
175
175
|
:style="{ height: `${ctx.SLOT_HEIGHT}px` }">
|
|
176
176
|
<div v-if="slot.label" data-slot="timeLabel" :class="ctx.ui.value.timeLabel({ class: ctx.propUi.value?.timeLabel })">
|
|
177
|
-
<slot name="time-label" :hour="slot.hour" :label="slot.label">
|
|
177
|
+
<slot name="time-grid-label" :hour="slot.hour" :label="slot.label">
|
|
178
178
|
{{ slot.label }}
|
|
179
179
|
</slot>
|
|
180
180
|
</div>
|
|
@@ -10,11 +10,11 @@ export interface EventCalendarTimeGridSlots {
|
|
|
10
10
|
event: CalendarEvent;
|
|
11
11
|
view: CalendarView;
|
|
12
12
|
}) => any;
|
|
13
|
-
"time-label": (props: {
|
|
13
|
+
"time-grid-label": (props: {
|
|
14
14
|
hour: number;
|
|
15
15
|
label: string;
|
|
16
16
|
}) => any;
|
|
17
|
-
"all-day": (props: {
|
|
17
|
+
"time-grid-all-day": (props: {
|
|
18
18
|
events: CalendarEvent[];
|
|
19
19
|
date: CalendarDate;
|
|
20
20
|
}) => any;
|