@m4l/components 0.0.45 → 0.0.48
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/components/CommonActions/components/ActionCancel/index.d.ts +3 -0
- package/dist/components/CommonActions/components/ActionCancel/index.js +14 -0
- package/dist/components/CommonActions/components/ActionFormCancel/index.d.ts +3 -0
- package/dist/components/CommonActions/components/ActionFormCancel/index.js +62 -0
- package/dist/components/CommonActions/components/ActionFormCancel/types.d.ts +6 -0
- package/dist/components/CommonActions/components/ActionFormIntro/index.d.ts +3 -0
- package/dist/components/CommonActions/components/ActionFormIntro/index.js +34 -0
- package/dist/components/CommonActions/components/ActionIntro/index.d.ts +3 -0
- package/dist/components/CommonActions/components/ActionIntro/index.js +16 -0
- package/dist/components/CommonActions/components/Actions/index.d.ts +3 -0
- package/dist/components/CommonActions/components/Actions/index.js +980 -0
- package/dist/components/CommonActions/components/Actions/styles.d.ts +2 -0
- package/dist/components/CommonActions/components/Actions/types.d.ts +6 -0
- package/dist/components/CommonActions/context/index.d.ts +5 -0
- package/dist/components/CommonActions/context/types.d.ts +9 -0
- package/dist/components/{FormActions → CommonActions}/dictionary.d.ts +1 -1
- package/dist/components/CommonActions/index.d.ts +6 -0
- package/dist/components/DataGrid/index.js +8 -648
- package/dist/components/DynamicFilter/components/fieldstypes/DateTimeFilter/index.d.ts +2 -1
- package/dist/components/DynamicFilter/components/fieldstypes/factory.d.ts +2 -1
- package/dist/components/DynamicFilter/index.js +21 -17
- package/dist/components/Icon/index.js +14 -12
- package/dist/components/ModalDialog/components/Header/types.d.ts +2 -2
- package/dist/components/ModalDialog/index.js +20 -20
- package/dist/components/ModalDialog/types.d.ts +2 -2
- package/dist/components/ObjectLogs/index.js +3 -6
- package/dist/components/SplitLayout/index.js +0 -1
- package/dist/components/formatters/DateFormatter/index.js +10 -8
- package/dist/components/hook-form/FormProvider/index.js +6 -116
- package/dist/components/hook-form/RHFTextField/index.d.ts +1 -1
- package/dist/components/index.d.ts +2 -2
- package/dist/components/mui_extended/Button/index.d.ts +3 -0
- package/dist/components/mui_extended/Button/styles.d.ts +12 -0
- package/dist/components/mui_extended/Button/types.d.ts +2 -0
- package/dist/components/mui_extended/IconButton/index.d.ts +0 -1
- package/dist/components/mui_extended/IconButton/index.js +23 -16
- package/dist/components/mui_extended/Pager/index.js +1 -66
- package/dist/contexts/ModalContext/components/ContentConfirm/types.d.ts +3 -3
- package/dist/contexts/ModalContext/index.js +12 -9
- package/dist/contexts/ModalContext/types.d.ts +5 -6
- package/dist/index.js +6 -3
- package/dist/react-lazy-load-image-component.js +197 -173
- package/dist/utils/index.d.ts +3 -3
- package/dist/utils/types.d.ts +1 -0
- package/dist/vendor.js +32 -11
- package/package.json +4 -5
- package/dist/components/FormActions/index.d.ts +0 -3
- package/dist/components/FormActions/index.js +0 -51
- package/dist/components/FormActions/styles.d.ts +0 -2
- package/dist/components/FormActions/types.d.ts +0 -7
- package/dist/components/mui_extended/MenuActions/index.js +0 -111
|
@@ -1,13 +1,14 @@
|
|
|
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,
|
|
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
8
|
import "react-router-dom";
|
|
9
9
|
import "@mui/lab";
|
|
10
|
-
import { styled as styled$1, Skeleton, MenuItem, Popper, Button } from "@mui/material";
|
|
10
|
+
import { styled as styled$1, Skeleton, MenuItem, useTheme, Popper, Button } from "@mui/material";
|
|
11
|
+
import { L as LabelMemuItem } from "../CommonActions/components/Actions/index.js";
|
|
11
12
|
import "../../contexts/ModalContext/index.js";
|
|
12
13
|
import { jsx, jsxs, Fragment } from "react/jsx-runtime";
|
|
13
14
|
import { R as RHFAutocomplete } from "../../vendor.js";
|
|
@@ -20,11 +21,9 @@ import "../../lodash.js";
|
|
|
20
21
|
import "../../react-lazy-load-image-component.js";
|
|
21
22
|
import "../Image/index.js";
|
|
22
23
|
import "../hook-form/RHFUpload.js";
|
|
23
|
-
import { format } from "date-fns";
|
|
24
24
|
import { I as IconButton } from "../mui_extended/IconButton/index.js";
|
|
25
25
|
import { I as Icon } from "../Icon/index.js";
|
|
26
26
|
import "../../simplebar.js";
|
|
27
|
-
import { L as LabelMemuItem } from "../mui_extended/MenuActions/index.js";
|
|
28
27
|
import { M as MenuPopover } from "../mui_extended/MenuPopover/index.js";
|
|
29
28
|
import { useResponsiveDesktop } from "@m4l/graphics";
|
|
30
29
|
const WrapperApplyedFilters = styled("div")(({
|
|
@@ -370,7 +369,7 @@ const verifyDateTime = (filter) => {
|
|
|
370
369
|
}
|
|
371
370
|
return true;
|
|
372
371
|
};
|
|
373
|
-
const getDefaultDateTimeFilter = (field, fixed, getLabel) => {
|
|
372
|
+
const getDefaultDateTimeFilter = (field, fixed, getLabel, hostTools) => {
|
|
374
373
|
const defaultStartDate = new Date();
|
|
375
374
|
const defaultEndDate = new Date();
|
|
376
375
|
let dfop1 = field.defaultOperand1;
|
|
@@ -408,7 +407,7 @@ const getDefaultDateTimeFilter = (field, fixed, getLabel) => {
|
|
|
408
407
|
}
|
|
409
408
|
defaultFilter.o1 = defaultStartDate.toISOString();
|
|
410
409
|
defaultFilter.o2 = defaultEndDate.toISOString();
|
|
411
|
-
defaultFilter.labelOperands = `${
|
|
410
|
+
defaultFilter.labelOperands = `${hostTools.formatDate(defaultStartDate, "yyyy-MM-dd HH:mm:ss")} - ${hostTools.formatDate(defaultEndDate, "yyyy-MM-dd HH:mm:ss")}`;
|
|
412
411
|
defaultFilter.labelOperator = getLabel(`dynamic_filter.operator_${defaultFilter.o}`);
|
|
413
412
|
return defaultFilter;
|
|
414
413
|
};
|
|
@@ -421,6 +420,9 @@ function DateTimeFilter() {
|
|
|
421
420
|
const {
|
|
422
421
|
getLabel
|
|
423
422
|
} = useModuleDictionary();
|
|
423
|
+
const {
|
|
424
|
+
formatDate
|
|
425
|
+
} = useHostTools();
|
|
424
426
|
const {
|
|
425
427
|
dfnsFormat: {
|
|
426
428
|
datetime_format
|
|
@@ -460,10 +462,10 @@ function DateTimeFilter() {
|
|
|
460
462
|
};
|
|
461
463
|
if (data.valueOperator.id === "b") {
|
|
462
464
|
newFilter.o2 = data.valueOperand2.toISOString();
|
|
463
|
-
newFilter.labelOperands = `${
|
|
465
|
+
newFilter.labelOperands = `${formatDate(data.valueOperand1, datetime_format)} - ${formatDate(data.valueOperand2, datetime_format)}`;
|
|
464
466
|
} else {
|
|
465
467
|
newFilter.o2 = newFilter.o2 ? newFilter.o2 : newFilter.o1;
|
|
466
|
-
newFilter.labelOperands =
|
|
468
|
+
newFilter.labelOperands = formatDate(data.valueOperand1, datetime_format);
|
|
467
469
|
}
|
|
468
470
|
return newFilter;
|
|
469
471
|
}, []);
|
|
@@ -671,9 +673,9 @@ const strategiesDefaultFilterValues = {
|
|
|
671
673
|
throw new Error("Type no defined");
|
|
672
674
|
}
|
|
673
675
|
};
|
|
674
|
-
const getDefaultFilterValues = (field, fixed, getLabel) => {
|
|
676
|
+
const getDefaultFilterValues = (field, fixed, getLabel, hostTools) => {
|
|
675
677
|
const transformer = strategiesDefaultFilterValues[field.type] ?? strategiesDefaultFilterValues.__default__;
|
|
676
|
-
return transformer(field, fixed, getLabel);
|
|
678
|
+
return transformer(field, fixed, getLabel, hostTools);
|
|
677
679
|
};
|
|
678
680
|
const strategiesEditFilterComponent = {
|
|
679
681
|
string: StringFilter,
|
|
@@ -751,7 +753,7 @@ const formatToRawFilter = (applyedFilter) => {
|
|
|
751
753
|
o2: af.o2
|
|
752
754
|
}));
|
|
753
755
|
};
|
|
754
|
-
const getInitialFilters = (fields, filters, getFieldByName, getLabel) => {
|
|
756
|
+
const getInitialFilters = (fields, filters, getFieldByName, getLabel, hostTools) => {
|
|
755
757
|
const newFilters = [];
|
|
756
758
|
const fixedFields = [];
|
|
757
759
|
for (let index = 0; index < filters.length; index++) {
|
|
@@ -801,7 +803,7 @@ const getInitialFilters = (fields, filters, getFieldByName, getLabel) => {
|
|
|
801
803
|
const field = fields[index];
|
|
802
804
|
if (field.presence === "initialized" || field.presence === "fixed") {
|
|
803
805
|
if (!filters.find((f) => f.n === field.name)) {
|
|
804
|
-
const newFilter = getDefaultFilterValues(field, field.presence === "fixed", getLabel);
|
|
806
|
+
const newFilter = getDefaultFilterValues(field, field.presence === "fixed", getLabel, hostTools);
|
|
805
807
|
newFilter.id = newFilters.length + 1;
|
|
806
808
|
newFilters.push(newFilter);
|
|
807
809
|
}
|
|
@@ -834,6 +836,7 @@ function BaseProvider(props) {
|
|
|
834
836
|
host_static_assets,
|
|
835
837
|
environment_assets
|
|
836
838
|
} = useEnvironment();
|
|
839
|
+
const hostTools = useHostTools();
|
|
837
840
|
const all_fields = useMemo(() => {
|
|
838
841
|
return {
|
|
839
842
|
...ALL_FIELDS,
|
|
@@ -855,7 +858,7 @@ function BaseProvider(props) {
|
|
|
855
858
|
const getLabelOperator = useCallback((operator) => {
|
|
856
859
|
return getLabel(`dynamic_filter.operator_${operator}`);
|
|
857
860
|
}, [getLabel]);
|
|
858
|
-
const [applyedFilters, setApplyedFilters] = useState(getInitialFilters(fields, initialFilters, getFieldByName, getLabel));
|
|
861
|
+
const [applyedFilters, setApplyedFilters] = useState(getInitialFilters(fields, initialFilters, getFieldByName, getLabel, hostTools));
|
|
859
862
|
const availableFields = useMemo(() => {
|
|
860
863
|
const newFields = [];
|
|
861
864
|
for (let index = 0; index < fields.length; index++) {
|
|
@@ -885,7 +888,7 @@ function BaseProvider(props) {
|
|
|
885
888
|
autoClose: 1e4
|
|
886
889
|
});
|
|
887
890
|
}
|
|
888
|
-
}, [isValid, applyedFilters]);
|
|
891
|
+
}, [isValid, applyedFilters, onChangeFilter]);
|
|
889
892
|
useEffect(() => {
|
|
890
893
|
const NoValid = applyedFilters.findIndex((f) => !f.isSetted) > -1;
|
|
891
894
|
if (NoValid) {
|
|
@@ -962,7 +965,7 @@ function BaseProvider(props) {
|
|
|
962
965
|
const showPopupForAddFilter = useCallback((anchorEl, field) => {
|
|
963
966
|
setPopupData({
|
|
964
967
|
popupAnchorEl: anchorEl,
|
|
965
|
-
filter: getDefaultFilterValues(field, false, getLabel),
|
|
968
|
+
filter: getDefaultFilterValues(field, false, getLabel, hostTools),
|
|
966
969
|
field
|
|
967
970
|
});
|
|
968
971
|
setInEdition(true);
|
|
@@ -1133,7 +1136,7 @@ function ApplyedFilter(props) {
|
|
|
1133
1136
|
children: labelOperands
|
|
1134
1137
|
})]
|
|
1135
1138
|
}), !fixed && /* @__PURE__ */ jsx(IconButton, {
|
|
1136
|
-
src: `${host_static_assets}/${environment_assets}/frontend/components/dynamic_filter/assets/icons/
|
|
1139
|
+
src: `${host_static_assets}/${environment_assets}/frontend/components/dynamic_filter/assets/icons/close_filter.svg`,
|
|
1137
1140
|
onClick: onDelete
|
|
1138
1141
|
})]
|
|
1139
1142
|
});
|
|
@@ -1470,6 +1473,7 @@ const PopupEditFilter = () => {
|
|
|
1470
1473
|
getLabelOperator,
|
|
1471
1474
|
fnTransformFormValuesIntoRawValues
|
|
1472
1475
|
} = useBase();
|
|
1476
|
+
const theme = useTheme();
|
|
1473
1477
|
const {
|
|
1474
1478
|
getLabel
|
|
1475
1479
|
} = useModuleDictionary();
|
|
@@ -1506,7 +1510,7 @@ const PopupEditFilter = () => {
|
|
|
1506
1510
|
open: Boolean(popupAnchorEl),
|
|
1507
1511
|
anchorEl: popupAnchorEl,
|
|
1508
1512
|
sx: {
|
|
1509
|
-
boxShadow:
|
|
1513
|
+
boxShadow: theme.customShadows.dropdown,
|
|
1510
1514
|
borderRadius: 1
|
|
1511
1515
|
},
|
|
1512
1516
|
children: /* @__PURE__ */ jsx(Fragment, {
|
|
@@ -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
|
-
|
|
8
|
-
|
|
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
|
|
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(
|
|
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:
|
|
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 {
|
|
2
|
+
import { VariantColor } from '../../../../utils/types';
|
|
3
3
|
export interface HeaderProps {
|
|
4
|
-
variant?:
|
|
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 {
|
|
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 {
|
|
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
|
-
|
|
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: [
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
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(
|
|
175
|
+
return ["modal_dialog"].concat(getStandardActionsDictionary());
|
|
176
176
|
}
|
|
177
177
|
const defaultModalDialogDictionary = {
|
|
178
178
|
modal_dialog: {}
|
|
@@ -126,13 +126,13 @@ function DetailFormatter(props) {
|
|
|
126
126
|
});
|
|
127
127
|
}
|
|
128
128
|
function ObjectLogs(props) {
|
|
129
|
-
const {
|
|
130
|
-
getLabel
|
|
131
|
-
} = useModuleDictionary();
|
|
132
129
|
const {
|
|
133
130
|
resource_id,
|
|
134
131
|
object_id
|
|
135
132
|
} = props;
|
|
133
|
+
const {
|
|
134
|
+
getLabel
|
|
135
|
+
} = useModuleDictionary();
|
|
136
136
|
const [queryParams, setQueryParams] = useState({
|
|
137
137
|
resource_id,
|
|
138
138
|
object_id
|
|
@@ -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",
|
|
@@ -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
|
|
8
|
+
format,
|
|
10
9
|
Component = require$$0.Fragment
|
|
11
10
|
} = props;
|
|
12
11
|
const {
|
|
13
12
|
dfnsFormat
|
|
14
13
|
} = useEnvironment();
|
|
15
|
-
|
|
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
|
|
22
|
+
finalFormat = format || dfnsFormat.datetime_format;
|
|
21
23
|
break;
|
|
22
24
|
case "date":
|
|
23
|
-
finalFormat = format
|
|
25
|
+
finalFormat = format || dfnsFormat.date_format;
|
|
24
26
|
break;
|
|
25
27
|
case "time":
|
|
26
|
-
finalFormat = 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 =
|
|
37
|
+
result = formatDate(resultDate, finalFormat);
|
|
36
38
|
} catch (e) {
|
|
37
39
|
result = "err_typing";
|
|
38
40
|
}
|
|
@@ -1,125 +1,15 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
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 {
|
|
6
|
-
import {
|
|
7
|
-
|
|
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 { F as FormActions } from "../../CommonActions/components/Actions/index.js";
|
|
6
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
7
|
+
const WrapperFormProvider = styled("form")(() => ({
|
|
14
8
|
display: "flex",
|
|
15
9
|
flexDirection: "column",
|
|
16
10
|
width: "100%",
|
|
17
|
-
overflow: "scroll"
|
|
18
|
-
marginBottom: theme.spacing(1)
|
|
11
|
+
overflow: "scroll"
|
|
19
12
|
}));
|
|
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
13
|
function FormProvider(props) {
|
|
124
14
|
const {
|
|
125
15
|
children,
|