@kingteza/crud-component 1.27.3 → 1.29.1
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/common/rich/index.d.ts +2 -1
- package/dist/common/text-field/NumberField.cjs.js +1 -1
- package/dist/common/text-field/NumberField.es.js +17 -18
- package/dist/crud/CrudComponent.cjs.js +1 -1
- package/dist/crud/CrudComponent.d.ts +20 -9
- package/dist/crud/CrudComponent.es.js +73 -69
- package/dist/crud/CrudField.cjs.js +1 -1
- package/dist/crud/CrudField.es.js +302 -286
- package/dist/crud/CrudForm.d.ts +2 -2
- package/dist/crud/CrudFormWizard.cjs.js +1 -1
- package/dist/crud/CrudFormWizard.d.ts +2 -2
- package/dist/crud/CrudFormWizard.es.js +82 -78
- package/dist/crud/CrudReportComponent.d.ts +5 -5
- package/dist/crud/CrudSearchComponent.d.ts +2 -2
- package/dist/crud/actions/index.cjs.js +1 -1
- package/dist/crud/actions/index.d.ts +3 -1
- package/dist/crud/actions/index.es.js +63 -61
- package/dist/crud/import/CrudImportComponent.d.ts +2 -2
- package/dist/crud/index.d.ts +1 -1
- package/dist/crud/modal/index.cjs.js +1 -1
- package/dist/crud/modal/index.d.ts +2 -2
- package/dist/crud/modal/index.es.js +101 -96
- package/dist/crud/view/CrudDecListView.cjs.js +1 -1
- package/dist/crud/view/CrudDecListView.d.ts +2 -2
- package/dist/crud/view/CrudDecListView.es.js +31 -30
- package/dist/crud/view/CrudViewer.cjs.js +1 -1
- package/dist/crud/view/CrudViewer.d.ts +3 -3
- package/dist/crud/view/CrudViewer.es.js +190 -182
- package/dist/crud/view/CrudViewerUtil.cjs.js +1 -1
- package/dist/crud/view/CrudViewerUtil.es.js +39 -38
- package/dist/util/CrudUtil.d.ts +1 -1
- package/dist/util/ObjectUtil.cjs.js +1 -0
- package/dist/util/ObjectUtil.d.ts +2 -0
- package/dist/util/ObjectUtil.es.js +10 -0
- package/package.json +1 -1
- package/dist/locale/index.d.ts +0 -86
package/dist/crud/CrudForm.d.ts
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { FormInstance, FormProps } from 'antd';
|
|
2
|
-
import {
|
|
2
|
+
import { CrudPurpose, FormBuilderFunc, ReadonlyCrudFields } from './CrudComponent';
|
|
3
3
|
export interface CurdFormFieldsProps<T> {
|
|
4
4
|
onDeleteFile?: (e: any) => void;
|
|
5
5
|
onUploadFile?: (e: any) => void;
|
|
6
6
|
grid?: boolean;
|
|
7
7
|
formBuilder?: FormBuilderFunc<T>;
|
|
8
|
-
fields:
|
|
8
|
+
fields: ReadonlyCrudFields<T>;
|
|
9
9
|
purpose?: CrudPurpose;
|
|
10
10
|
onValuesChange?: FormProps<T>["onValuesChange"];
|
|
11
11
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";const e=require("react/jsx-runtime"),
|
|
1
|
+
"use strict";const e=require("react/jsx-runtime"),y=require("@ant-design/icons"),a=require("antd"),q=require("react"),R=require("../locale/index.cjs.js"),S=require("./CrudForm.cjs.js"),B=require("../common/wizard/WizardViewForm.cjs.js"),v=require("../util/CrudUtil.cjs.js"),k=require("../util/ObjectUtil.cjs.js"),C=require("../common/button/Button.cjs.js");function w({fields:u,className:x,onDeleteFile:j,onUploadFile:i,purpose:l,wizard:t=[],updatingValue:g,onSave:b,submitting:F,onValuesChange:d}){const h=q.useMemo(()=>t.map(r=>{let n=!0;const o=u.filter(c=>{const s=v.getRealName(c.name);return!Array.isArray(s)&&r.fields.includes(s)});return o.forEach(c=>n&&(n=c.hidden??!1)),{...r,hidden:n,fieldThatShouldShowing:o}}),[u,t]),m=q.useMemo(()=>h.filter(r=>!r.hidden),[h]);return e.jsx(B,{onSubmit:(r,n)=>{b(n)},className:x,pages:m.map(({title:r,icon:n,fieldThatShouldShowing:o,hidden:c},s)=>({title:r,icon:n,hidden:c,component:f=>e.jsx(O,{fields:o,onDeleteFile:j,onUploadFile:i,purpose:l,i:s,updatingValue:g,backward:f.backward,forward:f.forward,wizard:m,submitting:F,onValuesChange:d},s)}))})}function O({fields:u,onDeleteFile:x,onUploadFile:j,purpose:i,wizard:l=[],i:t,forward:g,backward:b,submitting:F,updatingValue:d,onValuesChange:h}){const m=l[t],{t:r}=R.useTranslationLib(),[n]=a.Form.useForm();return q.useEffect(()=>{if(d&&(i==="update"||i==="clone")){const o={};for(const c of u){const s=v.getRealName(c.name,"upsertFieldName"),f=k.getValueByPath(d,s);k.setValueByPath(o,s,f)}n.setFieldsValue(o)}},[u,n,i,d]),e.jsxs(a.Form,{name:String(t),form:n,layout:"vertical",onValuesChange:h,children:[e.jsx(S.CrudFormFields,{fields:u,formBuilder:m.formBuilder,grid:m.grid,onDeleteFile:x,onUploadFile:j,purpose:i}),e.jsx(a.Divider,{}),e.jsxs(a.Row,{gutter:[8,8],children:[t>0&&e.jsx(a.Col,{md:12,children:e.jsx(C,{block:!0,icon:e.jsx(y.LeftOutlined,{}),htmlType:"button",type:"default",size:"large",onClick:()=>b(),children:r("str.back")})}),e.jsx(a.Col,{md:t>0?12:24,children:e.jsx(C,{block:!0,icon:l.length-1===t?e.jsx(y.SaveOutlined,{}):e.jsx(y.RightOutlined,{}),htmlType:"submit",type:"primary",loading:F,size:"large",onClick:()=>{n.validateFields().then(o=>{g(o,l.length-1===t,l.length-1===t)})},children:l.length-1===t?r("str."+(i==="update"?"update":"save")):r("str.next")})})]})]})}module.exports=w;
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { FormProps } from 'antd';
|
|
2
|
-
import {
|
|
2
|
+
import { CrudPurpose, CrudWizardProp, ReadonlyCrudFields } from './CrudComponent';
|
|
3
3
|
export interface CrudFormWizardProps<T> {
|
|
4
4
|
onDeleteFile?: (e: any) => void;
|
|
5
5
|
onUploadFile?: (e: any) => void;
|
|
6
|
-
fields:
|
|
6
|
+
fields: ReadonlyCrudFields<T>;
|
|
7
7
|
purpose?: CrudPurpose;
|
|
8
8
|
wizard?: CrudWizardProp<T>[];
|
|
9
9
|
className?: string;
|
|
@@ -1,145 +1,149 @@
|
|
|
1
|
-
import { jsx as o, jsxs as
|
|
2
|
-
import { LeftOutlined as
|
|
3
|
-
import { Form as
|
|
1
|
+
import { jsx as o, jsxs as F } from "react/jsx-runtime";
|
|
2
|
+
import { LeftOutlined as w, SaveOutlined as x, RightOutlined as R } from "@ant-design/icons";
|
|
3
|
+
import { Form as k, Divider as T, Row as W, Col as C } from "antd";
|
|
4
4
|
import { useMemo as v, useEffect as j } from "react";
|
|
5
5
|
import { useTranslationLib as z } from "../locale/index.es.js";
|
|
6
|
-
import { CrudFormFields as
|
|
6
|
+
import { CrudFormFields as N } from "./CrudForm.es.js";
|
|
7
7
|
import O from "../common/wizard/WizardViewForm.es.js";
|
|
8
|
-
import
|
|
9
|
-
import
|
|
10
|
-
|
|
8
|
+
import B from "../util/CrudUtil.es.js";
|
|
9
|
+
import { getValueByPath as A, setValueByPath as E } from "../util/ObjectUtil.es.js";
|
|
10
|
+
import S from "../common/button/Button.es.js";
|
|
11
|
+
function J({
|
|
11
12
|
fields: d,
|
|
12
|
-
className:
|
|
13
|
-
onDeleteFile:
|
|
14
|
-
onUploadFile:
|
|
15
|
-
purpose:
|
|
13
|
+
className: h,
|
|
14
|
+
onDeleteFile: g,
|
|
15
|
+
onUploadFile: l,
|
|
16
|
+
purpose: m,
|
|
16
17
|
wizard: e = [],
|
|
17
|
-
updatingValue:
|
|
18
|
-
onSave:
|
|
19
|
-
submitting:
|
|
20
|
-
onValuesChange:
|
|
18
|
+
updatingValue: p,
|
|
19
|
+
onSave: b,
|
|
20
|
+
submitting: y,
|
|
21
|
+
onValuesChange: c
|
|
21
22
|
}) {
|
|
22
|
-
const
|
|
23
|
+
const s = v(() => e.map((t) => {
|
|
23
24
|
let r = !0;
|
|
24
|
-
const n = d.filter(
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
25
|
+
const n = d.filter((a) => {
|
|
26
|
+
const i = B.getRealName(a.name);
|
|
27
|
+
return !Array.isArray(i) && t.fields.includes(i);
|
|
28
|
+
});
|
|
29
|
+
return n.forEach((a) => r && (r = a.hidden ?? !1)), {
|
|
28
30
|
...t,
|
|
29
31
|
hidden: r,
|
|
30
32
|
fieldThatShouldShowing: n
|
|
31
33
|
};
|
|
32
|
-
}), [d, e]),
|
|
33
|
-
() =>
|
|
34
|
-
[
|
|
34
|
+
}), [d, e]), u = v(
|
|
35
|
+
() => s.filter((t) => !t.hidden),
|
|
36
|
+
[s]
|
|
35
37
|
);
|
|
36
38
|
return /* @__PURE__ */ o(
|
|
37
39
|
O,
|
|
38
40
|
{
|
|
39
41
|
onSubmit: (t, r) => {
|
|
40
|
-
|
|
42
|
+
b(r);
|
|
41
43
|
},
|
|
42
|
-
className:
|
|
43
|
-
pages:
|
|
44
|
-
({ title: t, icon: r, fieldThatShouldShowing: n, hidden:
|
|
44
|
+
className: h,
|
|
45
|
+
pages: u.map(
|
|
46
|
+
({ title: t, icon: r, fieldThatShouldShowing: n, hidden: a }, i) => ({
|
|
45
47
|
title: t,
|
|
46
48
|
icon: r,
|
|
47
|
-
hidden:
|
|
48
|
-
component: (
|
|
49
|
-
|
|
49
|
+
hidden: a,
|
|
50
|
+
component: (f) => /* @__PURE__ */ o(
|
|
51
|
+
L,
|
|
50
52
|
{
|
|
51
53
|
fields: n,
|
|
52
|
-
onDeleteFile:
|
|
53
|
-
onUploadFile:
|
|
54
|
-
purpose:
|
|
55
|
-
i
|
|
56
|
-
updatingValue:
|
|
57
|
-
backward:
|
|
58
|
-
forward:
|
|
59
|
-
wizard:
|
|
60
|
-
submitting:
|
|
61
|
-
onValuesChange:
|
|
54
|
+
onDeleteFile: g,
|
|
55
|
+
onUploadFile: l,
|
|
56
|
+
purpose: m,
|
|
57
|
+
i,
|
|
58
|
+
updatingValue: p,
|
|
59
|
+
backward: f.backward,
|
|
60
|
+
forward: f.forward,
|
|
61
|
+
wizard: u,
|
|
62
|
+
submitting: y,
|
|
63
|
+
onValuesChange: c
|
|
62
64
|
},
|
|
63
|
-
|
|
65
|
+
i
|
|
64
66
|
)
|
|
65
67
|
})
|
|
66
68
|
)
|
|
67
69
|
}
|
|
68
70
|
);
|
|
69
71
|
}
|
|
70
|
-
function
|
|
72
|
+
function L({
|
|
71
73
|
fields: d,
|
|
72
|
-
onDeleteFile:
|
|
73
|
-
onUploadFile:
|
|
74
|
-
purpose:
|
|
75
|
-
wizard:
|
|
74
|
+
onDeleteFile: h,
|
|
75
|
+
onUploadFile: g,
|
|
76
|
+
purpose: l,
|
|
77
|
+
wizard: m = [],
|
|
76
78
|
i: e,
|
|
77
|
-
forward:
|
|
78
|
-
backward:
|
|
79
|
-
submitting:
|
|
80
|
-
updatingValue:
|
|
81
|
-
onValuesChange:
|
|
79
|
+
forward: p,
|
|
80
|
+
backward: b,
|
|
81
|
+
submitting: y,
|
|
82
|
+
updatingValue: c,
|
|
83
|
+
onValuesChange: s
|
|
82
84
|
}) {
|
|
83
|
-
const
|
|
85
|
+
const u = m[e], { t } = z(), [r] = k.useForm();
|
|
84
86
|
return j(() => {
|
|
85
|
-
if (
|
|
87
|
+
if (c && (l === "update" || l === "clone")) {
|
|
86
88
|
const n = {};
|
|
87
|
-
for (const
|
|
88
|
-
|
|
89
|
+
for (const a of d) {
|
|
90
|
+
const i = B.getRealName(a.name, "upsertFieldName"), f = A(c, i);
|
|
91
|
+
E(n, i, f);
|
|
92
|
+
}
|
|
89
93
|
r.setFieldsValue(n);
|
|
90
94
|
}
|
|
91
|
-
}, [d, r,
|
|
92
|
-
|
|
95
|
+
}, [d, r, l, c]), /* @__PURE__ */ F(
|
|
96
|
+
k,
|
|
93
97
|
{
|
|
94
98
|
name: String(e),
|
|
95
99
|
form: r,
|
|
96
100
|
layout: "vertical",
|
|
97
|
-
onValuesChange:
|
|
101
|
+
onValuesChange: s,
|
|
98
102
|
children: [
|
|
99
103
|
/* @__PURE__ */ o(
|
|
100
|
-
|
|
104
|
+
N,
|
|
101
105
|
{
|
|
102
106
|
fields: d,
|
|
103
|
-
formBuilder:
|
|
104
|
-
grid:
|
|
105
|
-
onDeleteFile:
|
|
106
|
-
onUploadFile:
|
|
107
|
-
purpose:
|
|
107
|
+
formBuilder: u.formBuilder,
|
|
108
|
+
grid: u.grid,
|
|
109
|
+
onDeleteFile: h,
|
|
110
|
+
onUploadFile: g,
|
|
111
|
+
purpose: l
|
|
108
112
|
}
|
|
109
113
|
),
|
|
110
114
|
/* @__PURE__ */ o(T, {}),
|
|
111
|
-
/* @__PURE__ */
|
|
112
|
-
e > 0 && /* @__PURE__ */ o(
|
|
113
|
-
|
|
115
|
+
/* @__PURE__ */ F(W, { gutter: [8, 8], children: [
|
|
116
|
+
e > 0 && /* @__PURE__ */ o(C, { md: 12, children: /* @__PURE__ */ o(
|
|
117
|
+
S,
|
|
114
118
|
{
|
|
115
119
|
block: !0,
|
|
116
|
-
icon: /* @__PURE__ */ o(
|
|
120
|
+
icon: /* @__PURE__ */ o(w, {}),
|
|
117
121
|
htmlType: "button",
|
|
118
122
|
type: "default",
|
|
119
123
|
size: "large",
|
|
120
|
-
onClick: () =>
|
|
124
|
+
onClick: () => b(),
|
|
121
125
|
children: t("str.back")
|
|
122
126
|
}
|
|
123
127
|
) }),
|
|
124
|
-
/* @__PURE__ */ o(
|
|
125
|
-
|
|
128
|
+
/* @__PURE__ */ o(C, { md: e > 0 ? 12 : 24, children: /* @__PURE__ */ o(
|
|
129
|
+
S,
|
|
126
130
|
{
|
|
127
131
|
block: !0,
|
|
128
|
-
icon:
|
|
132
|
+
icon: m.length - 1 === e ? /* @__PURE__ */ o(x, {}) : /* @__PURE__ */ o(R, {}),
|
|
129
133
|
htmlType: "submit",
|
|
130
134
|
type: "primary",
|
|
131
|
-
loading:
|
|
135
|
+
loading: y,
|
|
132
136
|
size: "large",
|
|
133
137
|
onClick: () => {
|
|
134
138
|
r.validateFields().then((n) => {
|
|
135
|
-
|
|
139
|
+
p(
|
|
136
140
|
n,
|
|
137
|
-
|
|
138
|
-
|
|
141
|
+
m.length - 1 === e,
|
|
142
|
+
m.length - 1 === e
|
|
139
143
|
);
|
|
140
144
|
});
|
|
141
145
|
},
|
|
142
|
-
children:
|
|
146
|
+
children: m.length - 1 === e ? t("str." + (l === "update" ? "update" : "save")) : t("str.next")
|
|
143
147
|
}
|
|
144
148
|
) })
|
|
145
149
|
] })
|
|
@@ -148,5 +152,5 @@ function E({
|
|
|
148
152
|
);
|
|
149
153
|
}
|
|
150
154
|
export {
|
|
151
|
-
|
|
155
|
+
J as default
|
|
152
156
|
};
|
|
@@ -15,7 +15,7 @@ export type SearchOnlyFields<F> = CrudFieldProps<F> & {
|
|
|
15
15
|
export type ReportCrudFields<T, F> = CrudFieldProps<T> | SearchOnlyFields<F>;
|
|
16
16
|
export interface CrudReportComponentProps<T_Data, F_Search> {
|
|
17
17
|
summary?: React.ReactNode;
|
|
18
|
-
fields: ReportCrudFields<T_Data, F_Search>[];
|
|
18
|
+
fields: readonly ReportCrudFields<T_Data, F_Search>[];
|
|
19
19
|
onSubmit: (value: CrudReportSubmitForm<F_Search>) => void;
|
|
20
20
|
data: T_Data[];
|
|
21
21
|
idField?: string;
|
|
@@ -23,16 +23,16 @@ export interface CrudReportComponentProps<T_Data, F_Search> {
|
|
|
23
23
|
size?: SizeType;
|
|
24
24
|
paginateProps?: CrudPaginateProps;
|
|
25
25
|
onClickPrint?: (props: {
|
|
26
|
-
fields: CrudFieldProps<T_Data>
|
|
26
|
+
fields: readonly (CrudFieldProps<T_Data> & {
|
|
27
27
|
render: (value: any, obj: T_Data, index: number) => any;
|
|
28
|
-
}[];
|
|
28
|
+
})[];
|
|
29
29
|
data: T_Data[];
|
|
30
30
|
tableId: string;
|
|
31
31
|
}) => void;
|
|
32
32
|
onClickExcelExport?: (props: {
|
|
33
|
-
fields: CrudFieldProps<T_Data>
|
|
33
|
+
fields: readonly (CrudFieldProps<T_Data> & {
|
|
34
34
|
render: (value: any, obj: T_Data, index: number) => any;
|
|
35
|
-
}[];
|
|
35
|
+
})[];
|
|
36
36
|
data: T_Data[];
|
|
37
37
|
tableId: string;
|
|
38
38
|
}) => void;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ColProps } from 'antd/lib';
|
|
2
|
-
import {
|
|
2
|
+
import { ReadonlyCrudFields } from './CrudComponent';
|
|
3
3
|
export type CrudSearchOption<T> = {
|
|
4
4
|
required?: boolean;
|
|
5
5
|
} & ({
|
|
@@ -12,7 +12,7 @@ export type CrudSearchOption<T> = {
|
|
|
12
12
|
});
|
|
13
13
|
export interface CrudSearchComponentProps<T, FormType> {
|
|
14
14
|
searchFields?: Array<keyof T | CrudSearchOption<T>>;
|
|
15
|
-
fields:
|
|
15
|
+
fields: ReadonlyCrudFields<T>;
|
|
16
16
|
searchOnChange?: boolean;
|
|
17
17
|
searchDefaultValues?: FormType;
|
|
18
18
|
onSearch?: (values: Partial<FormType>) => void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";const v=require("react/jsx-runtime"),
|
|
1
|
+
"use strict";const v=require("react/jsx-runtime"),z=require("react"),b=require("../../common/button/CloneButtonTable.cjs.js"),r=require("../../common/button/DeleteButtonTable.cjs.js"),k=require("../../common/button/ExportButton.cjs.js"),C=require("../../common/button/HideButtonTable.cjs.js"),F=require("../../common/button/UpdateButtonTable.cjs.js"),R=require("../modal/index.cjs.js");function B({data:q,idField:u="id",extraAction:E,onUpdate:N,onClickUpdate:x,onClickClone:h,onDelete:G,onHide:J,onExport:K,isHiding:Q,isDeleting:S,confirmHiding:A,confirmDeleting:s,closeViewOnClickUpdate:H,recentUpdateOrDeleteId:W,setRecentUpdateOrDeleteId:m,setOpenView:L,inBuiltModalProps:f,updatable:T,deletable:g}){var $;const y=E==null?void 0:E(q),X=z.useRef(null),Y=z.useCallback((j,V=!0,c=!1)=>{var w;m==null||m(j[u]),f?(w=X.current)==null||w.update(j,V,c):c?h==null||h(j):x==null||x(j),H&&(L==null||L(void 0))},[f,x]),Z=z.useMemo(()=>!!(!T||T!=null&&T(q)),[T,q]),_=z.useMemo(()=>!!(!g||g!=null&&g(q)),[g,q]);return(Array.isArray(y)?($=y==null?void 0:y.filter(Boolean))!=null&&$.length:y)||N||Z&&x||f!=null&&f.onUpdate||h||f!=null&&f.onCreate||_&&G||K||J?v.jsxs(v.Fragment,{children:[f&&v.jsx(R,{ref:X,...f}),y,(N||x||(f==null?void 0:f.onUpdate))&&Z&&v.jsx(F,{value:q,onClick:j=>Y(j)}),(h||(f==null?void 0:f.onCreate))&&v.jsx(b,{value:q,onClick:j=>Y(j,!1,!0)}),K&&v.jsx(k.ExportButton,{value:q,onClick:async j=>await K(j)}),J&&v.jsx(C,{value:q,disabled:Q,shouldConfirm:A,loading:Q&&q[u]===W,onClick:async j=>{m==null||m(j[u]),await J({[u]:j[u]})}}),G&&_&&v.jsx(r,{value:q,disabled:S,shouldConfirm:s,loading:S&&q[u]===W,onClick:async j=>{m==null||m(j[u]),await G({[u]:j[u]})}})]}):void 0}module.exports=B;
|
|
@@ -8,6 +8,8 @@ export interface CrudActionsProps<T, FormType> {
|
|
|
8
8
|
onClickUpdate?: (t: T) => void;
|
|
9
9
|
onClickClone?: (t: T) => Promise<any>;
|
|
10
10
|
onDelete?: (id: any) => Promise<any>;
|
|
11
|
+
updatable?: (t: T) => boolean;
|
|
12
|
+
deletable?: (t: T) => boolean;
|
|
11
13
|
onHide?: (id: any) => Promise<any>;
|
|
12
14
|
onExport?: (t: T) => Promise<any>;
|
|
13
15
|
isHiding?: boolean;
|
|
@@ -20,7 +22,7 @@ export interface CrudActionsProps<T, FormType> {
|
|
|
20
22
|
setOpenView?: (data: T | undefined) => void;
|
|
21
23
|
inBuiltModalProps?: CrudModalProps<T, FormType>;
|
|
22
24
|
}
|
|
23
|
-
declare function CrudActions<T, FormType>({ data, idField, extraAction, onUpdate, onClickUpdate, onClickClone, onDelete, onHide, onExport, isHiding, isDeleting, confirmHiding, confirmDeleting, closeViewOnClickUpdate, recentUpdateOrDeleteId, setRecentUpdateOrDeleteId, setOpenView, inBuiltModalProps, }: CrudActionsProps<T, FormType> & {
|
|
25
|
+
declare function CrudActions<T, FormType>({ data, idField, extraAction, onUpdate, onClickUpdate, onClickClone, onDelete, onHide, onExport, isHiding, isDeleting, confirmHiding, confirmDeleting, closeViewOnClickUpdate, recentUpdateOrDeleteId, setRecentUpdateOrDeleteId, setOpenView, inBuiltModalProps, updatable, deletable, }: CrudActionsProps<T, FormType> & {
|
|
24
26
|
data: T;
|
|
25
27
|
}): import("react/jsx-runtime").JSX.Element | undefined;
|
|
26
28
|
export default CrudActions;
|
|
@@ -1,83 +1,85 @@
|
|
|
1
|
-
import { jsxs as
|
|
2
|
-
import { useRef as
|
|
3
|
-
import
|
|
4
|
-
import
|
|
5
|
-
import { ExportButton as
|
|
6
|
-
import
|
|
7
|
-
import
|
|
8
|
-
import
|
|
9
|
-
function
|
|
10
|
-
data:
|
|
11
|
-
idField:
|
|
12
|
-
extraAction:
|
|
13
|
-
onUpdate:
|
|
14
|
-
onClickUpdate:
|
|
15
|
-
onClickClone:
|
|
16
|
-
onDelete:
|
|
17
|
-
onHide:
|
|
18
|
-
onExport:
|
|
19
|
-
isHiding:
|
|
20
|
-
isDeleting:
|
|
21
|
-
confirmHiding:
|
|
22
|
-
confirmDeleting:
|
|
23
|
-
closeViewOnClickUpdate:
|
|
24
|
-
recentUpdateOrDeleteId:
|
|
25
|
-
setRecentUpdateOrDeleteId:
|
|
26
|
-
setOpenView:
|
|
27
|
-
inBuiltModalProps: f
|
|
1
|
+
import { jsxs as r, Fragment as C, jsx as j } from "react/jsx-runtime";
|
|
2
|
+
import { useRef as F, useCallback as c, useMemo as H } from "react";
|
|
3
|
+
import R from "../../common/button/CloneButtonTable.es.js";
|
|
4
|
+
import B from "../../common/button/DeleteButtonTable.es.js";
|
|
5
|
+
import { ExportButton as I } from "../../common/button/ExportButton.es.js";
|
|
6
|
+
import D from "../../common/button/HideButtonTable.es.js";
|
|
7
|
+
import U from "../../common/button/UpdateButtonTable.es.js";
|
|
8
|
+
import s from "../modal/index.es.js";
|
|
9
|
+
function l({
|
|
10
|
+
data: v,
|
|
11
|
+
idField: y = "id",
|
|
12
|
+
extraAction: J,
|
|
13
|
+
onUpdate: S,
|
|
14
|
+
onClickUpdate: T,
|
|
15
|
+
onClickClone: q,
|
|
16
|
+
onDelete: K,
|
|
17
|
+
onHide: L,
|
|
18
|
+
onExport: N,
|
|
19
|
+
isHiding: W,
|
|
20
|
+
isDeleting: X,
|
|
21
|
+
confirmHiding: x,
|
|
22
|
+
confirmDeleting: V,
|
|
23
|
+
closeViewOnClickUpdate: b,
|
|
24
|
+
recentUpdateOrDeleteId: Y,
|
|
25
|
+
setRecentUpdateOrDeleteId: h,
|
|
26
|
+
setOpenView: Q,
|
|
27
|
+
inBuiltModalProps: f,
|
|
28
|
+
updatable: z,
|
|
29
|
+
deletable: G
|
|
28
30
|
}) {
|
|
29
|
-
var
|
|
30
|
-
const
|
|
31
|
-
(m,
|
|
32
|
-
var
|
|
33
|
-
|
|
31
|
+
var A;
|
|
32
|
+
const g = J == null ? void 0 : J(v), Z = F(null), _ = c(
|
|
33
|
+
(m, k = !0, E = !1) => {
|
|
34
|
+
var u;
|
|
35
|
+
h == null || h(m[y]), f ? (u = Z.current) == null || u.update(m, k, E) : E ? q == null || q(m) : T == null || T(m), b && (Q == null || Q(void 0));
|
|
34
36
|
},
|
|
35
|
-
[f,
|
|
36
|
-
);
|
|
37
|
-
return (Array.isArray(
|
|
38
|
-
f && /* @__PURE__ */
|
|
39
|
-
|
|
40
|
-
(
|
|
41
|
-
(
|
|
42
|
-
|
|
37
|
+
[f, T]
|
|
38
|
+
), $ = H(() => !!(!z || z != null && z(v)), [z, v]), w = H(() => !!(!G || G != null && G(v)), [G, v]);
|
|
39
|
+
return (Array.isArray(g) ? (A = g == null ? void 0 : g.filter(Boolean)) != null && A.length : g) || S || $ && T || f != null && f.onUpdate || q || f != null && f.onCreate || w && K || N || L ? /* @__PURE__ */ r(C, { children: [
|
|
40
|
+
f && /* @__PURE__ */ j(s, { ref: Z, ...f }),
|
|
41
|
+
g,
|
|
42
|
+
(S || T || (f == null ? void 0 : f.onUpdate)) && $ && /* @__PURE__ */ j(U, { value: v, onClick: (m) => _(m) }),
|
|
43
|
+
(q || (f == null ? void 0 : f.onCreate)) && /* @__PURE__ */ j(
|
|
44
|
+
R,
|
|
43
45
|
{
|
|
44
|
-
value:
|
|
45
|
-
onClick: (m) =>
|
|
46
|
+
value: v,
|
|
47
|
+
onClick: (m) => _(m, !1, !0)
|
|
46
48
|
}
|
|
47
49
|
),
|
|
48
|
-
|
|
49
|
-
|
|
50
|
+
N && /* @__PURE__ */ j(
|
|
51
|
+
I,
|
|
50
52
|
{
|
|
51
|
-
value:
|
|
52
|
-
onClick: async (m) => await
|
|
53
|
+
value: v,
|
|
54
|
+
onClick: async (m) => await N(m)
|
|
53
55
|
}
|
|
54
56
|
),
|
|
55
|
-
|
|
56
|
-
|
|
57
|
+
L && /* @__PURE__ */ j(
|
|
58
|
+
D,
|
|
57
59
|
{
|
|
58
|
-
value:
|
|
59
|
-
disabled:
|
|
60
|
-
shouldConfirm:
|
|
61
|
-
loading:
|
|
60
|
+
value: v,
|
|
61
|
+
disabled: W,
|
|
62
|
+
shouldConfirm: x,
|
|
63
|
+
loading: W && v[y] === Y,
|
|
62
64
|
onClick: async (m) => {
|
|
63
|
-
|
|
65
|
+
h == null || h(m[y]), await L({ [y]: m[y] });
|
|
64
66
|
}
|
|
65
67
|
}
|
|
66
68
|
),
|
|
67
|
-
|
|
68
|
-
|
|
69
|
+
K && w && /* @__PURE__ */ j(
|
|
70
|
+
B,
|
|
69
71
|
{
|
|
70
|
-
value:
|
|
71
|
-
disabled:
|
|
72
|
-
shouldConfirm:
|
|
73
|
-
loading:
|
|
72
|
+
value: v,
|
|
73
|
+
disabled: X,
|
|
74
|
+
shouldConfirm: V,
|
|
75
|
+
loading: X && v[y] === Y,
|
|
74
76
|
onClick: async (m) => {
|
|
75
|
-
|
|
77
|
+
h == null || h(m[y]), await K({ [y]: m[y] });
|
|
76
78
|
}
|
|
77
79
|
}
|
|
78
80
|
)
|
|
79
81
|
] }) : void 0;
|
|
80
82
|
}
|
|
81
83
|
export {
|
|
82
|
-
|
|
84
|
+
l as default
|
|
83
85
|
};
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ReadonlyCrudFields } from '../CrudComponent';
|
|
2
2
|
import { DialogProps } from '../../types/DialogComponentProp';
|
|
3
3
|
export interface CrudImportComponentProps<T> {
|
|
4
|
-
fields:
|
|
4
|
+
fields: ReadonlyCrudFields<T>;
|
|
5
5
|
importProps: CrudImportProps<T>;
|
|
6
6
|
}
|
|
7
7
|
export interface CrudImportProps<T> {
|
package/dist/crud/index.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export type { CheckboxBasedFieldProps, ColorPickerFieldProps, CrudComponentProps, CrudFieldGrid, CrudFieldProps, CrudPaginateProps, CrudPurpose, CrudWizardProp, DateBasedFieldProps, EnumCrudField, FormBuilderFunc, FormBuilderFunc0, GetFormFieldOptions, InitialCrudField, NumberBasedFieldProps, ObjectCrudField, SelectCrudField, SelectFieldItem, TextBasedFieldProps, TimeBasedFieldProps, } from './CrudComponent';
|
|
1
|
+
export type { CheckboxBasedFieldProps, ColorPickerFieldProps, CrudComponentProps, CrudFieldGrid, CrudFieldProps, CrudPaginateProps, ReadonlyCrudFields, CrudPurpose, CrudWizardProp, DateBasedFieldProps, EnumCrudField, FormBuilderFunc, FormBuilderFunc0, GetFormFieldOptions, InitialCrudField, NumberBasedFieldProps, ObjectCrudField, SelectCrudField, SelectFieldItem, TextBasedFieldProps, TimeBasedFieldProps, } from './CrudComponent';
|
|
2
2
|
export { default as CrudComponent } from './CrudComponent';
|
|
3
3
|
export { default as CrudField, ColorCrudFieldComponent, SelectCrudFieldComponent, } from './CrudField';
|
|
4
4
|
export { CrudForm, CrudFormFields } from './CrudForm';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";const
|
|
1
|
+
"use strict";const b=require("react/jsx-runtime"),S=require("antd"),t=require("react"),K=require("../CrudForm.cjs.js"),Q=require("../CrudFormWizard.cjs.js"),X=require("../../locale/index.cjs.js"),M=require("../../util/CrudUtil.cjs.js"),Y=require("dayjs"),d=require("../../util/ObjectUtil.cjs.js"),Z=({fields:r,wizard:l,grid:T,fullWidthModal:W,isCreating:C,isUpdating:x,onCreate:B,onUpdate:h,idField:v="id",formBuilder:_,onValuesChange:j},A)=>{const[s]=S.Form.useForm(),{t:V}=X.useTranslationLib(),[k,m]=t.useState(!1),[f,q]=t.useState("new"),[y,F]=t.useState(),[L,g]=t.useState(),[E,N]=t.useState(!1),[$,P]=t.useState(!1),[w,U]=t.useState(!1),O=t.useCallback(async c=>{var a;const p=l?c:await s.validateFields(),i=r.filter(o=>o.type==="color"),n={};for(const o of i){const e=M.getRealName(o.name,"upsertFieldName"),u=s.getFieldValue(e);d.setValueByPath(n,e,typeof u=="string"?u:(a=u==null?void 0:u.toHexString())==null?void 0:a.toUpperCase())}Object.assign(p,n),y&&h?(await h({...p,[v]:y[v]}),F(void 0)):!y&&B&&await B(p),g(void 0),s.resetFields(),m(!1)},[r,s,v,B,h,y,l]),R=t.useCallback(async c=>{N(c),P(!0)},[]),D=t.useCallback(async()=>{P(!0)},[]),H=t.useCallback(()=>{m(!0),q("new"),s.resetFields(),F(void 0),g(void 0)},[s]),I=t.useCallback(async(c,p=!0,i=!1)=>{try{U(!0),m(!0),q(i?"clone":"update");const n={};for(const a of r){const o=M.getRealName(a.name,"upsertFieldName"),e=d.getValueByPath(c,o);if(i&&a.type==="image"){const u=e;try{const J=await a.provider.clone(u);d.setValueByPath(n,o,J);continue}catch{continue}}a.type==="date"||a.type==="time"?e&&d.setValueByPath(n,o,Y(e)):a.type==="select"?a.multiple&&Array.isArray(e)?d.setValueByPath(n,o,e.map(u=>u[a.innerFieldId??"id"])):e&&typeof e=="object"?d.setValueByPath(n,o,e[a.innerFieldId??"id"]):(e&&typeof e=="string"||typeof e=="number")&&d.setValueByPath(n,o,e):d.setValueByPath(n,o,e)}s.setFieldsValue(n),g(n),p&&F(c)}finally{U(!1)}},[r,s]);t.useImperativeHandle(A,()=>({create:H,update:I}),[H,I]),t.useEffect(()=>{k&&(N(!1),P(!1))},[k]);const G=t.useCallback(async()=>{try{if(f==="clone"){const c=l?y:s.getFieldsValue(),p=r.filter(i=>i.type==="image");for(const i of p)c[i.name]&&i.provider.delete(c[i.name])}}finally{}l||s.resetFields(),g(void 0),F(void 0),m(!1)},[f,l,s,y,r]);return b.jsx(S.Modal,{width:W?"100%":void 0,title:V("str."+(f??"new")),open:k,confirmLoading:C||x,okText:V("str."+(f==="update"?"update":"save")),cancelText:V("str.cancel"),cancelButtonProps:{disabled:$,hidden:!!l},okButtonProps:{disabled:E,hidden:!!l},onCancel:G,onOk:()=>O(),destroyOnHidden:!0,children:b.jsxs(S.Spin,{spinning:w,children:[l?null:b.jsx(K.CrudForm,{purpose:f,fields:r,form:s,formBuilder:_,grid:T,onDeleteFile:D,onUploadFile:R,onValuesChange:j}),l&&b.jsx(Q,{submitting:C||x,className:"mt-2",onSave:O,updatingValue:L,fields:r,onDeleteFile:D,onUploadFile:R,purpose:f,wizard:l,onValuesChange:j})]})})},z=t.forwardRef(Z);module.exports=z;
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { FormProps } from 'antd';
|
|
2
2
|
import { Ref } from 'react';
|
|
3
|
-
import {
|
|
3
|
+
import { CrudWizardProp, FormBuilderFunc, ReadonlyCrudFields } from '../CrudComponent';
|
|
4
4
|
import { default as IdProps } from '../../types/Id';
|
|
5
5
|
export interface CrudModalProps<T, FormType> {
|
|
6
|
-
fields:
|
|
6
|
+
fields: ReadonlyCrudFields<T>;
|
|
7
7
|
wizard?: CrudWizardProp<T>[];
|
|
8
8
|
grid?: boolean;
|
|
9
9
|
fullWidthModal?: boolean;
|