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