@feedmepos/mf-order-setting 0.0.51 → 0.0.52-dev.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.tsbuildinfo +1 -0
- package/dist/{KioskDevicesView-TIls1ag1.js → KioskDevicesView-Vy9FLX1n.js} +1 -1
- package/dist/{KioskDevicesView.vue_vue_type_script_setup_true_lang-B2gjPfOJ.js → KioskDevicesView.vue_vue_type_script_setup_true_lang-DhZPOEEQ.js} +2 -2
- package/dist/KioskSettingView-cE-JdCBB.js +551 -0
- package/dist/{KioskView-B0Jj2sOl.js → KioskView-BYs5bem0.js} +108 -111
- package/dist/OrderSettingsView-C4aEpC1j.js +56063 -0
- package/dist/{app-JqOEacuf.js → app-CwYXsqxX.js} +182 -26
- package/dist/app.js +1 -1
- package/dist/{dayjs.min-B42nUieJ.js → dayjs.min-JEYIJz2D.js} +1 -1
- package/dist/frontend/mf-order/src/api/reservation/index.d.ts +8 -0
- package/dist/frontend/mf-order/src/app.d.ts +164 -8
- package/dist/frontend/mf-order/src/main.d.ts +164 -8
- package/dist/frontend/mf-order/src/modules/order-setting/kiosk/interface.d.ts +0 -2
- package/dist/frontend/mf-order/src/stores/order-setting/index.d.ts +0 -6
- package/dist/frontend/mf-order/src/stores/restaurant/index.d.ts +3 -3
- package/dist/frontend/mf-order/src/views/all-orders/ReflowOrder.vue.d.ts +2 -2
- package/dist/frontend/mf-order/src/views/order-settings/delivery/inhouse/InHouseDelivery.vue.d.ts +2 -2
- package/dist/frontend/mf-order/src/views/order-settings/reservation/CopySettingsSheet.vue.d.ts +186 -0
- package/dist/frontend/mf-order/src/views/order-settings/reservation/CustomSelect.vue.d.ts +15 -0
- package/dist/frontend/mf-order/src/views/order-settings/reservation/CustomTimePicker.vue.d.ts +10 -0
- package/dist/frontend/mf-order/src/views/order-settings/reservation/ReservationSetting.vue.d.ts +2 -0
- package/dist/{index-B0teNm7_.js → index-DZCjODMx.js} +2 -2
- package/dist/{menu.dto-DFTxveX1.js → menu.dto-D9CDVLiP.js} +22865 -20037
- package/dist/package/entity/food-court/order.do.d.ts +47 -2
- package/dist/package/entity/food-court/order.dto.d.ts +0 -3
- package/dist/package/entity/incoming-order/incoming-order-to-bill.dto.d.ts +12341 -1
- package/dist/package/entity/incoming-order/incoming-order.do.d.ts +3 -22266
- package/dist/package/entity/index.d.ts +5 -0
- package/dist/package/entity/kiosk/marketing/marketing.dto.d.ts +1 -19864
- package/dist/package/entity/order/order-item/order-item.dto.d.ts +1 -3721
- package/dist/package/entity/order-setting/kiosk/kiosk.do.d.ts +0 -3
- package/dist/package/entity/order-setting/kiosk/kiosk.dto.d.ts +0 -3
- package/dist/package/entity/order-setting/order-setting.do.d.ts +861 -5
- package/dist/package/entity/order-setting/order-setting.dto.d.ts +0 -10
- package/dist/package/entity/order-setting/reservationV2/reservation.do.d.ts +1269 -0
- package/dist/package/entity/queue/queue.do.d.ts +1 -11
- package/dist/package/entity/reservation/reservation.do.d.ts +101 -0
- package/dist/package/entity/reservation/reservation.dto.d.ts +325 -0
- package/dist/package/entity/reservation/reservation.enum.d.ts +3 -0
- package/dist/package/entity/reservation/reservation.utils.d.ts +152 -0
- package/dist/package/entity/restaurant/restaurant.dto.d.ts +0 -5
- package/dist/package/entity/websocket/websocket.dto.d.ts +0 -12
- package/dist/style.css +1 -0
- package/package.json +3 -3
- package/src/api/reservation/index.ts +28 -0
- package/src/assets/images/not-found.png +0 -0
- package/src/locales/en-US.json +57 -3
- package/src/locales/ja-JP.json +9 -11
- package/src/locales/th-TH.json +55 -3
- package/src/locales/zh-CN.json +55 -3
- package/src/main.ts +7 -5
- package/src/modules/order-setting/kiosk/interface.ts +13 -15
- package/src/stores/order-setting/mapper.ts +41 -44
- package/src/views/kiosk/settings/KioskPaymentTypeSection.vue +1 -19
- package/src/views/kiosk/settings/KioskSettingView.vue +23 -43
- package/src/views/order-settings/OrderSettingsView.vue +7 -2
- package/src/views/order-settings/delivery/integrated-delivery/IntegratedDelivery.vue +3 -1
- package/src/views/order-settings/drive-thru/DriveThruSetting.vue +13 -28
- package/src/views/order-settings/reservation/CopySettingsSheet.vue +238 -0
- package/src/views/order-settings/reservation/CustomSelect.vue +99 -0
- package/src/views/order-settings/reservation/CustomTimePicker.vue +201 -0
- package/src/views/order-settings/reservation/ReservationSetting.vue +1246 -0
- package/src/views/order-settings/servicecharge/ServiceChargeRule.vue +5 -1
- package/tsconfig.app.json +8 -6
- package/dist/KioskSettingView-UPE-q-Zd.js +0 -573
- package/dist/OrderSettingsView-Ca4y2PNF.js +0 -51603
- package/dist/frontend/mf-order/tsconfig.app.tsbuildinfo +0 -1
|
@@ -3456,16 +3456,6 @@ export declare const FdoRestaurantQueueCart: z.ZodObject<{
|
|
|
3456
3456
|
}>;
|
|
3457
3457
|
export type FdoRestaurantQueueCart = z.infer<typeof FdoRestaurantQueueCart>;
|
|
3458
3458
|
export declare const FdoRestaurantQueue: z.AnyZodObject;
|
|
3459
|
-
export declare const FdoRestaurantQueues: z.
|
|
3460
|
-
queues: z.ZodArray<z.AnyZodObject, "many">;
|
|
3461
|
-
}, "strip", z.ZodTypeAny, {
|
|
3462
|
-
queues: {
|
|
3463
|
-
[x: string]: any;
|
|
3464
|
-
}[];
|
|
3465
|
-
}, {
|
|
3466
|
-
queues: {
|
|
3467
|
-
[x: string]: any;
|
|
3468
|
-
}[];
|
|
3469
|
-
}>;
|
|
3459
|
+
export declare const FdoRestaurantQueues: z.AnyZodObject;
|
|
3470
3460
|
export type FdoRestaurantQueue = z.infer<typeof FdoRestaurantQueue>;
|
|
3471
3461
|
export type FdoRestaurantQueues = z.infer<typeof FdoRestaurantQueues>;
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
/** Guest preference value - supports text, single select (radio), and multi select (checkbox) */
|
|
3
|
+
export declare const FdoGuestPreferenceValue: z.ZodObject<{
|
|
4
|
+
/** The preference name (matches FdoReservationPreference.name) */
|
|
5
|
+
name: z.ZodString;
|
|
6
|
+
/** The customer's selection - string for text/radio, array for checkbox */
|
|
7
|
+
value: z.ZodUnion<[z.ZodString, z.ZodArray<z.ZodString, "many">]>;
|
|
8
|
+
}, "strip", z.ZodTypeAny, {
|
|
9
|
+
name: string;
|
|
10
|
+
value: string | string[];
|
|
11
|
+
}, {
|
|
12
|
+
name: string;
|
|
13
|
+
value: string | string[];
|
|
14
|
+
}>;
|
|
15
|
+
export type FdoGuestPreferenceValue = z.infer<typeof FdoGuestPreferenceValue>;
|
|
16
|
+
export declare const FdoRestaurantReservation: z.ZodObject<{
|
|
17
|
+
_id: z.ZodEffects<z.ZodString, string, string>;
|
|
18
|
+
status: z.ZodEnum<["DRAFT", "CONFIRMED", "CANCELLED", "SEATED", "NO_SHOW"]>;
|
|
19
|
+
/** * The timestamp until which this slot is held/blocked for the user.
|
|
20
|
+
* If the current time > reservedUntil and status is DRAFT,
|
|
21
|
+
* the inventory is released back to the public.
|
|
22
|
+
*/
|
|
23
|
+
reservedUntil: z.ZodEffects<z.ZodString, string, string>;
|
|
24
|
+
/** Restaurant _id */
|
|
25
|
+
restaurant: z.ZodEffects<z.ZodString, string, string>;
|
|
26
|
+
/** The capacity tier ID - the actual inventory unit being booked */
|
|
27
|
+
capacityTierId: z.ZodString;
|
|
28
|
+
/** The range ID - the zone/area this reservation belongs to */
|
|
29
|
+
rangeId: z.ZodString;
|
|
30
|
+
orderId: z.ZodNullable<z.ZodOptional<z.ZodEffects<z.ZodString, string, string>>>;
|
|
31
|
+
/** Pax */
|
|
32
|
+
pax: z.ZodNumber;
|
|
33
|
+
startDate: z.ZodEffects<z.ZodString, string, string>;
|
|
34
|
+
endDate: z.ZodEffects<z.ZodString, string, string>;
|
|
35
|
+
userName: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
36
|
+
/** User phone and email can be null if created by POS */
|
|
37
|
+
userPhone: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
38
|
+
userEmail: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
39
|
+
/** User _id that created the reservation, can be null if created by POS */
|
|
40
|
+
userId: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
41
|
+
/** POS assigned slot number */
|
|
42
|
+
slotNumber: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
43
|
+
/** Customer remarks, can be preset/custom */
|
|
44
|
+
customerRemarks: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
45
|
+
/** Guest preferences - customer's selections from range preferences */
|
|
46
|
+
guestPreferences: z.ZodNullable<z.ZodOptional<z.ZodArray<z.ZodObject<{
|
|
47
|
+
/** The preference name (matches FdoReservationPreference.name) */
|
|
48
|
+
name: z.ZodString;
|
|
49
|
+
/** The customer's selection - string for text/radio, array for checkbox */
|
|
50
|
+
value: z.ZodUnion<[z.ZodString, z.ZodArray<z.ZodString, "many">]>;
|
|
51
|
+
}, "strip", z.ZodTypeAny, {
|
|
52
|
+
name: string;
|
|
53
|
+
value: string | string[];
|
|
54
|
+
}, {
|
|
55
|
+
name: string;
|
|
56
|
+
value: string | string[];
|
|
57
|
+
}>, "many">>>;
|
|
58
|
+
}, "strip", z.ZodTypeAny, {
|
|
59
|
+
orderId?: string | null | undefined;
|
|
60
|
+
userId?: string | null | undefined;
|
|
61
|
+
userName?: string | null | undefined;
|
|
62
|
+
userPhone?: string | null | undefined;
|
|
63
|
+
userEmail?: string | null | undefined;
|
|
64
|
+
slotNumber?: string | null | undefined;
|
|
65
|
+
customerRemarks?: string | null | undefined;
|
|
66
|
+
guestPreferences?: {
|
|
67
|
+
name: string;
|
|
68
|
+
value: string | string[];
|
|
69
|
+
}[] | null | undefined;
|
|
70
|
+
status: "CANCELLED" | "DRAFT" | "CONFIRMED" | "SEATED" | "NO_SHOW";
|
|
71
|
+
_id: string;
|
|
72
|
+
restaurant: string;
|
|
73
|
+
pax: number;
|
|
74
|
+
startDate: string;
|
|
75
|
+
endDate: string;
|
|
76
|
+
reservedUntil: string;
|
|
77
|
+
capacityTierId: string;
|
|
78
|
+
rangeId: string;
|
|
79
|
+
}, {
|
|
80
|
+
orderId?: string | null | undefined;
|
|
81
|
+
userId?: string | null | undefined;
|
|
82
|
+
userName?: string | null | undefined;
|
|
83
|
+
userPhone?: string | null | undefined;
|
|
84
|
+
userEmail?: string | null | undefined;
|
|
85
|
+
slotNumber?: string | null | undefined;
|
|
86
|
+
customerRemarks?: string | null | undefined;
|
|
87
|
+
guestPreferences?: {
|
|
88
|
+
name: string;
|
|
89
|
+
value: string | string[];
|
|
90
|
+
}[] | null | undefined;
|
|
91
|
+
status: "CANCELLED" | "DRAFT" | "CONFIRMED" | "SEATED" | "NO_SHOW";
|
|
92
|
+
_id: string;
|
|
93
|
+
restaurant: string;
|
|
94
|
+
pax: number;
|
|
95
|
+
startDate: string;
|
|
96
|
+
endDate: string;
|
|
97
|
+
reservedUntil: string;
|
|
98
|
+
capacityTierId: string;
|
|
99
|
+
rangeId: string;
|
|
100
|
+
}>;
|
|
101
|
+
export type FdoRestaurantReservation = z.infer<typeof FdoRestaurantReservation>;
|
|
@@ -0,0 +1,325 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
export declare const RestaurantReservationDto: z.ZodObject<{
|
|
3
|
+
_id: z.ZodNullable<z.ZodOptional<z.ZodEffects<z.ZodString, string, string>>>;
|
|
4
|
+
restaurantId: z.ZodEffects<z.ZodString, string, string>;
|
|
5
|
+
/** The capacity tier ID - the actual inventory unit to deduct from */
|
|
6
|
+
capacityTierId: z.ZodString;
|
|
7
|
+
/** The range ID - the zone/area this booking belongs to (for reference) */
|
|
8
|
+
rangeId: z.ZodString;
|
|
9
|
+
/** The exact start/end time returned by the availability API */
|
|
10
|
+
startDate: z.ZodEffects<z.ZodString, string, string>;
|
|
11
|
+
endDate: z.ZodEffects<z.ZodString, string, string>;
|
|
12
|
+
pax: z.ZodNumber;
|
|
13
|
+
/** User _id that created the reservation, can be null if created by POS */
|
|
14
|
+
userId: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
15
|
+
userName: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
16
|
+
userPhone: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
17
|
+
userEmail: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
18
|
+
customerRemarks: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
19
|
+
/** Guest preferences - customer's selections from range preferences */
|
|
20
|
+
guestPreferences: z.ZodNullable<z.ZodOptional<z.ZodArray<z.ZodObject<{
|
|
21
|
+
name: z.ZodString;
|
|
22
|
+
value: z.ZodUnion<[z.ZodString, z.ZodArray<z.ZodString, "many">]>;
|
|
23
|
+
}, "strip", z.ZodTypeAny, {
|
|
24
|
+
name: string;
|
|
25
|
+
value: string | string[];
|
|
26
|
+
}, {
|
|
27
|
+
name: string;
|
|
28
|
+
value: string | string[];
|
|
29
|
+
}>, "many">>>;
|
|
30
|
+
}, "strip", z.ZodTypeAny, {
|
|
31
|
+
_id?: string | null | undefined;
|
|
32
|
+
userId?: string | null | undefined;
|
|
33
|
+
userName?: string | null | undefined;
|
|
34
|
+
userPhone?: string | null | undefined;
|
|
35
|
+
userEmail?: string | null | undefined;
|
|
36
|
+
customerRemarks?: string | null | undefined;
|
|
37
|
+
guestPreferences?: {
|
|
38
|
+
name: string;
|
|
39
|
+
value: string | string[];
|
|
40
|
+
}[] | null | undefined;
|
|
41
|
+
restaurantId: string;
|
|
42
|
+
pax: number;
|
|
43
|
+
startDate: string;
|
|
44
|
+
endDate: string;
|
|
45
|
+
capacityTierId: string;
|
|
46
|
+
rangeId: string;
|
|
47
|
+
}, {
|
|
48
|
+
_id?: string | null | undefined;
|
|
49
|
+
userId?: string | null | undefined;
|
|
50
|
+
userName?: string | null | undefined;
|
|
51
|
+
userPhone?: string | null | undefined;
|
|
52
|
+
userEmail?: string | null | undefined;
|
|
53
|
+
customerRemarks?: string | null | undefined;
|
|
54
|
+
guestPreferences?: {
|
|
55
|
+
name: string;
|
|
56
|
+
value: string | string[];
|
|
57
|
+
}[] | null | undefined;
|
|
58
|
+
restaurantId: string;
|
|
59
|
+
pax: number;
|
|
60
|
+
startDate: string;
|
|
61
|
+
endDate: string;
|
|
62
|
+
capacityTierId: string;
|
|
63
|
+
rangeId: string;
|
|
64
|
+
}>;
|
|
65
|
+
export declare const RestaurantReservationPOSDto: z.ZodObject<{
|
|
66
|
+
_id: z.ZodEffects<z.ZodString, string, string>;
|
|
67
|
+
/** Reservation status */
|
|
68
|
+
status: z.ZodEnum<["DRAFT", "CONFIRMED", "CANCELLED", "SEATED", "NO_SHOW"]>;
|
|
69
|
+
/** Restaurant _id */
|
|
70
|
+
restaurant: z.ZodEffects<z.ZodString, string, string>;
|
|
71
|
+
/** The capacity tier ID - the actual inventory unit */
|
|
72
|
+
capacityTierId: z.ZodString;
|
|
73
|
+
/** The range ID - the zone/area (for reference) */
|
|
74
|
+
rangeId: z.ZodString;
|
|
75
|
+
startDate: z.ZodEffects<z.ZodString, string, string>;
|
|
76
|
+
endDate: z.ZodEffects<z.ZodString, string, string>;
|
|
77
|
+
/** Pax */
|
|
78
|
+
pax: z.ZodNumber;
|
|
79
|
+
userName: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
80
|
+
/** User phone and email can be null if created by POS */
|
|
81
|
+
userPhone: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
82
|
+
userEmail: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
83
|
+
/** User _id that created the reservation, can be null if created by POS */
|
|
84
|
+
userId: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
85
|
+
/** POS assigned slot number */
|
|
86
|
+
slotNumber: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
87
|
+
/** Customer remarks */
|
|
88
|
+
customerRemarks: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
89
|
+
/** Guest preferences - customer's selections from range preferences */
|
|
90
|
+
guestPreferences: z.ZodNullable<z.ZodOptional<z.ZodArray<z.ZodObject<{
|
|
91
|
+
name: z.ZodString;
|
|
92
|
+
value: z.ZodUnion<[z.ZodString, z.ZodArray<z.ZodString, "many">]>;
|
|
93
|
+
}, "strip", z.ZodTypeAny, {
|
|
94
|
+
name: string;
|
|
95
|
+
value: string | string[];
|
|
96
|
+
}, {
|
|
97
|
+
name: string;
|
|
98
|
+
value: string | string[];
|
|
99
|
+
}>, "many">>>;
|
|
100
|
+
/** Reserved until timestamp */
|
|
101
|
+
reservedUntil: z.ZodEffects<z.ZodString, string, string>;
|
|
102
|
+
}, "strip", z.ZodTypeAny, {
|
|
103
|
+
userId?: string | null | undefined;
|
|
104
|
+
userName?: string | null | undefined;
|
|
105
|
+
userPhone?: string | null | undefined;
|
|
106
|
+
userEmail?: string | null | undefined;
|
|
107
|
+
slotNumber?: string | null | undefined;
|
|
108
|
+
customerRemarks?: string | null | undefined;
|
|
109
|
+
guestPreferences?: {
|
|
110
|
+
name: string;
|
|
111
|
+
value: string | string[];
|
|
112
|
+
}[] | null | undefined;
|
|
113
|
+
status: "CANCELLED" | "DRAFT" | "CONFIRMED" | "SEATED" | "NO_SHOW";
|
|
114
|
+
_id: string;
|
|
115
|
+
restaurant: string;
|
|
116
|
+
pax: number;
|
|
117
|
+
startDate: string;
|
|
118
|
+
endDate: string;
|
|
119
|
+
reservedUntil: string;
|
|
120
|
+
capacityTierId: string;
|
|
121
|
+
rangeId: string;
|
|
122
|
+
}, {
|
|
123
|
+
userId?: string | null | undefined;
|
|
124
|
+
userName?: string | null | undefined;
|
|
125
|
+
userPhone?: string | null | undefined;
|
|
126
|
+
userEmail?: string | null | undefined;
|
|
127
|
+
slotNumber?: string | null | undefined;
|
|
128
|
+
customerRemarks?: string | null | undefined;
|
|
129
|
+
guestPreferences?: {
|
|
130
|
+
name: string;
|
|
131
|
+
value: string | string[];
|
|
132
|
+
}[] | null | undefined;
|
|
133
|
+
status: "CANCELLED" | "DRAFT" | "CONFIRMED" | "SEATED" | "NO_SHOW";
|
|
134
|
+
_id: string;
|
|
135
|
+
restaurant: string;
|
|
136
|
+
pax: number;
|
|
137
|
+
startDate: string;
|
|
138
|
+
endDate: string;
|
|
139
|
+
reservedUntil: string;
|
|
140
|
+
capacityTierId: string;
|
|
141
|
+
rangeId: string;
|
|
142
|
+
}>;
|
|
143
|
+
export type RestaurantReservationDto = z.infer<typeof RestaurantReservationDto>;
|
|
144
|
+
export type RestaurantReservationPOSDto = z.infer<typeof RestaurantReservationPOSDto>;
|
|
145
|
+
/** DTO for updating a reservation from POS */
|
|
146
|
+
export declare const UpdateReservationPOSDto: z.ZodObject<{
|
|
147
|
+
status: z.ZodEnum<["DRAFT", "CONFIRMED", "CANCELLED", "SEATED", "NO_SHOW"]>;
|
|
148
|
+
pax: z.ZodNumber;
|
|
149
|
+
/** Optional: Update the capacity tier ID if changing time slot or pax */
|
|
150
|
+
capacityTierId: z.ZodString;
|
|
151
|
+
/** Optional: Update the range ID if changing time slot */
|
|
152
|
+
rangeId: z.ZodString;
|
|
153
|
+
/** Optional: Update the start time */
|
|
154
|
+
startDate: z.ZodEffects<z.ZodString, string, string>;
|
|
155
|
+
/** Optional: Update the end time */
|
|
156
|
+
endDate: z.ZodEffects<z.ZodString, string, string>;
|
|
157
|
+
/** Optional: Update pax count */
|
|
158
|
+
userName: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
159
|
+
userPhone: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
160
|
+
userEmail: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
161
|
+
slotNumber: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
162
|
+
customerRemarks: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
163
|
+
/** Guest preferences - customer's selections from range preferences */
|
|
164
|
+
guestPreferences: z.ZodNullable<z.ZodOptional<z.ZodArray<z.ZodObject<{
|
|
165
|
+
name: z.ZodString;
|
|
166
|
+
value: z.ZodUnion<[z.ZodString, z.ZodArray<z.ZodString, "many">]>;
|
|
167
|
+
}, "strip", z.ZodTypeAny, {
|
|
168
|
+
name: string;
|
|
169
|
+
value: string | string[];
|
|
170
|
+
}, {
|
|
171
|
+
name: string;
|
|
172
|
+
value: string | string[];
|
|
173
|
+
}>, "many">>>;
|
|
174
|
+
}, "strip", z.ZodTypeAny, {
|
|
175
|
+
userName?: string | null | undefined;
|
|
176
|
+
userPhone?: string | null | undefined;
|
|
177
|
+
userEmail?: string | null | undefined;
|
|
178
|
+
slotNumber?: string | null | undefined;
|
|
179
|
+
customerRemarks?: string | null | undefined;
|
|
180
|
+
guestPreferences?: {
|
|
181
|
+
name: string;
|
|
182
|
+
value: string | string[];
|
|
183
|
+
}[] | null | undefined;
|
|
184
|
+
status: "CANCELLED" | "DRAFT" | "CONFIRMED" | "SEATED" | "NO_SHOW";
|
|
185
|
+
pax: number;
|
|
186
|
+
startDate: string;
|
|
187
|
+
endDate: string;
|
|
188
|
+
capacityTierId: string;
|
|
189
|
+
rangeId: string;
|
|
190
|
+
}, {
|
|
191
|
+
userName?: string | null | undefined;
|
|
192
|
+
userPhone?: string | null | undefined;
|
|
193
|
+
userEmail?: string | null | undefined;
|
|
194
|
+
slotNumber?: string | null | undefined;
|
|
195
|
+
customerRemarks?: string | null | undefined;
|
|
196
|
+
guestPreferences?: {
|
|
197
|
+
name: string;
|
|
198
|
+
value: string | string[];
|
|
199
|
+
}[] | null | undefined;
|
|
200
|
+
status: "CANCELLED" | "DRAFT" | "CONFIRMED" | "SEATED" | "NO_SHOW";
|
|
201
|
+
pax: number;
|
|
202
|
+
startDate: string;
|
|
203
|
+
endDate: string;
|
|
204
|
+
capacityTierId: string;
|
|
205
|
+
rangeId: string;
|
|
206
|
+
}>;
|
|
207
|
+
export type UpdateReservationPOSDto = z.infer<typeof UpdateReservationPOSDto>;
|
|
208
|
+
/** DTO for creating a reservation from POS */
|
|
209
|
+
export declare const CreateReservationPOSDto: z.ZodObject<{
|
|
210
|
+
capacityTierId: z.ZodString;
|
|
211
|
+
rangeId: z.ZodString;
|
|
212
|
+
startDate: z.ZodEffects<z.ZodString, string, string>;
|
|
213
|
+
endDate: z.ZodEffects<z.ZodString, string, string>;
|
|
214
|
+
pax: z.ZodNumber;
|
|
215
|
+
userName: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
216
|
+
userPhone: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
217
|
+
userEmail: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
218
|
+
customerRemarks: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
219
|
+
slotNumber: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
220
|
+
/** Guest preferences - customer's selections from range preferences */
|
|
221
|
+
guestPreferences: z.ZodNullable<z.ZodOptional<z.ZodArray<z.ZodObject<{
|
|
222
|
+
name: z.ZodString;
|
|
223
|
+
value: z.ZodUnion<[z.ZodString, z.ZodArray<z.ZodString, "many">]>;
|
|
224
|
+
}, "strip", z.ZodTypeAny, {
|
|
225
|
+
name: string;
|
|
226
|
+
value: string | string[];
|
|
227
|
+
}, {
|
|
228
|
+
name: string;
|
|
229
|
+
value: string | string[];
|
|
230
|
+
}>, "many">>>;
|
|
231
|
+
}, "strip", z.ZodTypeAny, {
|
|
232
|
+
userName?: string | null | undefined;
|
|
233
|
+
userPhone?: string | null | undefined;
|
|
234
|
+
userEmail?: string | null | undefined;
|
|
235
|
+
slotNumber?: string | null | undefined;
|
|
236
|
+
customerRemarks?: string | null | undefined;
|
|
237
|
+
guestPreferences?: {
|
|
238
|
+
name: string;
|
|
239
|
+
value: string | string[];
|
|
240
|
+
}[] | null | undefined;
|
|
241
|
+
pax: number;
|
|
242
|
+
startDate: string;
|
|
243
|
+
endDate: string;
|
|
244
|
+
capacityTierId: string;
|
|
245
|
+
rangeId: string;
|
|
246
|
+
}, {
|
|
247
|
+
userName?: string | null | undefined;
|
|
248
|
+
userPhone?: string | null | undefined;
|
|
249
|
+
userEmail?: string | null | undefined;
|
|
250
|
+
slotNumber?: string | null | undefined;
|
|
251
|
+
customerRemarks?: string | null | undefined;
|
|
252
|
+
guestPreferences?: {
|
|
253
|
+
name: string;
|
|
254
|
+
value: string | string[];
|
|
255
|
+
}[] | null | undefined;
|
|
256
|
+
pax: number;
|
|
257
|
+
startDate: string;
|
|
258
|
+
endDate: string;
|
|
259
|
+
capacityTierId: string;
|
|
260
|
+
rangeId: string;
|
|
261
|
+
}>;
|
|
262
|
+
export type CreateReservationPOSDto = z.infer<typeof CreateReservationPOSDto>;
|
|
263
|
+
export declare const ReservationAvailabilitySlotDto: z.ZodObject<{
|
|
264
|
+
status: z.ZodEnum<["AVAILABLE", "FULL"]>;
|
|
265
|
+
/** The capacity tier ID - the actual inventory unit to book */
|
|
266
|
+
capacityTierId: z.ZodOptional<z.ZodEffects<z.ZodString, string, string>>;
|
|
267
|
+
/** The range ID - the zone/area this slot belongs to */
|
|
268
|
+
rangeId: z.ZodOptional<z.ZodEffects<z.ZodString, string, string>>;
|
|
269
|
+
/** The exact ISO start time the frontend should send back to create the booking */
|
|
270
|
+
isoStart: z.ZodOptional<z.ZodEffects<z.ZodString, string, string>>;
|
|
271
|
+
/** The exact ISO end time (Calculated: start + duration) */
|
|
272
|
+
isoEnd: z.ZodOptional<z.ZodEffects<z.ZodString, string, string>>;
|
|
273
|
+
/** Helpful metadata for the UI (e.g., "120 mins") */
|
|
274
|
+
durationMinutes: z.ZodOptional<z.ZodNumber>;
|
|
275
|
+
/** The name of the range (e.g., "VIP Room") - useful for debugging or UI labels */
|
|
276
|
+
label: z.ZodOptional<z.ZodString>;
|
|
277
|
+
}, "strip", z.ZodTypeAny, {
|
|
278
|
+
label?: string | undefined;
|
|
279
|
+
capacityTierId?: string | undefined;
|
|
280
|
+
rangeId?: string | undefined;
|
|
281
|
+
isoStart?: string | undefined;
|
|
282
|
+
isoEnd?: string | undefined;
|
|
283
|
+
durationMinutes?: number | undefined;
|
|
284
|
+
status: "AVAILABLE" | "FULL";
|
|
285
|
+
}, {
|
|
286
|
+
label?: string | undefined;
|
|
287
|
+
capacityTierId?: string | undefined;
|
|
288
|
+
rangeId?: string | undefined;
|
|
289
|
+
isoStart?: string | undefined;
|
|
290
|
+
isoEnd?: string | undefined;
|
|
291
|
+
durationMinutes?: number | undefined;
|
|
292
|
+
status: "AVAILABLE" | "FULL";
|
|
293
|
+
}>;
|
|
294
|
+
export declare const ReservationAvailabilityResponseDto: z.ZodRecord<z.ZodString, z.ZodObject<{
|
|
295
|
+
status: z.ZodEnum<["AVAILABLE", "FULL"]>;
|
|
296
|
+
/** The capacity tier ID - the actual inventory unit to book */
|
|
297
|
+
capacityTierId: z.ZodOptional<z.ZodEffects<z.ZodString, string, string>>;
|
|
298
|
+
/** The range ID - the zone/area this slot belongs to */
|
|
299
|
+
rangeId: z.ZodOptional<z.ZodEffects<z.ZodString, string, string>>;
|
|
300
|
+
/** The exact ISO start time the frontend should send back to create the booking */
|
|
301
|
+
isoStart: z.ZodOptional<z.ZodEffects<z.ZodString, string, string>>;
|
|
302
|
+
/** The exact ISO end time (Calculated: start + duration) */
|
|
303
|
+
isoEnd: z.ZodOptional<z.ZodEffects<z.ZodString, string, string>>;
|
|
304
|
+
/** Helpful metadata for the UI (e.g., "120 mins") */
|
|
305
|
+
durationMinutes: z.ZodOptional<z.ZodNumber>;
|
|
306
|
+
/** The name of the range (e.g., "VIP Room") - useful for debugging or UI labels */
|
|
307
|
+
label: z.ZodOptional<z.ZodString>;
|
|
308
|
+
}, "strip", z.ZodTypeAny, {
|
|
309
|
+
label?: string | undefined;
|
|
310
|
+
capacityTierId?: string | undefined;
|
|
311
|
+
rangeId?: string | undefined;
|
|
312
|
+
isoStart?: string | undefined;
|
|
313
|
+
isoEnd?: string | undefined;
|
|
314
|
+
durationMinutes?: number | undefined;
|
|
315
|
+
status: "AVAILABLE" | "FULL";
|
|
316
|
+
}, {
|
|
317
|
+
label?: string | undefined;
|
|
318
|
+
capacityTierId?: string | undefined;
|
|
319
|
+
rangeId?: string | undefined;
|
|
320
|
+
isoStart?: string | undefined;
|
|
321
|
+
isoEnd?: string | undefined;
|
|
322
|
+
durationMinutes?: number | undefined;
|
|
323
|
+
status: "AVAILABLE" | "FULL";
|
|
324
|
+
}>>;
|
|
325
|
+
export type ReservationAvailabilityResponseDto = z.infer<typeof ReservationAvailabilityResponseDto>;
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Duration unit type for lead time and booking duration
|
|
3
|
+
*/
|
|
4
|
+
export type DurationUnit = 'minute' | 'hour' | 'day';
|
|
5
|
+
/**
|
|
6
|
+
* Duration object with value and unit
|
|
7
|
+
*/
|
|
8
|
+
export interface Duration {
|
|
9
|
+
value: number;
|
|
10
|
+
unit: DurationUnit;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Time range with start and end in HH:mm format
|
|
14
|
+
*/
|
|
15
|
+
export interface TimeRange {
|
|
16
|
+
start: string;
|
|
17
|
+
end: string;
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Operating hours for a day
|
|
21
|
+
*/
|
|
22
|
+
export interface DayOperatingHours {
|
|
23
|
+
enable: boolean;
|
|
24
|
+
hours: TimeRange[];
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Time slot with availability status
|
|
28
|
+
*/
|
|
29
|
+
export interface TimeSlot {
|
|
30
|
+
time: string;
|
|
31
|
+
available: boolean;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Converts a duration to minutes for comparison
|
|
35
|
+
* @param duration - Duration object with value and unit
|
|
36
|
+
* @returns Total minutes
|
|
37
|
+
*/
|
|
38
|
+
export declare function convertDurationToMinutes(duration: Duration): number;
|
|
39
|
+
/**
|
|
40
|
+
* Validates that maxLeadDuration > minLeadDuration
|
|
41
|
+
* @param minLead - Minimum lead time duration
|
|
42
|
+
* @param maxLead - Maximum lead time duration
|
|
43
|
+
* @returns True if valid, false otherwise
|
|
44
|
+
*/
|
|
45
|
+
export declare function validateLeadDuration(minLead: Duration, maxLead: Duration): boolean;
|
|
46
|
+
/**
|
|
47
|
+
* Checks if two time ranges overlap
|
|
48
|
+
* @param range1 - First time range
|
|
49
|
+
* @param range2 - Second time range
|
|
50
|
+
* @returns True if ranges overlap, false otherwise
|
|
51
|
+
*/
|
|
52
|
+
export declare function validateTimeRangeOverlap(range1: TimeRange, range2: TimeRange): boolean;
|
|
53
|
+
/**
|
|
54
|
+
* Validates that end time is after start time for the same day
|
|
55
|
+
* @param timeRange - Time range to validate
|
|
56
|
+
* @returns True if valid (end > start), false otherwise
|
|
57
|
+
*/
|
|
58
|
+
export declare function validateSameDayTimeRange(timeRange: TimeRange): boolean;
|
|
59
|
+
/**
|
|
60
|
+
* Generates time slots for a given time window based on slot interval and booking duration
|
|
61
|
+
*
|
|
62
|
+
* IMPORTANT: This function ensures that bookings fit within operating hours.
|
|
63
|
+
* A slot is only generated if: slotStart + bookingDuration <= windowEnd
|
|
64
|
+
*
|
|
65
|
+
* Example: If window is 17:00-22:00, slotInterval=30min, bookingDuration=90min:
|
|
66
|
+
* - 17:00 ✓ (ends at 18:30)
|
|
67
|
+
* - 17:30 ✓ (ends at 19:00)
|
|
68
|
+
* - ...
|
|
69
|
+
* - 20:30 ✓ (ends at 22:00)
|
|
70
|
+
* - 21:00 ✗ (would end at 22:30, exceeds window)
|
|
71
|
+
*
|
|
72
|
+
* @param windowStart - Start time of the window in HH:mm format
|
|
73
|
+
* @param windowEnd - End time of the window in HH:mm format
|
|
74
|
+
* @param slotInterval - Interval between slots in minutes (e.g., 30)
|
|
75
|
+
* @param bookingDuration - Duration of each booking in minutes (e.g., 60)
|
|
76
|
+
* @returns Array of time slots in HH:mm format
|
|
77
|
+
*/
|
|
78
|
+
export declare function generateTimeSlots(windowStart: string, windowEnd: string, slotInterval: number, bookingDuration: number): string[];
|
|
79
|
+
/**
|
|
80
|
+
* Generates all time slots for a day based on operating hours configuration
|
|
81
|
+
* @param operatingHours - Operating hours configuration for the day
|
|
82
|
+
* @param slotInterval - Interval between slots in minutes
|
|
83
|
+
* @param bookingDuration - Duration of each booking in minutes
|
|
84
|
+
* @returns Array of all available time slots in HH:mm format
|
|
85
|
+
*/
|
|
86
|
+
export declare function generateDayTimeSlots(operatingHours: DayOperatingHours, slotInterval: number, bookingDuration: number): string[];
|
|
87
|
+
/**
|
|
88
|
+
* Categorizes time slots into morning, afternoon, and evening
|
|
89
|
+
* @param slots - Array of time slots in HH:mm format
|
|
90
|
+
* @returns Object with categorized slots
|
|
91
|
+
*/
|
|
92
|
+
export declare function categorizeTimeSlots(slots: string[]): {
|
|
93
|
+
morning: string[];
|
|
94
|
+
afternoon: string[];
|
|
95
|
+
evening: string[];
|
|
96
|
+
};
|
|
97
|
+
/**
|
|
98
|
+
* Categorizes time slots with status into morning, afternoon, and evening
|
|
99
|
+
* @param slots - Array of time slots with availability status
|
|
100
|
+
* @returns Object with categorized slots
|
|
101
|
+
*/
|
|
102
|
+
export declare function categorizeTimeSlotsWithStatus(slots: TimeSlot[]): {
|
|
103
|
+
morning: TimeSlot[];
|
|
104
|
+
afternoon: TimeSlot[];
|
|
105
|
+
evening: TimeSlot[];
|
|
106
|
+
};
|
|
107
|
+
/**
|
|
108
|
+
* Checks if a time slot falls within any of the operating hour windows
|
|
109
|
+
* @param slotTime - Time in HH:mm format
|
|
110
|
+
* @param operatingHours - Operating hours configuration
|
|
111
|
+
* @returns True if slot is within operating hours, false otherwise
|
|
112
|
+
*/
|
|
113
|
+
export declare function isSlotWithinOperatingHours(slotTime: string, operatingHours: TimeRange[]): boolean;
|
|
114
|
+
/**
|
|
115
|
+
* Generates all time slots for the entire day (00:00 - 23:59) with availability status
|
|
116
|
+
*
|
|
117
|
+
* This function generates slots for the full 24-hour period, marking each slot as:
|
|
118
|
+
* - available: true = within operating hours AND booking fits
|
|
119
|
+
* - available: false = outside operating hours OR booking doesn't fit
|
|
120
|
+
*
|
|
121
|
+
* Example: Operating hours 09:00-12:00, 15:00-21:00, slotInterval=30min, bookingDuration=60min
|
|
122
|
+
* - 08:30 ✗ (unavailable - before operating hours)
|
|
123
|
+
* - 09:00 ✓ (available)
|
|
124
|
+
* - 09:30 ✓ (available)
|
|
125
|
+
* - ...
|
|
126
|
+
* - 11:00 ✓ (available - ends at 12:00)
|
|
127
|
+
* - 11:30 ✗ (unavailable - booking would extend to 12:30, beyond window)
|
|
128
|
+
* - 12:00 ✗ (unavailable - outside operating hours)
|
|
129
|
+
* - ...
|
|
130
|
+
* - 14:30 ✗ (unavailable - outside operating hours)
|
|
131
|
+
* - 15:00 ✓ (available)
|
|
132
|
+
*
|
|
133
|
+
* @param operatingHours - Operating hours configuration for the day
|
|
134
|
+
* @param slotInterval - Interval between slots in minutes
|
|
135
|
+
* @param bookingDuration - Duration of each booking in minutes
|
|
136
|
+
* @param startTime - Start time for slot generation (default: '00:00')
|
|
137
|
+
* @param endTime - End time for slot generation (default: '23:59')
|
|
138
|
+
* @returns Array of all time slots with availability status
|
|
139
|
+
*/
|
|
140
|
+
export declare function generateFullDayTimeSlots(operatingHours: DayOperatingHours, slotInterval: number, bookingDuration: number, startTime?: string, endTime?: string): TimeSlot[];
|
|
141
|
+
/**
|
|
142
|
+
* Generates day time slots with availability status (only for operating hours range)
|
|
143
|
+
*
|
|
144
|
+
* This generates slots only within the min/max operating hours range, not full 24h.
|
|
145
|
+
* Useful for compact displays that don't need to show very early/late unavailable slots.
|
|
146
|
+
*
|
|
147
|
+
* @param operatingHours - Operating hours configuration for the day
|
|
148
|
+
* @param slotInterval - Interval between slots in minutes
|
|
149
|
+
* @param bookingDuration - Duration of each booking in minutes
|
|
150
|
+
* @returns Array of time slots with availability status
|
|
151
|
+
*/
|
|
152
|
+
export declare function generateDayTimeSlotsWithStatus(operatingHours: DayOperatingHours, slotInterval: number, bookingDuration: number): TimeSlot[];
|
|
@@ -3861,7 +3861,6 @@ export declare const RestaurantCustomerKioskDto: z.ZodObject<{
|
|
|
3861
3861
|
}, {
|
|
3862
3862
|
showAllOnly: boolean;
|
|
3863
3863
|
}>>>;
|
|
3864
|
-
otaChannel: z.ZodNullable<z.ZodOptional<z.ZodString>>;
|
|
3865
3864
|
}, "strip", z.ZodTypeAny, {
|
|
3866
3865
|
dineIn?: {
|
|
3867
3866
|
requiredSlot?: boolean | null | undefined;
|
|
@@ -3918,7 +3917,6 @@ export declare const RestaurantCustomerKioskDto: z.ZodObject<{
|
|
|
3918
3917
|
menuItem?: {
|
|
3919
3918
|
showAllOnly: boolean;
|
|
3920
3919
|
} | null | undefined;
|
|
3921
|
-
otaChannel?: string | null | undefined;
|
|
3922
3920
|
}, {
|
|
3923
3921
|
dineIn?: {
|
|
3924
3922
|
requiredSlot?: boolean | null | undefined;
|
|
@@ -3975,7 +3973,6 @@ export declare const RestaurantCustomerKioskDto: z.ZodObject<{
|
|
|
3975
3973
|
menuItem?: {
|
|
3976
3974
|
showAllOnly: boolean;
|
|
3977
3975
|
} | null | undefined;
|
|
3978
|
-
otaChannel?: string | null | undefined;
|
|
3979
3976
|
}>>>>;
|
|
3980
3977
|
paymentGateways: z.ZodArray<z.ZodDiscriminatedUnion<"paymentGateway", z.Primitive, z.ZodObject<z.extendShape<{
|
|
3981
3978
|
_id: z.ZodString;
|
|
@@ -4428,7 +4425,6 @@ export declare const RestaurantCustomerKioskDto: z.ZodObject<{
|
|
|
4428
4425
|
menuItem?: {
|
|
4429
4426
|
showAllOnly: boolean;
|
|
4430
4427
|
} | null | undefined;
|
|
4431
|
-
otaChannel?: string | null | undefined;
|
|
4432
4428
|
} | null | undefined;
|
|
4433
4429
|
_id: string;
|
|
4434
4430
|
businessId: string;
|
|
@@ -4683,7 +4679,6 @@ export declare const RestaurantCustomerKioskDto: z.ZodObject<{
|
|
|
4683
4679
|
menuItem?: {
|
|
4684
4680
|
showAllOnly: boolean;
|
|
4685
4681
|
} | null | undefined;
|
|
4686
|
-
otaChannel?: string | null | undefined;
|
|
4687
4682
|
} | null | undefined;
|
|
4688
4683
|
_id: string;
|
|
4689
4684
|
businessId: string;
|