@asdp/ferryui 0.1.22-dev.10162 → 0.1.22-dev.10167

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/index.js CHANGED
@@ -5476,7 +5476,7 @@ var DEFAULT_LABELS8 = {
5476
5476
  id: {
5477
5477
  fromLabel: "Dari",
5478
5478
  toLabel: "Ke",
5479
- departureDateLabel: "Tanggal Berangkat",
5479
+ departureDateLabel: "Tanggal Pergi",
5480
5480
  returnDateLabel: "Tanggal Pulang",
5481
5481
  serviceClassLabel: "Jenis Layanan",
5482
5482
  typeOfServiceLabel: "Jenis Penumpang",
@@ -5485,14 +5485,14 @@ var DEFAULT_LABELS8 = {
5485
5485
  searchButton: "Cari Tiket",
5486
5486
  placeholderPort: "Pilih Pelabuhan Asal",
5487
5487
  placeholderDestinationPort: "Pilih Pelabuhan Tujuan",
5488
- placeholderDepartureDate: "Pilih Tanggal Keberangkatan",
5489
- placeholderReturnDate: "Pilih Tanggal Kepulangan",
5488
+ placeholderDepartureDate: "Pilih Tanggal Pergi",
5489
+ placeholderReturnDate: "Pilih Tanggal Pulang",
5490
5490
  placeholderTypeClass: "Pilih Jenis Layanan",
5491
5491
  placeholderTypeService: "Pilih Jenis Penumpang",
5492
5492
  placeholderPassenger: "Pilih Jumlah Penumpang",
5493
5493
  errorOriginRequired: "Pelabuhan asal wajib diisi",
5494
5494
  errorDestinationRequired: "Pelabuhan tujuan wajib diisi",
5495
- errorDepartureDateRequired: "Tanggal Berangkat wajib diisi",
5495
+ errorDepartureDateRequired: "Tanggal Pergi wajib diisi",
5496
5496
  errorReturnDateRequired: "Tanggal Pulang wajib diisi",
5497
5497
  switchAriaLabel: "Tukar asal dan tujuan",
5498
5498
  ferryDescription: "Layanan Penyeberangan Ferry ASDP",
@@ -6182,7 +6182,8 @@ var DEFAULT_LABELS9 = {
6182
6182
  id: {
6183
6183
  originHarbor: "Pelabuhan Keberangkatan",
6184
6184
  destinationHarbor: "Pelabuhan Tujuan",
6185
- departureDate: "Tanggal Keberangkatan",
6185
+ departureDate: "Tanggal Pergi",
6186
+ returnDate: "Tanggal Pulang",
6186
6187
  serviceClass: "Jenis Layanan",
6187
6188
  typeOfService: "Jenis Penumpang",
6188
6189
  totalPassengers: "Jumlah Penumpang",
@@ -6193,6 +6194,7 @@ var DEFAULT_LABELS9 = {
6193
6194
  originHarbor: "Departure Port",
6194
6195
  destinationHarbor: "Destination Port",
6195
6196
  departureDate: "Departure Date",
6197
+ returnDate: "Return Date",
6196
6198
  serviceClass: "Service Type",
6197
6199
  typeOfService: "Type Of Passenger",
6198
6200
  totalPassengers: "Total Passengers",
@@ -6270,10 +6272,12 @@ var useStyles10 = reactComponents.makeStyles({
6270
6272
  }
6271
6273
  });
6272
6274
  var CardTicketSearchSummary = ({
6275
+ showReturnDate = false,
6273
6276
  language = "id",
6274
6277
  originHarbor,
6275
6278
  destinationHarbor,
6276
6279
  departureDate,
6280
+ returnDate,
6277
6281
  serviceClass,
6278
6282
  typeOfService,
6279
6283
  totalPassengers,
@@ -6469,8 +6473,8 @@ var CardTicketSearchSummary = ({
6469
6473
  children: /* @__PURE__ */ jsxRuntime.jsx(
6470
6474
  RenderField,
6471
6475
  {
6472
- label: mergedLabels.departureDate,
6473
- value: departureDate,
6476
+ label: showReturnDate ? mergedLabels.returnDate : mergedLabels.departureDate,
6477
+ value: showReturnDate ? returnDate : departureDate,
6474
6478
  icon: "fluent:calendar-24-regular"
6475
6479
  }
6476
6480
  )
@@ -7341,6 +7345,10 @@ var ModalSelectDate = ({
7341
7345
  }) => {
7342
7346
  const styles = useStyles13();
7343
7347
  const mergedLabels = { ...DEFAULT_LABELS12[language], ...labels };
7348
+ const isSameCalendarDay = (first, second) => {
7349
+ if (!first || !second) return false;
7350
+ return moment__default.default(first).isSame(second, "day");
7351
+ };
7344
7352
  React.useEffect(() => {
7345
7353
  moment__default.default.locale(language === "id" ? "id" : "en");
7346
7354
  }, [language]);
@@ -7352,24 +7360,26 @@ var ModalSelectDate = ({
7352
7360
  );
7353
7361
  const [hoveredDate, setHoveredDate] = React.useState();
7354
7362
  const [activeTab, setActiveTab] = React.useState(initialTab);
7355
- const previewEndDate = React.useMemo(() => {
7356
- if (selectedEndDate) return selectedEndDate;
7357
- if (selectedDate && hoveredDate && hoveredDate > selectedDate) {
7358
- return hoveredDate;
7363
+ const previewRange = React.useMemo(() => {
7364
+ if (selectedEndDate) {
7365
+ return { start: selectedDate, end: selectedEndDate };
7359
7366
  }
7360
- return void 0;
7367
+ if (selectedDate && hoveredDate && !isSameCalendarDay(hoveredDate, selectedDate)) {
7368
+ const earlier = hoveredDate < selectedDate ? hoveredDate : selectedDate;
7369
+ const later = hoveredDate > selectedDate ? hoveredDate : selectedDate;
7370
+ return { start: earlier, end: later };
7371
+ }
7372
+ return { start: selectedDate, end: void 0 };
7361
7373
  }, [hoveredDate, selectedDate, selectedEndDate]);
7362
- const isSameCalendarDay = (first, second) => {
7363
- if (!first || !second) return false;
7364
- return moment__default.default(first).isSame(second, "day");
7365
- };
7374
+ const prevOpenRef = React.useRef(false);
7366
7375
  React.useEffect(() => {
7367
- if (open) {
7376
+ if (open && !prevOpenRef.current) {
7368
7377
  setSelectedDate(selectedDepartureDate);
7369
7378
  setSelectedEndDate(selectedReturnDate);
7370
7379
  setActiveTab(initialTab);
7371
7380
  setHoveredDate(void 0);
7372
7381
  }
7382
+ prevOpenRef.current = open;
7373
7383
  }, [open, selectedDepartureDate, selectedReturnDate, initialTab]);
7374
7384
  const handleTabChange = (tab) => {
7375
7385
  setActiveTab(tab);
@@ -7393,18 +7403,19 @@ var ModalSelectDate = ({
7393
7403
  setHoveredDate(void 0);
7394
7404
  onSelectDepartureDate(date);
7395
7405
  } else {
7396
- if (date < currentStart) {
7397
- setSelectedEndDate(currentStart);
7406
+ const earlier = date < currentStart ? date : currentStart;
7407
+ const later = date > currentStart ? date : currentStart;
7408
+ if (isSameCalendarDay(date, currentStart)) {
7398
7409
  setSelectedDate(date);
7399
- onSelectDepartureDate(date);
7400
- if (onSelectReturnDate) {
7401
- onSelectReturnDate(currentStart);
7402
- }
7403
- } else {
7404
- setSelectedEndDate(date);
7405
- if (onSelectReturnDate) {
7406
- onSelectReturnDate(date);
7407
- }
7410
+ setSelectedEndDate(void 0);
7411
+ setHoveredDate(void 0);
7412
+ return;
7413
+ }
7414
+ setSelectedDate(earlier);
7415
+ setSelectedEndDate(later);
7416
+ onSelectDepartureDate(earlier);
7417
+ if (onSelectReturnDate) {
7418
+ onSelectReturnDate(later);
7408
7419
  }
7409
7420
  setHoveredDate(void 0);
7410
7421
  handleClose();
@@ -7437,14 +7448,15 @@ var ModalSelectDate = ({
7437
7448
  element.onmouseleave = null;
7438
7449
  return;
7439
7450
  }
7440
- const endDateForVisual = previewEndDate;
7441
- const startTime = selectedDate.getTime();
7442
- const endTime = endDateForVisual?.getTime();
7451
+ const rangeStart = previewRange.start;
7452
+ const rangeEnd = previewRange.end;
7453
+ const startTime = rangeStart?.getTime();
7454
+ const endTime = rangeEnd?.getTime();
7443
7455
  const currentTime = date.getTime();
7444
- const isSameStartEnd = isSameCalendarDay(endDateForVisual, selectedDate);
7445
- const isStartDay = isSameCalendarDay(date, selectedDate);
7446
- const isEndDay = isSameCalendarDay(date, endDateForVisual);
7447
- if (isStartDay && (!endDateForVisual || isSameStartEnd)) {
7456
+ const isSameStartEnd = isSameCalendarDay(rangeStart, rangeEnd);
7457
+ const isStartDay = isSameCalendarDay(date, rangeStart);
7458
+ const isEndDay = isSameCalendarDay(date, rangeEnd);
7459
+ if (isStartDay && (!rangeEnd || isSameStartEnd)) {
7448
7460
  addTokens(styles.rangeSingle);
7449
7461
  } else {
7450
7462
  if (isStartDay) {
@@ -7454,12 +7466,11 @@ var ModalSelectDate = ({
7454
7466
  addTokens(styles.rangeEnd);
7455
7467
  }
7456
7468
  }
7457
- if (endTime && currentTime > startTime && currentTime < endTime) {
7469
+ if (startTime && endTime && currentTime > startTime && currentTime < endTime) {
7458
7470
  addTokens(selectedEndDate ? styles.rangeMiddle : styles.rangePreview);
7459
7471
  }
7460
7472
  if (!selectedEndDate) {
7461
7473
  element.onmouseenter = () => {
7462
- if (date < selectedDate) return;
7463
7474
  setHoveredDate((prev) => {
7464
7475
  if (isSameCalendarDay(prev, date)) {
7465
7476
  return prev;
@@ -7477,7 +7488,7 @@ var ModalSelectDate = ({
7477
7488
  },
7478
7489
  [
7479
7490
  activeTab,
7480
- previewEndDate,
7491
+ previewRange,
7481
7492
  selectedDate,
7482
7493
  selectedEndDate,
7483
7494
  styles.rangeEnd,
@@ -8857,8 +8868,8 @@ var DEFAULT_LABELS16 = {
8857
8868
  recommendation: "Rekomendasi",
8858
8869
  highestPrice: "Harga Tertinggi",
8859
8870
  lowestPrice: "Harga Terendah",
8860
- earliestDeparture: "Keberangkatan Paling Awal",
8861
- latestDeparture: "Keberangkatan Paling Akhir",
8871
+ earliestDeparture: "Pergi Paling Awal",
8872
+ latestDeparture: "Pergi Paling Akhir",
8862
8873
  resetSortAriaLabel: "Hapus pengurutan"
8863
8874
  },
8864
8875
  en: {
@@ -8884,8 +8895,8 @@ var DEFAULT_SORT_OPTIONS = [
8884
8895
  { value: "recommended", sortBy: "recommendation", sortDir: "ASC", label: "Rekomendasi" },
8885
8896
  { value: "price-desc", sortBy: "price", sortDir: "DESC", label: "Harga Tertinggi" },
8886
8897
  { value: "price-asc", sortBy: "price", sortDir: "ASC", label: "Harga Terendah" },
8887
- { value: "departure-asc", sortBy: "departure", sortDir: "ASC", label: "Keberangkatan Paling Awal" },
8888
- { value: "departure-desc", sortBy: "departure", sortDir: "DESC", label: "Keberangkatan Paling Akhir" }
8898
+ { value: "departure-asc", sortBy: "departure", sortDir: "ASC", label: "Pergi Paling Awal" },
8899
+ { value: "departure-desc", sortBy: "departure", sortDir: "DESC", label: "Pergi Paling Akhir" }
8889
8900
  ];
8890
8901
  var getSortLabel = (value) => {
8891
8902
  const option = DEFAULT_SORT_OPTIONS.find((opt) => opt.value === value);
@@ -9780,9 +9791,9 @@ var DEFAULT_LABELS19 = {
9780
9791
  toLabel: "Ke",
9781
9792
  toPlaceholder: "Pilih pelabuhan tujuan",
9782
9793
  toRequired: "Pelabuhan tujuan wajib diisi",
9783
- departureDateLabel: "Tanggal Berangkat",
9784
- departureDatePlaceholder: "Pilih Tanggal Berangkat",
9785
- departureDateRequired: "Tanggal Berangkat wajib diisi",
9794
+ departureDateLabel: "Tanggal Pergi",
9795
+ departureDatePlaceholder: "Pilih Tanggal Pergi",
9796
+ departureDateRequired: "Tanggal Pergi wajib diisi",
9786
9797
  roundTripLabel: "Pulang Pergi",
9787
9798
  returnDateLabel: "Tanggal Pulang",
9788
9799
  returnDatePlaceholder: "Pilih Tanggal Pulang",
@@ -13836,19 +13847,21 @@ var CardBookingTicket = ({
13836
13847
  /* @__PURE__ */ jsxRuntime.jsxs(reactComponents.Card, { className: styles.bookingDetailBottom, children: [
13837
13848
  /* @__PURE__ */ jsxRuntime.jsxs("div", { className: styles.totalPrice, children: [
13838
13849
  /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Subtitle1, { children: mergedLabels.totalPriceLabel }),
13839
- /* @__PURE__ */ jsxRuntime.jsxs(reactComponents.Title3, { className: styles.priceText, children: [
13840
- mergedLabels.currencySymbol,
13841
- " ",
13842
- totalPrice
13843
- ] }),
13844
- /* @__PURE__ */ jsxRuntime.jsx(
13845
- react.Icon,
13846
- {
13847
- icon: "fluent:chevron-down-24-filled",
13848
- onClick: onPriceDetailClick,
13849
- style: { cursor: "pointer" }
13850
- }
13851
- )
13850
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { style: { display: "flex", gap: reactComponents.tokens.spacingHorizontalL, alignItems: "center" }, children: [
13851
+ /* @__PURE__ */ jsxRuntime.jsxs(reactComponents.Title3, { className: styles.priceText, children: [
13852
+ mergedLabels.currencySymbol,
13853
+ " ",
13854
+ totalPrice
13855
+ ] }),
13856
+ /* @__PURE__ */ jsxRuntime.jsx(
13857
+ react.Icon,
13858
+ {
13859
+ icon: "fluent:chevron-down-24-filled",
13860
+ onClick: onPriceDetailClick,
13861
+ style: { cursor: "pointer" }
13862
+ }
13863
+ )
13864
+ ] })
13852
13865
  ] }),
13853
13866
  /* @__PURE__ */ jsxRuntime.jsxs("div", { className: styles.gapButton, children: [
13854
13867
  !(paymentStep === "pay") && /* @__PURE__ */ jsxRuntime.jsx(
@@ -14409,7 +14422,7 @@ var CardAddon = ({
14409
14422
  )
14410
14423
  ] })
14411
14424
  ] }),
14412
- /* @__PURE__ */ jsxRuntime.jsxs("div", { className: styles.mealActions, children: [
14425
+ mealData.showActions !== false && /* @__PURE__ */ jsxRuntime.jsxs("div", { className: styles.mealActions, children: [
14413
14426
  /* @__PURE__ */ jsxRuntime.jsxs("div", { className: styles.qtySelector, children: [
14414
14427
  /* @__PURE__ */ jsxRuntime.jsx(
14415
14428
  reactComponents.Button,
@@ -14767,8 +14780,9 @@ var useStyles32 = reactComponents.makeStyles({
14767
14780
  card: {
14768
14781
  padding: "1.5rem",
14769
14782
  borderRadius: reactComponents.tokens.borderRadiusXLarge,
14770
- boxShadow: reactComponents.tokens.shadow4,
14771
- zIndex: 3
14783
+ boxShadow: "none",
14784
+ zIndex: 3,
14785
+ border: `${reactComponents.tokens.strokeWidthThin} solid ${reactComponents.tokens.colorNeutralStroke1}`
14772
14786
  },
14773
14787
  headerContainer: {
14774
14788
  display: "flex",
@@ -14874,93 +14888,69 @@ var DEFAULT_LABELS32 = {
14874
14888
  };
14875
14889
  var useStyles33 = reactComponents.makeStyles({
14876
14890
  card: {
14877
- padding: "1.5rem",
14891
+ boxShadow: "none",
14892
+ border: `${reactComponents.tokens.strokeWidthThin} solid ${reactComponents.tokens.colorNeutralStroke1}`,
14878
14893
  borderRadius: reactComponents.tokens.borderRadiusXLarge,
14879
- boxShadow: reactComponents.tokens.shadow4,
14880
- zIndex: 3
14894
+ padding: `${reactComponents.tokens.spacingHorizontalL} ${reactComponents.tokens.spacingHorizontalXXL}`
14881
14895
  },
14882
- headerContainer: {
14896
+ titleRow: {
14883
14897
  display: "flex",
14884
14898
  alignItems: "center",
14885
- marginBottom: "1rem",
14886
- gap: "1rem"
14887
- },
14888
- headerTitle: {
14889
- whiteSpace: "nowrap",
14890
- fontWeight: reactComponents.tokens.fontWeightSemibold
14899
+ gap: reactComponents.tokens.spacingHorizontalS
14891
14900
  },
14892
- headerLine: {
14893
- height: "1px",
14894
- flexGrow: 1,
14895
- backgroundColor: reactComponents.tokens.colorNeutralStroke2
14901
+ titleDivider: {
14902
+ flex: 1
14896
14903
  },
14897
- contentContainer: {
14904
+ list: {
14898
14905
  display: "flex",
14899
- flexDirection: "column"
14906
+ flexDirection: "column",
14907
+ rowGap: reactComponents.tokens.spacingVerticalL
14900
14908
  },
14901
- passengerItem: {
14909
+ passengerCard: {
14910
+ boxShadow: "none",
14911
+ border: `${reactComponents.tokens.strokeWidthThin} solid ${reactComponents.tokens.colorNeutralStroke1}`,
14912
+ borderRadius: reactComponents.tokens.borderRadius3XLarge,
14913
+ padding: reactComponents.tokens.spacingHorizontalL
14914
+ },
14915
+ passengerRow: {
14916
+ width: "100%",
14917
+ alignItems: "center"
14918
+ },
14919
+ passengerInfo: {
14902
14920
  display: "flex",
14903
14921
  flexDirection: "column",
14904
- gap: reactComponents.tokens.spacingVerticalS,
14905
- paddingBottom: reactComponents.tokens.spacingVerticalL,
14906
- paddingTop: reactComponents.tokens.spacingVerticalM,
14907
- borderBottom: `1px solid ${reactComponents.tokens.colorNeutralStroke2}`,
14908
- ":last-child": {
14909
- borderBottom: "none",
14910
- paddingBottom: 0
14911
- }
14912
- // Matches styles.passengerItem in Review.tsx
14922
+ gap: reactComponents.tokens.spacingVerticalXXS
14913
14923
  },
14914
- itemHeader: {
14915
- display: "flex",
14916
- justifyContent: "space-between",
14917
- alignItems: "center",
14918
- marginBottom: reactComponents.tokens.spacingVerticalS
14924
+ passengerName: {
14925
+ color: reactComponents.tokens.colorNeutralForeground1
14919
14926
  },
14920
- name: {
14921
- color: "#00B8D4",
14922
- // Cyan color from design
14923
- fontSize: reactComponents.tokens.fontSizeBase400
14927
+ passengerMeta: {
14928
+ color: reactComponents.tokens.colorNeutralForeground2
14924
14929
  },
14925
- // Badge Styles
14926
14930
  badgeContainer: {
14927
- display: "flex",
14928
- alignItems: "center",
14929
- position: "relative"
14930
- },
14931
- badgeContent: {
14932
- display: "flex",
14931
+ display: "inline-flex",
14933
14932
  alignItems: "center",
14934
- padding: "0.25rem 0.75rem 0.25rem 1.5rem",
14935
- // Extra left padding for the icon overlap
14936
- borderRadius: "0 4px 4px 0",
14937
- borderTopRightRadius: "9999px",
14938
- borderBottomRightRadius: "9999px",
14939
- color: "white",
14940
- fontSize: reactComponents.tokens.fontSizeBase200,
14941
- fontWeight: reactComponents.tokens.fontWeightMedium,
14942
- marginLeft: "-14px",
14943
- // Pull the text container under the icon
14944
- minHeight: "24px"
14933
+ overflow: "hidden",
14934
+ borderRadius: reactComponents.tokens.borderRadiusXLarge,
14935
+ minHeight: "32px",
14936
+ boxShadow: reactComponents.tokens.shadow2
14945
14937
  },
14946
14938
  badgeIcon: {
14947
- width: "28px",
14939
+ width: "32px",
14948
14940
  height: "32px",
14949
- zIndex: 1,
14950
- filter: "drop-shadow(0px 2px 2px rgba(0, 0, 0, 0.1))"
14951
- },
14952
- fields: {
14953
- display: "grid",
14954
- gridTemplateColumns: "1fr 1fr",
14955
- gap: reactComponents.tokens.spacingHorizontalL
14941
+ objectFit: "cover",
14942
+ flexShrink: 0,
14943
+ display: "block"
14956
14944
  },
14957
- inputBox: {
14958
- border: `1px solid ${reactComponents.tokens.colorNeutralStroke1}`,
14959
- borderRadius: reactComponents.tokens.borderRadiusMedium,
14960
- padding: `${reactComponents.tokens.spacingVerticalS} ${reactComponents.tokens.spacingHorizontalM}`,
14961
- display: "flex",
14945
+ badgeContent: {
14946
+ display: "inline-flex",
14962
14947
  alignItems: "center",
14963
- height: "32px"
14948
+ minHeight: "32px",
14949
+ padding: `0 ${reactComponents.tokens.spacingHorizontalM}`,
14950
+ color: reactComponents.tokens.colorNeutralForegroundOnBrand,
14951
+ fontSize: reactComponents.tokens.fontSizeBase200,
14952
+ fontWeight: reactComponents.tokens.fontWeightSemibold,
14953
+ whiteSpace: "nowrap"
14964
14954
  }
14965
14955
  });
14966
14956
  var CardReviewPassenger = ({
@@ -14973,48 +14963,140 @@ var CardReviewPassenger = ({
14973
14963
  const styles = useStyles33();
14974
14964
  const mergedLabels = { ...DEFAULT_LABELS32[language], ...labels };
14975
14965
  const displayTitle = title || mergedLabels.title;
14976
- return /* @__PURE__ */ jsxRuntime.jsxs(reactComponents.Card, { className: `${styles.card} ${className || ""}`, children: [
14977
- /* @__PURE__ */ jsxRuntime.jsxs("div", { className: styles.headerContainer, children: [
14978
- /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Subtitle1, { className: styles.headerTitle, children: displayTitle }),
14979
- /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles.headerLine })
14980
- ] }),
14981
- /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles.contentContainer, children: passengers.map((passenger, index) => {
14966
+ return /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Card, { className: `${styles.card} ${className || ""}`, children: /* @__PURE__ */ jsxRuntime.jsxs(reactGridSystem.Row, { direction: "column", nogutter: true, className: styles.list, children: [
14967
+ /* @__PURE__ */ jsxRuntime.jsx(reactGridSystem.Col, { xs: 12, children: /* @__PURE__ */ jsxRuntime.jsxs(reactGridSystem.Row, { nogutter: true, className: styles.titleRow, children: [
14968
+ /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Subtitle1, { children: displayTitle }),
14969
+ /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Divider, { className: styles.titleDivider })
14970
+ ] }) }),
14971
+ passengers.map((passenger, index) => {
14982
14972
  const badgeConfig = getBadgeConfig(passenger.serviceClass);
14983
- return /* @__PURE__ */ jsxRuntime.jsxs("div", { className: styles.passengerItem, children: [
14984
- /* @__PURE__ */ jsxRuntime.jsxs("div", { className: styles.itemHeader, children: [
14985
- /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Subtitle2, { className: styles.name, children: passenger.name }),
14986
- /* @__PURE__ */ jsxRuntime.jsxs("div", { className: styles.badgeContainer, children: [
14987
- badgeConfig.icon && /* @__PURE__ */ jsxRuntime.jsx(
14988
- reactComponents.Image,
14989
- {
14990
- src: badgeConfig.icon,
14991
- alt: passenger.ticketClass,
14992
- className: styles.badgeIcon,
14993
- height: 28,
14994
- width: 24
14995
- }
14996
- ),
14997
- /* @__PURE__ */ jsxRuntime.jsx(
14998
- "div",
14999
- {
15000
- className: styles.badgeContent,
15001
- style: { backgroundColor: badgeConfig.color },
15002
- children: passenger.ticketClass
15003
- }
15004
- )
15005
- ] })
14973
+ const passengerMeta = `${passenger.ageLabel} \xB7 ${mergedLabels.idNumber} ${passenger.identityNumber}`;
14974
+ return /* @__PURE__ */ jsxRuntime.jsx(reactGridSystem.Col, { xs: 12, children: /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Card, { className: styles.passengerCard, children: /* @__PURE__ */ jsxRuntime.jsxs(reactGridSystem.Row, { nogutter: true, className: styles.passengerRow, children: [
14975
+ /* @__PURE__ */ jsxRuntime.jsx(reactGridSystem.Col, { children: /* @__PURE__ */ jsxRuntime.jsxs("div", { className: styles.passengerInfo, children: [
14976
+ /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Subtitle2, { className: styles.passengerName, children: passenger.name }),
14977
+ /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Body1, { className: styles.passengerMeta, children: passengerMeta })
14978
+ ] }) }),
14979
+ /* @__PURE__ */ jsxRuntime.jsx(reactGridSystem.Col, { xs: "content", children: /* @__PURE__ */ jsxRuntime.jsxs(
14980
+ "div",
14981
+ {
14982
+ className: styles.badgeContainer,
14983
+ style: { backgroundColor: badgeConfig.color },
14984
+ children: [
14985
+ badgeConfig.icon ? /* @__PURE__ */ jsxRuntime.jsx(
14986
+ "img",
14987
+ {
14988
+ src: badgeConfig.icon,
14989
+ alt: passenger.ticketClass,
14990
+ className: styles.badgeIcon
14991
+ }
14992
+ ) : null,
14993
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles.badgeContent, children: passenger.ticketClass })
14994
+ ]
14995
+ }
14996
+ ) })
14997
+ ] }) }) }, passenger.id || index);
14998
+ })
14999
+ ] }) });
15000
+ };
15001
+
15002
+ // src/components/CardReviewDetail/CardReviewDetail.constants.ts
15003
+ var DEFAULT_LABELS33 = {
15004
+ id: {
15005
+ title: "Detail Pemesanan",
15006
+ fromLabel: "Dari",
15007
+ toLabel: "Ke",
15008
+ scheduleLabel: "Jadwal Masuk",
15009
+ bookingNameLabel: "Nama Pemesanan",
15010
+ passengerTypeLabel: "Jenis Penumpang",
15011
+ addOnLabel: "Add On",
15012
+ viewDetail: "Lihat Detail"
15013
+ },
15014
+ en: {
15015
+ title: "Booking Details",
15016
+ fromLabel: "From",
15017
+ toLabel: "To",
15018
+ scheduleLabel: "Entry Schedule",
15019
+ bookingNameLabel: "Booking Name",
15020
+ passengerTypeLabel: "Passenger Type",
15021
+ addOnLabel: "Add On",
15022
+ viewDetail: "View Details"
15023
+ }
15024
+ };
15025
+ var useStyles34 = reactComponents.makeStyles({
15026
+ card: {
15027
+ boxShadow: "none",
15028
+ border: `${reactComponents.tokens.strokeWidthThin} solid ${reactComponents.tokens.colorNeutralStroke1}`,
15029
+ borderRadius: reactComponents.tokens.borderRadiusXLarge,
15030
+ padding: `${reactComponents.tokens.spacingHorizontalL} ${reactComponents.tokens.spacingHorizontalXXL}`
15031
+ },
15032
+ titleRow: {
15033
+ display: "flex",
15034
+ alignItems: "center",
15035
+ gap: reactComponents.tokens.spacingHorizontalS
15036
+ },
15037
+ fieldRow: {
15038
+ display: "flex",
15039
+ alignItems: "flex-start",
15040
+ gap: reactComponents.tokens.spacingHorizontalL
15041
+ },
15042
+ addOnRow: {
15043
+ display: "flex",
15044
+ alignItems: "center",
15045
+ justifyContent: "space-between",
15046
+ width: "100%"
15047
+ }
15048
+ });
15049
+ var CardReviewDetail = ({
15050
+ language = "id",
15051
+ labels,
15052
+ from,
15053
+ to,
15054
+ scheduleTime,
15055
+ bookingName,
15056
+ passengerType,
15057
+ addOnsCount,
15058
+ onViewAddOns,
15059
+ className
15060
+ }) => {
15061
+ const styles = useStyles34();
15062
+ const mergedLabels = { ...DEFAULT_LABELS33[language], ...labels };
15063
+ return /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Card, { className: `${styles.card} ${className || ""}`, children: /* @__PURE__ */ jsxRuntime.jsxs(reactGridSystem.Row, { nogutter: true, direction: "column", style: { gap: reactComponents.tokens.spacingHorizontalL }, children: [
15064
+ /* @__PURE__ */ jsxRuntime.jsx(reactGridSystem.Col, { xs: 12, children: /* @__PURE__ */ jsxRuntime.jsxs(reactGridSystem.Row, { nogutter: true, className: styles.titleRow, children: [
15065
+ /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Subtitle1, { children: mergedLabels.title }),
15066
+ /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Divider, { style: { width: 0 } })
15067
+ ] }) }),
15068
+ /* @__PURE__ */ jsxRuntime.jsx(reactGridSystem.Col, { xs: 12, children: /* @__PURE__ */ jsxRuntime.jsxs(reactGridSystem.Row, { nogutter: true, className: styles.fieldRow, children: [
15069
+ /* @__PURE__ */ jsxRuntime.jsx(reactGridSystem.Col, { children: /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Field, { label: mergedLabels.fromLabel, children: /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Body1Strong, { children: from }) }) }),
15070
+ /* @__PURE__ */ jsxRuntime.jsx(reactGridSystem.Col, { children: /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Field, { label: mergedLabels.toLabel, children: /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Body1Strong, { children: to }) }) })
15071
+ ] }) }),
15072
+ /* @__PURE__ */ jsxRuntime.jsx(reactGridSystem.Col, { xs: 12, children: /* @__PURE__ */ jsxRuntime.jsxs(reactGridSystem.Row, { nogutter: true, className: styles.fieldRow, children: [
15073
+ /* @__PURE__ */ jsxRuntime.jsx(reactGridSystem.Col, { children: /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Field, { label: mergedLabels.scheduleLabel, children: /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Body1Strong, { children: scheduleTime }) }) }),
15074
+ /* @__PURE__ */ jsxRuntime.jsx(reactGridSystem.Col, { children: /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Field, { label: mergedLabels.bookingNameLabel, children: /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Body1Strong, { children: bookingName }) }) })
15075
+ ] }) }),
15076
+ /* @__PURE__ */ jsxRuntime.jsx(reactGridSystem.Col, { xs: 12, children: /* @__PURE__ */ jsxRuntime.jsxs(reactGridSystem.Row, { nogutter: true, className: styles.fieldRow, children: [
15077
+ /* @__PURE__ */ jsxRuntime.jsx(reactGridSystem.Col, { children: /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Field, { label: mergedLabels.passengerTypeLabel, children: /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Body1Strong, { children: passengerType }) }) }),
15078
+ /* @__PURE__ */ jsxRuntime.jsx(reactGridSystem.Col, { children: /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Field, { label: mergedLabels.addOnLabel, children: /* @__PURE__ */ jsxRuntime.jsxs("div", { className: styles.addOnRow, children: [
15079
+ /* @__PURE__ */ jsxRuntime.jsxs(reactComponents.Body1Strong, { children: [
15080
+ addOnsCount,
15081
+ " ",
15082
+ addOnsCount === 1 ? "Layanan" : "Layanan"
15006
15083
  ] }),
15007
- /* @__PURE__ */ jsxRuntime.jsxs("div", { className: styles.fields, children: [
15008
- /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Field, { label: mergedLabels.idNumber, size: "small", children: /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles.inputBox, children: /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Body1, { children: passenger.identityNumber }) }) }),
15009
- /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Field, { label: passenger.ageLabel, size: "small", children: /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles.inputBox, children: /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Body1, { children: passenger.ageValue }) }) })
15010
- ] })
15011
- ] }, passenger.id || index);
15012
- }) })
15013
- ] });
15084
+ /* @__PURE__ */ jsxRuntime.jsx(
15085
+ reactComponents.Button,
15086
+ {
15087
+ appearance: "transparent",
15088
+ onClick: onViewAddOns,
15089
+ style: { color: brandColors[80] },
15090
+ children: mergedLabels.viewDetail
15091
+ }
15092
+ )
15093
+ ] }) }) })
15094
+ ] }) })
15095
+ ] }) });
15014
15096
  };
15015
15097
 
15016
15098
  // src/components/CardPriceDetails/CardPriceDetails.constants.ts
15017
- var DEFAULT_LABELS33 = {
15099
+ var DEFAULT_LABELS34 = {
15018
15100
  id: {
15019
15101
  defaultTitle: "Rincian Harga",
15020
15102
  totalPayment: "Total Pembayaran",
@@ -15050,7 +15132,7 @@ var DEFAULT_LABELS33 = {
15050
15132
  currencyPrefix: "Rp. "
15051
15133
  }
15052
15134
  };
15053
- var useStyles34 = reactComponents.makeStyles({
15135
+ var useStyles35 = reactComponents.makeStyles({
15054
15136
  list: {
15055
15137
  margin: 0,
15056
15138
  padding: 0,
@@ -15072,7 +15154,7 @@ var PriceDetailsTerms = ({
15072
15154
  language = "id",
15073
15155
  labels
15074
15156
  }) => {
15075
- const styles = useStyles34();
15157
+ const styles = useStyles35();
15076
15158
  const linkColor = reactComponents.tokens.colorBrandBackground;
15077
15159
  const bookingTerms = labels.bookingTerms;
15078
15160
  const agreementTerms = [
@@ -15092,7 +15174,7 @@ var PriceDetailsTerms = ({
15092
15174
  ] })
15093
15175
  ] });
15094
15176
  };
15095
- var useStyles35 = reactComponents.makeStyles({
15177
+ var useStyles36 = reactComponents.makeStyles({
15096
15178
  card: {
15097
15179
  padding: "1.5rem",
15098
15180
  borderRadius: reactComponents.tokens.borderRadiusXLarge,
@@ -15169,8 +15251,8 @@ var CardPriceDetails = ({
15169
15251
  total,
15170
15252
  labels
15171
15253
  }) => {
15172
- const styles = useStyles35();
15173
- const mergedLabels = { ...DEFAULT_LABELS33[language], ...labels };
15254
+ const styles = useStyles36();
15255
+ const mergedLabels = { ...DEFAULT_LABELS34[language], ...labels };
15174
15256
  const displayTitle = title || mergedLabels.defaultTitle;
15175
15257
  const getVariantClass = (variant) => {
15176
15258
  switch (variant) {
@@ -15229,7 +15311,7 @@ var CardPriceDetails = ({
15229
15311
  };
15230
15312
 
15231
15313
  // src/components/CardPaymentMethodList/CardPaymentMethodList.constants.ts
15232
- var DEFAULT_LABELS34 = {
15314
+ var DEFAULT_LABELS35 = {
15233
15315
  id: {
15234
15316
  selectAriaLabel: "Pilih metode pembayaran"
15235
15317
  },
@@ -15237,7 +15319,7 @@ var DEFAULT_LABELS34 = {
15237
15319
  selectAriaLabel: "Select payment method"
15238
15320
  }
15239
15321
  };
15240
- var useStyles36 = reactComponents.makeStyles({
15322
+ var useStyles37 = reactComponents.makeStyles({
15241
15323
  container: {
15242
15324
  display: "flex",
15243
15325
  flexDirection: "column",
@@ -15297,8 +15379,8 @@ var CardPaymentMethodList = ({
15297
15379
  selectedValue,
15298
15380
  onSelect
15299
15381
  }) => {
15300
- const styles = useStyles36();
15301
- const mergedLabels = { ...DEFAULT_LABELS34[language], ...labels };
15382
+ const styles = useStyles37();
15383
+ const mergedLabels = { ...DEFAULT_LABELS35[language], ...labels };
15302
15384
  return /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles.card, children: /* @__PURE__ */ jsxRuntime.jsx("div", { className: `${styles.container}`, children: methods.map((category, index) => /* @__PURE__ */ jsxRuntime.jsxs("div", { children: [
15303
15385
  index > 0 && /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles.dividerContainer, children: /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Divider, {}) }),
15304
15386
  /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Accordion, { multiple: true, collapsible: true, children: /* @__PURE__ */ jsxRuntime.jsxs(reactComponents.AccordionItem, { value: category.value, children: [
@@ -15347,7 +15429,7 @@ var CardPaymentMethodList = ({
15347
15429
  };
15348
15430
 
15349
15431
  // src/components/CardPaymentGuide/CardPaymentGuide.constants.ts
15350
- var DEFAULT_LABELS35 = {
15432
+ var DEFAULT_LABELS36 = {
15351
15433
  id: {
15352
15434
  title: "Cara Pembayaran"
15353
15435
  },
@@ -15355,7 +15437,7 @@ var DEFAULT_LABELS35 = {
15355
15437
  title: "Payment Method"
15356
15438
  }
15357
15439
  };
15358
- var useStyles37 = reactComponents.makeStyles({
15440
+ var useStyles38 = reactComponents.makeStyles({
15359
15441
  container: {
15360
15442
  display: "flex",
15361
15443
  flexDirection: "column",
@@ -15391,8 +15473,8 @@ var CardPaymentGuide = ({
15391
15473
  guides,
15392
15474
  className
15393
15475
  }) => {
15394
- const styles = useStyles37();
15395
- const mergedLabels = { ...DEFAULT_LABELS35[language], ...labels };
15476
+ const styles = useStyles38();
15477
+ const mergedLabels = { ...DEFAULT_LABELS36[language], ...labels };
15396
15478
  const displayTitle = title || mergedLabels.title;
15397
15479
  return /* @__PURE__ */ jsxRuntime.jsxs("div", { className: `${styles.container} ${className || ""}`, children: [
15398
15480
  displayTitle && /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles.titleContainer, children: /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Subtitle1, { className: styles.title, children: displayTitle }) }),
@@ -15411,7 +15493,7 @@ var CardPaymentGuide = ({
15411
15493
  };
15412
15494
 
15413
15495
  // src/components/CardPaymentInfo/CardPaymentInfo.constants.ts
15414
- var DEFAULT_LABELS36 = {
15496
+ var DEFAULT_LABELS37 = {
15415
15497
  id: {
15416
15498
  expiryPrefix: "Kode virtual akun berlaku sampai",
15417
15499
  copyCodeButton: "Salin Kode",
@@ -15431,7 +15513,7 @@ var DEFAULT_LABELS36 = {
15431
15513
  changePayment: "Change Payment Method"
15432
15514
  }
15433
15515
  };
15434
- var useStyles38 = reactComponents.makeStyles({
15516
+ var useStyles39 = reactComponents.makeStyles({
15435
15517
  container: {
15436
15518
  display: "flex",
15437
15519
  flexDirection: "column",
@@ -15523,8 +15605,8 @@ var CardPaymentInfo = ({
15523
15605
  onCheckStatus,
15524
15606
  onChangePayment
15525
15607
  }) => {
15526
- const styles = useStyles38();
15527
- const mergedLabels = { ...DEFAULT_LABELS36[language], ...labels };
15608
+ const styles = useStyles39();
15609
+ const mergedLabels = { ...DEFAULT_LABELS37[language], ...labels };
15528
15610
  return /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles.card, children: /* @__PURE__ */ jsxRuntime.jsxs("div", { className: styles.container, children: [
15529
15611
  /* @__PURE__ */ jsxRuntime.jsxs("div", { className: styles.headerRow, children: [
15530
15612
  /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Subtitle1, { children: mergedLabels.expiryPrefix }),
@@ -15596,7 +15678,7 @@ var CardPaymentInfo = ({
15596
15678
  };
15597
15679
 
15598
15680
  // src/components/CardStatusOrder/CardStatusOrder.constants.ts
15599
- var DEFAULT_LABELS37 = {
15681
+ var DEFAULT_LABELS38 = {
15600
15682
  id: {
15601
15683
  detailTitle: "Detail Pemesanan",
15602
15684
  statusLabel: "Status",
@@ -15626,7 +15708,7 @@ var DEFAULT_LABELS37 = {
15626
15708
  illustrationAlt: "E-Ticket Illustration"
15627
15709
  }
15628
15710
  };
15629
- var useStyles39 = reactComponents.makeStyles({
15711
+ var useStyles40 = reactComponents.makeStyles({
15630
15712
  activeCard: {
15631
15713
  width: "100%",
15632
15714
  // padding: tokens.spacingHorizontalNone, // default
@@ -15696,8 +15778,8 @@ var CardStatusOrder = ({
15696
15778
  onClickViewTicket,
15697
15779
  className
15698
15780
  }) => {
15699
- const styles = useStyles39();
15700
- const mergedLabels = { ...DEFAULT_LABELS37[language], ...labels };
15781
+ const styles = useStyles40();
15782
+ const mergedLabels = { ...DEFAULT_LABELS38[language], ...labels };
15701
15783
  const displayStatus = statusLabel || mergedLabels.defaultStatus;
15702
15784
  const displayTitle = title || mergedLabels.defaultTitle;
15703
15785
  const displayDescription = description || mergedLabels.defaultDescription;
@@ -15794,7 +15876,7 @@ var CardStatusOrder = ({
15794
15876
  };
15795
15877
 
15796
15878
  // src/components/ModalPriceDetail/ModalPriceDetail.constants.ts
15797
- var DEFAULT_LABELS38 = {
15879
+ var DEFAULT_LABELS39 = {
15798
15880
  id: {
15799
15881
  title: "Rincian Harga",
15800
15882
  addonHeader: "Add On",
@@ -15820,7 +15902,7 @@ var DEFAULT_LABELS38 = {
15820
15902
  closeAriaLabel: "Close"
15821
15903
  }
15822
15904
  };
15823
- var useStyles40 = reactComponents.makeStyles({
15905
+ var useStyles41 = reactComponents.makeStyles({
15824
15906
  surface: {
15825
15907
  width: "680px",
15826
15908
  maxWidth: "90vw",
@@ -15947,8 +16029,8 @@ var ModalPriceDetail = ({
15947
16029
  grandTotal,
15948
16030
  ...props
15949
16031
  }) => {
15950
- const styles = useStyles40();
15951
- const mergedLabels = { ...DEFAULT_LABELS38[language], ...labels };
16032
+ const styles = useStyles41();
16033
+ const mergedLabels = { ...DEFAULT_LABELS39[language], ...labels };
15952
16034
  return /* @__PURE__ */ jsxRuntime.jsx(
15953
16035
  reactComponents.Dialog,
15954
16036
  {
@@ -16090,7 +16172,7 @@ var ModalPriceDetail = ({
16090
16172
  // src/components/FileUpload/FileUpload.constants.ts
16091
16173
  var ACCEPTED_FILES = ".pdf,.jpg,.jpeg,.png";
16092
16174
  var MAX_FILE_SIZE_MB = 10;
16093
- var DEFAULT_LABELS39 = {
16175
+ var DEFAULT_LABELS40 = {
16094
16176
  id: {
16095
16177
  placeholder: "Ketuk untuk pilih file",
16096
16178
  maxSizeWarning: "Maksimal {maxSize}MB per file dalam format PDF, JPG, JPEG, PNG.",
@@ -16108,7 +16190,7 @@ var DEFAULT_LABELS39 = {
16108
16190
  downloadTemplateDocument: "Download Template Document"
16109
16191
  }
16110
16192
  };
16111
- var useStyles41 = reactComponents.makeStyles({
16193
+ var useStyles42 = reactComponents.makeStyles({
16112
16194
  surface: {
16113
16195
  maxWidth: "90vw",
16114
16196
  maxHeight: "90vh",
@@ -16135,7 +16217,7 @@ var ModalPreviewImage = ({
16135
16217
  imageUrl,
16136
16218
  alt = "Preview"
16137
16219
  }) => {
16138
- const styles = useStyles41();
16220
+ const styles = useStyles42();
16139
16221
  return /* @__PURE__ */ jsxRuntime.jsx(reactComponents.Dialog, { open, onOpenChange: (_, data) => onOpenChange(data.open), children: /* @__PURE__ */ jsxRuntime.jsx(reactComponents.DialogSurface, { className: styles.surface, children: /* @__PURE__ */ jsxRuntime.jsxs(reactComponents.DialogBody, { children: [
16140
16222
  /* @__PURE__ */ jsxRuntime.jsx(
16141
16223
  reactComponents.DialogTitle,
@@ -16261,7 +16343,7 @@ var FileUpload = React__default.default.forwardRef(
16261
16343
  downloadTemplateDocument = false,
16262
16344
  infoLabel
16263
16345
  }, ref) => {
16264
- const mergedLabels = { ...DEFAULT_LABELS39[language], ...customLabels };
16346
+ const mergedLabels = { ...DEFAULT_LABELS40[language], ...customLabels };
16265
16347
  const styles = uploadStyles();
16266
16348
  const fileInputRef = React.useRef(null);
16267
16349
  const [, setIsDragOver] = React.useState(false);
@@ -16698,11 +16780,11 @@ function hexToRgba(hex, alpha = 1) {
16698
16780
  }
16699
16781
 
16700
16782
  // src/components/CardProfileMenu/CardProfileMenu.constants.ts
16701
- var DEFAULT_LABELS40 = {
16783
+ var DEFAULT_LABELS41 = {
16702
16784
  id: {},
16703
16785
  en: {}
16704
16786
  };
16705
- var useStyles42 = reactComponents.makeStyles({
16787
+ var useStyles43 = reactComponents.makeStyles({
16706
16788
  container: {
16707
16789
  display: "flex",
16708
16790
  flexDirection: "column",
@@ -16762,8 +16844,8 @@ var CardProfileMenu = ({
16762
16844
  selectedValue,
16763
16845
  onTabSelect
16764
16846
  }) => {
16765
- const styles = useStyles42();
16766
- ({ ...DEFAULT_LABELS40[language], ...labels });
16847
+ const styles = useStyles43();
16848
+ ({ ...DEFAULT_LABELS41[language], ...labels });
16767
16849
  const handleTabSelect = (_, data) => {
16768
16850
  onTabSelect(data.value);
16769
16851
  };
@@ -16812,6 +16894,7 @@ exports.CardPriceDetails = CardPriceDetails;
16812
16894
  exports.CardProfileMenu = CardProfileMenu;
16813
16895
  exports.CardPromo = CardPromo;
16814
16896
  exports.CardReview = CardReview;
16897
+ exports.CardReviewDetail = CardReviewDetail;
16815
16898
  exports.CardReviewPassenger = CardReviewPassenger;
16816
16899
  exports.CardServiceMenu = CardServiceMenu;
16817
16900
  exports.CardStatusOrder = CardStatusOrder;