iticket-seatingplan-dev 1.2.8 → 1.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/SeatingPlan.js +46 -25
- package/package.json +1 -1
|
@@ -24,7 +24,7 @@ const SeatingPlan = _ref => {
|
|
|
24
24
|
sessionId,
|
|
25
25
|
showingId,
|
|
26
26
|
areaId,
|
|
27
|
-
|
|
27
|
+
priceSectionIds,
|
|
28
28
|
price,
|
|
29
29
|
quantity,
|
|
30
30
|
callbackFunction,
|
|
@@ -61,13 +61,13 @@ const SeatingPlan = _ref => {
|
|
|
61
61
|
fillOpacity: s.loading ? 0 : 1
|
|
62
62
|
};
|
|
63
63
|
};
|
|
64
|
-
const addTicketToCart = (s,
|
|
64
|
+
const addTicketToCart = (s, priceage, cs) => {
|
|
65
65
|
map.target.closePopup();
|
|
66
66
|
setProcessing(true);
|
|
67
67
|
fetch("".concat(baseUrl, "/legacy/").concat(countryCode, "/shop/events/").concat(eventId, "/").concat(eventVenueId, "/showings/").concat(showingId, "/tickets/allocated/").concat(areaId), {
|
|
68
68
|
method: 'POST',
|
|
69
69
|
body: JSON.stringify({
|
|
70
|
-
priceAgeId:
|
|
70
|
+
priceAgeId: priceage.paId,
|
|
71
71
|
seatId: s.ssId,
|
|
72
72
|
connectedShowings: connectedShowings
|
|
73
73
|
}),
|
|
@@ -82,7 +82,6 @@ const SeatingPlan = _ref => {
|
|
|
82
82
|
fillColor: statusColors.sold
|
|
83
83
|
});
|
|
84
84
|
cs ? cs.seat.s = 2 : chosenSeat.seat.s = 2;
|
|
85
|
-
console.log(cs.seat, chosenSeat);
|
|
86
85
|
const event = {
|
|
87
86
|
type: 'error',
|
|
88
87
|
details: {
|
|
@@ -141,9 +140,23 @@ const SeatingPlan = _ref => {
|
|
|
141
140
|
r: s.r,
|
|
142
141
|
c: s.c,
|
|
143
142
|
showingId: showingId,
|
|
144
|
-
|
|
145
|
-
|
|
143
|
+
pId: priceage.paId,
|
|
144
|
+
p: priceage.p,
|
|
145
|
+
paName: priceage.paName
|
|
146
146
|
}]);
|
|
147
|
+
const event = {
|
|
148
|
+
type: 'cart-change-add',
|
|
149
|
+
details: [...bookedSeats, {
|
|
150
|
+
ssId: s.ssId,
|
|
151
|
+
r: s.r,
|
|
152
|
+
c: s.c,
|
|
153
|
+
showingId: showingId,
|
|
154
|
+
pId: priceage.paId,
|
|
155
|
+
p: priceage.p,
|
|
156
|
+
paName: priceage.paName
|
|
157
|
+
}]
|
|
158
|
+
};
|
|
159
|
+
callbackFunction(event);
|
|
147
160
|
}
|
|
148
161
|
}).catch(error => {
|
|
149
162
|
s.loading = false;
|
|
@@ -184,6 +197,11 @@ const SeatingPlan = _ref => {
|
|
|
184
197
|
});
|
|
185
198
|
setBookedSeats(bookedSeats.filter(bs => bs.ssId !== s.ssId));
|
|
186
199
|
setProcessing(false);
|
|
200
|
+
const event = {
|
|
201
|
+
type: 'cart-change-remove',
|
|
202
|
+
details: bookedSeats.filter(bs => bs.ssId === s.ssId)
|
|
203
|
+
};
|
|
204
|
+
callbackFunction(event);
|
|
187
205
|
}).catch(error => {
|
|
188
206
|
e.target.setStyle({
|
|
189
207
|
fillColor: statusColors.booked
|
|
@@ -219,10 +237,10 @@ const SeatingPlan = _ref => {
|
|
|
219
237
|
seat: s
|
|
220
238
|
});
|
|
221
239
|
if (s.s === 1) {
|
|
222
|
-
const availablePrices = seats.pricing.filter(price => price.psId ===
|
|
240
|
+
const availablePrices = seats.pricing.filter(price => (!priceSectionIds || priceSectionIds.includes(price.psId)) && s.psId === price.psId);
|
|
223
241
|
if (availablePrices.length === 1) {
|
|
224
242
|
s.loading = true;
|
|
225
|
-
addTicketToCart(s, availablePrices[0]
|
|
243
|
+
addTicketToCart(s, availablePrices[0], {
|
|
226
244
|
circle: e,
|
|
227
245
|
seat: s
|
|
228
246
|
});
|
|
@@ -262,7 +280,8 @@ const SeatingPlan = _ref => {
|
|
|
262
280
|
c: s.c,
|
|
263
281
|
showingId: showingId,
|
|
264
282
|
p: price || s.defaultPrice,
|
|
265
|
-
|
|
283
|
+
psId: null,
|
|
284
|
+
paName: null
|
|
266
285
|
})));
|
|
267
286
|
img.onload = () => {
|
|
268
287
|
setPosition([img.height * 0.005, img.width * 0.005]);
|
|
@@ -291,25 +310,24 @@ const SeatingPlan = _ref => {
|
|
|
291
310
|
setPosition(null);
|
|
292
311
|
}
|
|
293
312
|
}, [areaId]);
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
}, [bookedSeats]);
|
|
313
|
+
|
|
314
|
+
// useEffect(() => {
|
|
315
|
+
// if (bookedSeats && position && chosenSeat) {
|
|
316
|
+
// const event = { type: 'cart-change', details: bookedSeats }
|
|
317
|
+
// callbackFunction(event)
|
|
318
|
+
// }
|
|
319
|
+
// }, [bookedSeats])
|
|
320
|
+
|
|
303
321
|
(0, _react.useEffect)(() => {
|
|
304
322
|
if (processing) {
|
|
305
|
-
const availablePrices = seats.pricing.filter(price => price.psId
|
|
323
|
+
const availablePrices = seats.pricing.filter(price => !priceSectionIds || priceSectionIds.includes(price.psId));
|
|
306
324
|
availablePrices.length === 1 && (chosenSeat === null || chosenSeat === void 0 ? void 0 : chosenSeat.circle.target.setStyle({
|
|
307
325
|
fillOpacity: 0
|
|
308
326
|
}));
|
|
309
327
|
}
|
|
310
328
|
}, [chosenSeat, processing]);
|
|
311
329
|
const calculateCenterOfMap = (height, seats) => {
|
|
312
|
-
const filteredSeats = seats.filter(price => price.psId
|
|
330
|
+
const filteredSeats = seats.filter(price => !priceSectionIds || priceSectionIds.includes(price.psId));
|
|
313
331
|
const avgY = filteredSeats.reduce((acc, val) => {
|
|
314
332
|
return acc + val.y / filteredSeats.length;
|
|
315
333
|
}, 0);
|
|
@@ -319,7 +337,7 @@ const SeatingPlan = _ref => {
|
|
|
319
337
|
return [height * 0.05 - avgY / (height > 800 ? height > 999 ? 3.5 : 3.3 : 3.35) - (height > 800 ? height > 999 ? height * 0.0201 : height * 0.0198 : height * 0.0206), avgX * 0.3 + 0.15];
|
|
320
338
|
};
|
|
321
339
|
const determineZoom = seats => {
|
|
322
|
-
const filteredSeats = seats.filter(price => price.psId
|
|
340
|
+
const filteredSeats = seats.filter(price => !priceSectionIds || priceSectionIds.includes(price.psId));
|
|
323
341
|
const x = filteredSeats.map(fs => fs.x);
|
|
324
342
|
const y = filteredSeats.map(fs => fs.y);
|
|
325
343
|
const maxX = Math.max(...x) - Math.min(...x);
|
|
@@ -486,7 +504,7 @@ const SeatingPlan = _ref => {
|
|
|
486
504
|
|
|
487
505
|
opacity: s.loading ? 100 : 0,
|
|
488
506
|
zIndex: 10
|
|
489
|
-
}), !
|
|
507
|
+
}), !priceSectionIds || priceSectionIds.includes(s.psId) ? s.s === 6 ? /*#__PURE__*/_react.default.createElement(_reactLeaflet.ImageOverlay, {
|
|
490
508
|
url: '',
|
|
491
509
|
bounds: [
|
|
492
510
|
// [
|
|
@@ -536,13 +554,16 @@ const SeatingPlan = _ref => {
|
|
|
536
554
|
click: e => handleClick(e, s)
|
|
537
555
|
}
|
|
538
556
|
// value={s}
|
|
539
|
-
},
|
|
557
|
+
}, /*#__PURE__*/_react.default.createElement(_reactLeaflet.Tooltip, {
|
|
558
|
+
direction: 'top',
|
|
559
|
+
offset: [0, height * 0.03 + -30]
|
|
560
|
+
}, s.r + '-' + s.c, ' '), s.s === 1 && /*#__PURE__*/_react.default.createElement(_reactLeaflet.Popup, null, /*#__PURE__*/_react.default.createElement("p", {
|
|
540
561
|
style: {
|
|
541
562
|
marginTop: '0.2rem',
|
|
542
563
|
marginBottom: '0.2rem',
|
|
543
564
|
fontWeight: 'bold'
|
|
544
565
|
}
|
|
545
|
-
}, "Select option:"), seats.pricing.filter(price => price.psId ===
|
|
566
|
+
}, "Select option:"), seats.pricing.filter(price => (!priceSectionIds || priceSectionIds.includes(price.psId)) && price.psId === s.psId).map(price => /*#__PURE__*/_react.default.createElement("div", {
|
|
546
567
|
key: price.paId,
|
|
547
568
|
style: {
|
|
548
569
|
minWidth: '10rem',
|
|
@@ -555,7 +576,7 @@ const SeatingPlan = _ref => {
|
|
|
555
576
|
className: "priceage",
|
|
556
577
|
onClick: () => {
|
|
557
578
|
s.loading = true;
|
|
558
|
-
addTicketToCart(s, price
|
|
579
|
+
addTicketToCart(s, price);
|
|
559
580
|
}
|
|
560
581
|
}, /*#__PURE__*/_react.default.createElement("p", {
|
|
561
582
|
style: {
|