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.
@@ -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: 100
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 || processing || bookedSeats.length >= quantity && s.s === 1) {
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 && addTicketToCart(s, availablePrices[0].paId, {
200
- circle: e,
201
- seat: s
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
- chosenSeat === null || chosenSeat === void 0 ? void 0 : chosenSeat.circle.target.setStyle({
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: [height * 0.015, width * 0.015],
294
- zoom: 6,
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([height * 0.015, width * 0.015], 6),
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 6px 6px',
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 / 48.5 - 0.11, s.x * 0.3 + 0.15 - 0.11], [height * 0.05 - s.y / 3.35 - height / 48.5 + 0.11, s.x * 0.3 + 0.15 + 0.11]
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: chosenSeat && chosenSeat.seat.ssId === s.ssId && processing ? 100 : 0,
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 / 48.5 - 0.11, s.x * 0.3 + 0.15 - 0.11], [height * 0.05 - s.y / 3.35 - height / 48.5 + 0.11, s.x * 0.3 + 0.15 + 0.11]],
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 / 48.5, s.x * 0.3 + 0.15
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 && !processing && /*#__PURE__*/_react.default.createElement(_reactLeaflet.Popup, null, /*#__PURE__*/_react.default.createElement("p", {
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: () => addTicketToCart(s, price.paId)
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",
package/package.json CHANGED
@@ -2,7 +2,7 @@
2
2
  "name": "iticket-seatingplan-dev",
3
3
  "description": "Seating plan with FLEXi pricing",
4
4
  "author": "gedwyne",
5
- "version": "1.1.9",
5
+ "version": "1.2.1",
6
6
  "private": false,
7
7
  "keywords": [
8
8
  "iticket",