@m4l/components 0.0.46 → 0.0.49

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.
Files changed (55) hide show
  1. package/dist/commonjs.js +1 -1
  2. package/dist/components/CommonActions/components/ActionCancel/index.d.ts +3 -0
  3. package/dist/components/CommonActions/components/ActionCancel/index.js +15 -0
  4. package/dist/components/CommonActions/components/ActionFormCancel/index.d.ts +3 -0
  5. package/dist/components/CommonActions/components/ActionFormCancel/index.js +62 -0
  6. package/dist/components/CommonActions/components/ActionFormCancel/types.d.ts +6 -0
  7. package/dist/components/CommonActions/components/ActionFormIntro/index.d.ts +3 -0
  8. package/dist/components/CommonActions/components/ActionFormIntro/index.js +35 -0
  9. package/dist/components/CommonActions/components/ActionIntro/index.d.ts +3 -0
  10. package/dist/components/CommonActions/components/ActionIntro/index.js +16 -0
  11. package/dist/components/CommonActions/components/Actions/index.d.ts +3 -0
  12. package/dist/components/CommonActions/components/Actions/index.js +857 -0
  13. package/dist/components/CommonActions/components/Actions/styles.d.ts +2 -0
  14. package/dist/components/CommonActions/components/Actions/types.d.ts +4 -0
  15. package/dist/components/{FormActions → CommonActions}/dictionary.d.ts +1 -1
  16. package/dist/components/CommonActions/index.d.ts +6 -0
  17. package/dist/components/DataGrid/index.js +8 -648
  18. package/dist/components/DynamicFilter/components/fieldstypes/DateTimeFilter/index.d.ts +2 -1
  19. package/dist/components/DynamicFilter/components/fieldstypes/factory.d.ts +2 -1
  20. package/dist/components/DynamicFilter/index.js +23 -23
  21. package/dist/components/Icon/index.js +14 -12
  22. package/dist/components/ModalDialog/components/Header/types.d.ts +2 -2
  23. package/dist/components/ModalDialog/index.js +20 -20
  24. package/dist/components/ModalDialog/types.d.ts +2 -2
  25. package/dist/components/ObjectLogs/index.js +0 -3
  26. package/dist/components/SplitLayout/index.js +0 -1
  27. package/dist/components/formatters/DateFormatter/index.js +10 -8
  28. package/dist/components/hook-form/FormProvider/index.js +8 -124
  29. package/dist/components/hook-form/FormProvider/types.d.ts +0 -2
  30. package/dist/components/hook-form/RHFTextField/index.d.ts +1 -1
  31. package/dist/components/index.d.ts +2 -2
  32. package/dist/components/mui_extended/Button/index.d.ts +3 -0
  33. package/dist/components/mui_extended/Button/styles.d.ts +12 -0
  34. package/dist/components/mui_extended/Button/types.d.ts +2 -0
  35. package/dist/components/mui_extended/IconButton/index.d.ts +0 -1
  36. package/dist/components/mui_extended/IconButton/index.js +23 -16
  37. package/dist/components/mui_extended/Pager/index.js +1 -66
  38. package/dist/contexts/ModalContext/components/ContentConfirm/types.d.ts +3 -3
  39. package/dist/contexts/ModalContext/index.js +12 -9
  40. package/dist/contexts/ModalContext/types.d.ts +5 -6
  41. package/dist/index.js +8 -5
  42. package/dist/react-lazy-load-image-component.js +197 -173
  43. package/dist/utils/index.d.ts +3 -3
  44. package/dist/utils/types.d.ts +1 -0
  45. package/dist/vendor.js +55 -34
  46. package/package.json +4 -5
  47. package/dist/components/FormActions/index.d.ts +0 -3
  48. package/dist/components/FormActions/index.js +0 -51
  49. package/dist/components/FormActions/styles.d.ts +0 -2
  50. package/dist/components/FormActions/types.d.ts +0 -7
  51. package/dist/components/hook-form/FormProvider/components/FormActions/index.d.ts +0 -3
  52. package/dist/components/hook-form/FormProvider/components/FormActions/skeleton.d.ts +0 -2
  53. package/dist/components/hook-form/FormProvider/components/FormActions/styles.d.ts +0 -3
  54. package/dist/components/hook-form/FormProvider/components/FormActions/types.d.ts +0 -4
  55. package/dist/components/mui_extended/MenuActions/index.js +0 -111
@@ -1,16 +1,13 @@
1
1
  import { S as ScrollBar } from "../ScrollBar/index.js";
2
2
  import { styled, alpha } from "@mui/material/styles";
3
3
  import require$$0, { useRef, useState, useMemo, useCallback, useEffect, createContext, useContext } from "react";
4
- import { useModuleDictionary, useEnvironment, voidFunction, useHostTools, useFlagsPresent } from "@m4l/core";
4
+ import { useModuleDictionary, useHostTools, useEnvironment, voidFunction, useFlagsPresent } from "@m4l/core";
5
5
  import * as Yup from "yup";
6
6
  import { useFormContext, useWatch } from "react-hook-form";
7
7
  import { F as FormProvider } from "../hook-form/FormProvider/index.js";
8
- import "react-router-dom";
9
- import "@mui/lab";
10
- import { styled as styled$1, Skeleton, MenuItem, Popper, Button } from "@mui/material";
11
- import "../../contexts/ModalContext/index.js";
12
8
  import { jsx, jsxs, Fragment } from "react/jsx-runtime";
13
9
  import { R as RHFAutocomplete } from "../../vendor.js";
10
+ import { styled as styled$1, Skeleton, MenuItem, useTheme, Popper, Button } from "@mui/material";
14
11
  import "../hook-form/RHFAutocompleteAsync/index.js";
15
12
  import "../hook-form/RHFCheckbox/index.js";
16
13
  import { R as RHFDateTime } from "../hook-form/RHFDateTime.js";
@@ -20,11 +17,10 @@ import "../../lodash.js";
20
17
  import "../../react-lazy-load-image-component.js";
21
18
  import "../Image/index.js";
22
19
  import "../hook-form/RHFUpload.js";
23
- import { format } from "date-fns";
24
20
  import { I as IconButton } from "../mui_extended/IconButton/index.js";
25
21
  import { I as Icon } from "../Icon/index.js";
26
22
  import "../../simplebar.js";
27
- import { L as LabelMemuItem } from "../mui_extended/MenuActions/index.js";
23
+ import { L as LabelMemuItem } from "../CommonActions/components/Actions/index.js";
28
24
  import { M as MenuPopover } from "../mui_extended/MenuPopover/index.js";
29
25
  import { useResponsiveDesktop } from "@m4l/graphics";
30
26
  const WrapperApplyedFilters = styled("div")(({
@@ -370,7 +366,7 @@ const verifyDateTime = (filter) => {
370
366
  }
371
367
  return true;
372
368
  };
373
- const getDefaultDateTimeFilter = (field, fixed, getLabel) => {
369
+ const getDefaultDateTimeFilter = (field, fixed, getLabel, hostTools) => {
374
370
  const defaultStartDate = new Date();
375
371
  const defaultEndDate = new Date();
376
372
  let dfop1 = field.defaultOperand1;
@@ -408,7 +404,7 @@ const getDefaultDateTimeFilter = (field, fixed, getLabel) => {
408
404
  }
409
405
  defaultFilter.o1 = defaultStartDate.toISOString();
410
406
  defaultFilter.o2 = defaultEndDate.toISOString();
411
- defaultFilter.labelOperands = `${format(defaultStartDate, "yyyy-MM-dd HH:mm:ss")} - ${format(defaultEndDate, "yyyy-MM-dd HH:mm:ss")}`;
407
+ defaultFilter.labelOperands = `${hostTools.formatDate(defaultStartDate, "yyyy-MM-dd HH:mm:ss")} - ${hostTools.formatDate(defaultEndDate, "yyyy-MM-dd HH:mm:ss")}`;
412
408
  defaultFilter.labelOperator = getLabel(`dynamic_filter.operator_${defaultFilter.o}`);
413
409
  return defaultFilter;
414
410
  };
@@ -421,6 +417,9 @@ function DateTimeFilter() {
421
417
  const {
422
418
  getLabel
423
419
  } = useModuleDictionary();
420
+ const {
421
+ formatDate
422
+ } = useHostTools();
424
423
  const {
425
424
  dfnsFormat: {
426
425
  datetime_format
@@ -460,10 +459,10 @@ function DateTimeFilter() {
460
459
  };
461
460
  if (data.valueOperator.id === "b") {
462
461
  newFilter.o2 = data.valueOperand2.toISOString();
463
- newFilter.labelOperands = `${format(data.valueOperand1, datetime_format)} - ${format(data.valueOperand2, datetime_format)}`;
462
+ newFilter.labelOperands = `${formatDate(data.valueOperand1, datetime_format)} - ${formatDate(data.valueOperand2, datetime_format)}`;
464
463
  } else {
465
464
  newFilter.o2 = newFilter.o2 ? newFilter.o2 : newFilter.o1;
466
- newFilter.labelOperands = format(data.valueOperand1, datetime_format);
465
+ newFilter.labelOperands = formatDate(data.valueOperand1, datetime_format);
467
466
  }
468
467
  return newFilter;
469
468
  }, []);
@@ -671,9 +670,9 @@ const strategiesDefaultFilterValues = {
671
670
  throw new Error("Type no defined");
672
671
  }
673
672
  };
674
- const getDefaultFilterValues = (field, fixed, getLabel) => {
673
+ const getDefaultFilterValues = (field, fixed, getLabel, hostTools) => {
675
674
  const transformer = strategiesDefaultFilterValues[field.type] ?? strategiesDefaultFilterValues.__default__;
676
- return transformer(field, fixed, getLabel);
675
+ return transformer(field, fixed, getLabel, hostTools);
677
676
  };
678
677
  const strategiesEditFilterComponent = {
679
678
  string: StringFilter,
@@ -751,7 +750,7 @@ const formatToRawFilter = (applyedFilter) => {
751
750
  o2: af.o2
752
751
  }));
753
752
  };
754
- const getInitialFilters = (fields, filters, getFieldByName, getLabel) => {
753
+ const getInitialFilters = (fields, filters, getFieldByName, getLabel, hostTools) => {
755
754
  const newFilters = [];
756
755
  const fixedFields = [];
757
756
  for (let index = 0; index < filters.length; index++) {
@@ -801,7 +800,7 @@ const getInitialFilters = (fields, filters, getFieldByName, getLabel) => {
801
800
  const field = fields[index];
802
801
  if (field.presence === "initialized" || field.presence === "fixed") {
803
802
  if (!filters.find((f) => f.n === field.name)) {
804
- const newFilter = getDefaultFilterValues(field, field.presence === "fixed", getLabel);
803
+ const newFilter = getDefaultFilterValues(field, field.presence === "fixed", getLabel, hostTools);
805
804
  newFilter.id = newFilters.length + 1;
806
805
  newFilters.push(newFilter);
807
806
  }
@@ -834,6 +833,7 @@ function BaseProvider(props) {
834
833
  host_static_assets,
835
834
  environment_assets
836
835
  } = useEnvironment();
836
+ const hostTools = useHostTools();
837
837
  const all_fields = useMemo(() => {
838
838
  return {
839
839
  ...ALL_FIELDS,
@@ -855,7 +855,7 @@ function BaseProvider(props) {
855
855
  const getLabelOperator = useCallback((operator) => {
856
856
  return getLabel(`dynamic_filter.operator_${operator}`);
857
857
  }, [getLabel]);
858
- const [applyedFilters, setApplyedFilters] = useState(getInitialFilters(fields, initialFilters, getFieldByName, getLabel));
858
+ const [applyedFilters, setApplyedFilters] = useState(getInitialFilters(fields, initialFilters, getFieldByName, getLabel, hostTools));
859
859
  const availableFields = useMemo(() => {
860
860
  const newFields = [];
861
861
  for (let index = 0; index < fields.length; index++) {
@@ -885,7 +885,7 @@ function BaseProvider(props) {
885
885
  autoClose: 1e4
886
886
  });
887
887
  }
888
- }, [isValid, applyedFilters]);
888
+ }, [isValid, applyedFilters, onChangeFilter]);
889
889
  useEffect(() => {
890
890
  const NoValid = applyedFilters.findIndex((f) => !f.isSetted) > -1;
891
891
  if (NoValid) {
@@ -962,7 +962,7 @@ function BaseProvider(props) {
962
962
  const showPopupForAddFilter = useCallback((anchorEl, field) => {
963
963
  setPopupData({
964
964
  popupAnchorEl: anchorEl,
965
- filter: getDefaultFilterValues(field, false, getLabel),
965
+ filter: getDefaultFilterValues(field, false, getLabel, hostTools),
966
966
  field
967
967
  });
968
968
  setInEdition(true);
@@ -1133,7 +1133,7 @@ function ApplyedFilter(props) {
1133
1133
  children: labelOperands
1134
1134
  })]
1135
1135
  }), !fixed && /* @__PURE__ */ jsx(IconButton, {
1136
- src: `${host_static_assets}/${environment_assets}/frontend/components/dynamic_filter/assets/icons/close.svg`,
1136
+ src: `${host_static_assets}/${environment_assets}/frontend/components/dynamic_filter/assets/icons/close_filter.svg`,
1137
1137
  onClick: onDelete
1138
1138
  })]
1139
1139
  });
@@ -1470,6 +1470,7 @@ const PopupEditFilter = () => {
1470
1470
  getLabelOperator,
1471
1471
  fnTransformFormValuesIntoRawValues
1472
1472
  } = useBase();
1473
+ const theme = useTheme();
1473
1474
  const {
1474
1475
  getLabel
1475
1476
  } = useModuleDictionary();
@@ -1506,7 +1507,7 @@ const PopupEditFilter = () => {
1506
1507
  open: Boolean(popupAnchorEl),
1507
1508
  anchorEl: popupAnchorEl,
1508
1509
  sx: {
1509
- boxShadow: "0 8px 16px 0 rgb(0 0 0 / 12%)",
1510
+ boxShadow: theme.customShadows.dropdown,
1510
1511
  borderRadius: 1
1511
1512
  },
1512
1513
  children: /* @__PURE__ */ jsx(Fragment, {
@@ -1514,7 +1515,6 @@ const PopupEditFilter = () => {
1514
1515
  onSubmit,
1515
1516
  values,
1516
1517
  validationSchema: popupValidationSchema,
1517
- urlCancel: -1,
1518
1518
  children: /* @__PURE__ */ jsxs(WrapperPopupEditFilter, {
1519
1519
  children: [/* @__PURE__ */ jsxs(HeaderContainer, {
1520
1520
  children: [field?.urlIcon && /* @__PURE__ */ jsx(Icon, {
@@ -1529,12 +1529,12 @@ const PopupEditFilter = () => {
1529
1529
  variant: "outlined",
1530
1530
  color: "inherit",
1531
1531
  onClick: onClose,
1532
- children: `Cerrar`
1532
+ children: getLabel(`dyamic_filter.cancel`)
1533
1533
  }), /* @__PURE__ */ jsx(Button, {
1534
1534
  variant: "contained",
1535
1535
  color: "primary",
1536
1536
  type: "submit",
1537
- children: `Agregar ${filter.id}`
1537
+ children: getLabel(`dyamic_filter.intro`)
1538
1538
  })]
1539
1539
  })]
1540
1540
  })
@@ -1,15 +1,15 @@
1
1
  import { styled, useTheme } from "@mui/material";
2
- import { useState, useEffect } from "react";
2
+ import { useState, useMemo, useEffect } from "react";
3
3
  import { jsx } from "react/jsx-runtime";
4
4
  const MaskIcon = styled("div", {
5
5
  shouldForwardProp: (props) => props !== "src" && props !== "width" && props !== "height" && props !== "bgColor"
6
6
  })((props) => ({
7
- WebkitMask: `url(${props.src}) no-repeat`,
8
- mask: `url(${props.src}) no-repeat`,
9
- maskPosition: "center",
7
+ maskPosition: "center!important",
8
+ maskRepeat: "no-repeat!important",
10
9
  width: props.width === void 0 ? "20px" : props.width,
11
10
  height: props.height === void 0 ? "20px" : props.height,
12
- backgroundColor: props.bgColor
11
+ backgroundColor: props.bgColor,
12
+ mask: `url('data:image/svg+xml;base64,${props.src}')`
13
13
  }));
14
14
  const WrapperPlaceHolder = styled("div", {
15
15
  shouldForwardProp: (props) => props !== "widht" && props !== "height"
@@ -29,7 +29,7 @@ function Icon(props) {
29
29
  } = props;
30
30
  const [resource, setResource] = useState(void 0);
31
31
  const theme = useTheme();
32
- const getBgColor = () => {
32
+ const finalBgColor = useMemo(() => {
33
33
  if (bgColor === "active") {
34
34
  return theme.palette.action.active;
35
35
  }
@@ -49,23 +49,25 @@ function Icon(props) {
49
49
  return theme.palette.action.disabled;
50
50
  }
51
51
  return bgColor;
52
- };
52
+ }, [bgColor]);
53
53
  useEffect(() => {
54
54
  let mounted = true;
55
- if (resource)
56
- return;
57
55
  (async function networkOperation() {
58
56
  await fetch(src).then((response) => {
57
+ return response.text() || "";
58
+ }).then((xml) => {
59
+ xml = xml.match(/(<svg\b[^>]*\s*(viewBox="(\b[^"]*)").*?>([\s\S]*?)<\/svg>|<svg>([\s\S]*?)<\/svg>)/g)?.toString() || "";
59
60
  if (mounted) {
60
- setResource(response.url);
61
+ setResource(window.btoa(xml));
61
62
  }
62
63
  }).catch((_err) => {
64
+ console.log("error icon");
63
65
  });
64
66
  })();
65
67
  return function clenUp() {
66
68
  mounted = false;
67
69
  };
68
- }, []);
70
+ }, [src]);
69
71
  const placeHolder = "";
70
72
  return /* @__PURE__ */ jsx(WrapperPlaceHolder, {
71
73
  id: "IconReact",
@@ -75,7 +77,7 @@ function Icon(props) {
75
77
  src: resource,
76
78
  width,
77
79
  height,
78
- bgColor: getBgColor()
80
+ bgColor: finalBgColor
79
81
  }) : /* @__PURE__ */ jsx("img", {
80
82
  src: placeHolder,
81
83
  alt: "icon_svg"
@@ -1,7 +1,7 @@
1
1
  import { ReactNode } from 'react';
2
- import { VariantModal } from '../../../../contexts/ModalContext/types';
2
+ import { VariantColor } from '../../../../utils/types';
3
3
  export interface HeaderProps {
4
- variant?: VariantModal;
4
+ variant?: VariantColor;
5
5
  title: string;
6
6
  iconComponent?: ReactNode;
7
7
  withClose?: boolean;
@@ -2,13 +2,13 @@ import { Dialog, IconButton, Paper } from "@mui/material";
2
2
  import { D as Draggable } from "../../react-draggable.js";
3
3
  import { u as useModal } from "../../hooks/useModal/index.js";
4
4
  import { styled } from "@mui/material/styles";
5
- import { a as getThemeVariantColor } from "../../vendor.js";
5
+ import { g as getThemeVariantColor } from "../../vendor.js";
6
6
  import { R as Resizeable } from "../Resizeable/index.js";
7
7
  import { useResponsiveDesktop } from "@m4l/graphics";
8
8
  import { useEnvironment } from "@m4l/core";
9
9
  import { I as Icon } from "../Icon/index.js";
10
10
  import { jsxs, jsx } from "react/jsx-runtime";
11
- import { F as FormActions, g as getActionnsComponentsDictionary } from "../FormActions/index.js";
11
+ import { b as Actions, g as getStandardActionsDictionary } from "../CommonActions/components/Actions/index.js";
12
12
  const WrapperDialog = styled(Dialog)(() => ({}));
13
13
  const Container = styled("div")(({ theme }) => ({
14
14
  display: "flex",
@@ -128,8 +128,7 @@ const ModalDialog = () => {
128
128
  title,
129
129
  closeModal,
130
130
  iconComponent,
131
- standardActions,
132
- actionComponents,
131
+ actions,
133
132
  variant
134
133
  } = useModal();
135
134
  const isDesktop = useResponsiveDesktop();
@@ -138,21 +137,22 @@ const ModalDialog = () => {
138
137
  };
139
138
  const contentComnponent = /* @__PURE__ */ jsxs(Container, {
140
139
  id: "Container",
141
- children: [/* @__PURE__ */ jsx(Header, {
142
- variant,
143
- title,
144
- iconComponent,
145
- withClose,
146
- onCloseModal
147
- }), /* @__PURE__ */ jsx(Content, {
148
- id: "Content",
149
- children: typeof contentComponent === "function" ? contentComponent() : contentComponent
150
- }), (standardActions || actionComponents) && /* @__PURE__ */ jsx(FormActions, {
151
- variant,
152
- standardActions,
153
- actionComponents,
154
- onCloseModal
155
- })]
140
+ children: [
141
+ /* @__PURE__ */ jsx(Header, {
142
+ variant,
143
+ title,
144
+ iconComponent,
145
+ withClose,
146
+ onCloseModal
147
+ }),
148
+ /* @__PURE__ */ jsx(Content, {
149
+ id: "Content",
150
+ children: typeof contentComponent === "function" ? contentComponent() : contentComponent
151
+ }),
152
+ actions && /* @__PURE__ */ jsx(Actions, {
153
+ children: actions
154
+ })
155
+ ]
156
156
  });
157
157
  return /* @__PURE__ */ jsxs(WrapperDialog, {
158
158
  open,
@@ -172,7 +172,7 @@ const ModalDialog = () => {
172
172
  });
173
173
  };
174
174
  function getModalDialogComponentsDictionary() {
175
- return ["modal_dialog"].concat(getActionnsComponentsDictionary());
175
+ return ["modal_dialog"].concat(getStandardActionsDictionary());
176
176
  }
177
177
  const defaultModalDialogDictionary = {
178
178
  modal_dialog: {}
@@ -1,6 +1,6 @@
1
- import { VariantModal } from '../../contexts/ModalContext/types';
1
+ import { VariantColor } from '../../utils/types';
2
2
  export interface ModalDialogProps {
3
3
  }
4
4
  export interface VariantProps {
5
- variant?: VariantModal;
5
+ variant?: VariantColor;
6
6
  }
@@ -186,7 +186,6 @@ function ObjectLogs(props) {
186
186
  queryParams
187
187
  });
188
188
  useEffect(() => {
189
- console.log("useEffect ObjectLogs", object_id);
190
189
  clearRows();
191
190
  setQueryParams((oldParms) => ({
192
191
  ...oldParms,
@@ -194,14 +193,12 @@ function ObjectLogs(props) {
194
193
  }));
195
194
  }, [object_id]);
196
195
  const onChangeFilter = (_initFilters, rawFilters) => {
197
- console.log("onChangeFilter*", object_id);
198
196
  setQueryParams((oldParms) => ({
199
197
  ...oldParms,
200
198
  f: rawFilters
201
199
  }));
202
200
  Refresh();
203
201
  };
204
- console.log("Render ObjectLogs", object_id, queryParams);
205
202
  return /* @__PURE__ */ jsxs(Container$1, {
206
203
  children: [/* @__PURE__ */ jsx(Actions, {
207
204
  id: "objectLogsActions",
@@ -32,7 +32,6 @@ const WrapperSplit = styled("div")(({
32
32
  display: "flex",
33
33
  alignItems: "center",
34
34
  backgroundColor: theme.palette.divider,
35
- zIndex: "1",
36
35
  boxSizing: "border-box",
37
36
  backgroundClip: "padding-box",
38
37
  width: "11px",
@@ -1,29 +1,31 @@
1
- import { useEnvironment } from "@m4l/core";
2
- import { format } from "date-fns";
1
+ import { useEnvironment, useHostTools } from "@m4l/core";
3
2
  import require$$0 from "react";
4
3
  import { jsx } from "react/jsx-runtime";
5
4
  function DateFormatter(props) {
6
5
  const {
7
6
  presentationType,
8
7
  value,
9
- format: format$1,
8
+ format,
10
9
  Component = require$$0.Fragment
11
10
  } = props;
12
11
  const {
13
12
  dfnsFormat
14
13
  } = useEnvironment();
15
- let finalFormat = format$1 || dfnsFormat.datetime_format;
14
+ const {
15
+ formatDate
16
+ } = useHostTools();
17
+ let finalFormat = format || dfnsFormat.datetime_format;
16
18
  let result;
17
19
  let resultDate;
18
20
  switch (presentationType) {
19
21
  case "datetime":
20
- finalFormat = format$1 || dfnsFormat.datetime_format;
22
+ finalFormat = format || dfnsFormat.datetime_format;
21
23
  break;
22
24
  case "date":
23
- finalFormat = format$1 || dfnsFormat.date_format;
25
+ finalFormat = format || dfnsFormat.date_format;
24
26
  break;
25
27
  case "time":
26
- finalFormat = format$1 || dfnsFormat.time_format;
28
+ finalFormat = format || dfnsFormat.time_format;
27
29
  break;
28
30
  }
29
31
  try {
@@ -32,7 +34,7 @@ function DateFormatter(props) {
32
34
  } else {
33
35
  resultDate = value;
34
36
  }
35
- result = format(resultDate, finalFormat);
37
+ result = formatDate(resultDate, finalFormat);
36
38
  } catch (e) {
37
39
  result = "err_typing";
38
40
  }
@@ -1,133 +1,20 @@
1
- import { useCallback, useEffect } from "react";
2
- import { useFormContext, useFormState, useForm, FormProvider as FormProvider$1 } from "react-hook-form";
1
+ import { useEffect } from "react";
2
+ import { useForm, FormProvider as FormProvider$1 } from "react-hook-form";
3
3
  import { o } from "../../../node_modules.js";
4
4
  import { styled } from "@mui/material/styles";
5
- import { useNavigate } from "react-router-dom";
6
- import { useModuleDictionary, useFlagsPresent } from "@m4l/core";
7
- import { LoadingButton } from "@mui/lab";
8
- import { Skeleton, Button } from "@mui/material";
9
- import { u as useModal } from "../../../hooks/useModal/index.js";
10
- import { jsxs, jsx } from "react/jsx-runtime";
11
- const WrapperFormProvider = styled("form")(({
12
- theme
13
- }) => ({
5
+ import { jsx } from "react/jsx-runtime";
6
+ const WrapperFormProvider = styled("form")(() => ({
14
7
  display: "flex",
15
8
  flexDirection: "column",
16
9
  width: "100%",
17
- overflow: "scroll",
18
- marginBottom: theme.spacing(1)
10
+ overflow: "scroll"
19
11
  }));
20
- const WrapperFormActions = styled("div")(({
21
- theme
22
- }) => ({
23
- paddingTop: theme.spacing(3),
24
- marginRight: theme.spacing(1.5),
25
- display: "flex",
26
- flexDirection: "row",
27
- justifyContent: "flex-end",
28
- "& > button": {
29
- marginLeft: "10px"
30
- },
31
- "& .MuiLoadingButton-root ": {
32
- minWidth: "80px"
33
- }
34
- }));
35
- const WrapperSKTFormActions = styled("div")(({
36
- theme
37
- }) => ({
38
- display: "grid",
39
- gridTemplateColumns: "auto auto",
40
- margin: "0px",
41
- gridGap: `${theme.spacing(3)}`,
42
- justifyContent: "flex-end",
43
- paddingTop: `${theme.spacing(3)}`,
44
- borderTop: `1px solid ${theme.palette.divider}`,
45
- [theme.breakpoints.up("sm")]: {
46
- margin: `0 ${theme.spacing(4.5)}`
47
- }
48
- }));
49
- function SKTFormActions() {
50
- return /* @__PURE__ */ jsxs(WrapperSKTFormActions, {
51
- children: [/* @__PURE__ */ jsx(Skeleton, {
52
- variant: "text",
53
- width: 57,
54
- height: 30
55
- }), /* @__PURE__ */ jsx(Skeleton, {
56
- variant: "text",
57
- width: 57,
58
- height: 30
59
- })]
60
- });
61
- }
62
- function FormActions(props) {
63
- const {
64
- withIntro,
65
- urlCancel
66
- } = props;
67
- const navigate = useNavigate();
68
- const {
69
- getLabel
70
- } = useModuleDictionary();
71
- const isSkeleton = !useFlagsPresent(["dictionary_loaded", "form_loaded"]);
72
- const {
73
- openModalConfirm
74
- } = useModal();
75
- const {
76
- control
77
- } = useFormContext();
78
- const {
79
- isDirty,
80
- isSubmitting
81
- } = useFormState({
82
- control
83
- });
84
- const onConfirmCancel = useCallback(() => {
85
- if (typeof urlCancel === "number") {
86
- navigate(urlCancel);
87
- }
88
- if (urlCancel && typeof urlCancel === "undefined") {
89
- navigate(urlCancel, {
90
- replace: false
91
- });
92
- }
93
- }, [navigate, urlCancel]);
94
- const onClickCancel = useCallback(() => {
95
- if (isDirty) {
96
- openModalConfirm({
97
- variant: "warning",
98
- title: getLabel("form_provider.confirm_quit_title"),
99
- msg: getLabel("form_provider.confirm_quit_msg"),
100
- onClickIntro: onConfirmCancel
101
- });
102
- } else {
103
- onConfirmCancel();
104
- }
105
- }, [getLabel, isDirty, onConfirmCancel, openModalConfirm]);
106
- if (isSkeleton) {
107
- return /* @__PURE__ */ jsx(SKTFormActions, {});
108
- }
109
- return /* @__PURE__ */ jsxs(WrapperFormActions, {
110
- children: [urlCancel && /* @__PURE__ */ jsx(Button, {
111
- variant: "outlined",
112
- color: "inherit",
113
- onClick: onClickCancel,
114
- children: getLabel("actions.action_cancel")
115
- }), withIntro && /* @__PURE__ */ jsx(LoadingButton, {
116
- variant: "contained",
117
- type: "submit",
118
- loading: isSubmitting,
119
- children: getLabel("actions.action_accept")
120
- })]
121
- });
122
- }
123
12
  function FormProvider(props) {
124
13
  const {
125
14
  children,
126
15
  onSubmit,
127
16
  values,
128
- validationSchema,
129
- withIntro,
130
- urlCancel = -1
17
+ validationSchema
131
18
  } = props;
132
19
  const methods = useForm({
133
20
  resolver: o(validationSchema),
@@ -148,13 +35,10 @@ function FormProvider(props) {
148
35
  }, [methods, values]);
149
36
  return /* @__PURE__ */ jsx(FormProvider$1, {
150
37
  ...methods,
151
- children: /* @__PURE__ */ jsxs(WrapperFormProvider, {
38
+ children: /* @__PURE__ */ jsx(WrapperFormProvider, {
152
39
  id: "formProvider",
153
40
  onSubmit: methods.handleSubmit(onSubmit),
154
- children: [children, withIntro && /* @__PURE__ */ jsx(FormActions, {
155
- withIntro,
156
- urlCancel
157
- })]
41
+ children
158
42
  })
159
43
  });
160
44
  }
@@ -5,6 +5,4 @@ export interface FormProviderProps {
5
5
  onSubmit: (data: FieldValues) => void;
6
6
  values: FieldValues;
7
7
  validationSchema: any;
8
- withIntro?: boolean;
9
- urlCancel?: string | number;
10
8
  }