iticket-seatingplan-dev 2.0.3 → 2.0.5
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.
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
var _react = _interopRequireDefault(require("react"));
|
|
8
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
9
|
+
const Badge = props => {
|
|
10
|
+
return /*#__PURE__*/_react.default.createElement("div", {
|
|
11
|
+
className: "badge ".concat(!props.value ? 'badge--none' : '', " ")
|
|
12
|
+
}, /*#__PURE__*/_react.default.createElement("h4", {
|
|
13
|
+
className: "heavy"
|
|
14
|
+
}, props.value || 0));
|
|
15
|
+
};
|
|
16
|
+
var _default = Badge;
|
|
17
|
+
exports.default = _default;
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
var _react = _interopRequireDefault(require("react"));
|
|
8
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
9
|
+
const Button = props => {
|
|
10
|
+
return /*#__PURE__*/_react.default.createElement("button", {
|
|
11
|
+
className: "btn btn--".concat(props.kind, " CTA"),
|
|
12
|
+
"data-id": props.id,
|
|
13
|
+
type: props.type,
|
|
14
|
+
name: props.name,
|
|
15
|
+
value: props.value,
|
|
16
|
+
disabled: props.disabled,
|
|
17
|
+
onClick: props.handleClick
|
|
18
|
+
}, /*#__PURE__*/_react.default.createElement("h4", null, props.label));
|
|
19
|
+
};
|
|
20
|
+
var _default = Button;
|
|
21
|
+
exports.default = _default;
|
|
@@ -4,7 +4,7 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = Controls;
|
|
7
|
-
var
|
|
7
|
+
var _reactLeafletCustomControl = _interopRequireDefault(require("react-leaflet-custom-control"));
|
|
8
8
|
var _reactLeafletDraw = require("react-leaflet-draw");
|
|
9
9
|
var _reactLeaflet = require("react-leaflet");
|
|
10
10
|
var _react = _interopRequireWildcard(require("react"));
|
|
@@ -35,7 +35,7 @@ function Controls(_ref) {
|
|
|
35
35
|
} = _ref;
|
|
36
36
|
const [isLegendOpen, setIsLegendOpen] = (0, _react.useState)(true);
|
|
37
37
|
const map = (0, _reactLeaflet.useMap)();
|
|
38
|
-
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, preventOrphanedSeats && /*#__PURE__*/_react.default.createElement(
|
|
38
|
+
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, preventOrphanedSeats && /*#__PURE__*/_react.default.createElement(_reactLeafletCustomControl.default, {
|
|
39
39
|
position: "topright"
|
|
40
40
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
41
41
|
className: "extra-controls seat-quantity-control"
|
|
@@ -49,7 +49,7 @@ function Controls(_ref) {
|
|
|
49
49
|
height: "16px",
|
|
50
50
|
width: "16px",
|
|
51
51
|
strokeWidth: "2"
|
|
52
|
-
})))), /*#__PURE__*/_react.default.createElement(
|
|
52
|
+
})))), /*#__PURE__*/_react.default.createElement(_reactLeafletCustomControl.default, {
|
|
53
53
|
position: "bottomright"
|
|
54
54
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
55
55
|
className: "legendBox"
|
|
@@ -90,7 +90,7 @@ function Controls(_ref) {
|
|
|
90
90
|
src: _encodedSvgs.userIcon,
|
|
91
91
|
width: 15,
|
|
92
92
|
height: 15
|
|
93
|
-
}), /*#__PURE__*/_react.default.createElement("p", null, "membership seats"))) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null)))), /*#__PURE__*/_react.default.createElement(
|
|
93
|
+
}), /*#__PURE__*/_react.default.createElement("p", null, "membership seats"))) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null)))), /*#__PURE__*/_react.default.createElement(_reactLeafletCustomControl.default, {
|
|
94
94
|
position: "topleft"
|
|
95
95
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
96
96
|
className: "extra-controls"
|
|
@@ -120,7 +120,7 @@ function Controls(_ref) {
|
|
|
120
120
|
style: {
|
|
121
121
|
height: "17px"
|
|
122
122
|
}
|
|
123
|
-
})))), /*#__PURE__*/_react.default.createElement(
|
|
123
|
+
})))), /*#__PURE__*/_react.default.createElement(_reactLeafletCustomControl.default, {
|
|
124
124
|
position: "topleft"
|
|
125
125
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
126
126
|
className: "extra-controls full-screen-control"
|
|
@@ -135,7 +135,7 @@ function Controls(_ref) {
|
|
|
135
135
|
style: {
|
|
136
136
|
height: "24px"
|
|
137
137
|
}
|
|
138
|
-
})))), canMultiSelect && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(
|
|
138
|
+
})))), canMultiSelect && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_reactLeafletCustomControl.default, {
|
|
139
139
|
position: "bottomleft"
|
|
140
140
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
141
141
|
className: "extra-controls multi-select-control"
|
|
@@ -215,7 +215,7 @@ function Controls(_ref) {
|
|
|
215
215
|
onMounted: drawInstance => {
|
|
216
216
|
drawRef.current = drawInstance;
|
|
217
217
|
}
|
|
218
|
-
}))), /*#__PURE__*/_react.default.createElement(
|
|
218
|
+
}))), /*#__PURE__*/_react.default.createElement(_reactLeafletCustomControl.default, {
|
|
219
219
|
position: "topright"
|
|
220
220
|
}, /*#__PURE__*/_react.default.createElement("button", {
|
|
221
221
|
title: "Close full screen",
|
package/dist/components/Map.js
CHANGED
|
@@ -81,13 +81,13 @@ function SeatMap(_ref) {
|
|
|
81
81
|
const hideTooltipTimeoutRef = (0, _react.useRef)(null);
|
|
82
82
|
const map = (0, _reactLeaflet.useMap)();
|
|
83
83
|
const imgBounds = [[0, 0], [-_constants.SCALE, width / height * _constants.SCALE]];
|
|
84
|
-
const seatsMap =
|
|
84
|
+
const seatsMap = new Map(seats.seats.map(s => {
|
|
85
85
|
const latlng = (0, _utils.getSeatCenterLatLng)(s, height, width, imgBounds);
|
|
86
86
|
return [s.sId, _objectSpread(_objectSpread({}, s), {}, {
|
|
87
87
|
center: latlng
|
|
88
88
|
})];
|
|
89
|
-
}))
|
|
90
|
-
const isOrphanMode = (seats === null || seats === void 0 ? void 0 : seats.preventOrphanedSeats) && desiredSeatQuantity > 0
|
|
89
|
+
}));
|
|
90
|
+
const isOrphanMode = (seats === null || seats === void 0 ? void 0 : seats.preventOrphanedSeats) && desiredSeatQuantity > 0;
|
|
91
91
|
const isTouchScreen = (0, _utils.getIsTouchScreen)();
|
|
92
92
|
|
|
93
93
|
// L.drawLocal.draw.toolbar.buttons.rectangle = "Box select";
|
|
@@ -119,7 +119,7 @@ function SeatMap(_ref) {
|
|
|
119
119
|
} else if (mode === _utils.modes.REMOVE) {
|
|
120
120
|
const seatsToRemove = [];
|
|
121
121
|
selectedSeats.forEach(seat => {
|
|
122
|
-
if (!seatsToRemove.
|
|
122
|
+
if (!seatsToRemove.find(s => s.ssId === seat.ssId) && seat.s === _utils.statuses.USER_PENDING) {
|
|
123
123
|
seatsToRemove.push(seat);
|
|
124
124
|
}
|
|
125
125
|
});
|
|
@@ -223,7 +223,7 @@ function SeatMap(_ref) {
|
|
|
223
223
|
lng: seat.x
|
|
224
224
|
};
|
|
225
225
|
const latlng = [seatCenter.lat, seatCenter.lng];
|
|
226
|
-
if (boxBounds.contains(latlng) && !seatsToBook.
|
|
226
|
+
if (boxBounds.contains(latlng) && !seatsToBook.find(s => s.ssId === seat.ssId) && seat.s === _utils.statuses.UNSOLD) {
|
|
227
227
|
seatsToBook.push(seat);
|
|
228
228
|
}
|
|
229
229
|
});
|
|
@@ -324,7 +324,7 @@ function SeatMap(_ref) {
|
|
|
324
324
|
}
|
|
325
325
|
};
|
|
326
326
|
const onMouseDown = (0, _react.useCallback)((s, hasSeatPrices) => {
|
|
327
|
-
if ((mode === _utils.modes.DRAG || mode === _utils.modes.REMOVE) && canMultiSelect && hasSeatPrices && !selectedSeats.
|
|
327
|
+
if ((mode === _utils.modes.DRAG || mode === _utils.modes.REMOVE) && canMultiSelect && hasSeatPrices && !selectedSeats.find(seat => seat.ssId === s.ssId) && s.s === (mode === _utils.modes.DRAG ? _utils.statuses.UNSOLD : _utils.statuses.USER_PENDING)) {
|
|
328
328
|
setSelectedSeats(prev => [...prev, s]);
|
|
329
329
|
}
|
|
330
330
|
}, [mode, canMultiSelect, selectedSeats, setSelectedSeats]);
|
|
@@ -335,7 +335,7 @@ function SeatMap(_ref) {
|
|
|
335
335
|
if (hideTooltipTimeoutRef.current) {
|
|
336
336
|
clearTimeout(hideTooltipTimeoutRef.current);
|
|
337
337
|
}
|
|
338
|
-
if ((mode === _utils.modes.DRAG || mode === _utils.modes.REMOVE) && isDragging && canMultiSelect && hasSeatPrices && !selectedSeats.
|
|
338
|
+
if ((mode === _utils.modes.DRAG || mode === _utils.modes.REMOVE) && isDragging && canMultiSelect && hasSeatPrices && !selectedSeats.find(seat => seat.ssId === s.ssId) && s.s === (mode === _utils.modes.DRAG ? _utils.statuses.UNSOLD : _utils.statuses.USER_PENDING)) {
|
|
339
339
|
setSelectedSeats(prev => [...prev, s]);
|
|
340
340
|
return;
|
|
341
341
|
}
|
|
@@ -367,7 +367,7 @@ function SeatMap(_ref) {
|
|
|
367
367
|
infoVisible: false
|
|
368
368
|
}));
|
|
369
369
|
}
|
|
370
|
-
if ((highlightedSeats === null || highlightedSeats === void 0 ? void 0 : highlightedSeats.length) > 0
|
|
370
|
+
if ((highlightedSeats === null || highlightedSeats === void 0 ? void 0 : highlightedSeats.length) > 0) {
|
|
371
371
|
setHighlightedSeats([]);
|
|
372
372
|
}
|
|
373
373
|
}, 400);
|
|
@@ -477,7 +477,7 @@ function SeatMap(_ref) {
|
|
|
477
477
|
zIndex: 10
|
|
478
478
|
}) : /*#__PURE__*/_react.default.createElement(_reactLeaflet.Circle, {
|
|
479
479
|
center: [seatCenter.lat, seatCenter.lng],
|
|
480
|
-
pathOptions: (0, _utils.getInitialColor)(s, price, s.loading || ticketPopupOpen && (chosenSeat === null || chosenSeat === void 0 || (_chosenSeat$seat3 = chosenSeat.seat) === null || _chosenSeat$seat3 === void 0 ? void 0 : _chosenSeat$seat3.ssId) === s.ssId, !hasSeatPrices, (selectedSeats.some(selectedSeat => selectedSeat.ssId === s.ssId) || highlightedSeats.some(hs => hs.ssId === s.ssId)) &&
|
|
480
|
+
pathOptions: (0, _utils.getInitialColor)(s, price, s.loading || ticketPopupOpen && (chosenSeat === null || chosenSeat === void 0 || (_chosenSeat$seat3 = chosenSeat.seat) === null || _chosenSeat$seat3 === void 0 ? void 0 : _chosenSeat$seat3.ssId) === s.ssId, !hasSeatPrices, (selectedSeats.some(selectedSeat => selectedSeat.ssId === s.ssId) || highlightedSeats.some(hs => hs.ssId === s.ssId)) && isHoveringOnSeat, greyedOutSeats.some(gs => gs.ssId === s.ssId)),
|
|
481
481
|
radius: seatCenter.radius,
|
|
482
482
|
eventHandlers: eventHandlers
|
|
483
483
|
}, s.s === _utils.statuses.UNSOLD && hasSeatPrices ? /*#__PURE__*/_react.default.createElement(_reactLeaflet.Popup, {
|
|
@@ -44,15 +44,7 @@ const SeatingPlan = _ref => {
|
|
|
44
44
|
connectedShowings,
|
|
45
45
|
areaName,
|
|
46
46
|
promoCode,
|
|
47
|
-
bookingMode = _utils.bookingModes.SHOPSITE
|
|
48
|
-
theme = {
|
|
49
|
-
accent: "#6366f1",
|
|
50
|
-
accentDark: "#3730a3",
|
|
51
|
-
accentLight: "#e0e7ff",
|
|
52
|
-
flexiAccent: "#e32664",
|
|
53
|
-
flexiAccentDark: "#ffd3e2",
|
|
54
|
-
flexiAccentLight: "#be003f"
|
|
55
|
-
}
|
|
47
|
+
bookingMode = _utils.bookingModes.SHOPSITE
|
|
56
48
|
} = _ref;
|
|
57
49
|
const [initialiseMessage, setInitialiseMessage] = (0, _react.useState)("Initialising seating plan...");
|
|
58
50
|
const [isReloading, setIsReloading] = (0, _react.useState)(false);
|
|
@@ -548,28 +540,19 @@ const SeatingPlan = _ref => {
|
|
|
548
540
|
// in full screen mode, render the map in the body, otherwise render in the seating-plan-root div
|
|
549
541
|
const mapContainer = mounted && (isFullScreen ? (_document = document) === null || _document === void 0 ? void 0 : _document.body : (_document2 = document) === null || _document2 === void 0 ? void 0 : _document2.getElementById("seating-plan-root"));
|
|
550
542
|
const backdropContainer = mounted && ((_document3 = document) === null || _document3 === void 0 ? void 0 : _document3.body);
|
|
551
|
-
|
|
552
|
-
|
|
553
|
-
"--accent-dark": theme.accentDark,
|
|
554
|
-
"--accent-light": theme.accentLight,
|
|
555
|
-
"--flexi-accent": theme.flexiAccent,
|
|
556
|
-
"--flexi-accent-light": theme.flexiAccentLight,
|
|
557
|
-
"--flexi-accent-dark": theme.flexiAccentDark
|
|
558
|
-
};
|
|
543
|
+
|
|
544
|
+
// return seating plan
|
|
559
545
|
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
|
|
560
546
|
className: "seating-plan-root",
|
|
561
|
-
id: "seating-plan-root"
|
|
562
|
-
style: themeStyles
|
|
547
|
+
id: "seating-plan-root"
|
|
563
548
|
}, error ? /*#__PURE__*/_react.default.createElement("div", {
|
|
564
549
|
className: "loading"
|
|
565
550
|
}, /*#__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, backdropContainer && /*#__PURE__*/(0, _reactDom.createPortal)(/*#__PURE__*/_react.default.createElement("div", {
|
|
566
551
|
className: "seating-plan-backdrop ".concat(isFullScreen ? "full-screen" : ""),
|
|
567
|
-
onClick: () => setIsFullScreen(false)
|
|
568
|
-
style: themeStyles
|
|
552
|
+
onClick: () => setIsFullScreen(false)
|
|
569
553
|
}), backdropContainer), mapContainer && /*#__PURE__*/(0, _reactDom.createPortal)(/*#__PURE__*/_react.default.createElement("div", {
|
|
570
554
|
className: "seating-plan-container ".concat(isFullScreen ? "full-screen" : ""),
|
|
571
|
-
"data-mode": mode
|
|
572
|
-
style: themeStyles
|
|
555
|
+
"data-mode": mode
|
|
573
556
|
}, pricingPopupOpen && seats && seats.pricing && (canMultiSelect || seats.preventOrphanedSeats) ? /*#__PURE__*/_react.default.createElement(_PricingPopup.default, {
|
|
574
557
|
onClose: () => {
|
|
575
558
|
setPricingPopupOpen(false);
|
|
@@ -27,12 +27,12 @@ button {
|
|
|
27
27
|
}
|
|
28
28
|
|
|
29
29
|
.seating-plan-container {
|
|
30
|
-
|
|
30
|
+
--accent: rgb(99 102 241);
|
|
31
31
|
--accent-dark: rgb(55 48 163);
|
|
32
32
|
--accent-light: rgb(224 231 255);
|
|
33
33
|
--flexi-accent: rgb(227 38 100);
|
|
34
34
|
--flexi-accent-light: rgb(255 211 226);
|
|
35
|
-
--flexi-accent-dark: rgb(190 0 63);
|
|
35
|
+
--flexi-accent-dark: rgb(190 0 63);
|
|
36
36
|
font-family: inherit;
|
|
37
37
|
}
|
|
38
38
|
|
|
@@ -42,7 +42,6 @@ button {
|
|
|
42
42
|
border-radius: 3px;
|
|
43
43
|
text-align: left;
|
|
44
44
|
backdrop-filter: blur(2px);
|
|
45
|
-
color: #333;
|
|
46
45
|
}
|
|
47
46
|
|
|
48
47
|
.legend-header {
|
package/package.json
CHANGED
|
@@ -1,61 +1,62 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "iticket-seatingplan-dev",
|
|
3
|
-
"description": "Seating plan
|
|
4
|
-
"author": "gedwyne",
|
|
5
|
-
"version": "2.0.
|
|
6
|
-
"private": false,
|
|
7
|
-
"keywords": [
|
|
8
|
-
"iticket",
|
|
9
|
-
"seatingplan"
|
|
10
|
-
],
|
|
11
|
-
"main": "dist/index.js",
|
|
12
|
-
"module": "dist/index.js",
|
|
13
|
-
"files": [
|
|
14
|
-
"dist",
|
|
15
|
-
"README.md"
|
|
16
|
-
],
|
|
17
|
-
"dependencies": {
|
|
18
|
-
"@babel/polyfill": "^7.12.1",
|
|
19
|
-
"@types/leaflet": "^1.9.14",
|
|
20
|
-
"@types/leaflet-draw": "^1.0.11",
|
|
21
|
-
"
|
|
22
|
-
"leaflet
|
|
23
|
-
"
|
|
24
|
-
"react
|
|
25
|
-
"react-
|
|
26
|
-
"react-leaflet
|
|
27
|
-
"react-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
"
|
|
32
|
-
"
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
"
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
"
|
|
42
|
-
"not
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
"last 1
|
|
47
|
-
"last 1
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
"@babel/
|
|
53
|
-
"@babel/
|
|
54
|
-
"@babel/
|
|
55
|
-
"@babel/preset-
|
|
56
|
-
"@babel/preset-
|
|
57
|
-
"@
|
|
58
|
-
"@types/react
|
|
59
|
-
"
|
|
60
|
-
|
|
61
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"name": "iticket-seatingplan-dev",
|
|
3
|
+
"description": "Seating plan for external sites",
|
|
4
|
+
"author": "gedwyne",
|
|
5
|
+
"version": "2.0.5",
|
|
6
|
+
"private": false,
|
|
7
|
+
"keywords": [
|
|
8
|
+
"iticket",
|
|
9
|
+
"seatingplan"
|
|
10
|
+
],
|
|
11
|
+
"main": "dist/index.js",
|
|
12
|
+
"module": "dist/index.js",
|
|
13
|
+
"files": [
|
|
14
|
+
"dist",
|
|
15
|
+
"README.md"
|
|
16
|
+
],
|
|
17
|
+
"dependencies": {
|
|
18
|
+
"@babel/polyfill": "^7.12.1",
|
|
19
|
+
"@types/leaflet": "^1.9.14",
|
|
20
|
+
"@types/leaflet-draw": "^1.0.11",
|
|
21
|
+
"iticket-seatingplan": "^1.0.19",
|
|
22
|
+
"leaflet": "^1.9.4",
|
|
23
|
+
"leaflet-draw": "^1.0.4",
|
|
24
|
+
"react": "^19.0.0",
|
|
25
|
+
"react-dom": "^19.0.0",
|
|
26
|
+
"react-leaflet": "^5.0.0-rc.2",
|
|
27
|
+
"react-leaflet-draw": "^0.20.4",
|
|
28
|
+
"react-scripts": "^5.0.1"
|
|
29
|
+
},
|
|
30
|
+
"codependencies": {
|
|
31
|
+
"@babel/polyfill": "^7.12.1",
|
|
32
|
+
"leaflet": "^1.9.3",
|
|
33
|
+
"react-leaflet": "^4.2.1"
|
|
34
|
+
},
|
|
35
|
+
"scripts": {
|
|
36
|
+
"build": "babel src/lib --out-dir dist --extensions '.tsx,.ts,.js' --copy-files",
|
|
37
|
+
"start": "react-scripts start"
|
|
38
|
+
},
|
|
39
|
+
"browserslist": {
|
|
40
|
+
"production": [
|
|
41
|
+
">0.2%",
|
|
42
|
+
"not dead",
|
|
43
|
+
"not op_mini all"
|
|
44
|
+
],
|
|
45
|
+
"development": [
|
|
46
|
+
"last 1 chrome version",
|
|
47
|
+
"last 1 firefox version",
|
|
48
|
+
"last 1 safari version"
|
|
49
|
+
]
|
|
50
|
+
},
|
|
51
|
+
"devDependencies": {
|
|
52
|
+
"@babel/cli": "^7.22.5",
|
|
53
|
+
"@babel/core": "^7.22.5",
|
|
54
|
+
"@babel/plugin-proposal-private-property-in-object": "^7.21.11",
|
|
55
|
+
"@babel/preset-env": "^7.22.5",
|
|
56
|
+
"@babel/preset-react": "^7.22.5",
|
|
57
|
+
"@babel/preset-typescript": "^7.26.0",
|
|
58
|
+
"@types/react": "^18.3.12",
|
|
59
|
+
"@types/react-dom": "^18.3.1",
|
|
60
|
+
"typescript": "^5.7.2"
|
|
61
|
+
}
|
|
62
|
+
}
|