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.
@@ -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
  }),
@@ -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
- p: price || s.defaultPrice,
145
- paName: s.priceAgeName
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 === 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
  });
@@ -262,7 +280,8 @@ const SeatingPlan = _ref => {
262
280
  c: s.c,
263
281
  showingId: showingId,
264
282
  p: price || s.defaultPrice,
265
- paName: s.priceAgeName
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
- (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]);
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 === priceSectionId);
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 === priceSectionId);
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 === priceSectionId);
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
- }), !priceSectionId || s.psId === priceSectionId ? s.s === 6 ? /*#__PURE__*/_react.default.createElement(_reactLeaflet.ImageOverlay, {
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
- }, s.s === 1 && /*#__PURE__*/_react.default.createElement(_reactLeaflet.Popup, null, /*#__PURE__*/_react.default.createElement("p", {
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 === priceSectionId).map(price => /*#__PURE__*/_react.default.createElement("div", {
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.paId);
579
+ addTicketToCart(s, price);
559
580
  }
560
581
  }, /*#__PURE__*/_react.default.createElement("p", {
561
582
  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.8",
5
+ "version": "1.3.0",
6
6
  "private": false,
7
7
  "keywords": [
8
8
  "iticket",