iticket-seatingplan-dev 1.1.9 → 1.2.1
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 +66 -27
- package/package.json +1 -1
|
@@ -29,7 +29,8 @@ const SeatingPlan = _ref => {
|
|
|
29
29
|
callbackFunction,
|
|
30
30
|
apiKey,
|
|
31
31
|
baseUrl,
|
|
32
|
-
countryCode
|
|
32
|
+
countryCode,
|
|
33
|
+
connectedShowings
|
|
33
34
|
} = _ref;
|
|
34
35
|
const [initialiseMessage, setInitialiseMessage] = (0, _react.useState)('Initialising seating plan...');
|
|
35
36
|
const [isReloading, setIsReloading] = (0, _react.useState)(false);
|
|
@@ -56,7 +57,7 @@ const SeatingPlan = _ref => {
|
|
|
56
57
|
return {
|
|
57
58
|
fillColor: s.s === 1 ? statusColors.available : s.s === 4 ? s.bookedPrice === price ? statusColors.booked : statusColors.bookedWithDifferentPrice : statusColors.sold,
|
|
58
59
|
color: 'none',
|
|
59
|
-
fillOpacity:
|
|
60
|
+
fillOpacity: s.loading ? 0 : 1
|
|
60
61
|
};
|
|
61
62
|
};
|
|
62
63
|
const addTicketToCart = (s, priceAgeId, cs) => {
|
|
@@ -66,7 +67,8 @@ const SeatingPlan = _ref => {
|
|
|
66
67
|
method: 'POST',
|
|
67
68
|
body: JSON.stringify({
|
|
68
69
|
priceAgeId: priceAgeId,
|
|
69
|
-
seatId: s.ssId
|
|
70
|
+
seatId: s.ssId,
|
|
71
|
+
connectedShowings: connectedShowings
|
|
70
72
|
}),
|
|
71
73
|
headers: {
|
|
72
74
|
'content-type': 'application/json',
|
|
@@ -74,7 +76,7 @@ const SeatingPlan = _ref => {
|
|
|
74
76
|
}
|
|
75
77
|
}).then(response => {
|
|
76
78
|
if ((response === null || response === void 0 ? void 0 : response.status) === 403) {
|
|
77
|
-
;
|
|
79
|
+
s.loading = false;
|
|
78
80
|
(cs || chosenSeat).circle.target.setStyle({
|
|
79
81
|
fillColor: statusColors.sold
|
|
80
82
|
})(cs || chosenSeat).seat.s = 2;
|
|
@@ -90,7 +92,7 @@ const SeatingPlan = _ref => {
|
|
|
90
92
|
callbackFunction(event);
|
|
91
93
|
setProcessing(false);
|
|
92
94
|
} else if ((response === null || response === void 0 ? void 0 : response.status) === 429) {
|
|
93
|
-
;
|
|
95
|
+
s.loading = false;
|
|
94
96
|
(cs || chosenSeat).circle.target.setStyle({
|
|
95
97
|
fillColor: statusColors.available
|
|
96
98
|
});
|
|
@@ -109,6 +111,7 @@ const SeatingPlan = _ref => {
|
|
|
109
111
|
// console.log(chosenSeat.seat.ssId, cs?.seat.ssId)
|
|
110
112
|
s.s = 4;
|
|
111
113
|
s.bookedPrice = price;
|
|
114
|
+
s.loading = false;
|
|
112
115
|
(cs || chosenSeat).circle.target.setStyle({
|
|
113
116
|
fillColor: statusColors.booked
|
|
114
117
|
});
|
|
@@ -123,7 +126,7 @@ const SeatingPlan = _ref => {
|
|
|
123
126
|
}]);
|
|
124
127
|
}
|
|
125
128
|
}).catch(error => {
|
|
126
|
-
;
|
|
129
|
+
s.loading = false;
|
|
127
130
|
(cs || chosenSeat).circle.target.setStyle({
|
|
128
131
|
fillColor: statusColors.available
|
|
129
132
|
});
|
|
@@ -153,6 +156,7 @@ const SeatingPlan = _ref => {
|
|
|
153
156
|
'basket-key': sessionId
|
|
154
157
|
}
|
|
155
158
|
}).then(response => {
|
|
159
|
+
s.loading = false;
|
|
156
160
|
s.s = 1;
|
|
157
161
|
s.bookedPrice = null;
|
|
158
162
|
e.target.setStyle({
|
|
@@ -178,7 +182,7 @@ const SeatingPlan = _ref => {
|
|
|
178
182
|
});
|
|
179
183
|
};
|
|
180
184
|
const handleClick = (e, s) => {
|
|
181
|
-
if (s.s !== 1 && s.s !== 4 ||
|
|
185
|
+
if (s.s !== 1 && s.s !== 4 || bookedSeats.length >= quantity && s.s === 1) {
|
|
182
186
|
if (bookedSeats.length >= quantity) {
|
|
183
187
|
const event = {
|
|
184
188
|
type: 'error',
|
|
@@ -196,11 +200,15 @@ const SeatingPlan = _ref => {
|
|
|
196
200
|
});
|
|
197
201
|
if (s.s === 1) {
|
|
198
202
|
const availablePrices = seats.pricing.filter(price => price.psId === priceSectionId);
|
|
199
|
-
availablePrices.length === 1
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
+
if (availablePrices.length === 1) {
|
|
204
|
+
s.loading = true;
|
|
205
|
+
addTicketToCart(s, availablePrices[0].paId, {
|
|
206
|
+
circle: e,
|
|
207
|
+
seat: s
|
|
208
|
+
});
|
|
209
|
+
}
|
|
203
210
|
} else {
|
|
211
|
+
s.loading = true;
|
|
204
212
|
removeTicketFromCart(s, e);
|
|
205
213
|
}
|
|
206
214
|
};
|
|
@@ -273,13 +281,32 @@ const SeatingPlan = _ref => {
|
|
|
273
281
|
}, [bookedSeats]);
|
|
274
282
|
(0, _react.useEffect)(() => {
|
|
275
283
|
if (processing) {
|
|
276
|
-
|
|
284
|
+
const availablePrices = seats.pricing.filter(price => price.psId === priceSectionId);
|
|
285
|
+
availablePrices.length === 1 && (chosenSeat === null || chosenSeat === void 0 ? void 0 : chosenSeat.circle.target.setStyle({
|
|
277
286
|
fillOpacity: 0
|
|
278
|
-
});
|
|
287
|
+
}));
|
|
279
288
|
}
|
|
280
289
|
}, [chosenSeat, processing]);
|
|
290
|
+
const calculateCenterOfMap = (height, seats) => {
|
|
291
|
+
const filteredSeats = seats.filter(price => price.psId === priceSectionId);
|
|
292
|
+
const avgY = filteredSeats.reduce((acc, val) => {
|
|
293
|
+
return acc + val.y / filteredSeats.length;
|
|
294
|
+
}, 0);
|
|
295
|
+
const avgX = filteredSeats.reduce((acc, val) => {
|
|
296
|
+
return acc + val.x / filteredSeats.length;
|
|
297
|
+
}, 0);
|
|
298
|
+
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];
|
|
299
|
+
};
|
|
300
|
+
const determineZoom = seats => {
|
|
301
|
+
const filteredSeats = seats.filter(price => price.psId === priceSectionId);
|
|
302
|
+
const x = filteredSeats.map(fs => fs.x);
|
|
303
|
+
const y = filteredSeats.map(fs => fs.y);
|
|
304
|
+
const maxX = Math.max(...x) - Math.min(...x);
|
|
305
|
+
const maxY = Math.max(...y) - Math.min(...y);
|
|
306
|
+
console.log(maxX, maxY);
|
|
307
|
+
if (maxY > 67.5) return 4;else return 6;
|
|
308
|
+
};
|
|
281
309
|
|
|
282
|
-
// console.log(height, width)
|
|
283
310
|
// return seating plan
|
|
284
311
|
return /*#__PURE__*/_react.default.createElement("div", {
|
|
285
312
|
style: {
|
|
@@ -288,10 +315,14 @@ const SeatingPlan = _ref => {
|
|
|
288
315
|
}
|
|
289
316
|
}, error ? /*#__PURE__*/_react.default.createElement("div", {
|
|
290
317
|
className: "loading"
|
|
291
|
-
}, /*#__PURE__*/_react.default.createElement("h1", null, "OOPS!"), /*#__PURE__*/_react.default.createElement("div", null, error.response.data.message)) : position && area === areaId ? /*#__PURE__*/_react.default.createElement(_reactLeaflet.MapContainer, {
|
|
292
|
-
whenReady: setMap
|
|
293
|
-
center
|
|
294
|
-
|
|
318
|
+
}, /*#__PURE__*/_react.default.createElement("h1", null, "OOPS!"), /*#__PURE__*/_react.default.createElement("div", null, error.response.data.message)) : position && area === areaId ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_reactLeaflet.MapContainer, {
|
|
319
|
+
whenReady: setMap
|
|
320
|
+
// center={[height * 0.015, width * 0.015]}
|
|
321
|
+
,
|
|
322
|
+
center: calculateCenterOfMap(height, seats.seats)
|
|
323
|
+
// zoom={6}
|
|
324
|
+
,
|
|
325
|
+
zoom: determineZoom(seats.seats),
|
|
295
326
|
zoomControl: true,
|
|
296
327
|
scrollWheelZoom: true,
|
|
297
328
|
style: {
|
|
@@ -372,7 +403,7 @@ const SeatingPlan = _ref => {
|
|
|
372
403
|
}
|
|
373
404
|
}, /*#__PURE__*/_react.default.createElement("button", {
|
|
374
405
|
title: "Re-centre Seating Plan",
|
|
375
|
-
onClick: () => map.target.setView(
|
|
406
|
+
onClick: () => map.target.setView(calculateCenterOfMap(height, seats.seats), determineZoom(seats.seats)),
|
|
376
407
|
className: "leaflet-control-zoom-in",
|
|
377
408
|
style: {
|
|
378
409
|
border: 'none',
|
|
@@ -393,7 +424,7 @@ const SeatingPlan = _ref => {
|
|
|
393
424
|
className: "leaflet-control-zoom-in",
|
|
394
425
|
style: {
|
|
395
426
|
border: 'none',
|
|
396
|
-
borderRadius: '0 0
|
|
427
|
+
borderRadius: '0 0',
|
|
397
428
|
borderTop: '1px solid gray',
|
|
398
429
|
background: '#fff',
|
|
399
430
|
padding: '8px 6px',
|
|
@@ -414,14 +445,14 @@ const SeatingPlan = _ref => {
|
|
|
414
445
|
key: i
|
|
415
446
|
}, /*#__PURE__*/_react.default.createElement(_reactLeaflet.ImageOverlay, {
|
|
416
447
|
url: "https://iticketseatingplan.blob.core.windows.net/embed/static/media/rippleload.08e6a08dd832819226ef.gif",
|
|
417
|
-
bounds: [[height * 0.05 - s.y / 3.35 - height
|
|
448
|
+
bounds: [[height * 0.05 - s.y / (height > 800 ? height > 999 ? 3.5 : 3.3 : 3.35) - (height > 800 ? height > 999 ? height * 0.0201 : height * 0.0198 : height * 0.0206) - 0.11, s.x * 0.3 + 0.15 - 0.11], [height * 0.05 - s.y / (height > 800 ? height > 999 ? 3.5 : 3.3 : 3.35) - (height > 800 ? height > 999 ? height * 0.0201 : height * 0.0198 : height * 0.0206) + 0.11, s.x * 0.3 + 0.15 + 0.11]
|
|
418
449
|
// [height * 0.0302 - s.y * 0.602 - 0.3, s.x * 0.61 - 0.3],
|
|
419
450
|
// [height * 0.0302 - s.y * 0.602 + 0.3, s.x * 0.61 + 0.3],
|
|
420
451
|
// [height * 0.0302 - s.y * 0.602 - 0.17, s.x * 0.61 - 0.17],
|
|
421
452
|
// [height * 0.0302 - s.y * 0.602 + 0.17, s.x * 0.61 + 0.17],
|
|
422
453
|
],
|
|
423
454
|
|
|
424
|
-
opacity:
|
|
455
|
+
opacity: s.loading ? 100 : 0,
|
|
425
456
|
zIndex: 10
|
|
426
457
|
}), !priceSectionId || s.psId === priceSectionId ? s.s === 6 ? /*#__PURE__*/_react.default.createElement(_reactLeaflet.ImageOverlay, {
|
|
427
458
|
url: '',
|
|
@@ -434,7 +465,7 @@ const SeatingPlan = _ref => {
|
|
|
434
465
|
// height * 0.0302 - s.y * 0.602 + 0.17,
|
|
435
466
|
// s.x * 0.61 + 0.17,
|
|
436
467
|
// ],
|
|
437
|
-
[height * 0.05 - s.y / 3.35 - height
|
|
468
|
+
[height * 0.05 - s.y / (height > 800 ? height > 999 ? 3.5 : 3.3 : 3.35) - (height > 800 ? height > 999 ? height * 0.0201 : height * 0.0198 : height * 0.0206) - 0.11, s.x * 0.3 + 0.15 - 0.11], [height * 0.05 - s.y / (height > 800 ? height > 999 ? 3.5 : 3.3 : 3.35) - (height > 800 ? height > 999 ? height * 0.0201 : height * 0.0198 : height * 0.0206) + 0.11, s.x * 0.3 + 0.15 + 0.11]],
|
|
438
469
|
zIndex: 10
|
|
439
470
|
}) : /*#__PURE__*/_react.default.createElement(_reactLeaflet.Circle, {
|
|
440
471
|
center: [
|
|
@@ -443,7 +474,12 @@ const SeatingPlan = _ref => {
|
|
|
443
474
|
// height * (height > 700 ? 0.0001 : 0.0006),
|
|
444
475
|
// s.x * 0.6 + 0.25,
|
|
445
476
|
|
|
446
|
-
height * 0.05 - s.y / 3.35 - height
|
|
477
|
+
height * 0.05 - s.y / (height > 800 ? height > 999 ? 3.5 : 3.3 : 3.35) - (height > 800 ? height > 999 ? height * 0.0201 : height * 0.0198 : height * 0.0206), s.x * 0.3 + 0.15
|
|
478
|
+
|
|
479
|
+
// height * 0.04 -
|
|
480
|
+
// s.y / (height > 800 ? 3.5 : 3.35) -
|
|
481
|
+
// (height > 800 ? height * 0.0101 : height * 0.0206),
|
|
482
|
+
// s.x * 0.3 + 0.15,
|
|
447
483
|
|
|
448
484
|
// -s.y * (height * 0.00037) + 24.2,
|
|
449
485
|
// s.x * 0.3 + 0.15,
|
|
@@ -455,7 +491,7 @@ const SeatingPlan = _ref => {
|
|
|
455
491
|
click: e => handleClick(e, s)
|
|
456
492
|
}
|
|
457
493
|
// value={s}
|
|
458
|
-
}, s.s === 1 &&
|
|
494
|
+
}, s.s === 1 && /*#__PURE__*/_react.default.createElement(_reactLeaflet.Popup, null, /*#__PURE__*/_react.default.createElement("p", {
|
|
459
495
|
style: {
|
|
460
496
|
marginTop: '0.2rem',
|
|
461
497
|
marginBottom: '0.2rem',
|
|
@@ -472,7 +508,10 @@ const SeatingPlan = _ref => {
|
|
|
472
508
|
cursor: 'pointer'
|
|
473
509
|
},
|
|
474
510
|
className: "priceage",
|
|
475
|
-
onClick: () =>
|
|
511
|
+
onClick: () => {
|
|
512
|
+
s.loading = true;
|
|
513
|
+
addTicketToCart(s, price.paId);
|
|
514
|
+
}
|
|
476
515
|
}, /*#__PURE__*/_react.default.createElement("p", {
|
|
477
516
|
style: {
|
|
478
517
|
margin: '0px'
|
|
@@ -481,7 +520,7 @@ const SeatingPlan = _ref => {
|
|
|
481
520
|
style: {
|
|
482
521
|
float: 'right'
|
|
483
522
|
}
|
|
484
|
-
}, NZDollar.format(price.p))))))) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null)))) : /*#__PURE__*/_react.default.createElement("div", {
|
|
523
|
+
}, NZDollar.format(price.p))))))) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null))))) : /*#__PURE__*/_react.default.createElement("div", {
|
|
485
524
|
className: "loading"
|
|
486
525
|
}, /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("svg", {
|
|
487
526
|
width: "105",
|