mozrest-sdk-react-dev 0.1.62 → 0.1.64

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/mozrest-sdk.es.js CHANGED
@@ -6304,6 +6304,10 @@ const NAME = "Name";
6304
6304
  const CREATEDAT = "Created at";
6305
6305
  const CHANNEL = "Channel";
6306
6306
  const NOTABLESAVAILABLE = "No tables available";
6307
+ const NOTES = "Notes";
6308
+ const CANCELRESERVATION = "Cancel reservation";
6309
+ const AREYOUSURECANCELRESERVATION = "Are you sure you want to cancel this reservation?";
6310
+ const CANCELREASON = "Cancel reason";
6307
6311
  var en = {
6308
6312
  errors,
6309
6313
  SPECIALCLOSINGDATES,
@@ -6569,7 +6573,11 @@ var en = {
6569
6573
  NAME,
6570
6574
  CREATEDAT,
6571
6575
  CHANNEL,
6572
- NOTABLESAVAILABLE
6576
+ NOTABLESAVAILABLE,
6577
+ NOTES,
6578
+ CANCELRESERVATION,
6579
+ AREYOUSURECANCELRESERVATION,
6580
+ CANCELREASON
6573
6581
  };
6574
6582
  instance.use(initReactI18next).init({
6575
6583
  resources: {
@@ -96639,23 +96647,23 @@ const formatData = (data2) => {
96639
96647
  };
96640
96648
  });
96641
96649
  };
96642
- const mainConatiner = "_mainConatiner_1d3x0_1";
96643
- const btnDanger = "_btnDanger_1d3x0_5";
96644
- const btnWarning = "_btnWarning_1d3x0_10";
96645
- const btnSuccess = "_btnSuccess_1d3x0_15";
96646
- const container$2 = "_container_1d3x0_20";
96647
- const button = "_button_1d3x0_52";
96648
- const skeleton = "_skeleton_1d3x0_60";
96649
- const pulse$1 = "_pulse_1d3x0_1";
96650
- const item$2 = "_item_1d3x0_63";
96651
- const icons = "_icons_1d3x0_68";
96652
- const column = "_column_1d3x0_73";
96653
- const row = "_row_1d3x0_80";
96654
- const cards = "_cards_1d3x0_100";
96655
- const cardActive = "_cardActive_1d3x0_106";
96656
- const cards1 = "_cards1_1d3x0_111";
96657
- const dot$1 = "_dot_1d3x0_122";
96658
- const formInline = "_formInline_1d3x0_134";
96650
+ const mainConatiner = "_mainConatiner_ldb0i_1";
96651
+ const btnDanger = "_btnDanger_ldb0i_5";
96652
+ const btnWarning = "_btnWarning_ldb0i_10";
96653
+ const btnSuccess = "_btnSuccess_ldb0i_15";
96654
+ const container$2 = "_container_ldb0i_20";
96655
+ const button = "_button_ldb0i_52";
96656
+ const skeleton = "_skeleton_ldb0i_60";
96657
+ const pulse$1 = "_pulse_ldb0i_1";
96658
+ const item$2 = "_item_ldb0i_63";
96659
+ const icons = "_icons_ldb0i_69";
96660
+ const column = "_column_ldb0i_74";
96661
+ const row = "_row_ldb0i_81";
96662
+ const cards = "_cards_ldb0i_101";
96663
+ const cardActive = "_cardActive_ldb0i_107";
96664
+ const cards1 = "_cards1_ldb0i_112";
96665
+ const dot$1 = "_dot_ldb0i_123";
96666
+ const formInline = "_formInline_ldb0i_135";
96659
96667
  var styles$8 = {
96660
96668
  mainConatiner,
96661
96669
  btnDanger,
@@ -96663,7 +96671,7 @@ var styles$8 = {
96663
96671
  btnSuccess,
96664
96672
  container: container$2,
96665
96673
  button,
96666
- "button-disable": "_button-disable_1d3x0_55",
96674
+ "button-disable": "_button-disable_ldb0i_55",
96667
96675
  skeleton,
96668
96676
  pulse: pulse$1,
96669
96677
  item: item$2,
@@ -96716,7 +96724,7 @@ const SelectedDateDisplay = ({ selectedDate, onSelectDate, datesSummary }) => {
96716
96724
  index2 === selectedCardIndex && styles$8.cardActive
96717
96725
  ])
96718
96726
  }, /* @__PURE__ */ React__default.createElement("p", {
96719
- style: { fontSize: "12px", marginBottom: "5px", textAlign: "center", fontWeight: "bold" }
96727
+ style: { fontSize: "12px", marginBottom: 0, textAlign: "center", fontWeight: "bold" }
96720
96728
  }, " ", d2.date.toLocaleDateString([], { weekday: "short" }).toUpperCase(), " "), /* @__PURE__ */ React__default.createElement("div", {
96721
96729
  style: { textAlign: "center", position: "relative", bottom: "10px" }
96722
96730
  }, /* @__PURE__ */ React__default.createElement("strong", {
@@ -97069,7 +97077,7 @@ const ReservationComp = ({
97069
97077
  }, /* @__PURE__ */ React__default.createElement("img", {
97070
97078
  src: logo2,
97071
97079
  style: { width: 25, height: 25, display: "inline-block", marginRight: 8, marginLeft: 16 }
97072
- }), /* @__PURE__ */ React__default.createElement("p", null, name)), /* @__PURE__ */ React__default.createElement("td", {
97080
+ }), name), /* @__PURE__ */ React__default.createElement("td", {
97073
97081
  style: { textAlign: "center" }
97074
97082
  }, partySize), /* @__PURE__ */ React__default.createElement("td", {
97075
97083
  style: { textAlign: "center" }
@@ -97134,17 +97142,14 @@ var styles$6 = {
97134
97142
  table,
97135
97143
  item
97136
97144
  };
97137
- const FilterForm = ({ partyOptions, areasOptions, hoursOptions, setBookingValues }) => {
97145
+ const FilterForm = ({ partyOptions, areasOptions, hoursOptions, setBookingValues, currentDate }) => {
97138
97146
  const { t: t2 } = useTranslation();
97139
97147
  const [currentDayHours, setCurrentDayHours] = useState([]);
97140
97148
  const {
97141
97149
  handleChange,
97142
97150
  setFieldValue,
97143
- validateForm,
97144
97151
  handleSubmit,
97145
- values,
97146
- errors: errors2,
97147
- isSubmitting
97152
+ values
97148
97153
  } = useFormikContext();
97149
97154
  useEffect(() => {
97150
97155
  setBookingValues(values);
@@ -97154,8 +97159,10 @@ const FilterForm = ({ partyOptions, areasOptions, hoursOptions, setBookingValues
97154
97159
  setFieldValue("time", hoursOptions.find((d2) => d2.weekday === hooks(values.date).format("dddd").toLocaleLowerCase()).hours.filter((d2) => d2.id)[0]);
97155
97160
  }, [values.date]);
97156
97161
  useEffect(() => {
97162
+ if (currentDate)
97163
+ setFieldValue("date", currentDate);
97157
97164
  handleSubmit();
97158
- }, []);
97165
+ }, [currentDate]);
97159
97166
  return /* @__PURE__ */ React__default.createElement("div", {
97160
97167
  className: styles$6.filterRow
97161
97168
  }, /* @__PURE__ */ React__default.createElement("div", {
@@ -98554,7 +98561,7 @@ var require$$1 = {
98554
98561
  var moment = momentTimezone$1.exports = momentTimezone.exports;
98555
98562
  moment.tz.load(require$$1);
98556
98563
  var moment$1 = momentTimezone$1.exports;
98557
- const TableFilters = ({ venueId, params, setParams, reload, setBookingValues, currentTimeZone }) => {
98564
+ const TableFilters = ({ venueId, params, setParams, reload, setBookingValues, currentTimeZone, currentDate }) => {
98558
98565
  const {
98559
98566
  data: data2,
98560
98567
  isLoading,
@@ -98610,19 +98617,20 @@ const TableFilters = ({ venueId, params, setParams, reload, setBookingValues, cu
98610
98617
  partyOptions: data2.partySizes,
98611
98618
  areasOptions: data2.areas,
98612
98619
  hoursOptions: data2.hours,
98613
- setBookingValues
98620
+ setBookingValues,
98621
+ currentDate
98614
98622
  })));
98615
98623
  };
98616
98624
  const TableRow = ({ row: row2, setSelectedTable }) => {
98617
- var _a2, _b, _c;
98625
+ var _a2, _b;
98618
98626
  return /* @__PURE__ */ React__default.createElement("tr", {
98619
98627
  className: styles$6.item,
98620
98628
  onClick: () => setSelectedTable(row2)
98621
98629
  }, /* @__PURE__ */ React__default.createElement("td", {
98622
- style: { textAlign: "left" }
98623
- }, `${row2.name} (${(_a2 = row2.area) != null ? _a2 : "No area"})`), /* @__PURE__ */ React__default.createElement("td", {
98630
+ style: { textAlign: "left", paddingTop: 10, paddingBottom: 10 }
98631
+ }, `${row2.name} ${row2.area ? "(" + row2.area + ")" : ""}`), /* @__PURE__ */ React__default.createElement("td", {
98624
98632
  style: { textAlign: "center" }
98625
- }, `${(_b = row2.minCapacity) != null ? _b : "?"} - ${(_c = row2.maxCapacity) != null ? _c : "?"}`), /* @__PURE__ */ React__default.createElement("td", {
98633
+ }, `${(_a2 = row2.minCapacity) != null ? _a2 : "?"} - ${(_b = row2.maxCapacity) != null ? _b : "?"}`), /* @__PURE__ */ React__default.createElement("td", {
98626
98634
  style: { textAlign: "center" }
98627
98635
  }, " ", row2.nextBookingIn ? /* @__PURE__ */ React__default.createElement(TimeFormatter, {
98628
98636
  seconds: row2.nextBookingIn,
@@ -98667,7 +98675,7 @@ const GetTableAvailability = async ({
98667
98675
  }
98668
98676
  return [];
98669
98677
  };
98670
- const TableAvailability = ({ venueId, setSelectedTable, setBookingValues, params, setParams, currentTimeZone }) => {
98678
+ const TableAvailability = ({ venueId, setSelectedTable, setBookingValues, params, setParams, currentTimeZone, currentDate }) => {
98671
98679
  const { data: data2, reload } = useFetch(GetTableAvailability, { cacheId: "reservation0dashboard0table0availability", venue_id: venueId, params });
98672
98680
  const handleOnSelectTable = (row2) => {
98673
98681
  setSelectedTable(row2);
@@ -98680,7 +98688,8 @@ const TableAvailability = ({ venueId, setSelectedTable, setBookingValues, params
98680
98688
  setParams,
98681
98689
  reload,
98682
98690
  setBookingValues,
98683
- currentTimeZone
98691
+ currentTimeZone,
98692
+ currentDate
98684
98693
  }), /* @__PURE__ */ React__default.createElement(Table, {
98685
98694
  data: data2 != null ? data2 : [],
98686
98695
  setSelectedTable: (row2) => handleOnSelectTable(row2)
@@ -98693,7 +98702,7 @@ const AddBooking = async ({
98693
98702
  await instance$1.post(`/resbook/venue/${venueId}/bookings`, data2);
98694
98703
  return { data: "created" };
98695
98704
  };
98696
- const ContactDetailsFormFields = (props) => {
98705
+ const ContactDetailsFormFields = ({ isExecuting = false }) => {
98697
98706
  const { t: t2 } = useTranslation();
98698
98707
  const {
98699
98708
  handleChange,
@@ -98713,47 +98722,42 @@ const ContactDetailsFormFields = (props) => {
98713
98722
  xs: 24,
98714
98723
  lg: 10
98715
98724
  }, /* @__PURE__ */ React__default.createElement(TextInputField, {
98716
- style: { width: "90%" },
98717
98725
  id: "firstname",
98718
98726
  label: t2("FIRSTNAME")
98719
98727
  })), /* @__PURE__ */ React__default.createElement(Col$1, {
98720
98728
  xs: 20,
98721
98729
  lg: 10
98722
98730
  }, /* @__PURE__ */ React__default.createElement(TextInputField, {
98723
- style: { width: "90%" },
98724
98731
  id: "lastname",
98725
98732
  label: t2("LASTNAME")
98726
98733
  })), /* @__PURE__ */ React__default.createElement(Col$1, {
98727
98734
  xs: 20,
98728
98735
  lg: 10
98729
98736
  }, /* @__PURE__ */ React__default.createElement(TextInputField, {
98730
- style: { width: "90%" },
98731
98737
  id: "telephone",
98732
98738
  label: t2("PHONENUMBER")
98733
98739
  })), /* @__PURE__ */ React__default.createElement(Col$1, {
98734
98740
  xs: 24,
98735
98741
  lg: 10
98736
98742
  }, /* @__PURE__ */ React__default.createElement(TextInputField, {
98737
- style: { width: "90%" },
98738
98743
  id: "email",
98739
98744
  label: t2("EMAIL")
98740
98745
  })), /* @__PURE__ */ React__default.createElement(Col$1, {
98741
98746
  xs: 24,
98742
98747
  lg: 28
98743
- }, /* @__PURE__ */ React__default.createElement("div", {
98744
- style: { width: "80%" }
98745
98748
  }, /* @__PURE__ */ React__default.createElement(TextAreaField, {
98746
98749
  id: "notes",
98747
98750
  label: t2("SPECIALREQUESTS"),
98748
98751
  maxLength: 100
98749
- }))))), /* @__PURE__ */ React__default.createElement("div", {
98752
+ })))), /* @__PURE__ */ React__default.createElement("div", {
98750
98753
  style: { display: "flex", marginTop: 12, width: "100%" }
98751
98754
  }, /* @__PURE__ */ React__default.createElement(Button$3, {
98752
98755
  size: "small",
98753
98756
  mode: "primary",
98754
98757
  className: "w-full",
98755
98758
  type: "submit",
98756
- disabled: !isValid2
98759
+ disabled: !isValid2,
98760
+ isLoading: isExecuting
98757
98761
  }, t2("CREATERESERVATION"))));
98758
98762
  };
98759
98763
  const ContactDetailsForm = ({ venueId, selectedTable, setSelectedTable, setCreated, bookingValues, currentTimeZone, reloadMainTable }) => {
@@ -98772,7 +98776,7 @@ const ContactDetailsForm = ({ venueId, selectedTable, setSelectedTable, setCreat
98772
98776
  email: create$2().required(t2("errors.required")).email(t2("errors.email")),
98773
98777
  telephone: create$2().required(t2("errors.required")).matches(new RegExp(/^\+?[1-9]\d{8,14}$/), t2("errors.phone"))
98774
98778
  });
98775
- const { execute, data: data2 } = useService(AddBooking);
98779
+ const { execute, data: data2, isExecuting } = useService(AddBooking);
98776
98780
  const handleOnSubmit = async (values) => {
98777
98781
  var _a2, _b;
98778
98782
  const toSend = {
@@ -98804,14 +98808,16 @@ const ContactDetailsForm = ({ venueId, selectedTable, setSelectedTable, setCreat
98804
98808
  initialValues,
98805
98809
  onSubmit: handleOnSubmit,
98806
98810
  validationSchema: bookingSchema
98807
- }, /* @__PURE__ */ React__default.createElement(ContactDetailsFormFields, null)));
98811
+ }, /* @__PURE__ */ React__default.createElement(ContactDetailsFormFields, {
98812
+ isExecuting
98813
+ })));
98808
98814
  };
98809
98815
  const ContactDetails = ({ setSelectedTable, selectedTable, venueId, setCreated, bookingValues, reloadMainTable, currentTimeZone }) => {
98810
98816
  var _a2, _b, _c;
98811
98817
  return /* @__PURE__ */ React__default.createElement("div", {
98812
98818
  className: ""
98813
98819
  }, /* @__PURE__ */ React__default.createElement("div", {
98814
- style: { display: "flex", justifyContent: "start", gap: 20 }
98820
+ style: { display: "flex", justifyContent: "start", gap: 20, marginBottom: 30 }
98815
98821
  }, /* @__PURE__ */ React__default.createElement(Icon$1, {
98816
98822
  icon: "arrowLeft",
98817
98823
  onClick: () => setSelectedTable(null),
@@ -98831,7 +98837,7 @@ const ContactDetails = ({ setSelectedTable, selectedTable, venueId, setCreated,
98831
98837
  }, /* @__PURE__ */ React__default.createElement(Icon$1, {
98832
98838
  icon: "people",
98833
98839
  className: "mr-2"
98834
- }), (bookingValues == null ? void 0 : bookingValues.partySize.id) ? bookingValues.partySize.id : `${(_b = selectedTable.minCapacity) != null ? _b : "?"}-${(_c = selectedTable.maxCapacity) != null ? _c : "?"}`), /* @__PURE__ */ React__default.createElement("div", {
98840
+ }), (bookingValues == null ? void 0 : bookingValues.partySize.id) ? bookingValues.partySize.id : `${(_b = selectedTable.minCapacity) != null ? _b : "?"}-${(_c = selectedTable.maxCapacity) != null ? _c : "?"}`), (bookingValues == null ? void 0 : bookingValues.area.id) && /* @__PURE__ */ React__default.createElement("div", {
98835
98841
  style: { display: "flex" }
98836
98842
  }, /* @__PURE__ */ React__default.createElement(Icon$1, {
98837
98843
  icon: "business",
@@ -98852,7 +98858,7 @@ const BookingConfirmation = ({ bookingDetails }) => {
98852
98858
  return /* @__PURE__ */ React__default.createElement("div", null, /* @__PURE__ */ React__default.createElement("h1", {
98853
98859
  style: { textAlign: "center" }
98854
98860
  }, t2("BOOKINGCONFIRMED")), /* @__PURE__ */ React__default.createElement("div", {
98855
- style: { display: "flex", justifyContent: "start", gap: 20 }
98861
+ style: { display: "flex", justifyContent: "start", gap: 20, marginBottom: 30 }
98856
98862
  }, /* @__PURE__ */ React__default.createElement("div", {
98857
98863
  style: { display: "flex" }
98858
98864
  }, /* @__PURE__ */ React__default.createElement(Icon$1, {
@@ -98868,7 +98874,7 @@ const BookingConfirmation = ({ bookingDetails }) => {
98868
98874
  }, /* @__PURE__ */ React__default.createElement(Icon$1, {
98869
98875
  icon: "people",
98870
98876
  className: "mr-2"
98871
- }), (_c = bookingDetails == null ? void 0 : bookingDetails.partySize) != null ? _c : "?"), /* @__PURE__ */ React__default.createElement("div", {
98877
+ }), (_c = bookingDetails == null ? void 0 : bookingDetails.partySize) != null ? _c : "?"), (bookingDetails == null ? void 0 : bookingDetails.area) && /* @__PURE__ */ React__default.createElement("div", {
98872
98878
  style: { display: "flex" }
98873
98879
  }, /* @__PURE__ */ React__default.createElement(Icon$1, {
98874
98880
  icon: "business",
@@ -98883,7 +98889,7 @@ const BookingConfirmation = ({ bookingDetails }) => {
98883
98889
  style: { color: "GrayText", marginTop: 0 }
98884
98890
  }, bookingDetails.notes && bookingDetails.notes.length > 0 ? bookingDetails.notes : "---"));
98885
98891
  };
98886
- const CreateReservation = ({ open, onClose: onClose2, venueId, reloadMainTable, currentTimeZone }) => {
98892
+ const CreateReservation = ({ open, onClose: onClose2, venueId, reloadMainTable, currentTimeZone, currentDate }) => {
98887
98893
  const { t: t2 } = useTranslation();
98888
98894
  const [params, setParams] = useState(null);
98889
98895
  const [selectedTable, setSelectedTable] = useState(null);
@@ -98896,6 +98902,7 @@ const CreateReservation = ({ open, onClose: onClose2, venueId, reloadMainTable,
98896
98902
  return /* @__PURE__ */ React__default.createElement(Modal2, {
98897
98903
  open,
98898
98904
  onClose: onClose2,
98905
+ width: 800,
98899
98906
  title: /* @__PURE__ */ React__default.createElement("div", null, /* @__PURE__ */ React__default.createElement(Heading, null, t2("ADDRESERVATION")))
98900
98907
  }, /* @__PURE__ */ React__default.createElement("div", null, !selectedTable && !created && /* @__PURE__ */ React__default.createElement(TableAvailability, {
98901
98908
  venueId,
@@ -98903,7 +98910,8 @@ const CreateReservation = ({ open, onClose: onClose2, venueId, reloadMainTable,
98903
98910
  setBookingValues,
98904
98911
  params,
98905
98912
  setParams,
98906
- currentTimeZone
98913
+ currentTimeZone,
98914
+ currentDate
98907
98915
  }), selectedTable && !created && /* @__PURE__ */ React__default.createElement(ContactDetails, {
98908
98916
  venueId,
98909
98917
  setSelectedTable,
@@ -98961,7 +98969,11 @@ const TableSelectField = ({ value: value2, tableOptions, isEdit, setIsEdit }) =>
98961
98969
  };
98962
98970
  const UpdateBooking = async ({ venueId, bookingId, data: data2 }) => {
98963
98971
  await instance$1.put(`/resbook/venue/${venueId}/bookings/${bookingId}`, data2);
98964
- return { data: "created" };
98972
+ return { data: "updated" };
98973
+ };
98974
+ const CancelBooking = async ({ venueId, bookingId, data: data2 }) => {
98975
+ await instance$1.put(`/resbook/venue/${venueId}/bookings/${bookingId}/cancel`, data2);
98976
+ return { data: "canceled" };
98965
98977
  };
98966
98978
  const TableSelectForm = ({ table: table2, id: id2, tableOptions, initialValues, isEdit, setIsEdit, reloadMainTable, onClose: onClose2, venueId }) => {
98967
98979
  const emptyVal = {
@@ -98986,9 +98998,53 @@ const TableSelectForm = ({ table: table2, id: id2, tableOptions, initialValues,
98986
98998
  setIsEdit
98987
98999
  }));
98988
99000
  };
98989
- const ReservationDetail = ({ open, onClose: onClose2, venueId, reloadMainTable, selectedRow, currentTimeZone }) => {
99001
+ const CancelReservationModal = ({ onAccept, isLoading, message: message2, title: title2, ...props }) => {
99002
+ const { t: t2 } = useTranslation();
99003
+ const initialValues = {
99004
+ cancelActor: "",
99005
+ cancelReason: ""
99006
+ };
99007
+ const bookingSchema = create$1().shape({
99008
+ cancelActor: create$2().required(t2("errors.required")),
99009
+ cancelReason: create$2()
99010
+ });
99011
+ return /* @__PURE__ */ React__default.createElement(Modal2, {
99012
+ ...props,
99013
+ title: t2("CANCELRESERVATION")
99014
+ }, /* @__PURE__ */ React__default.createElement("h5", null, t2("AREYOUSURECANCELRESERVATION")), /* @__PURE__ */ React__default.createElement("div", null, /* @__PURE__ */ React__default.createElement(Formik, {
99015
+ initialValues,
99016
+ validationSchema: bookingSchema,
99017
+ onSubmit: (values, { resetForm }) => {
99018
+ onAccept(values);
99019
+ resetForm({ values: initialValues });
99020
+ }
99021
+ }, ({ values, errors: errors2, touched, isValid: isValid2 }) => /* @__PURE__ */ React__default.createElement(Form$c, null, /* @__PURE__ */ React__default.createElement(TextInputField, {
99022
+ id: "cancelActor",
99023
+ label: t2("FIRSTNAME")
99024
+ }), /* @__PURE__ */ React__default.createElement(TextAreaField, {
99025
+ id: "cancelReason",
99026
+ label: t2("CANCELREASON"),
99027
+ maxLength: 100
99028
+ }), /* @__PURE__ */ React__default.createElement("div", {
99029
+ style: { display: "flex", justifyContent: "center", gap: 20, marginTop: 20 }
99030
+ }, /* @__PURE__ */ React__default.createElement(Button$3, {
99031
+ size: "small",
99032
+ mode: "tertiary",
99033
+ onClick: props.onClose,
99034
+ disabled: isLoading
99035
+ }, t2("CANCEL")), /* @__PURE__ */ React__default.createElement(Button$3, {
99036
+ size: "small",
99037
+ type: "submit",
99038
+ disabled: !isValid2,
99039
+ isLoading
99040
+ }, t2("ACCEPT")))))));
99041
+ };
99042
+ const ReservationDetail = ({ open, onClose: onClose2, venueId, reloadMainTable, selectedRow, currentTimeZone, setSelectedRow }) => {
98990
99043
  var _a2, _b, _c, _d, _e2, _f, _g;
98991
99044
  const { t: t2 } = useTranslation();
99045
+ const [openCancelReservationModal, setOpenCancelReservationModal] = useState(false);
99046
+ const onOpenCancelRevModal = () => setOpenCancelReservationModal(true);
99047
+ const onCloseCancelRevModal = () => setOpenCancelReservationModal(false);
98992
99048
  const [isEdit, setIsEdit] = useState(false);
98993
99049
  const [initialValues, setInitialValues] = useState(null);
98994
99050
  const { data: data2 } = useFetch(GetTableAvailability, {
@@ -98999,6 +99055,20 @@ const ReservationDetail = ({ open, onClose: onClose2, venueId, reloadMainTable,
98999
99055
  partySize: selectedRow.partySize
99000
99056
  } : { startSec: null }
99001
99057
  });
99058
+ const { isExecuting, execute } = useService(CancelBooking, {
99059
+ onSuccess: async () => {
99060
+ setSelectedRow({ ...selectedRow, status: "canceled" });
99061
+ onCloseCancelRevModal();
99062
+ reloadMainTable();
99063
+ }
99064
+ });
99065
+ const cancelReservation = async (values) => {
99066
+ const toSend = {
99067
+ cancelActor: values.cancelActor,
99068
+ cancelReason: values.cancelReason
99069
+ };
99070
+ execute({ data: toSend, venueId, bookingId: selectedRow.id });
99071
+ };
99002
99072
  useEffect(() => {
99003
99073
  if (selectedRow && selectedRow.table && open) {
99004
99074
  setInitialValues({ id: selectedRow.table.id, label: selectedRow.table.name });
@@ -99011,31 +99081,31 @@ const ReservationDetail = ({ open, onClose: onClose2, venueId, reloadMainTable,
99011
99081
  onClose: onClose2,
99012
99082
  title: /* @__PURE__ */ React__default.createElement("div", null, /* @__PURE__ */ React__default.createElement(Heading, null, t2("RESERVATIONDETAILS")))
99013
99083
  }, selectedRow && selectedRow.table && initialValues && /* @__PURE__ */ React__default.createElement("div", {
99014
- style: { display: "flex", justifyContent: "start", flexDirection: "column", fontSize: 17 }
99084
+ style: { display: "flex", justifyContent: "start", flexDirection: "column", fontSize: 17, gap: 20 }
99015
99085
  }, /* @__PURE__ */ React__default.createElement("div", {
99016
99086
  style: { display: "flex", justifyContent: "start", flexDirection: "row", gap: 10, alignItems: "center" }
99017
- }, /* @__PURE__ */ React__default.createElement("p", {
99087
+ }, /* @__PURE__ */ React__default.createElement("div", {
99018
99088
  style: { fontWeight: "bold" }
99019
99089
  }, t2("CHANNEL"), ":"), selectedRow.bookingChannelLogo && /* @__PURE__ */ React__default.createElement("img", {
99020
99090
  src: selectedRow.bookingChannelLogo,
99021
99091
  style: { width: 25, height: 25 }
99022
- }), /* @__PURE__ */ React__default.createElement("p", null, (_a2 = selectedRow.bookingChannelName) != null ? _a2 : "---")), /* @__PURE__ */ React__default.createElement("div", {
99092
+ }), /* @__PURE__ */ React__default.createElement("div", null, (_a2 = selectedRow.bookingChannelName) != null ? _a2 : "---")), /* @__PURE__ */ React__default.createElement("div", {
99023
99093
  style: { display: "flex", justifyContent: "start", flexDirection: "row", gap: 10 }
99024
- }, /* @__PURE__ */ React__default.createElement("p", {
99094
+ }, /* @__PURE__ */ React__default.createElement("div", {
99025
99095
  style: { fontWeight: "bold" }
99026
- }, t2("NAME"), ":"), /* @__PURE__ */ React__default.createElement("p", null, selectedRow.name)), /* @__PURE__ */ React__default.createElement("div", {
99096
+ }, t2("NAME"), ":"), /* @__PURE__ */ React__default.createElement("div", null, selectedRow.name)), /* @__PURE__ */ React__default.createElement("div", {
99027
99097
  style: { display: "flex", justifyContent: "start", flexDirection: "row", gap: 10 }
99028
- }, /* @__PURE__ */ React__default.createElement("p", {
99098
+ }, /* @__PURE__ */ React__default.createElement("div", {
99029
99099
  style: { fontWeight: "bold" }
99030
- }, t2("PHONE"), ":"), /* @__PURE__ */ React__default.createElement("p", null, (_b = selectedRow.contact.telephone) != null ? _b : "---")), /* @__PURE__ */ React__default.createElement("div", {
99100
+ }, t2("PHONE"), ":"), /* @__PURE__ */ React__default.createElement("div", null, (_b = selectedRow.contact.telephone) != null ? _b : "---")), /* @__PURE__ */ React__default.createElement("div", {
99031
99101
  style: { display: "flex", justifyContent: "start", flexDirection: "row", gap: 10 }
99032
- }, /* @__PURE__ */ React__default.createElement("p", {
99102
+ }, /* @__PURE__ */ React__default.createElement("div", {
99033
99103
  style: { fontWeight: "bold" }
99034
- }, t2("EMAIL"), ":"), /* @__PURE__ */ React__default.createElement("p", null, (_c = selectedRow.contact.email) != null ? _c : "---")), /* @__PURE__ */ React__default.createElement("div", {
99104
+ }, t2("EMAIL"), ":"), /* @__PURE__ */ React__default.createElement("div", null, (_c = selectedRow.contact.email) != null ? _c : "---")), /* @__PURE__ */ React__default.createElement("div", {
99035
99105
  style: { display: "flex", justifyContent: "start", flexDirection: "row", gap: 10 }
99036
- }, /* @__PURE__ */ React__default.createElement("p", {
99106
+ }, /* @__PURE__ */ React__default.createElement("div", {
99037
99107
  style: { fontWeight: "bold" }
99038
- }, t2("MEALDATE"), ":"), /* @__PURE__ */ React__default.createElement("p", null, (_d = new Date(selectedRow.date).toLocaleString(void 0, {
99108
+ }, t2("MEALDATE"), ":"), /* @__PURE__ */ React__default.createElement("div", null, (_d = new Date(selectedRow.date).toLocaleString(void 0, {
99039
99109
  ...currentTimeZone ? {
99040
99110
  timeZone: currentTimeZone
99041
99111
  } : {},
@@ -99047,13 +99117,13 @@ const ReservationDetail = ({ open, onClose: onClose2, venueId, reloadMainTable,
99047
99117
  hour12: false
99048
99118
  })) != null ? _d : "---")), /* @__PURE__ */ React__default.createElement("div", {
99049
99119
  style: { display: "flex", justifyContent: "start", flexDirection: "row", gap: 10 }
99050
- }, /* @__PURE__ */ React__default.createElement("p", {
99120
+ }, /* @__PURE__ */ React__default.createElement("div", {
99051
99121
  style: { fontWeight: "bold" }
99052
- }, t2("PARTYSIZE"), ":"), /* @__PURE__ */ React__default.createElement("p", null, (_e2 = selectedRow.partySize) != null ? _e2 : "---")), /* @__PURE__ */ React__default.createElement("div", {
99122
+ }, t2("PARTYSIZE"), ":"), /* @__PURE__ */ React__default.createElement("div", null, (_e2 = selectedRow.partySize) != null ? _e2 : "---")), /* @__PURE__ */ React__default.createElement("div", {
99053
99123
  style: { display: "flex", justifyContent: "start", flexDirection: "row", gap: 10 }
99054
- }, /* @__PURE__ */ React__default.createElement("p", {
99124
+ }, /* @__PURE__ */ React__default.createElement("div", {
99055
99125
  style: { fontWeight: "bold" }
99056
- }, t2("CREATEDAT"), ":"), /* @__PURE__ */ React__default.createElement("p", null, (_f = new Date(selectedRow.createAt).toLocaleString(void 0, {
99126
+ }, t2("CREATEDAT"), ":"), /* @__PURE__ */ React__default.createElement("div", null, (_f = new Date(selectedRow.createAt).toLocaleString(void 0, {
99057
99127
  ...currentTimeZone ? {
99058
99128
  timeZone: currentTimeZone
99059
99129
  } : {},
@@ -99065,9 +99135,9 @@ const ReservationDetail = ({ open, onClose: onClose2, venueId, reloadMainTable,
99065
99135
  hour12: false
99066
99136
  })) != null ? _f : "---")), /* @__PURE__ */ React__default.createElement("div", {
99067
99137
  style: { display: "flex", justifyContent: "start", flexDirection: "row", gap: 10 }
99068
- }, /* @__PURE__ */ React__default.createElement("p", {
99138
+ }, /* @__PURE__ */ React__default.createElement("div", {
99069
99139
  style: { fontWeight: "bold" }
99070
- }, t2("NOTES"), ":"), /* @__PURE__ */ React__default.createElement("p", null, (_g = selectedRow.notes) != null ? _g : "---")), /* @__PURE__ */ React__default.createElement("div", {
99140
+ }, t2("NOTES"), ":"), /* @__PURE__ */ React__default.createElement("div", null, (_g = selectedRow.notes) != null ? _g : "---")), /* @__PURE__ */ React__default.createElement("div", {
99071
99141
  style: { display: "flex", justifyContent: "start" }
99072
99142
  }, /* @__PURE__ */ React__default.createElement(TableSelectForm, {
99073
99143
  id: selectedRow.id,
@@ -99079,7 +99149,19 @@ const ReservationDetail = ({ open, onClose: onClose2, venueId, reloadMainTable,
99079
99149
  reloadMainTable,
99080
99150
  onClose: onClose2,
99081
99151
  venueId
99082
- }))));
99152
+ })), selectedRow && selectedRow.status && selectedRow.status !== "canceled" && /* @__PURE__ */ React__default.createElement(Button$3, {
99153
+ style: { marginTop: 10 },
99154
+ type: "submit",
99155
+ className: styles$8.btnDanger,
99156
+ onClick: () => onOpenCancelRevModal()
99157
+ }, t2("CANCELRESERVATION"))), selectedRow && selectedRow.status && selectedRow.status !== "canceled" && /* @__PURE__ */ React__default.createElement(CancelReservationModal, {
99158
+ width: 400,
99159
+ message: t2("AREYOUSURECANCELRESERVATION"),
99160
+ onAccept: cancelReservation,
99161
+ open: openCancelReservationModal,
99162
+ onClose: onCloseCancelRevModal,
99163
+ isLoading: isExecuting
99164
+ }));
99083
99165
  };
99084
99166
  const ReservationDashboard = ({
99085
99167
  Header: Header2,
@@ -99162,7 +99244,8 @@ const ReservationDashboard = ({
99162
99244
  onClick: () => onOpenCreateReservation()
99163
99245
  }, "Add a reservation"), /* @__PURE__ */ React__default.createElement(Button$3, {
99164
99246
  size: "small",
99165
- className: styles$8.btnDanger
99247
+ className: styles$8.btnDanger,
99248
+ disabled: true
99166
99249
  }, "Add a walk-in"))), /* @__PURE__ */ React__default.createElement("br", null), /* @__PURE__ */ React__default.createElement(Card, {
99167
99250
  className: classNameConatiner,
99168
99251
  header: Header2
@@ -99184,12 +99267,14 @@ const ReservationDashboard = ({
99184
99267
  open: openCreateReservation,
99185
99268
  onClose: onCloseCreateReservation,
99186
99269
  currentTimeZone,
99270
+ currentDate,
99187
99271
  venueId,
99188
99272
  reloadMainTable: reload
99189
99273
  }), /* @__PURE__ */ React__default.createElement(ReservationDetail, {
99190
99274
  open: openDetailReservation,
99191
99275
  onClose: onCloseDetailReservation,
99192
99276
  selectedRow,
99277
+ setSelectedRow,
99193
99278
  currentTimeZone,
99194
99279
  venueId,
99195
99280
  reloadMainTable: reload
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "mozrest-sdk-react-dev",
3
- "version": "0.1.62",
3
+ "version": "0.1.64",
4
4
  "main": "mozrest-sdk.es.js",
5
5
  "keywords": ["mozrest"],
6
6
  "author": {