@kingteza/crud-component 1.34.1 → 1.35.0

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.
@@ -1 +1 @@
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;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const s=require("react/jsx-runtime"),b=require("react"),$=require("../../common/button/CloneButtonTable.cjs.js"),H=require("../../common/button/DeleteButtonTable.cjs.js"),w=require("../../common/button/ExportButton.cjs.js"),B=require("../../common/button/HideButtonTable.cjs.js"),C=require("../../common/button/UpdateButtonTable.cjs.js"),k=require("../../util/crud/crud-action.util.cjs.js"),V=require("../modal/index.cjs.js");function K({data:u,idField:r="id",extraAction:c,onUpdate:L,onClickUpdate:v,onClickClone:m,onDelete:y,onHide:g,onExport:_,isHiding:o,isDeleting:S,confirmHiding:N,confirmDeleting:Q,closeViewOnClickUpdate:n,recentUpdateOrDeleteId:A,setRecentUpdateOrDeleteId:j,setOpenView:x,inBuiltModalProps:q,updatable:T,deletable:h}){const W=c==null?void 0:c(u),E=b.useRef(null),z=b.useCallback((f,Z=!0,G=!1)=>{var J;j==null||j(f[r]),q?(J=E.current)==null||J.update(f,Z,G):G?m==null||m(f):v==null||v(f),n&&(x==null||x(void 0))},[r,q,m,v,n,x,j]),X=b.useMemo(()=>!!(!T||T(u)),[T,u]),Y=b.useMemo(()=>!!(!h||h(u)),[h,u]);return s.jsxs(s.Fragment,{children:[q&&s.jsx(V,{ref:E,...q}),W,(L||v||(q==null?void 0:q.onUpdate))&&X&&s.jsx(C,{value:u,onClick:f=>z(f)}),(m||(q==null?void 0:q.onCreate))&&s.jsx($,{value:u,onClick:f=>z(f,!1,!0)}),_&&s.jsx(w.ExportButton,{value:u,onClick:async f=>await _(f)}),g&&s.jsx(B,{value:u,disabled:o,shouldConfirm:N,loading:o&&u[r]===A,onClick:async f=>{j==null||j(f[r]),await g({[r]:f[r]})}}),y&&Y&&s.jsx(H,{value:u,disabled:S,shouldConfirm:Q,loading:S&&u[r]===A,onClick:async f=>{j==null||j(f[r]),await y({[r]:f[r]})}})]})}function F(u){if(k.hasCrudActions(u,u.data))return s.jsx(K,{...u})}exports.CrudActionsInternal=K;exports.default=F;
@@ -22,7 +22,10 @@ export interface CrudActionsProps<T, FormType> {
22
22
  setOpenView?: (data: T | undefined) => void;
23
23
  inBuiltModalProps?: CrudModalProps<T, FormType>;
24
24
  }
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> & {
25
+ export declare function CrudActionsInternal<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> & {
26
+ data: T;
27
+ }): import("react/jsx-runtime").JSX.Element;
28
+ declare function CrudActions<T, FormType>(props: CrudActionsProps<T, FormType> & {
26
29
  data: T;
27
30
  }): import("react/jsx-runtime").JSX.Element | undefined;
28
31
  export default CrudActions;
@@ -1,85 +1,104 @@
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,
1
+ import { jsx as h, jsxs as w, Fragment as C } from "react/jsx-runtime";
2
+ import { useRef as k, useCallback as B, useMemo as W } from "react";
3
+ import V from "../../common/button/CloneButtonTable.es.js";
4
+ import F from "../../common/button/DeleteButtonTable.es.js";
5
+ import { ExportButton as c } from "../../common/button/ExportButton.es.js";
6
+ import M from "../../common/button/HideButtonTable.es.js";
7
+ import s from "../../common/button/UpdateButtonTable.es.js";
8
+ import { hasCrudActions as P } from "../../util/crud/crud-action.util.es.js";
9
+ import R from "../modal/index.es.js";
10
+ function I({
11
+ data: f,
12
+ idField: u = "id",
13
+ extraAction: y,
14
+ onUpdate: X,
14
15
  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
16
+ onClickClone: b,
17
+ onDelete: q,
18
+ onHide: x,
19
+ onExport: z,
20
+ isHiding: E,
21
+ isDeleting: G,
22
+ confirmHiding: Y,
23
+ confirmDeleting: Z,
24
+ closeViewOnClickUpdate: J,
25
+ recentUpdateOrDeleteId: K,
26
+ setRecentUpdateOrDeleteId: r,
27
+ setOpenView: o,
28
+ inBuiltModalProps: v,
29
+ updatable: j,
30
+ deletable: g
30
31
  }) {
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));
32
+ const _ = y == null ? void 0 : y(f), L = k(null), N = B(
33
+ (m, H = !0, Q = !1) => {
34
+ var S;
35
+ r == null || r(m[u]), v ? (S = L.current) == null || S.update(m, H, Q) : Q ? b == null || b(m) : T == null || T(m), J && (o == null || o(void 0));
36
36
  },
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,
37
+ [
38
+ u,
39
+ v,
40
+ b,
41
+ T,
42
+ J,
43
+ o,
44
+ r
45
+ ]
46
+ ), $ = W(
47
+ () => !!(!j || j(f)),
48
+ [j, f]
49
+ ), A = W(
50
+ () => !!(!g || g(f)),
51
+ [g, f]
52
+ );
53
+ return /* @__PURE__ */ w(C, { children: [
54
+ v && /* @__PURE__ */ h(R, { ref: L, ...v }),
55
+ _,
56
+ (X || T || (v == null ? void 0 : v.onUpdate)) && $ && /* @__PURE__ */ h(s, { value: f, onClick: (m) => N(m) }),
57
+ (b || (v == null ? void 0 : v.onCreate)) && /* @__PURE__ */ h(
58
+ V,
45
59
  {
46
- value: v,
47
- onClick: (m) => _(m, !1, !0)
60
+ value: f,
61
+ onClick: (m) => N(m, !1, !0)
48
62
  }
49
63
  ),
50
- N && /* @__PURE__ */ j(
51
- I,
64
+ z && /* @__PURE__ */ h(
65
+ c,
52
66
  {
53
- value: v,
54
- onClick: async (m) => await N(m)
67
+ value: f,
68
+ onClick: async (m) => await z(m)
55
69
  }
56
70
  ),
57
- L && /* @__PURE__ */ j(
58
- D,
71
+ x && /* @__PURE__ */ h(
72
+ M,
59
73
  {
60
- value: v,
61
- disabled: W,
62
- shouldConfirm: x,
63
- loading: W && v[y] === Y,
74
+ value: f,
75
+ disabled: E,
76
+ shouldConfirm: Y,
77
+ loading: E && f[u] === K,
64
78
  onClick: async (m) => {
65
- h == null || h(m[y]), await L({ [y]: m[y] });
79
+ r == null || r(m[u]), await x({ [u]: m[u] });
66
80
  }
67
81
  }
68
82
  ),
69
- K && w && /* @__PURE__ */ j(
70
- B,
83
+ q && A && /* @__PURE__ */ h(
84
+ F,
71
85
  {
72
- value: v,
73
- disabled: X,
74
- shouldConfirm: V,
75
- loading: X && v[y] === Y,
86
+ value: f,
87
+ disabled: G,
88
+ shouldConfirm: Z,
89
+ loading: G && f[u] === K,
76
90
  onClick: async (m) => {
77
- h == null || h(m[y]), await K({ [y]: m[y] });
91
+ r == null || r(m[u]), await q({ [u]: m[u] });
78
92
  }
79
93
  }
80
94
  )
81
- ] }) : void 0;
95
+ ] });
96
+ }
97
+ function d(f) {
98
+ if (P(f, f.data))
99
+ return /* @__PURE__ */ h(I, { ...f });
82
100
  }
83
101
  export {
84
- l as default
102
+ I as CrudActionsInternal,
103
+ d as default
85
104
  };
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const r=require("react/jsx-runtime"),x=require("../../common/description/DescList.cjs.js"),j=require("react"),C=require("../../locale/index.cjs.js"),V=require("./CrudViewerUtil.cjs.js"),v=require("../../util/CrudUtil.cjs.js"),f=require("../actions/index.cjs.js"),p=require("../../util/ObjectUtil.cjs.js");function w({className:m,fields:i,data:e,descListColumn:a={xs:1,md:3,sm:2,lg:4},layout:d,keepEmptyValues:b,inBuiltModalProps:u,...s}){const{t:o}=C.useTranslationLib(),g=j.useMemo(()=>{const l=i.filter(({hidden:t,hideInDescList:n})=>!t&&!n).map((t,n)=>{const q=v.getRealName(t.name);return{label:t.label,noFormatting:!0,value:V.getRendererValueCrudViewer(t)(p.getValueByPath(e,q),e,n)}}),c=e?r.jsx(f,{data:e,...s,inBuiltModalProps:u?{...u,fields:i}:void 0}):void 0;return c&&l.push({label:o("str.action"),value:c}),l},[e,i,o,s]);return e?r.jsx(x,{keepEmptyValues:b,bordered:!0,column:a,className:m,layout:d,list:g}):r.jsx(r.Fragment,{})}exports.CrudDecListView=w;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const r=require("react/jsx-runtime"),C=require("../../common/description/DescList.cjs.js"),h=require("react"),x=require("../../locale/index.cjs.js"),j=require("./CrudViewerUtil.cjs.js"),w=require("../../util/CrudUtil.cjs.js"),V=require("../actions/index.cjs.js"),v=require("../../util/ObjectUtil.cjs.js"),f=require("../../util/crud/crud-action.util.cjs.js");function L({className:a,fields:n,data:e,descListColumn:d={xs:1,md:3,sm:2,lg:4},layout:m,keepEmptyValues:q,inBuiltModalProps:o,...i}){const{t:s}=x.useTranslationLib(),b=h.useMemo(()=>{const c=n.filter(({hidden:t,hideInDescList:u})=>!t&&!u).map((t,u)=>{const g=w.getRealName(t.name);return{label:t.label,noFormatting:!0,value:j.getRendererValueCrudViewer(t)(v.getValueByPath(e,g),e,u)}}),l=f.hasCrudActions(i,e)?r.jsx(V.CrudActionsInternal,{data:e,...i,inBuiltModalProps:o?{...o,fields:n}:void 0}):void 0;return l&&c.push({label:s("str.action"),value:l}),c},[e,n,s,i]);return e?r.jsx(C,{keepEmptyValues:q,bordered:!0,column:d,className:a,layout:m,list:b}):r.jsx(r.Fragment,{})}exports.CrudDecListView=L;
@@ -1,57 +1,61 @@
1
- import { jsx as m, Fragment as C } from "react/jsx-runtime";
2
- import d from "../../common/description/DescList.es.js";
3
- import { useMemo as v } from "react";
4
- import { useTranslationLib as V } from "../../locale/index.es.js";
5
- import { getRendererValueCrudViewer as x } from "./CrudViewerUtil.es.js";
6
- import F from "../../util/CrudUtil.es.js";
7
- import L from "../actions/index.es.js";
8
- import { getValueByPath as h } from "../../util/ObjectUtil.es.js";
1
+ import { jsx as m, Fragment as g } from "react/jsx-runtime";
2
+ import C from "../../common/description/DescList.es.js";
3
+ import { useMemo as b } from "react";
4
+ import { useTranslationLib as v } from "../../locale/index.es.js";
5
+ import { getRendererValueCrudViewer as w } from "./CrudViewerUtil.es.js";
6
+ import V from "../../util/CrudUtil.es.js";
7
+ import { CrudActionsInternal as x } from "../actions/index.es.js";
8
+ import { getValueByPath as F } from "../../util/ObjectUtil.es.js";
9
+ import { hasCrudActions as L } from "../../util/crud/crud-action.util.es.js";
9
10
  function T({
10
- className: p,
11
+ className: c,
11
12
  fields: t,
12
- data: r,
13
+ data: o,
13
14
  descListColumn: f = { xs: 1, md: 3, sm: 2, lg: 4 },
14
- layout: c,
15
+ layout: p,
15
16
  keepEmptyValues: a,
16
- inBuiltModalProps: i,
17
- ...n
17
+ inBuiltModalProps: n,
18
+ ...e
18
19
  }) {
19
- const { t: u } = V(), g = v(() => {
20
- const l = t.filter(({ hidden: e, hideInDescList: o }) => !e && !o).map((e, o) => {
21
- const b = F.getRealName(e.name);
20
+ const { t: s } = v(), h = b(() => {
21
+ const l = t.filter(({ hidden: r, hideInDescList: i }) => !r && !i).map((r, i) => {
22
+ const d = V.getRealName(r.name);
22
23
  return {
23
- label: e.label,
24
+ label: r.label,
24
25
  noFormatting: !0,
25
- value: x(e)(
26
- h(r, b),
27
- r,
28
- o
26
+ value: w(r)(
27
+ F(o, d),
28
+ o,
29
+ i
29
30
  )
30
31
  };
31
- }), s = r ? /* @__PURE__ */ m(
32
- L,
32
+ }), u = L(
33
+ e,
34
+ o
35
+ ) ? /* @__PURE__ */ m(
36
+ x,
33
37
  {
34
- data: r,
35
- ...n,
36
- inBuiltModalProps: i ? { ...i, fields: t } : void 0
38
+ data: o,
39
+ ...e,
40
+ inBuiltModalProps: n ? { ...n, fields: t } : void 0
37
41
  }
38
42
  ) : void 0;
39
- return s && l.push({
40
- label: u("str.action"),
41
- value: s
43
+ return u && l.push({
44
+ label: s("str.action"),
45
+ value: u
42
46
  }), l;
43
- }, [r, t, u, n]);
44
- return r ? /* @__PURE__ */ m(
45
- d,
47
+ }, [o, t, s, e]);
48
+ return o ? /* @__PURE__ */ m(
49
+ C,
46
50
  {
47
51
  keepEmptyValues: a,
48
52
  bordered: !0,
49
53
  column: f,
50
- className: p,
51
- layout: c,
52
- list: g
54
+ className: c,
55
+ layout: p,
56
+ list: h
53
57
  }
54
- ) : /* @__PURE__ */ m(C, {});
58
+ ) : /* @__PURE__ */ m(g, {});
55
59
  }
56
60
  export {
57
61
  T as CrudDecListView
@@ -1 +1 @@
1
- "use strict";const n=require("react/jsx-runtime"),qt=require("antd"),Ct=require("@dnd-kit/core"),St=require("@dnd-kit/modifiers"),It=require("@dnd-kit/utilities"),T=require("@dnd-kit/sortable"),Rt=require("../../common/button/Button.cjs.js"),lt=require("../../common/button/RefreshButton.cjs.js"),Mt=require("../../common/button/ViewButtonTable.cjs.js"),dt=require("../actions/index.cjs.js"),Tt=require("../../common/table/table.cjs.js"),s=require("react"),Vt=require("../../locale/index.cjs.js"),Bt=require("../CrudSearchComponent.cjs.js"),Dt=require("./CrudDecListView.cjs.js"),st=require("./CrudViewerUtil.cjs.js"),Ot=require("@ant-design/icons"),rt=require("../../util/CrudUtil.cjs.js"),Nt=require("../../common/layout/VerticalSpace.cjs.js"),kt=s.memo(Tt);function Et({summary:j,idField:o="id",loadingData:q,fields:h,isDeleting:l,isHiding:V,viewable:c=!1,paginateProps:f,onDelete:S,deletable:M,updatable:k,onHide:z,onUpdate:B,data:I=[],extraAction:D,onClickUpdate:O,minusHeight:E,scroll:$,onClickClone:A,className:_,expandable:G,size:J,bordered:K,descListColumn:ut,extraView:L,decListLayout:it,scrollToTop:zt,onClickRefresh:Q,closeViewOnClickUpdate:X,onExport:Y,confirmHiding:Z,confirmDeleting:W,rowClassName:P,actionWidth:H=190,draggable:t,rowSelection:U,...ft}){const{t:w}=Vt.useTranslationLib(),p=s.useMemo(()=>h.map(({hideInTable:e,hidden:r,width:u,label:m,halign:R,...C})=>{const N=rt.getRealName(C.name);return{title:m,width:u,key:N,dataIndex:N,hidden:e||r,align:R??(C.type==="number"?"right":void 0),render:st.getRendererValueCrudViewer(C),sorter:C.sorter,defaultSortOrder:C.defaultSortOrder}}),[h]),[i,d]=s.useState(),[F,a]=s.useState(),[y,b]=s.useState([]),mt=s.useCallback(e=>{d(e)},[]);s.useEffect(()=>{I&&b(I)},[I]),s.useEffect(()=>{I&&d(e=>{if(e)return I.find(r=>r[o]===e[o])})},[I,o,i]);const g=s.useCallback(e=>{var m;const{active:r,over:u}=e;if(t!=null&&t.onDragEnd&&(t==null||t.onDragEnd(e)),r.id!==(u==null?void 0:u.id)){const R=y.findIndex(x=>x[o]===r.id),C=y.findIndex(x=>x[o]===(u==null?void 0:u.id)),N=T.arrayMove(y,R,C);b(x=>{const ht=x.findIndex(v=>v[o]===(r==null?void 0:r.id)),yt=x.findIndex(v=>v[o]===(u==null?void 0:u.id));return T.arrayMove(x,ht,yt)}),(m=t==null?void 0:t.onDrag)==null||m.call(t,{newOrder:N.map(x=>x[o])})}},[y,o,t]),xt=s.useMemo(()=>{let e=typeof c=="string"?i==null?void 0:i[c]:void 0;if(typeof e=="object"){const r=h.find(u=>rt.getRealName(u.name)===c);e=st.getRendererValueCrudViewer(r)(e,i,0)}return e},[c,i,h]),tt=s.useMemo(()=>({rowSelection:U,rowClassName:P,className:_,scroll:$??(E?{y:`calc(100vh - ${E})`}:void 0),id:"crud-table",bordered:K,size:J,expandable:G}),[U,P,_,$,E,K,J,G]),et=s.useMemo(()=>f?{...f,total:f.count,onChange:f.setPage,current:f.page,pageSize:f.pageSize}:void 0,[f]),nt=s.useMemo(()=>{const e=B||O||S||D||c,r=[];return t&&r.push({key:"key",align:"center",width:5,title:t==null?void 0:t.columnLabel,render:()=>n.jsx(Lt,{tooltip:t==null?void 0:t.tooltip})}),r.push(...p),e&&e&&r.push({title:w("str.action"),fixed:"right",width:H,render:(u,m)=>n.jsxs(n.Fragment,{children:[c&&n.jsx(Mt,{value:m,onClick:typeof c=="object"?()=>{var R;return(R=c.onClick)==null?void 0:R.call(c,m)}:mt}),n.jsx(dt,{data:m,idField:o,extraAction:D,onUpdate:B,onClickUpdate:O,onClickClone:A,onDelete:S,deletable:M,updatable:k,onHide:z,onExport:Y,isHiding:V,isDeleting:l,confirmHiding:Z,confirmDeleting:W,closeViewOnClickUpdate:X,recentUpdateOrDeleteId:F,setRecentUpdateOrDeleteId:a,setOpenView:d})]})}),r},[p,B,O,S,M,k,D,c,w,H]),ot=s.useMemo(()=>y.map(e=>e[o]),[y,o]),jt=s.useCallback(()=>{const e=n.jsx(kt,{...tt,summary:j,dataSource:y,loading:q,components:t?{body:{row:vt}}:void 0,pagination:et,columns:nt});return t?n.jsx(Ct.DndContext,{modifiers:[St.restrictToVerticalAxis],onDragEnd:g,children:n.jsx(T.SortableContext,{items:ot,strategy:T.verticalListSortingStrategy,children:e})}):e},[tt,y,q,et,nt,j,t,ot,g]);return n.jsxs("div",{children:[(typeof c=="boolean"||typeof c=="string")&&n.jsx(qt.Modal,{width:"100%",open:!!i,title:xt??n.jsx("div",{children:" "}),footer:n.jsx(n.Fragment,{}),closable:!0,onCancel:()=>d(void 0),children:!!i&&n.jsxs("div",{children:[n.jsx(Dt.CrudDecListView,{layout:it,descListColumn:ut,data:i,fields:h,idField:o,extraAction:D,onUpdate:B,onClickUpdate:O,onClickClone:A,onDelete:S,deletable:M,updatable:k,onHide:z,onExport:Y,isHiding:V,isDeleting:l,confirmHiding:Z,confirmDeleting:W,closeViewOnClickUpdate:X,recentUpdateOrDeleteId:F,setRecentUpdateOrDeleteId:a,setOpenView:d}),L==null?void 0:L(i)]},i==null?void 0:i[o])}),n.jsx(Bt,{fields:h,...ft}),n.jsxs(Nt,{children:[!!Q&&n.jsx(lt.RefreshButton,{onClick:Q}),jt()]})]})}const ct=s.createContext({}),Lt=({tooltip:j})=>{const{setActivatorNodeRef:o,listeners:q}=s.useContext(ct);return n.jsx(Rt,{type:"text",size:"small",tooltip:j,icon:n.jsx(Ot.HolderOutlined,{}),style:{cursor:"move",border:"none"},ref:o,...q})},vt=j=>{const{attributes:o,listeners:q,setNodeRef:h,setActivatorNodeRef:l,transform:V,transition:c,isDragging:f}=T.useSortable({id:j["data-row-key"]}),S={...j.style,transform:It.CSS.Translate.toString(V),transition:c,...f?{position:"relative",zIndex:9999}:{}},M=s.useMemo(()=>({setActivatorNodeRef:l,listeners:q}),[l,q]);return n.jsx(ct.Provider,{value:M,children:n.jsx("tr",{...j,ref:h,style:S,...o})})};module.exports=Et;
1
+ "use strict";const n=require("react/jsx-runtime"),qt=require("antd"),Ct=require("@dnd-kit/core"),St=require("@dnd-kit/modifiers"),It=require("@dnd-kit/utilities"),T=require("@dnd-kit/sortable"),Rt=require("../../common/button/Button.cjs.js"),lt=require("../../common/button/RefreshButton.cjs.js"),dt=require("../../common/button/ViewButtonTable.cjs.js"),Mt=require("../actions/index.cjs.js"),Tt=require("../../common/table/table.cjs.js"),s=require("react"),Vt=require("../../locale/index.cjs.js"),Bt=require("../CrudSearchComponent.cjs.js"),Dt=require("./CrudDecListView.cjs.js"),st=require("./CrudViewerUtil.cjs.js"),Ot=require("@ant-design/icons"),rt=require("../../util/CrudUtil.cjs.js"),Nt=require("../../common/layout/VerticalSpace.cjs.js"),kt=s.memo(Tt);function Et({summary:j,idField:o="id",loadingData:q,fields:h,isDeleting:l,isHiding:V,viewable:c=!1,paginateProps:f,onDelete:S,deletable:d,updatable:k,onHide:z,onUpdate:B,data:I=[],extraAction:D,onClickUpdate:O,minusHeight:E,scroll:$,onClickClone:A,className:_,expandable:G,size:J,bordered:K,descListColumn:ut,extraView:L,decListLayout:it,scrollToTop:zt,onClickRefresh:Q,closeViewOnClickUpdate:X,onExport:Y,confirmHiding:Z,confirmDeleting:W,rowClassName:P,actionWidth:H=190,draggable:t,rowSelection:U,...ft}){const{t:w}=Vt.useTranslationLib(),p=s.useMemo(()=>h.map(({hideInTable:e,hidden:r,width:u,label:m,halign:R,...C})=>{const N=rt.getRealName(C.name);return{title:m,width:u,key:N,dataIndex:N,hidden:e||r,align:R??(C.type==="number"?"right":void 0),render:st.getRendererValueCrudViewer(C),sorter:C.sorter,defaultSortOrder:C.defaultSortOrder}}),[h]),[i,M]=s.useState(),[F,a]=s.useState(),[y,b]=s.useState([]),mt=s.useCallback(e=>{M(e)},[]);s.useEffect(()=>{I&&b(I)},[I]),s.useEffect(()=>{I&&M(e=>{if(e)return I.find(r=>r[o]===e[o])})},[I,o,i]);const g=s.useCallback(e=>{var m;const{active:r,over:u}=e;if(t!=null&&t.onDragEnd&&(t==null||t.onDragEnd(e)),r.id!==(u==null?void 0:u.id)){const R=y.findIndex(x=>x[o]===r.id),C=y.findIndex(x=>x[o]===(u==null?void 0:u.id)),N=T.arrayMove(y,R,C);b(x=>{const ht=x.findIndex(v=>v[o]===(r==null?void 0:r.id)),yt=x.findIndex(v=>v[o]===(u==null?void 0:u.id));return T.arrayMove(x,ht,yt)}),(m=t==null?void 0:t.onDrag)==null||m.call(t,{newOrder:N.map(x=>x[o])})}},[y,o,t]),xt=s.useMemo(()=>{let e=typeof c=="string"?i==null?void 0:i[c]:void 0;if(typeof e=="object"){const r=h.find(u=>rt.getRealName(u.name)===c);e=st.getRendererValueCrudViewer(r)(e,i,0)}return e},[c,i,h]),tt=s.useMemo(()=>({rowSelection:U,rowClassName:P,className:_,scroll:$??(E?{y:`calc(100vh - ${E})`}:void 0),id:"crud-table",bordered:K,size:J,expandable:G}),[U,P,_,$,E,K,J,G]),et=s.useMemo(()=>f?{...f,total:f.count,onChange:f.setPage,current:f.page,pageSize:f.pageSize}:void 0,[f]),nt=s.useMemo(()=>{const e=B||O||S||D||c,r=[];return t&&r.push({key:"key",align:"center",width:5,title:t==null?void 0:t.columnLabel,render:()=>n.jsx(Lt,{tooltip:t==null?void 0:t.tooltip})}),r.push(...p),e&&e&&r.push({title:w("str.action"),fixed:"right",width:H,render:(u,m)=>n.jsxs(n.Fragment,{children:[c&&n.jsx(dt,{value:m,onClick:typeof c=="object"?()=>{var R;return(R=c.onClick)==null?void 0:R.call(c,m)}:mt}),n.jsx(Mt.default,{data:m,idField:o,extraAction:D,onUpdate:B,onClickUpdate:O,onClickClone:A,onDelete:S,deletable:d,updatable:k,onHide:z,onExport:Y,isHiding:V,isDeleting:l,confirmHiding:Z,confirmDeleting:W,closeViewOnClickUpdate:X,recentUpdateOrDeleteId:F,setRecentUpdateOrDeleteId:a,setOpenView:M})]})}),r},[p,B,O,S,d,k,D,c,w,H]),ot=s.useMemo(()=>y.map(e=>e[o]),[y,o]),jt=s.useCallback(()=>{const e=n.jsx(kt,{...tt,summary:j,dataSource:y,loading:q,components:t?{body:{row:vt}}:void 0,pagination:et,columns:nt});return t?n.jsx(Ct.DndContext,{modifiers:[St.restrictToVerticalAxis],onDragEnd:g,children:n.jsx(T.SortableContext,{items:ot,strategy:T.verticalListSortingStrategy,children:e})}):e},[tt,y,q,et,nt,j,t,ot,g]);return n.jsxs("div",{children:[(typeof c=="boolean"||typeof c=="string")&&n.jsx(qt.Modal,{width:"100%",open:!!i,title:xt??n.jsx("div",{children:" "}),footer:n.jsx(n.Fragment,{}),closable:!0,onCancel:()=>M(void 0),children:!!i&&n.jsxs("div",{children:[n.jsx(Dt.CrudDecListView,{layout:it,descListColumn:ut,data:i,fields:h,idField:o,extraAction:D,onUpdate:B,onClickUpdate:O,onClickClone:A,onDelete:S,deletable:d,updatable:k,onHide:z,onExport:Y,isHiding:V,isDeleting:l,confirmHiding:Z,confirmDeleting:W,closeViewOnClickUpdate:X,recentUpdateOrDeleteId:F,setRecentUpdateOrDeleteId:a,setOpenView:M}),L==null?void 0:L(i)]},i==null?void 0:i[o])}),n.jsx(Bt,{fields:h,...ft}),n.jsxs(Nt,{children:[!!Q&&n.jsx(lt.RefreshButton,{onClick:Q}),jt()]})]})}const ct=s.createContext({}),Lt=({tooltip:j})=>{const{setActivatorNodeRef:o,listeners:q}=s.useContext(ct);return n.jsx(Rt,{type:"text",size:"small",tooltip:j,icon:n.jsx(Ot.HolderOutlined,{}),style:{cursor:"move",border:"none"},ref:o,...q})},vt=j=>{const{attributes:o,listeners:q,setNodeRef:h,setActivatorNodeRef:l,transform:V,transition:c,isDragging:f}=T.useSortable({id:j["data-row-key"]}),S={...j.style,transform:It.CSS.Translate.toString(V),transition:c,...f?{position:"relative",zIndex:9999}:{}},d=s.useMemo(()=>({setActivatorNodeRef:l,listeners:q}),[l,q]);return n.jsx(ct.Provider,{value:d,children:n.jsx("tr",{...j,ref:h,style:S,...o})})};module.exports=Et;
package/dist/index.cjs.js CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});;/* empty css */const i=require("./locale/hooks/translation-constants.cjs.js"),u=require("./locale/index.cjs.js"),C=require("./crud/CrudComponent.cjs.js"),r=require("./crud/CrudField.cjs.js"),t=require("./crud/CrudFormWizard.cjs.js"),n=require("./crud/CrudReportComponent.cjs.js"),l=require("./crud/CrudSearchComponent.cjs.js"),e=require("./crud/ImageCrudField.cjs.js"),o=require("./crud/FileCrudField.cjs.js"),a=require("./crud/FileCrudDragNDropField.cjs.js"),s=require("./crud/CrudTextAreaComponent.cjs.js"),m=require("./crud/import/CrudImportComponent.cjs.js"),F=require("./crud/import/CrudImportButton.cjs.js"),p=require("./crud/actions/index.cjs.js"),c=require("./crud/view/CrudViewer.cjs.js"),q=require("./context/CrudComponentProvider.cjs.js"),d=require("./crud/CrudForm.cjs.js"),V=require("./crud/modal/index.cjs.js"),I=require("./crud/view/CrudDecListView.cjs.js"),g=require("./crud/view/CrudViewerUtil.cjs.js");exports.TRANSLATION_NAMESPACE=i.TRANSLATION_NAMESPACE;exports.setupI18n=u.setupI18n;exports.updateTranslations=u.updateTranslations;exports.CrudComponent=C;exports.ColorCrudFieldComponent=r.ColorCrudFieldComponent;exports.CrudField=r.default;exports.SelectCrudFieldComponent=r.SelectCrudFieldComponent;exports.CrudFormWizard=t;exports.CrudReportComponent=n;exports.CrudSearchComponent=l;exports.FileDownloadProvider=e.FileDownloadProvider;exports.FileUploadProvider=e.FileUploadProvider;exports.ImageCellValue=e.ImageCellValue;exports.ImageCrudCellValue=e.ImageCrudCellValue;exports.ImageCrudField=e.default;exports.FileCellValue=o.FileCellValue;exports.FileCrudCellValue=o.FileCrudCellValue;exports.FileCrudField=o.default;exports.FileCrudDragNDropField=a;exports.CrudTextAreaComponent=s;exports.CrudImportComponent=m;exports.CrudImportButton=F;exports.CrudActions=p;exports.CrudViewer=c;exports.CrudComponentProvider=q.CrudComponentProvider;exports.CrudForm=d.CrudForm;exports.CrudFormFields=d.CrudFormFields;exports.CrudModal=V;exports.CrudDecListView=I.CrudDecListView;exports.getRendererValueCrudViewer=g.getRendererValueCrudViewer;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});;/* empty css */const i=require("./locale/hooks/translation-constants.cjs.js"),u=require("./locale/index.cjs.js"),t=require("./crud/CrudComponent.cjs.js"),r=require("./crud/CrudField.cjs.js"),C=require("./crud/CrudFormWizard.cjs.js"),n=require("./crud/CrudReportComponent.cjs.js"),l=require("./crud/CrudSearchComponent.cjs.js"),e=require("./crud/ImageCrudField.cjs.js"),o=require("./crud/FileCrudField.cjs.js"),a=require("./crud/FileCrudDragNDropField.cjs.js"),s=require("./crud/CrudTextAreaComponent.cjs.js"),m=require("./crud/import/CrudImportComponent.cjs.js"),F=require("./crud/import/CrudImportButton.cjs.js"),p=require("./crud/actions/index.cjs.js"),c=require("./crud/view/CrudViewer.cjs.js"),q=require("./context/CrudComponentProvider.cjs.js"),d=require("./crud/CrudForm.cjs.js"),V=require("./crud/modal/index.cjs.js"),I=require("./crud/view/CrudDecListView.cjs.js"),g=require("./crud/view/CrudViewerUtil.cjs.js");exports.TRANSLATION_NAMESPACE=i.TRANSLATION_NAMESPACE;exports.setupI18n=u.setupI18n;exports.updateTranslations=u.updateTranslations;exports.CrudComponent=t;exports.ColorCrudFieldComponent=r.ColorCrudFieldComponent;exports.CrudField=r.default;exports.SelectCrudFieldComponent=r.SelectCrudFieldComponent;exports.CrudFormWizard=C;exports.CrudReportComponent=n;exports.CrudSearchComponent=l;exports.FileDownloadProvider=e.FileDownloadProvider;exports.FileUploadProvider=e.FileUploadProvider;exports.ImageCellValue=e.ImageCellValue;exports.ImageCrudCellValue=e.ImageCrudCellValue;exports.ImageCrudField=e.default;exports.FileCellValue=o.FileCellValue;exports.FileCrudCellValue=o.FileCrudCellValue;exports.FileCrudField=o.default;exports.FileCrudDragNDropField=a;exports.CrudTextAreaComponent=s;exports.CrudImportComponent=m;exports.CrudImportButton=F;exports.CrudActions=p.default;exports.CrudViewer=c;exports.CrudComponentProvider=q.CrudComponentProvider;exports.CrudForm=d.CrudForm;exports.CrudFormFields=d.CrudFormFields;exports.CrudModal=V;exports.CrudDecListView=I.CrudDecListView;exports.getRendererValueCrudViewer=g.getRendererValueCrudViewer;
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});function p(a,n){const{extraAction:t,onUpdate:l,onClickUpdate:s,onClickClone:u,onDelete:C,onHide:d,onExport:f,inBuiltModalProps:e,updatable:r,deletable:c}=a;if(!n)return!1;const o=t==null?void 0:t(n),i=r?r(n):!0,b=c?c(n):!0;return!!((Array.isArray(o)?o.filter(Boolean).length:o)||l||i&&s||e!=null&&e.onUpdate||u||e!=null&&e.onCreate||b&&C||f||d)}exports.hasCrudActions=p;
@@ -0,0 +1,2 @@
1
+ import { CrudActionsProps } from '../../crud';
2
+ export declare function hasCrudActions<T, FormType>(props: CrudActionsProps<T, FormType>, data: T | undefined): boolean;
@@ -0,0 +1,20 @@
1
+ function d(a, n) {
2
+ const {
3
+ extraAction: t,
4
+ onUpdate: l,
5
+ onClickUpdate: s,
6
+ onClickClone: C,
7
+ onDelete: f,
8
+ onHide: p,
9
+ onExport: u,
10
+ inBuiltModalProps: e,
11
+ updatable: r,
12
+ deletable: c
13
+ } = a;
14
+ if (!n) return !1;
15
+ const o = t == null ? void 0 : t(n), U = r ? r(n) : !0, b = c ? c(n) : !0;
16
+ return !!((Array.isArray(o) ? o.filter(Boolean).length : o) || l || U && s || e != null && e.onUpdate || C || e != null && e.onCreate || b && f || u || p);
17
+ }
18
+ export {
19
+ d as hasCrudActions
20
+ };
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@kingteza/crud-component",
3
3
  "private": false,
4
- "version": "1.34.1",
4
+ "version": "1.35.0",
5
5
  "description": "React CRUD component library with Ant Design",
6
6
  "keywords": [
7
7
  "react",