@roomstay/frontend 2.6.40 → 2.6.42

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 (70) hide show
  1. package/dist/586.bundle.js +1 -1
  2. package/dist/839.bundle.js +1 -1
  3. package/dist/927.bundle.js +1 -1
  4. package/dist/main.bundle.js +1 -1
  5. package/dist/src/components/generic/modal/SigninModal/AuthenticatedUserModal.d.ts +0 -1
  6. package/dist/src/components/generic/modal/SigninModal/AuthenticatedUserModal.js +2 -2
  7. package/dist/src/components/generic/modal/SigninModal/AuthenticatedUserModal.js.map +1 -1
  8. package/dist/src/components/steps/date/PeoplePickerRow.js +47 -60
  9. package/dist/src/components/steps/date/PeoplePickerRow.js.map +1 -1
  10. package/dist/src/components/steps/room/AvailableUpgradesModal.js +9 -4
  11. package/dist/src/components/steps/room/AvailableUpgradesModal.js.map +1 -1
  12. package/dist/src/components/steps/room/roomDetails/RoomDetails.js +9 -2
  13. package/dist/src/components/steps/room/roomDetails/RoomDetails.js.map +1 -1
  14. package/dist/src/components/steps/room/roomDetails/roomRates/ReadMoreRoomRateRow.js +5 -1
  15. package/dist/src/components/steps/room/roomDetails/roomRates/ReadMoreRoomRateRow.js.map +1 -1
  16. package/dist/src/components/steps/room/roomDetails/roomRates/RoomRateDescriptionTab.js +2 -1
  17. package/dist/src/components/steps/room/roomDetails/roomRates/RoomRateDescriptionTab.js.map +1 -1
  18. package/dist/src/components/steps/room/roomDetails/roomRates/RoomRateRow.js +5 -2
  19. package/dist/src/components/steps/room/roomDetails/roomRates/RoomRateRow.js.map +1 -1
  20. package/dist/src/contexts/BasketContext/BasketContextType.js.map +1 -1
  21. package/dist/src/contexts/CompanyContext/CompanyContextWrapper.js +2 -10
  22. package/dist/src/contexts/CompanyContext/CompanyContextWrapper.js.map +1 -1
  23. package/dist/src/contexts/FullPageEngineContext/EnginePageLayout.js +32 -1
  24. package/dist/src/contexts/FullPageEngineContext/EnginePageLayout.js.map +1 -1
  25. package/dist/src/contexts/FullPageEngineContext/FullPageEngineContextWrapper.js.map +1 -1
  26. package/dist/src/engines/MemberPortalWidget/MemberPortalWidget.d.ts +3 -4
  27. package/dist/src/engines/MemberPortalWidget/MemberPortalWidget.js +1 -0
  28. package/dist/src/engines/MemberPortalWidget/MemberPortalWidget.js.map +1 -1
  29. package/dist/src/engines/MemberPortalWidget/MemberPortalWidgetElement.d.ts +2 -2
  30. package/dist/src/engines/MemberPortalWidget/MemberPortalWidgetElement.js +20 -9
  31. package/dist/src/engines/MemberPortalWidget/MemberPortalWidgetElement.js.map +1 -1
  32. package/dist/src/hooks/useSignedInMember.d.ts +1 -1
  33. package/dist/src/index.d.ts +1 -0
  34. package/dist/src/index.js +4 -2
  35. package/dist/src/index.js.map +1 -1
  36. package/dist/src/models/Api/HotelDTO.d.ts +1 -0
  37. package/dist/src/models/Api/HotelDTO.js.map +1 -1
  38. package/dist/src/models/Room/Room.d.ts +4 -1
  39. package/dist/src/models/Room/Room.js +6 -1
  40. package/dist/src/models/Room/Room.js.map +1 -1
  41. package/dist/src/models/Room/RoomRate.d.ts +6 -1
  42. package/dist/src/models/Room/RoomRate.js +12 -1
  43. package/dist/src/models/Room/RoomRate.js.map +1 -1
  44. package/dist/src/models/Room/RoomRateSortable.d.ts +2 -1
  45. package/dist/src/models/Room/RoomRateSortable.js.map +1 -1
  46. package/dist/src/pages/findReservation/ReservationRow.js +1 -1
  47. package/dist/src/pages/findReservation/ReservationRow.js.map +1 -1
  48. package/dist/src/pages/hotel/HotelInfo.js +20 -15
  49. package/dist/src/pages/hotel/HotelInfo.js.map +1 -1
  50. package/dist/src/providers/RoomSortProvider.js +6 -2
  51. package/dist/src/providers/RoomSortProvider.js.map +1 -1
  52. package/dist/src/util/Analytics/Analytics.d.ts +31 -0
  53. package/dist/src/util/Analytics/Analytics.js +22 -0
  54. package/dist/src/util/Analytics/Analytics.js.map +1 -0
  55. package/dist/src/util/Analytics/GoogleAnalytics4.d.ts +127 -0
  56. package/dist/src/util/Analytics/GoogleAnalytics4.js +217 -0
  57. package/dist/src/util/Analytics/GoogleAnalytics4.js.map +1 -0
  58. package/dist/src/util/Analytics/UniversalAnalytics.d.ts +110 -0
  59. package/dist/src/util/Analytics/UniversalAnalytics.js +210 -0
  60. package/dist/src/util/Analytics/UniversalAnalytics.js.map +1 -0
  61. package/dist/src/util/DataLayer.d.ts +33 -29
  62. package/dist/src/util/DataLayer.js +78 -233
  63. package/dist/src/util/DataLayer.js.map +1 -1
  64. package/dist/test.bundle.js +1 -1
  65. package/dist/tests/jest/models/RoomRate.test.js +1 -1
  66. package/dist/tests/jest/models/RoomRate.test.js.map +1 -1
  67. package/dist/tests/offline/entry/OfflineEngineDefaults.js +4 -0
  68. package/dist/tests/offline/entry/OfflineEngineDefaults.js.map +1 -1
  69. package/dist/vendors.bundle.js +1 -1
  70. package/package.json +2 -2
@@ -0,0 +1,210 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.UniversalAnalytics = void 0;
7
+ const dayjs_1 = __importDefault(require("dayjs"));
8
+ const Analytics_1 = require("./Analytics");
9
+ const DATALAYER_DATE_FORMAT = 'YYYY-M-D';
10
+ class UniversalAnalytics extends Analytics_1.Analytics {
11
+ getProductInfo(room, rate, listPosition, quantity) {
12
+ var _a, _b, _c;
13
+ const providerId = (_a = this.hotel) === null || _a === void 0 ? void 0 : _a.providerHotelID;
14
+ const price = rate ? rate.getAveragePrice() : room.getLowestPrice();
15
+ const nameParts = [room.name];
16
+ const idParts = [providerId, room.code];
17
+ if (rate) {
18
+ nameParts.push(rate.name);
19
+ idParts.push(rate.code);
20
+ }
21
+ const product = {
22
+ name: nameParts.join(' - '),
23
+ id: idParts.join(' - '),
24
+ price: price,
25
+ brand: [(_b = this.hotel) === null || _b === void 0 ? void 0 : _b.name, providerId, (_c = this.company) === null || _c === void 0 ? void 0 : _c.brandSuffix].filter(Boolean).join(' - '),
26
+ category: room.name,
27
+ };
28
+ if (rate) {
29
+ product.variant = rate.name;
30
+ }
31
+ if (listPosition !== undefined) {
32
+ product.list = 'BE List';
33
+ product.position = listPosition;
34
+ }
35
+ if (quantity !== undefined) {
36
+ product.quantity = quantity;
37
+ }
38
+ return product;
39
+ }
40
+ generateAddonProductInfo(addonRow) {
41
+ var _a, _b, _c;
42
+ const addon = addonRow.getAddon();
43
+ return {
44
+ name: addon.name,
45
+ id: addon.code,
46
+ price: addonRow.getTotalPrice(),
47
+ brand: [(_a = this.hotel) === null || _a === void 0 ? void 0 : _a.name, (_b = this.hotel) === null || _b === void 0 ? void 0 : _b.providerHotelID, (_c = this.company) === null || _c === void 0 ? void 0 : _c.brandSuffix].filter(Boolean).join(' - '),
48
+ category: addon.category,
49
+ quantity: addonRow.getTotalQuantity(),
50
+ };
51
+ }
52
+ generateRoomImpressionMessageObject(impressions) {
53
+ return {
54
+ event: 'Product impressions',
55
+ ecommerce: {
56
+ currencyCode: this.currency.original,
57
+ impressions: impressions.map((item, index) => {
58
+ const { room, quantity } = item;
59
+ return this.getProductInfo(room, undefined, index, quantity);
60
+ }),
61
+ },
62
+ };
63
+ }
64
+ generateProductClickMessageObject(product) {
65
+ const { room, rate, quantity } = product;
66
+ return {
67
+ event: 'productClick',
68
+ ecommerce: {
69
+ currencyCode: this.currency.original,
70
+ click: {
71
+ products: [this.getProductInfo(room, rate, undefined, quantity)],
72
+ },
73
+ StartDate: product.dateRange.from.format(DATALAYER_DATE_FORMAT),
74
+ EndDate: product.dateRange.to.format(DATALAYER_DATE_FORMAT),
75
+ },
76
+ };
77
+ }
78
+ generateDateSelectionMessageObject(dateRange, adults, children, infants) {
79
+ return {
80
+ event: 'dateSelection',
81
+ arrivalDate: dateRange.from.format(DATALAYER_DATE_FORMAT),
82
+ departureDate: dateRange.to.format(DATALAYER_DATE_FORMAT),
83
+ adultQty: Number.isInteger(adults) ? `${adults}` : null,
84
+ childQty: Number.isInteger(children) ? `${children}` : null,
85
+ infantQty: Number.isInteger(infants) ? `${infants}` : null,
86
+ };
87
+ }
88
+ generateAddToCartMessageObject(product) {
89
+ const productInfo = this.getProductInfo(product.room, product.rate, undefined, product.quantity);
90
+ return {
91
+ event: 'addToCart',
92
+ ecommerce: {
93
+ currencyCode: this.currency.original,
94
+ add: {
95
+ products: [productInfo],
96
+ },
97
+ StartDate: product.dateRange.from.format(DATALAYER_DATE_FORMAT),
98
+ EndDate: product.dateRange.to.format(DATALAYER_DATE_FORMAT),
99
+ },
100
+ };
101
+ }
102
+ generateUpsellConfirmedMessageObject(oldProduct, newProduct) {
103
+ const newRate = newProduct.rate;
104
+ const oldRate = oldProduct.rate;
105
+ if (!newRate || !oldRate) {
106
+ return null;
107
+ }
108
+ const oldConvertedProduct = this.getProductInfo(oldRate.getRoom(), oldRate);
109
+ const newConvertedProduct = this.getProductInfo(newRate.getRoom(), newRate);
110
+ return {
111
+ event: 'upsellConfirmed',
112
+ priceDifference: newRate.getTotalPrice() - oldRate.getTotalPrice(),
113
+ old: {
114
+ products: [oldConvertedProduct],
115
+ },
116
+ new: {
117
+ products: [newConvertedProduct],
118
+ },
119
+ };
120
+ }
121
+ generateUpsellCancelledMessageObject(product) {
122
+ const { room, rate, quantity } = product;
123
+ const productInfo = this.getProductInfo(room, rate, undefined, quantity);
124
+ return {
125
+ event: 'upsellCancelled',
126
+ item: [productInfo],
127
+ };
128
+ }
129
+ generateCheckoutViewMessageObject(basketRows, addonRows) {
130
+ const products = [];
131
+ let startDate = undefined;
132
+ let endDate = undefined;
133
+ basketRows.forEach((row) => {
134
+ startDate = row.getStartDate();
135
+ endDate = row.getEndDate();
136
+ products.push(this.getProductInfo(row.getRoom(), row.getRate(), undefined, row.getNumberOfDays()));
137
+ });
138
+ addonRows.forEach((row) => {
139
+ products.push(this.generateAddonProductInfo(row));
140
+ });
141
+ return {
142
+ event: 'checkout',
143
+ ecommerce: {
144
+ currencyCode: this.currency.original,
145
+ checkout: {
146
+ actionField: { step: 1 },
147
+ products,
148
+ },
149
+ StartDate: startDate === null || startDate === void 0 ? void 0 : startDate.format(DATALAYER_DATE_FORMAT),
150
+ EndDate: endDate === null || endDate === void 0 ? void 0 : endDate.format(DATALAYER_DATE_FORMAT),
151
+ PageType: 'conversionintent',
152
+ },
153
+ };
154
+ }
155
+ generateRoomPurchaseMessageObject(basketRows, addonRows, reservations) {
156
+ let i = 0;
157
+ return basketRows.map((row) => {
158
+ var _a;
159
+ const products = [this.getProductInfo(row.getRoom(), row.getRate(), undefined, row.getNumberOfDays())];
160
+ if (i === 0) {
161
+ addonRows.forEach((addonRow) => {
162
+ products.push(this.generateAddonProductInfo(addonRow));
163
+ });
164
+ }
165
+ try {
166
+ const upsellPrevRoom = row.getUpsellPrevRoom();
167
+ const extraData = {};
168
+ if (upsellPrevRoom) {
169
+ extraData.checkoutUpsell = {
170
+ active: true,
171
+ oldRoom: upsellPrevRoom.code,
172
+ newRoom: row.getRoom().code,
173
+ priceDifference: (((_a = row.getRate()) === null || _a === void 0 ? void 0 : _a.getTotalPrice()) || 0) - (upsellPrevRoom.price || 0),
174
+ };
175
+ }
176
+ return {
177
+ event: 'roomPurchase',
178
+ ecommerce: Object.assign({ currencyCode: this.currency.original, purchase: {
179
+ actionField: {
180
+ id: reservations.reservations[i].reservationNumber,
181
+ revenue: reservations.reservations[i].total.afterTax,
182
+ tax: reservations.reservations[i].total.afterTax - reservations.reservations[i].total.beforeTax,
183
+ coupon: row.getPromoCode(),
184
+ },
185
+ products,
186
+ }, StartDate: row.getStartDate().format(DATALAYER_DATE_FORMAT), EndDate: row.getEndDate().format(DATALAYER_DATE_FORMAT), BookingDate: (0, dayjs_1.default)().format(DATALAYER_DATE_FORMAT), PageType: 'conversion', paymentType: reservations.reservations[i].paymentMethod }, extraData),
187
+ };
188
+ }
189
+ catch (e) {
190
+ // test
191
+ }
192
+ i++;
193
+ });
194
+ }
195
+ generateRefundMessageObject(reservation) {
196
+ return {
197
+ event: 'refund',
198
+ ecommerce: {
199
+ refund: {
200
+ actionField: {
201
+ id: reservation.reservationNumber,
202
+ },
203
+ },
204
+ },
205
+ };
206
+ }
207
+ }
208
+ const ua = new UniversalAnalytics();
209
+ exports.UniversalAnalytics = ua;
210
+ //# sourceMappingURL=UniversalAnalytics.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UniversalAnalytics.js","sourceRoot":"/","sources":["src/util/Analytics/UniversalAnalytics.ts"],"names":[],"mappings":"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","sourcesContent":["import dayjs, { Dayjs } from 'dayjs';\n\nimport ReservationsDTO, { ReservationDTO } from '@/models/Api/ReservationsDTO';\nimport BasketAddonRow from '@/models/BasketAddonRow';\nimport BasketRow from '@/models/BasketRow';\nimport { Room } from '@/models/Room/Room';\nimport { RoomRate } from '@/models/Room/RoomRate';\n\nimport { DateRange, GenericAnalyticsAccommodation } from '../DataLayer';\nimport { Analytics } from './Analytics';\n\nconst DATALAYER_DATE_FORMAT = 'YYYY-M-D';\n\nclass UniversalAnalytics extends Analytics {\n private getProductInfo(room: Room, rate?: RoomRate, listPosition?: number, quantity?: number): Product {\n const providerId = this.hotel?.providerHotelID;\n\n const price = rate ? rate.getAveragePrice() : room.getLowestPrice();\n const nameParts = [room.name];\n const idParts = [providerId, room.code];\n if (rate) {\n nameParts.push(rate.name);\n idParts.push(rate.code);\n }\n\n const product: Product = {\n name: nameParts.join(' - '),\n id: idParts.join(' - '),\n price: price,\n brand: [this.hotel?.name, providerId, this.company?.brandSuffix].filter(Boolean).join(' - '),\n category: room.name as string,\n };\n\n if (rate) {\n product.variant = rate.name;\n }\n\n if (listPosition !== undefined) {\n product.list = 'BE List';\n product.position = listPosition;\n }\n\n if (quantity !== undefined) {\n product.quantity = quantity;\n }\n\n return product;\n }\n\n private generateAddonProductInfo(addonRow: BasketAddonRow): Product {\n const addon = addonRow.getAddon();\n return {\n name: addon.name,\n id: addon.code,\n price: addonRow.getTotalPrice(),\n brand: [this.hotel?.name, this.hotel?.providerHotelID, this.company?.brandSuffix].filter(Boolean).join(' - '),\n category: addon.category,\n quantity: addonRow.getTotalQuantity(),\n };\n }\n\n public generateRoomImpressionMessageObject(impressions: GenericAnalyticsAccommodation[]) {\n return {\n event: 'Product impressions',\n ecommerce: {\n currencyCode: this.currency.original,\n impressions: impressions.map((item, index) => {\n const { room, quantity } = item;\n return this.getProductInfo(room, undefined, index, quantity);\n }),\n },\n };\n }\n\n public generateProductClickMessageObject(product: GenericAnalyticsAccommodation) {\n const { room, rate, quantity } = product;\n return {\n event: 'productClick',\n ecommerce: {\n currencyCode: this.currency.original,\n click: {\n products: [this.getProductInfo(room, rate, undefined, quantity)],\n },\n StartDate: product.dateRange.from.format(DATALAYER_DATE_FORMAT),\n EndDate: product.dateRange.to.format(DATALAYER_DATE_FORMAT),\n },\n };\n }\n\n public generateDateSelectionMessageObject(dateRange: DateRange, adults: number, children: number, infants?: number | undefined) {\n return {\n event: 'dateSelection',\n arrivalDate: dateRange.from.format(DATALAYER_DATE_FORMAT),\n departureDate: dateRange.to.format(DATALAYER_DATE_FORMAT),\n adultQty: Number.isInteger(adults) ? `${adults}` : null,\n childQty: Number.isInteger(children) ? `${children}` : null,\n infantQty: Number.isInteger(infants) ? `${infants}` : null,\n };\n }\n\n public generateAddToCartMessageObject(product: GenericAnalyticsAccommodation) {\n const productInfo = this.getProductInfo(product.room, product.rate, undefined, product.quantity);\n\n return {\n event: 'addToCart',\n ecommerce: {\n currencyCode: this.currency.original,\n add: {\n products: [productInfo],\n },\n StartDate: product.dateRange.from.format(DATALAYER_DATE_FORMAT),\n EndDate: product.dateRange.to.format(DATALAYER_DATE_FORMAT),\n },\n };\n }\n\n public generateUpsellConfirmedMessageObject(oldProduct: GenericAnalyticsAccommodation, newProduct: GenericAnalyticsAccommodation) {\n const newRate = newProduct.rate;\n const oldRate = oldProduct.rate;\n\n if (!newRate || !oldRate) {\n return null;\n }\n\n const oldConvertedProduct = this.getProductInfo(oldRate.getRoom(), oldRate);\n const newConvertedProduct = this.getProductInfo(newRate.getRoom(), newRate);\n\n return {\n event: 'upsellConfirmed',\n priceDifference: newRate.getTotalPrice() - oldRate.getTotalPrice(),\n old: {\n products: [oldConvertedProduct],\n },\n new: {\n products: [newConvertedProduct],\n },\n };\n }\n\n public generateUpsellCancelledMessageObject(product: GenericAnalyticsAccommodation) {\n const { room, rate, quantity } = product;\n\n const productInfo = this.getProductInfo(room, rate, undefined, quantity);\n\n return {\n event: 'upsellCancelled',\n item: [productInfo],\n };\n }\n\n public generateCheckoutViewMessageObject(basketRows: BasketRow[], addonRows: BasketAddonRow[]) {\n const products: Product[] = [];\n\n let startDate: Dayjs | undefined = undefined;\n let endDate: Dayjs | undefined = undefined;\n\n basketRows.forEach((row) => {\n startDate = row.getStartDate();\n endDate = row.getEndDate();\n products.push(this.getProductInfo(row.getRoom(), row.getRate() as RoomRate, undefined, row.getNumberOfDays()));\n });\n\n addonRows.forEach((row) => {\n products.push(this.generateAddonProductInfo(row));\n });\n\n return {\n event: 'checkout',\n ecommerce: {\n currencyCode: this.currency.original,\n checkout: {\n actionField: { step: 1 },\n products,\n },\n StartDate: (startDate as Dayjs | undefined)?.format(DATALAYER_DATE_FORMAT),\n EndDate: (endDate as Dayjs | undefined)?.format(DATALAYER_DATE_FORMAT),\n PageType: 'conversionintent',\n },\n };\n }\n\n public generateRoomPurchaseMessageObject(basketRows: BasketRow[], addonRows: BasketAddonRow[], reservations: ReservationsDTO) {\n let i = 0;\n return basketRows.map((row) => {\n const products = [this.getProductInfo(row.getRoom(), row.getRate() as RoomRate, undefined, row.getNumberOfDays())];\n\n if (i === 0) {\n addonRows.forEach((addonRow) => {\n products.push(this.generateAddonProductInfo(addonRow));\n });\n }\n\n try {\n const upsellPrevRoom = row.getUpsellPrevRoom();\n const extraData: { checkoutUpsell?: any } = {};\n if (upsellPrevRoom) {\n extraData.checkoutUpsell = {\n active: true,\n oldRoom: upsellPrevRoom.code,\n newRoom: row.getRoom().code,\n priceDifference: (row.getRate()?.getTotalPrice() || 0) - (upsellPrevRoom.price || 0),\n };\n }\n\n return {\n event: 'roomPurchase',\n ecommerce: {\n currencyCode: this.currency.original,\n purchase: {\n actionField: {\n id: reservations.reservations[i].reservationNumber,\n revenue: reservations.reservations[i].total.afterTax,\n tax: reservations.reservations[i].total.afterTax - reservations.reservations[i].total.beforeTax,\n coupon: row.getPromoCode(),\n },\n products,\n },\n StartDate: row.getStartDate().format(DATALAYER_DATE_FORMAT),\n EndDate: row.getEndDate().format(DATALAYER_DATE_FORMAT),\n BookingDate: dayjs().format(DATALAYER_DATE_FORMAT),\n PageType: 'conversion',\n paymentType: reservations.reservations[i].paymentMethod,\n ...extraData,\n },\n };\n } catch (e) {\n // test\n }\n\n i++;\n });\n }\n\n public generateRefundMessageObject(reservation: ReservationDTO): any {\n return {\n event: 'refund',\n ecommerce: {\n refund: {\n actionField: {\n id: reservation.reservationNumber,\n },\n },\n },\n };\n }\n}\n\nconst ua = new UniversalAnalytics();\n\nexport { ua as UniversalAnalytics };\n\ntype Product = {\n name: string; // <Put the Room Variant here example - ‘BAE - Best Available Everyday - Superoo’>\n id: string; // <Put the SKU for Room variant here example - ‘62991 - VEK - 04BAE’>\n price: number; // <Put the PER DAY price of room>\n brand: string; // <Put the hotel brand here example - ‘Australia - Ovolo Woolloomooloo - 62991’>\n category: string; // <Put the Category of room here example - ‘Superoo’>\n variant?: string; // <Put the Variant of room here example - ‘BAE - Best Available Everyday - Prepaid Rate’>\n list?: string; // <Put ‘BE List’ if shown in Booking Engine else put ‘Hotel List’>\n position?: number; // <Put the position of hotel in the list here example 1’>\n quantity?: number; // <Put the rooms X nights>\n};\n"]}
@@ -1,39 +1,55 @@
1
1
  import { Dayjs } from 'dayjs';
2
- import ReservationsDTO from '../models/Api/ReservationsDTO';
2
+ import ReservationsDTO, { ReservationDTO } from '../models/Api/ReservationsDTO';
3
3
  import BasketAddonRow from '../models/BasketAddonRow';
4
4
  import BasketRow from '../models/BasketRow';
5
- import { ConfigCompany, HasDatalayerTags } from '../models/Client/Hotel/Company';
5
+ import { ConfigCompany } from '../models/Client/Hotel/Company';
6
6
  import { Room } from '../models/Room/Room';
7
7
  import { RoomRate } from '../models/Room/RoomRate';
8
+ import { Hotel } from '..';
9
+ import { Analytics } from './Analytics/Analytics';
10
+ export declare enum DatalayerAnalyticsMode {
11
+ UniversalAnaltics = "UniversalAnalytics",
12
+ GoogleAnalytics4 = "GoogleAnalytics4"
13
+ }
14
+ export type GenericAnalyticsAccommodation = {
15
+ room: Room;
16
+ dateRange: {
17
+ from: Dayjs;
18
+ to: Dayjs;
19
+ };
20
+ rate?: RoomRate;
21
+ quantity?: number;
22
+ promoCode?: string;
23
+ };
24
+ export interface DateRange {
25
+ from: Dayjs;
26
+ to: Dayjs;
27
+ }
8
28
  export default class DataLayer {
9
29
  static instance: DataLayer;
10
30
  private enableLogging;
11
- private hotelName;
12
- private providerHotelID;
13
31
  private originalCurrencyCode?;
32
+ private currentCurrencyCode;
14
33
  private impressions;
15
- private brandSuffix?;
16
- static initialiseGTM(hotelConfig?: HasDatalayerTags): void;
17
- setProviderHotelID(id: string): void;
18
- setHotelName(hotelName: string): void;
34
+ private hotel?;
35
+ private company?;
36
+ initialiseGTM(company: ConfigCompany, hotel?: Hotel): void;
37
+ setAnalyticsMode(mode: Analytics): void;
19
38
  setCurrencyCodes(currentCurrencyCode: string, originalCurrencyCode?: string): void;
20
- setBrandSuffix(brandSuffix?: ConfigCompany['brandSuffix']): void;
21
- generateProductInfo(room: Room, rate?: RoomRate, listPosition?: number, quantity?: number): Product;
22
- generateAddonProductInfo(addonRow: BasketAddonRow): Product;
23
- addRoomImpression(room: Room): void;
24
- addRoomRateImpression(room: Room, rate: RoomRate): void;
39
+ addRoomImpression(room: Room, dateRange: DateRange, promoCode: string): void;
40
+ addRoomRateImpression(room: Room, rate: RoomRate, dateRange: DateRange, promoCode: string): void;
25
41
  sendRoomImpressions(): void;
26
- sendRoomClick(room: Room, startDate: Dayjs, endDate: Dayjs): void;
42
+ sendRoomClick(room: Room, startDate: Dayjs, endDate: Dayjs, promoCode?: string): void;
27
43
  sendAwayWindowOpen(): void;
28
44
  sendRoomRateAddToCart(rate: RoomRate, quantity: number, startDate: Dayjs, endDate: Dayjs): void;
29
- sendUpsellCancelled(rate: RoomRate): void;
30
- sendUpsellConfirmed(oldRate: RoomRate, newRate: RoomRate): void;
45
+ sendUpsellConfirmed(dateRange: DateRange, oldRate: RoomRate, newRate: RoomRate): void;
46
+ sendUpsellCancelled(dateRange: DateRange, rate: RoomRate): void;
31
47
  sendRoomView(startDate: Dayjs, endDate: Dayjs): void;
32
48
  sendCheckoutView(basketRows: BasketRow[], addonRows: BasketAddonRow[]): void;
33
49
  sendReservationConfirmed(basketRows: BasketRow[], addonRows: BasketAddonRow[], reservations: ReservationsDTO): void;
50
+ sendCancellation(reservationNumber: ReservationDTO): void;
34
51
  sendMemberSignUp(): void;
35
52
  sendInteraction(name: string, type: InteractionType, step: InteractionStep): void;
36
- sendCancellation(reservationNumber: string): void;
37
53
  sendDateSelection({ startDate, endDate, adult, children, infant }: {
38
54
  startDate: Dayjs;
39
55
  endDate: Dayjs;
@@ -43,17 +59,6 @@ export default class DataLayer {
43
59
  }): void;
44
60
  protected log(...output: any): void;
45
61
  }
46
- type Product = {
47
- name: string;
48
- id: string;
49
- price: number;
50
- brand: string;
51
- category: string;
52
- variant?: string;
53
- list?: string;
54
- position?: number;
55
- quantity?: number;
56
- };
57
62
  export declare enum InteractionType {
58
63
  NUMBER_INPUT = "+-widget",
59
64
  CALENDAR = "Calendar",
@@ -69,4 +74,3 @@ export declare enum InteractionStep {
69
74
  ROOMS = "Rooms",
70
75
  GUEST_DETAILS = "Guest Details"
71
76
  }
72
- export {};