iticket-seatingplan-dev 1.2.7 → 1.2.9

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.
@@ -24,7 +24,7 @@ const SeatingPlan = _ref => {
24
24
  sessionId,
25
25
  showingId,
26
26
  areaId,
27
- priceSectionId,
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, priceAgeId, cs) => {
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: priceAgeId,
70
+ priceAgeId: priceage.paId,
71
71
  seatId: s.ssId,
72
72
  connectedShowings: connectedShowings
73
73
  }),
@@ -93,8 +93,7 @@ const SeatingPlan = _ref => {
93
93
  };
94
94
  callbackFunction(event);
95
95
  setProcessing(false);
96
- }
97
- if ((response === null || response === void 0 ? void 0 : response.status) === 400) {
96
+ } else if ((response === null || response === void 0 ? void 0 : response.status) === 400) {
98
97
  s.loading = false;
99
98
  (cs || chosenSeat).circle.target.setStyle({
100
99
  fillColor: statusColors.sold
@@ -141,9 +140,23 @@ const SeatingPlan = _ref => {
141
140
  r: s.r,
142
141
  c: s.c,
143
142
  showingId: showingId,
144
- p: price || s.defaultPrice,
143
+ pId: priceage.paId,
144
+ p: priceage.p,
145
145
  paName: s.priceAgeName
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: s.priceAgeName
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 === priceSectionId);
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].paId, {
243
+ addTicketToCart(s, availablePrices[0], {
226
244
  circle: e,
227
245
  seat: s
228
246
  });
@@ -291,25 +309,24 @@ const SeatingPlan = _ref => {
291
309
  setPosition(null);
292
310
  }
293
311
  }, [areaId]);
294
- (0, _react.useEffect)(() => {
295
- if (bookedSeats && position && chosenSeat) {
296
- const event = {
297
- type: 'cart-change',
298
- details: bookedSeats
299
- };
300
- callbackFunction(event);
301
- }
302
- }, [bookedSeats]);
312
+
313
+ // useEffect(() => {
314
+ // if (bookedSeats && position && chosenSeat) {
315
+ // const event = { type: 'cart-change', details: bookedSeats }
316
+ // callbackFunction(event)
317
+ // }
318
+ // }, [bookedSeats])
319
+
303
320
  (0, _react.useEffect)(() => {
304
321
  if (processing) {
305
- const availablePrices = seats.pricing.filter(price => price.psId === priceSectionId);
322
+ const availablePrices = seats.pricing.filter(price => !priceSectionIds || priceSectionIds.includes(price.psId));
306
323
  availablePrices.length === 1 && (chosenSeat === null || chosenSeat === void 0 ? void 0 : chosenSeat.circle.target.setStyle({
307
324
  fillOpacity: 0
308
325
  }));
309
326
  }
310
327
  }, [chosenSeat, processing]);
311
328
  const calculateCenterOfMap = (height, seats) => {
312
- const filteredSeats = seats.filter(price => price.psId === priceSectionId);
329
+ const filteredSeats = seats.filter(price => !priceSectionIds || priceSectionIds.includes(price.psId));
313
330
  const avgY = filteredSeats.reduce((acc, val) => {
314
331
  return acc + val.y / filteredSeats.length;
315
332
  }, 0);
@@ -319,7 +336,7 @@ const SeatingPlan = _ref => {
319
336
  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
337
  };
321
338
  const determineZoom = seats => {
322
- const filteredSeats = seats.filter(price => price.psId === priceSectionId);
339
+ const filteredSeats = seats.filter(price => !priceSectionIds || priceSectionIds.includes(price.psId));
323
340
  const x = filteredSeats.map(fs => fs.x);
324
341
  const y = filteredSeats.map(fs => fs.y);
325
342
  const maxX = Math.max(...x) - Math.min(...x);
@@ -412,7 +429,19 @@ const SeatingPlan = _ref => {
412
429
  style: {
413
430
  margin: '0 0.5rem'
414
431
  }
415
- }, "wheelchair"))))), /*#__PURE__*/_react.default.createElement(_reactLeafletCustomControl.default, {
432
+ }, "wheelchair"))), seats.seats.filter(seat => seat.m).length > 0 ? /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("div", {
433
+ style: {
434
+ display: 'inline-flex'
435
+ }
436
+ }, /*#__PURE__*/_react.default.createElement("img", {
437
+ src: '',
438
+ width: 15,
439
+ height: 15
440
+ }), /*#__PURE__*/_react.default.createElement("p", {
441
+ style: {
442
+ margin: '0 0.5rem'
443
+ }
444
+ }, "membership seats"))) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null))), /*#__PURE__*/_react.default.createElement(_reactLeafletCustomControl.default, {
416
445
  position: "topleft"
417
446
  }, /*#__PURE__*/_react.default.createElement("div", {
418
447
  style: {
@@ -474,7 +503,7 @@ const SeatingPlan = _ref => {
474
503
 
475
504
  opacity: s.loading ? 100 : 0,
476
505
  zIndex: 10
477
- }), !priceSectionId || s.psId === priceSectionId ? s.s === 6 ? /*#__PURE__*/_react.default.createElement(_reactLeaflet.ImageOverlay, {
506
+ }), !priceSectionIds || priceSectionIds.includes(s.psId) ? s.s === 6 ? /*#__PURE__*/_react.default.createElement(_reactLeaflet.ImageOverlay, {
478
507
  url: '',
479
508
  bounds: [
480
509
  // [
@@ -524,13 +553,16 @@ const SeatingPlan = _ref => {
524
553
  click: e => handleClick(e, s)
525
554
  }
526
555
  // value={s}
527
- }, s.s === 1 && /*#__PURE__*/_react.default.createElement(_reactLeaflet.Popup, null, /*#__PURE__*/_react.default.createElement("p", {
556
+ }, /*#__PURE__*/_react.default.createElement(_reactLeaflet.Tooltip, {
557
+ direction: 'top',
558
+ offset: [0, height * 0.03 + -30]
559
+ }, s.r + '-' + s.c, ' '), s.s === 1 && /*#__PURE__*/_react.default.createElement(_reactLeaflet.Popup, null, /*#__PURE__*/_react.default.createElement("p", {
528
560
  style: {
529
561
  marginTop: '0.2rem',
530
562
  marginBottom: '0.2rem',
531
563
  fontWeight: 'bold'
532
564
  }
533
- }, "Select option:"), seats.pricing.filter(price => price.psId === priceSectionId).map(price => /*#__PURE__*/_react.default.createElement("div", {
565
+ }, "Select option:"), seats.pricing.filter(price => (!priceSectionIds || priceSectionIds.includes(price.psId)) && price.psId === s.psId).map(price => /*#__PURE__*/_react.default.createElement("div", {
534
566
  key: price.paId,
535
567
  style: {
536
568
  minWidth: '10rem',
@@ -543,7 +575,7 @@ const SeatingPlan = _ref => {
543
575
  className: "priceage",
544
576
  onClick: () => {
545
577
  s.loading = true;
546
- addTicketToCart(s, price.paId);
578
+ addTicketToCart(s, price);
547
579
  }
548
580
  }, /*#__PURE__*/_react.default.createElement("p", {
549
581
  style: {
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.2.7",
5
+ "version": "1.2.9",
6
6
  "private": false,
7
7
  "keywords": [
8
8
  "iticket",