@nocobase/plugin-workflow-manual 0.19.0-alpha.3 → 0.19.0-alpha.4
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/client/index.js +4 -4
- package/dist/client/instruction/index.d.ts +6 -0
- package/dist/externalVersion.js +7 -7
- package/dist/locale/ko_KR.json +32 -0
- package/dist/locale/zh-CN.json +2 -1
- package/dist/server/ManualInstruction.js +1 -0
- package/package.json +2 -2
- package/src/client/WorkflowTodo.tsx +29 -16
- package/src/client/index.ts +1 -2
- package/src/client/instruction/SchemaConfig.tsx +0 -1
- package/src/client/instruction/index.tsx +5 -2
- package/src/locale/ko_KR.json +32 -0
- package/src/locale/zh-CN.json +2 -1
- package/src/server/ManualInstruction.ts +1 -0
package/dist/client/index.js
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
(function(h,e){typeof exports=="object"&&typeof module!="undefined"?e(exports,require("@nocobase/client"),require("@nocobase/plugin-workflow/client"),require("react/jsx-runtime"),require("@formily/antd-v5"),require("@formily/core"),require("@formily/react"),require("antd"),require("react"),require("react-i18next"),require("@nocobase/utils/client"),require("lodash"),require("@ant-design/icons"),require("dayjs")):typeof define=="function"&&define.amd?define(["exports","@nocobase/client","@nocobase/plugin-workflow/client","react/jsx-runtime","@formily/antd-v5","@formily/core","@formily/react","antd","react","react-i18next","@nocobase/utils/client","lodash","@ant-design/icons","dayjs"],e):(h=typeof globalThis!="undefined"?globalThis:h||self,e(h["@nocobase/plugin-workflow-manual"]={},h["@nocobase/client"],h["@nocobase/plugin-workflow"],h.jsxRuntime,h["@formily/antd-v5"],h["@formily/core"],h["@formily/react"],h.antd,h.react,h["react-i18next"],h["@nocobase/utils"],h.lodash,h["@ant-design/icons"],h.dayjs))})(this,function(h,e,p,s,q,U,S,v,u,j,T,G,_,se){"use strict";var We=Object.defineProperty,Re=Object.defineProperties;var eo=Object.getOwnPropertyDescriptors;var J=Object.getOwnPropertySymbols;var ne=Object.prototype.hasOwnProperty,re=Object.prototype.propertyIsEnumerable;var L=(h,e,p)=>e in h?We(h,e,{enumerable:!0,configurable:!0,writable:!0,value:p}):h[e]=p,y=(h,e)=>{for(var p in e||(e={}))ne.call(e,p)&&L(h,p,e[p]);if(J)for(var p of J(e))re.call(e,p)&&L(h,p,e[p]);return h},F=(h,e)=>Re(h,eo(e));var M=(h,e)=>{var p={};for(var s in h)ne.call(h,s)&&e.indexOf(s)<0&&(p[s]=h[s]);if(h!=null&&J)for(var s of J(h))e.indexOf(s)<0&&re.call(h,s)&&(p[s]=h[s]);return p};var $=(h,e,p)=>(L(h,typeof e!="symbol"?e+"":e,p),p);var E=(h,e,p)=>new Promise((s,q)=>{var U=u=>{try{v(p.next(u))}catch(j){q(j)}},S=u=>{try{v(p.throw(u))}catch(j){q(j)}},v=u=>u.done?s(u.value):Promise.resolve(u.value).then(U,S);v((p=p.apply(h,e)).next())});const C="workflow-manual";function B(o,n={}){const{t:r}=ie(n);return r(o)}function ie(o){return j.useTranslation(C,o)}function ae(o){const{execution:n,nodes:r}=p.useFlowContext(),t=u.useMemo(()=>r.reduce((c,d)=>Object.assign(c,{[d.id]:d.key}),{}),[r]),i=u.useMemo(()=>{var c;return{$context:n==null?void 0:n.context,$jobsMapByNodeKey:((c=n==null?void 0:n.jobs)!=null?c:[]).reduce((d,l)=>Object.assign(d,{[t[l.nodeId]]:l.result}),{})}},[n==null?void 0:n.context,n==null?void 0:n.jobs,t]);return u.useMemo(()=>T.parse(o)(i),[i,o])}function Q(o){const n=S.useField(),r=u.useRef(null),{getAssociationAppends:t}=e.useAssociationNames(),{appends:i,updateAssociationValues:a}=t(),c=ae(o.dataSource),d=u.useMemo(()=>U.createForm({values:c,readPretty:!0}),[c]),l={appends:i},f={loading:!1,data:{data:c}},x=e.useAPIClient().resource(o.collection),m=u.useContext(e.BlockRequestContext);return s.jsx(e.CollectionProvider,{collection:o.collection,children:s.jsx(e.RecordProvider,{record:c,parent:!1,children:s.jsx(e.BlockRequestContext.Provider,{value:{block:"form",field:n,service:f,resource:x,__parent:m},children:s.jsx(e.FormBlockContext.Provider,{value:{params:l,form:d,field:n,service:f,updateAssociationValues:a,formBlockRef:r},children:o.children})})})})}function Y(o){var A,D,N;const n=e.useRecord(),r=S.useFieldSchema(),t=S.useField(),i=u.useRef(null),{getAssociationAppends:a}=e.useAssociationNames(),{appends:c,updateAssociationValues:d}=a(),[l]=Object.keys((A=r.toJSON().properties)!=null?A:{}),f=(D=n==null?void 0:n.result)==null?void 0:D[l],{findComponent:g}=e.useDesignable(),x=g((N=t.component)==null?void 0:N[0])||u.Fragment,m=u.useMemo(()=>U.createForm({initialValues:f}),[f]),b=u.useMemo(()=>y({appends:c},o.params),[c,o.params]),k=u.useMemo(()=>({loading:!1,data:{data:f}}),[f]),w=e.useAPIClient().resource(o.collection),O=u.useContext(e.BlockRequestContext),z=u.useMemo(()=>({params:b,form:m,field:t,service:k,updateAssociationValues:d,formBlockRef:i}),[t,m,b,k,d]);return!n.status||f?s.jsx(e.CollectionProvider,{collection:o.collection,children:s.jsx(e.RecordProvider,{record:f,parent:!1,children:s.jsx(e.FormActiveFieldsProvider,{name:"form",children:s.jsx(e.BlockRequestContext.Provider,{value:{block:"form",props:o,field:t,service:k,resource:w,__parent:O},children:s.jsx(e.FormBlockContext.Provider,{value:z,children:s.jsxs(x,F(y({},t.componentProps),{children:[s.jsx(e.FormV2.Templates,{style:{marginBottom:18},form:m}),s.jsx("div",{ref:i,children:s.jsx(S.RecursionField,{schema:r,onlyRenderProperties:!0})})]}))})})})})}):null}function ce(r){var t=r,{schema:o}=t,n=M(t,["schema"]);const{getTemplateSchemaByMode:i}=e.useSchemaTemplateManager(),{insert:a}=e.useSchemaInitializer(),c=e.useRecordCollectionDataSourceItems("FormItem");function d(f){return E(this,arguments,function*({item:l}){const g=l.template?yield i(l):null,x=e.createFormBlockSchema(F(y({actionInitializers:"AddActionButton",actions:{resolve:{type:"void",title:`{{t("Continue the process", { ns: "${C}" })}}`,"x-decorator":"ManualActionStatusProvider","x-decorator-props":{value:p.JOB_STATUS.RESOLVED},"x-component":"Action","x-component-props":{type:"primary",useAction:"{{ useSubmit }}"},"x-designer":"ManualActionDesigner","x-designer-props":{}}}},o),{template:g}));delete x["x-acl-action-props"],delete x["x-acl-action"];const[m]=Object.keys(x.properties);x.properties[m].properties.actions["x-decorator"]="ActionBarProvider",x.properties[m].properties.actions["x-component-props"].style={marginTop:"1.5em",flexWrap:"wrap"},p.traverseSchema(x,b=>{b["x-uid"]&&delete b["x-uid"]}),a(x)})}return s.jsx(e.SchemaInitializerItem,F(y({},n),{onClick:d,items:c}))}function H(){var n;const o=e.useSchemaInitializerItem();return s.jsx(e.CollectionProvider,{collection:(n=o.schema)==null?void 0:n.collection,children:s.jsx(ce,y({},o))})}function P(o,n,r=!1){const t=[];return o?n(o)&&(!r||!o.properties)?(t.push(o),t):(o.properties&&Object.keys(o.properties).forEach(i=>{t.push(...P(o.properties[i],n))}),t):t}function le(){const{name:o,title:n}=e.useCollection();return s.jsxs(e.GeneralSchemaDesigner,{title:n||o,children:[s.jsx(e.SchemaSettingsBlockTitleItem,{}),s.jsx(e.SchemaSettingsLinkageRules,{collectionName:o}),s.jsx(e.SchemaSettingsDataTemplates,{collectionName:o}),s.jsx(e.SchemaSettingsDivider,{}),s.jsx(e.SchemaSettingsRemove,{removeParentsIfNoChildren:!0,breakRemoveOn:{"x-component":"Grid"}})]})}const pe={title:`{{t("Create record form", { ns: "${C}" })}}`,config:{useInitializer({collections:o}){const n=u.useMemo(()=>o.map(a=>({name:G.camelCase(`createRecordForm-child-${a.name}`),type:"item",title:a.title,label:a.label,schema:{collection:a.name,title:`{{t("Create record", { ns: "${C}" })}}`,formType:"create","x-designer":"CreateFormDesigner"},Component:H})),[o]),[r,t]=u.useState(!1),i=e.useMenuSearch(n,r,!0);return{name:"createRecordForm",key:"createRecordForm",type:"subMenu",title:`{{t("Create record form", { ns: "${C}" })}}`,componentProps:{onOpenChange(a){t(a.length>0)}},children:i}},initializers:{},components:{CreateFormDesigner:le},parseFormOptions(o){const n={};return P(o,t=>t["x-decorator"]==="FormBlockProvider"&&t["x-decorator-props"].formType==="create").forEach(t=>{var c;const[i]=Object.keys(t.properties),a=t.properties[i];n[i]={type:"create",title:((c=t["x-component-props"])==null?void 0:c.title)||i,actions:P(a.properties.actions,d=>d["x-component"]==="Action").map(d=>{var l,f;return{status:d["x-decorator-props"].value,values:(f=(l=d["x-action-settings"])==null?void 0:l.assignedValues)==null?void 0:f.values,key:d.name}}),collection:t["x-decorator-props"].collection}}),n}},block:{scope:{},components:{}}};function X(o){var f,g,x,m;const[n,r]=u.useState((g=(f=o.collection)==null?void 0:f.fields)!=null?g:[]),t=e.useRecord(),i=S.useField(),a=S.useFieldSchema(),[c]=Object.keys((x=a.toJSON().properties)!=null?x:{}),d=(m=t==null?void 0:t.result)==null?void 0:m[c],l=u.useMemo(()=>U.createForm({initialValues:d}),[d]);return!t.status||d?s.jsx(e.CollectionProvider,{collection:F(y({},o.collection),{fields:n}),children:s.jsx(e.RecordProvider,{record:d,parent:!1,children:s.jsx(e.FormBlockContext.Provider,{value:{form:l,field:i,setCollectionFields:r},children:o.children})})}):null}function de(){const{insert:o}=e.useSchemaInitializer(),n=e.useSchemaInitializerItem();return s.jsx(e.SchemaInitializerItem,F(y({},n),{onClick:()=>{o({type:"void","x-decorator":"CustomFormBlockProvider","x-decorator-props":{collection:{name:T.uid(),fields:[]}},"x-component":"CardItem","x-component-props":{title:'{{t("Form")}}'},"x-designer":"SimpleDesigner","x-designer-props":{type:"customForm"},properties:{[T.uid()]:{type:"void","x-component":"FormV2","x-component-props":{useProps:"{{ useFormBlockProps }}"},properties:{grid:{type:"void","x-component":"Grid","x-initializer":"AddCustomFormField"},actions:{type:"void","x-decorator":"ActionBarProvider","x-component":"ActionBar","x-component-props":{layout:"one-column",style:{marginTop:"1.5em",flexWrap:"wrap"}},"x-initializer":"AddActionButton",properties:{resolve:{type:"void",title:`{{t("Continue the process", { ns: "${C}" })}}`,"x-decorator":"ManualActionStatusProvider","x-decorator-props":{value:p.JOB_STATUS.RESOLVED},"x-component":"Action","x-component-props":{type:"primary",useAction:"{{ useSubmit }}"},"x-designer":"ManualActionDesigner"}}}}}}})}}))}const Z={basic:'{{t("Basic")}}',choices:'{{t("Choices")}}',media:'{{t("Media")}}',datetime:'{{t("Date & Time")}}',relation:'{{t("Relation")}}',advanced:'{{t("Advanced type")}}',systemInfo:'{{t("System info")}}',others:'{{t("Others")}}'};function ue(o){const n={};return Object.keys(o).forEach(r=>{const t=o[r],{group:i="others"}=t;n[i]=n[i]||{},G.set(n,[i,r],t)}),Object.keys(Z).filter(r=>["basic","choices","datetime","media"].includes(r)).map(r=>({title:Z[r],children:Object.keys(n[r]||{}).map(t=>{const i=n[r][t];return y({value:t,title:i.title,name:t},n[r][t])}).sort((t,i)=>t.order-i.order)}))}function me(){const{interfaces:o}=e.useCollectionManager();return ue(o).map(r=>({name:r.title,type:"itemGroup",title:r.title,children:r.children.map(t=>({name:t.name,type:"item",title:t.title,Component:xe,fieldInterface:t.name}))}))}const W=u.createContext({}),fe=o=>{const[n,r]=u.useState(null),[t,i]=u.useState(),a=me(),c=u.useContext(e.CollectionContext),{setCollectionFields:d}=u.useContext(e.FormBlockContext);return s.jsxs(W.Provider,{value:{onAddField(l){const b=G.cloneDeep(l),{properties:k}=b,I=k,{unique:f,type:g}=I,x=M(I,["unique","type"]),m=M(b,["properties"]);delete x.name["x-disabled"],r(F(y({},m),{properties:x}))},setCallback:i},children:[s.jsx(e.SchemaInitializerItems,F(y({},o),{items:a})),s.jsx(e.ActionContextProvider,{value:{visible:!!n},children:n?s.jsx(e.SchemaComponent,{schema:{type:"void",name:"drawer",title:'{{t("Configure field")}}',"x-decorator":"Form","x-component":"Action.Drawer",properties:F(y({},n.properties),{footer:{type:"void","x-component":"Action.Drawer.Footer",properties:{cancel:{type:"void",title:'{{t("Cancel")}}',"x-component":"Action","x-component-props":{useAction(){const l=S.useForm();return{run(){return E(this,null,function*(){i(null),r(null),l.reset()})}}}}},submit:{type:"void",title:'{{t("Submit")}}',"x-component":"Action","x-component-props":{type:"primary",useAction(){const{values:l,query:f}=S.useForm(),g=[B("Field name existed in form")];return{run(){return E(this,null,function*(){var w,O,z,A;const{default:m}=n,b=T.uid();if(m.name=(w=l.name)!=null?w:b,m.uiSchema.title=(z=(O=l.uiSchema)==null?void 0:O.title)!=null?z:b,m.interface=n.name,(A=c.fields)==null?void 0:A.find(D=>D.name===m.name)){f("name").take().setFeedback({type:"error",messages:g});return}const I=T.merge(m,l);d([...c.fields,I]),t({name:m.name,type:m.uiSchema.type,"x-decorator":"FormItem","x-component":"CollectionField","x-component-props":{field:I},"x-collection-field":`${c.name}.${m.name}`,"x-designer":"FormItem.Designer"}),i(null),r(null)})}}}}}}}})},components:{ArrayTable:q.ArrayTable}}):null})]})},he=new e.SchemaInitializer({name:"AddCustomFormField",wrap:e.gridRowColWrap,insertPosition:"beforeEnd",title:"{{t('Configure fields')}}",ItemsComponent:fe});function xe(){const o=e.useSchemaInitializerItem(),{insert:n,setVisible:r}=e.useSchemaInitializer(),{onAddField:t,setCallback:i}=u.useContext(W),{getInterface:a}=e.useCollectionManager(),c=a(o.fieldInterface);return s.jsx(e.SchemaInitializerItem,y({onClick:()=>{i(()=>n),t(c),r(!1)}},o),o.fieldInterface)}const R={title:`{{t("Custom form", { ns: "${C}" })}}`,config:{useInitializer(){return{name:"customForm",type:"item",title:`{{t("Custom form", { ns: "${C}" })}}`,Component:de}},initializers:{},components:{CustomFormBlockProvider:X},parseFormOptions(o){const n={};return P(o,t=>t["x-decorator"]==="CustomFormBlockProvider").forEach(t=>{var d;const[i]=Object.keys(t.properties),a=t.properties[i],c=P(a.properties.grid,l=>l["x-component"]==="CollectionField",!0);t["x-decorator-props"].collection.fields=c.map(l=>{var f,g;return(g=(f=l["x-component-props"])==null?void 0:f.field)!=null?g:l["x-interface-options"]}),n[i]={type:"custom",title:((d=t["x-component-props"])==null?void 0:d.title)||i,actions:P(a.properties.actions,l=>l["x-component"]==="Action").map(l=>{var f,g;return{status:l["x-decorator-props"].value,values:(g=(f=l["x-action-settings"])==null?void 0:f.assignedValues)==null?void 0:g.values,key:l.name}}),collection:t["x-decorator-props"].collection}}),n}},block:{scope:{},components:{CustomFormBlockProvider:X}}};function Ce(){const{name:o,title:n}=e.useCollection(),r=S.useFieldSchema(),{t}=j.useTranslation(),{dn:i}=e.useDesignable();return s.jsxs(e.GeneralSchemaDesigner,{title:n||o,children:[s.jsx(e.SchemaSettingsBlockTitleItem,{}),s.jsx(e.SchemaSettingsActionModalItem,{title:t("Filter settings",{ns:C}),schema:{name:"filter",type:"object",title:'{{t("Filter")}}',"x-component":"Filter","x-component-props":{useProps(){var c;return{options:e.useCollectionFilterOptions((c=r==null?void 0:r["x-decorator-props"])==null?void 0:c.collection)}},dynamicComponent:"FilterDynamicComponent"}},initialValues:r==null?void 0:r["x-decorator-props"],onSubmit:({filter:a})=>{r["x-decorator-props"].filter=a,i.emit("patch",{schema:{"x-decorator-props":r["x-decorator-props"]}}),i.refresh()}}),s.jsx(e.SchemaSettingsLinkageRules,{collectionName:o}),s.jsx(e.SchemaSettingsDivider,{}),s.jsx(e.SchemaSettingsRemove,{removeParentsIfNoChildren:!0,breakRemoveOn:{"x-component":"Grid"}})]})}const ge={title:`{{t("Update record form", { ns: "${C}" })}}`,config:{useInitializer({collections:o}){const n=u.useMemo(()=>o.map(a=>({name:G.camelCase(`updateRecordForm-child-${a.name}`),type:"item",title:a.title,label:a.label,schema:{collection:a.name,title:`{{t("Update record", { ns: "${C}" })}}`,formType:"update","x-designer":"UpdateFormDesigner"},Component:H})),[o]),[r,t]=u.useState(!1),i=e.useMenuSearch(n,r,!0);return{name:"updateRecordForm",key:"updateRecordForm",type:"subMenu",title:`{{t("Update record form", { ns: "${C}" })}}`,componentProps:{onOpenChange(a){t(a.length>0)}},children:i}},initializers:{},components:{FilterDynamicComponent:p.FilterDynamicComponent,UpdateFormDesigner:Ce},parseFormOptions(o){const n={};return P(o,t=>t["x-decorator"]==="FormBlockProvider"&&t["x-decorator-props"].formType==="update").forEach(t=>{var c;const[i]=Object.keys(t.properties),a=t.properties[i];n[i]=F(y({},t["x-decorator-props"]),{type:"update",title:((c=t["x-component-props"])==null?void 0:c.title)||i,actions:P(a.properties.actions,d=>d["x-component"]==="Action").map(d=>{var l,f;return{status:d["x-decorator-props"].value,values:(f=(l=d["x-action-settings"])==null?void 0:l.assignedValues)==null?void 0:f.values,key:d.name}})})}),n}},block:{scope:{},components:{}}},V=new T.Registry;V.register("customForm",R),V.register("createForm",pe),V.register("updateForm",ge);function ye(){const{workflow:o}=p.useFlowContext(),n=p.useTrigger();return n.useInitializers?n.useInitializers(o.config):null}const be={customForm:R.title,record:`{{t("Data record", { ns: "${C}" })}}`};function Se(){var t,i;const o=S.useFieldSchema(),n=(i=be[(t=o["x-designer-props"])==null?void 0:t.type])!=null?i:'{{t("Block")}}',r=e.useCompile();return s.jsxs(e.GeneralSchemaDesigner,{title:r(n),children:[s.jsx(e.SchemaSettingsBlockTitleItem,{}),s.jsx(e.SchemaSettingsDivider,{}),s.jsx(e.SchemaSettingsRemove,{removeParentsIfNoChildren:!0,breakRemoveOn:{"x-component":"Grid"}})]})}const ve=new e.SchemaInitializer({name:"AddBlockButton",wrap:e.gridRowColWrap,title:'{{t("Add block")}}',items:[{type:"itemGroup",name:"dataBlocks",title:'{{t("Data blocks")}}',checkChildrenLength:!0,useChildren(){const o=e.usePlugin(p),n=p.useNodeContext(),r=p.useAvailableUpstreams(n),t=[ye()].filter(Boolean),i=r.map(c=>{var l;const d=o.instructions.get(c.type);return(l=d==null?void 0:d.useInitializers)==null?void 0:l.call(d,c)}).filter(Boolean);return[...t,...i.length?[{name:"nodes",type:"subMenu",title:`{{t("Node result", { ns: "${C}" })}}`,children:i}]:[]].filter(Boolean)}},{type:"itemGroup",name:"form",title:'{{t("Form")}}',useChildren(){const{collections:o}=e.useCollectionManager();return Array.from(V.getValues()).map(n=>{const{useInitializer:r}=n.config;return r({collections:o})})}},{type:"itemGroup",name:"otherBlocks",title:'{{t("Other blocks")}}',children:[{name:"markdown",title:'{{t("Markdown")}}',Component:"MarkdownBlockInitializer"}]}]});function Fe(){var w,O,z;const o=u.useContext(e.SchemaComponentContext),{t:n}=j.useTranslation(),r=S.useFieldSchema(),t=p.useWorkflowVariableOptions(),[i,a]=u.useState(!1),[c,d]=u.useState((z=(O=(w=r==null?void 0:r["x-action-settings"])==null?void 0:w.assignedValues)==null?void 0:O.schema)!=null?z:{type:"void","x-component":"Grid","x-initializer":"CustomFormItemInitializers",properties:{}}),[l,f]=u.useState(null),{components:g}=e.useSchemaOptionsContext();u.useEffect(()=>{f(new S.Schema({properties:{grid:c}}))},[c]);const x=u.useMemo(()=>{var D,N;const A=(N=(D=r==null?void 0:r["x-action-settings"])==null?void 0:D.assignedValues)==null?void 0:N.values;return U.createForm({initialValues:T.lodash.cloneDeep(A),values:T.lodash.cloneDeep(A)})},[r]),m=e.useFormActiveFields(),b=n("Assign field values");function k(){a(!1)}function I(){r["x-action-settings"]||(r["x-action-settings"]={}),r["x-action-settings"].assignedValues||(r["x-action-settings"].assignedValues={}),r["x-action-settings"].assignedValues.schema=c,r["x-action-settings"].assignedValues.values=x.values,a(!1),setTimeout(()=>{var A;(A=o.refresh)==null||A.call(o)},300)}return s.jsxs(s.Fragment,{children:[s.jsx(e.SchemaSettingsItem,{title:b,onClick:()=>a(!0),children:b}),s.jsx(v.Modal,{width:"50%",title:b,open:i,onCancel:k,footer:s.jsxs(v.Space,{children:[s.jsx(v.Button,{onClick:k,children:n("Cancel")}),s.jsx(v.Button,{type:"primary",onClick:I,children:n("Submit")})]}),children:s.jsx(e.DefaultValueProvider,{isAllowToSetDefaultValue:()=>!1,children:s.jsx(e.VariableScopeProvider,{scope:t,children:s.jsx(e.FormActiveFieldsProvider,{name:"form",getActiveFieldsName:m==null?void 0:m.getActiveFieldsName,children:s.jsx(S.FormProvider,{form:x,children:s.jsxs(q.FormLayout,{layout:"vertical",children:[s.jsx(v.Alert,{message:B("Values preset in this form will override user submitted ones when continue or reject.")}),s.jsx("br",{}),i&&l&&s.jsx(e.SchemaComponentContext.Provider,{value:F(y({},o),{refresh(){d(T.lodash.get(l.toJSON(),"properties.grid"))}}),children:s.jsx(e.SchemaComponent,{schema:l,components:g})})]})})})})})})]})}function ke(o){return s.jsxs(e.GeneralSchemaDesigner,F(y({},o),{disableInitializer:!0,children:[s.jsx(e.Action.Designer.ButtonEditor,{}),s.jsx(Fe,{}),s.jsx(e.SchemaSettingsDivider,{}),s.jsx(e.SchemaSettingsRemove,{removeParentsIfNoChildren:!0,breakRemoveOn:{"x-component":"ActionBar"}})]}))}function Ie(){const a=e.useSchemaInitializerItem(),{action:n,actionProps:r}=a,t=M(a,["action","actionProps"]),{insert:i}=e.useSchemaInitializer();return s.jsx(e.SchemaInitializerItem,F(y({},t),{onClick:()=>{i({type:"void",title:t.title,"x-decorator":"ManualActionStatusProvider","x-decorator-props":{value:n},"x-component":"Action","x-component-props":F(y({},r),{useAction:"{{ useSubmit }}"}),"x-designer":"ManualActionDesigner","x-action-settings":{}})}}))}function ee(){const o=e.useSchemaInitializerItem(),i=o,{action:n,actionProps:r}=i,t=M(i,["action","actionProps"]);return s.jsx(e.InitializerWithSwitch,F(y({},t),{item:o,schema:{type:"void",title:t.title,"x-decorator":"ManualActionStatusProvider","x-decorator-props":{value:n},"x-component":"Action","x-component-props":F(y({},r),{useAction:"{{ useSubmit }}"}),"x-designer":"Action.Designer","x-action":`${n}`},type:"x-action"}))}const we=new e.SchemaInitializer({name:"AddActionButton",title:'{{t("Configure actions")}}',items:[{name:"jobStatusResolved",title:`{{t("Continue the process", { ns: "${C}" })}}`,Component:Ie,action:p.JOB_STATUS.RESOLVED,actionProps:{type:"primary"}},{name:"jobStatusRejected",title:`{{t("Terminate the process", { ns: "${C}" })}}`,Component:ee,action:p.JOB_STATUS.REJECTED,actionProps:{danger:!0}},{name:"jobStatusPending",title:`{{t("Save temporarily", { ns: "${C}" })}}`,Component:ee,action:p.JOB_STATUS.PENDING}]});function Ae(){return{run(){}}}function Be({value:o,onChange:n}){const r=e.usePlugin(p),t=u.useContext(e.SchemaComponentContext),i=p.useNodeContext(),a=p.useAvailableUpstreams(i),c=S.useForm(),{workflow:d}=p.useFlowContext(),l={},f={};a.forEach(m=>{const b=r.instructions.get(m.type);Object.assign(l,b.initializers),Object.assign(f,b.components)});const g=u.useMemo(()=>new S.Schema({properties:{drawer:{type:"void",title:`{{t("User interface", { ns: "${C}" })}}`,"x-decorator":"Form","x-component":"Action.Drawer","x-component-props":{className:e.css`
|
|
1
|
+
(function(x,e){typeof exports=="object"&&typeof module!="undefined"?e(exports,require("@nocobase/client"),require("@nocobase/plugin-workflow/client"),require("react/jsx-runtime"),require("@formily/antd-v5"),require("@formily/core"),require("@formily/react"),require("antd"),require("react"),require("react-i18next"),require("@nocobase/utils/client"),require("lodash"),require("@ant-design/icons"),require("dayjs")):typeof define=="function"&&define.amd?define(["exports","@nocobase/client","@nocobase/plugin-workflow/client","react/jsx-runtime","@formily/antd-v5","@formily/core","@formily/react","antd","react","react-i18next","@nocobase/utils/client","lodash","@ant-design/icons","dayjs"],e):(x=typeof globalThis!="undefined"?globalThis:x||self,e(x["@nocobase/plugin-workflow-manual"]={},x["@nocobase/client"],x["@nocobase/plugin-workflow"],x.jsxRuntime,x["@formily/antd-v5"],x["@formily/core"],x["@formily/react"],x.antd,x.react,x["react-i18next"],x["@nocobase/utils"],x.lodash,x["@ant-design/icons"],x.dayjs))})(this,function(x,e,p,s,U,q,b,S,u,j,T,G,_,se){"use strict";var Re=Object.defineProperty,eo=Object.defineProperties;var oo=Object.getOwnPropertyDescriptors;var J=Object.getOwnPropertySymbols;var ne=Object.prototype.hasOwnProperty,re=Object.prototype.propertyIsEnumerable;var L=(x,e,p)=>e in x?Re(x,e,{enumerable:!0,configurable:!0,writable:!0,value:p}):x[e]=p,g=(x,e)=>{for(var p in e||(e={}))ne.call(e,p)&&L(x,p,e[p]);if(J)for(var p of J(e))re.call(e,p)&&L(x,p,e[p]);return x},F=(x,e)=>eo(x,oo(e));var M=(x,e)=>{var p={};for(var s in x)ne.call(x,s)&&e.indexOf(s)<0&&(p[s]=x[s]);if(x!=null&&J)for(var s of J(x))e.indexOf(s)<0&&re.call(x,s)&&(p[s]=x[s]);return p};var $=(x,e,p)=>(L(x,typeof e!="symbol"?e+"":e,p),p);var E=(x,e,p)=>new Promise((s,U)=>{var q=u=>{try{S(p.next(u))}catch(j){U(j)}},b=u=>{try{S(p.throw(u))}catch(j){U(j)}},S=u=>u.done?s(u.value):Promise.resolve(u.value).then(q,b);S((p=p.apply(x,e)).next())});const C="workflow-manual";function A(o,n={}){const{t:r}=ie(n);return r(o)}function ie(o){return j.useTranslation(C,o)}function ae(o){const{execution:n,nodes:r}=p.useFlowContext(),t=u.useMemo(()=>r.reduce((c,d)=>Object.assign(c,{[d.id]:d.key}),{}),[r]),i=u.useMemo(()=>{var c;return{$context:n==null?void 0:n.context,$jobsMapByNodeKey:((c=n==null?void 0:n.jobs)!=null?c:[]).reduce((d,l)=>Object.assign(d,{[t[l.nodeId]]:l.result}),{})}},[n==null?void 0:n.context,n==null?void 0:n.jobs,t]);return u.useMemo(()=>T.parse(o)(i),[i,o])}function Q(o){const n=b.useField(),r=u.useRef(null),{getAssociationAppends:t}=e.useAssociationNames(),{appends:i,updateAssociationValues:a}=t(),c=ae(o.dataSource),d=u.useMemo(()=>q.createForm({values:c,readPretty:!0}),[c]),l={appends:i},h={loading:!1,data:{data:c}},f=e.useAPIClient().resource(o.collection),m=u.useContext(e.BlockRequestContext);return s.jsx(e.CollectionProvider,{collection:o.collection,children:s.jsx(e.RecordProvider,{record:c,parent:!1,children:s.jsx(e.BlockRequestContext.Provider,{value:{block:"form",field:n,service:h,resource:f,__parent:m},children:s.jsx(e.FormBlockContext.Provider,{value:{params:l,form:d,field:n,service:h,updateAssociationValues:a,formBlockRef:r},children:o.children})})})})}function Y(o){var w,z,N;const n=e.useRecord(),r=b.useFieldSchema(),t=b.useField(),i=u.useRef(null),{getAssociationAppends:a}=e.useAssociationNames(),{appends:c,updateAssociationValues:d}=a(),[l]=Object.keys((w=r.toJSON().properties)!=null?w:{}),h=(z=n==null?void 0:n.result)==null?void 0:z[l],{findComponent:y}=e.useDesignable(),f=y((N=t.component)==null?void 0:N[0])||u.Fragment,m=u.useMemo(()=>q.createForm({initialValues:h}),[h]),v=u.useMemo(()=>g({appends:c},o.params),[c,o.params]),k=u.useMemo(()=>({loading:!1,data:{data:h}}),[h]),B=e.useAPIClient().resource(o.collection),O=u.useContext(e.BlockRequestContext),D=u.useMemo(()=>({params:v,form:m,field:t,service:k,updateAssociationValues:d,formBlockRef:i}),[t,m,v,k,d]);return!n.status||h?s.jsx(e.CollectionProvider,{collection:o.collection,children:s.jsx(e.RecordProvider,{record:h,parent:!1,children:s.jsx(e.FormActiveFieldsProvider,{name:"form",children:s.jsx(e.BlockRequestContext.Provider,{value:{block:"form",props:o,field:t,service:k,resource:B,__parent:O},children:s.jsx(e.FormBlockContext.Provider,{value:D,children:s.jsxs(f,F(g({},t.componentProps),{children:[s.jsx(e.FormV2.Templates,{style:{marginBottom:18},form:m}),s.jsx("div",{ref:i,children:s.jsx(b.RecursionField,{schema:r,onlyRenderProperties:!0})})]}))})})})})}):null}function ce(r){var t=r,{schema:o}=t,n=M(t,["schema"]);const{getTemplateSchemaByMode:i}=e.useSchemaTemplateManager(),{insert:a}=e.useSchemaInitializer(),c=e.useRecordCollectionDataSourceItems("FormItem");function d(h){return E(this,arguments,function*({item:l}){const y=l.template?yield i(l):null,f=e.createFormBlockSchema(F(g({actionInitializers:"AddActionButton",actions:{resolve:{type:"void",title:`{{t("Continue the process", { ns: "${C}" })}}`,"x-decorator":"ManualActionStatusProvider","x-decorator-props":{value:p.JOB_STATUS.RESOLVED},"x-component":"Action","x-component-props":{type:"primary",useAction:"{{ useSubmit }}"},"x-designer":"ManualActionDesigner","x-designer-props":{}}}},o),{template:y}));delete f["x-acl-action-props"],delete f["x-acl-action"];const[m]=Object.keys(f.properties);f.properties[m].properties.actions["x-decorator"]="ActionBarProvider",f.properties[m].properties.actions["x-component-props"].style={marginTop:"1.5em",flexWrap:"wrap"},p.traverseSchema(f,v=>{v["x-uid"]&&delete v["x-uid"]}),a(f)})}return s.jsx(e.SchemaInitializerItem,F(g({},n),{onClick:d,items:c}))}function H(){var n;const o=e.useSchemaInitializerItem();return s.jsx(e.CollectionProvider,{collection:(n=o.schema)==null?void 0:n.collection,children:s.jsx(ce,g({},o))})}function P(o,n,r=!1){const t=[];return o?n(o)&&(!r||!o.properties)?(t.push(o),t):(o.properties&&Object.keys(o.properties).forEach(i=>{t.push(...P(o.properties[i],n))}),t):t}function le(){const{name:o,title:n}=e.useCollection();return s.jsxs(e.GeneralSchemaDesigner,{title:n||o,children:[s.jsx(e.SchemaSettingsBlockTitleItem,{}),s.jsx(e.SchemaSettingsLinkageRules,{collectionName:o}),s.jsx(e.SchemaSettingsDataTemplates,{collectionName:o}),s.jsx(e.SchemaSettingsDivider,{}),s.jsx(e.SchemaSettingsRemove,{removeParentsIfNoChildren:!0,breakRemoveOn:{"x-component":"Grid"}})]})}const pe={title:`{{t("Create record form", { ns: "${C}" })}}`,config:{useInitializer({collections:o}){const n=u.useMemo(()=>o.map(a=>({name:G.camelCase(`createRecordForm-child-${a.name}`),type:"item",title:a.title,label:a.label,schema:{collection:a.name,title:`{{t("Create record", { ns: "${C}" })}}`,formType:"create","x-designer":"CreateFormDesigner"},Component:H})),[o]),[r,t]=u.useState(!1),i=e.useMenuSearch(n,r,!0);return{name:"createRecordForm",key:"createRecordForm",type:"subMenu",title:`{{t("Create record form", { ns: "${C}" })}}`,componentProps:{onOpenChange(a){t(a.length>0)}},children:i}},initializers:{},components:{CreateFormDesigner:le},parseFormOptions(o){const n={};return P(o,t=>t["x-decorator"]==="FormBlockProvider"&&t["x-decorator-props"].formType==="create").forEach(t=>{var c;const[i]=Object.keys(t.properties),a=t.properties[i];n[i]={type:"create",title:((c=t["x-component-props"])==null?void 0:c.title)||i,actions:P(a.properties.actions,d=>d["x-component"]==="Action").map(d=>{var l,h;return{status:d["x-decorator-props"].value,values:(h=(l=d["x-action-settings"])==null?void 0:l.assignedValues)==null?void 0:h.values,key:d.name}}),collection:t["x-decorator-props"].collection}}),n}},block:{scope:{},components:{}}};function X(o){var h,y,f,m;const[n,r]=u.useState((y=(h=o.collection)==null?void 0:h.fields)!=null?y:[]),t=e.useRecord(),i=b.useField(),a=b.useFieldSchema(),[c]=Object.keys((f=a.toJSON().properties)!=null?f:{}),d=(m=t==null?void 0:t.result)==null?void 0:m[c],l=u.useMemo(()=>q.createForm({initialValues:d}),[d]);return!t.status||d?s.jsx(e.CollectionProvider,{collection:F(g({},o.collection),{fields:n}),children:s.jsx(e.RecordProvider,{record:d,parent:!1,children:s.jsx(e.FormBlockContext.Provider,{value:{form:l,field:i,setCollectionFields:r},children:o.children})})}):null}function de(){const{insert:o}=e.useSchemaInitializer(),n=e.useSchemaInitializerItem();return s.jsx(e.SchemaInitializerItem,F(g({},n),{onClick:()=>{o({type:"void","x-decorator":"CustomFormBlockProvider","x-decorator-props":{collection:{name:T.uid(),fields:[]}},"x-component":"CardItem","x-component-props":{title:'{{t("Form")}}'},"x-designer":"SimpleDesigner","x-designer-props":{type:"customForm"},properties:{[T.uid()]:{type:"void","x-component":"FormV2","x-component-props":{useProps:"{{ useFormBlockProps }}"},properties:{grid:{type:"void","x-component":"Grid","x-initializer":"AddCustomFormField"},actions:{type:"void","x-decorator":"ActionBarProvider","x-component":"ActionBar","x-component-props":{layout:"one-column",style:{marginTop:"1.5em",flexWrap:"wrap"}},"x-initializer":"AddActionButton",properties:{resolve:{type:"void",title:`{{t("Continue the process", { ns: "${C}" })}}`,"x-decorator":"ManualActionStatusProvider","x-decorator-props":{value:p.JOB_STATUS.RESOLVED},"x-component":"Action","x-component-props":{type:"primary",useAction:"{{ useSubmit }}"},"x-designer":"ManualActionDesigner"}}}}}}})}}))}const Z={basic:'{{t("Basic")}}',choices:'{{t("Choices")}}',media:'{{t("Media")}}',datetime:'{{t("Date & Time")}}',relation:'{{t("Relation")}}',advanced:'{{t("Advanced type")}}',systemInfo:'{{t("System info")}}',others:'{{t("Others")}}'};function ue(o){const n={};return Object.keys(o).forEach(r=>{const t=o[r],{group:i="others"}=t;n[i]=n[i]||{},G.set(n,[i,r],t)}),Object.keys(Z).filter(r=>["basic","choices","datetime","media"].includes(r)).map(r=>({title:Z[r],children:Object.keys(n[r]||{}).map(t=>{const i=n[r][t];return g({value:t,title:i.title,name:t},n[r][t])}).sort((t,i)=>t.order-i.order)}))}function me(){const{interfaces:o}=e.useCollectionManager();return ue(o).map(r=>({name:r.title,type:"itemGroup",title:r.title,children:r.children.map(t=>({name:t.name,type:"item",title:t.title,Component:xe,fieldInterface:t.name}))}))}const W=u.createContext({}),fe=o=>{const[n,r]=u.useState(null),[t,i]=u.useState(),a=me(),c=u.useContext(e.CollectionContext),{setCollectionFields:d}=u.useContext(e.FormBlockContext);return s.jsxs(W.Provider,{value:{onAddField(l){const v=G.cloneDeep(l),{properties:k}=v,I=k,{unique:h,type:y}=I,f=M(I,["unique","type"]),m=M(v,["properties"]);delete f.name["x-disabled"],r(F(g({},m),{properties:f}))},setCallback:i},children:[s.jsx(e.SchemaInitializerItems,F(g({},o),{items:a})),s.jsx(e.ActionContextProvider,{value:{visible:!!n},children:n?s.jsx(e.SchemaComponent,{schema:{type:"void",name:"drawer",title:'{{t("Configure field")}}',"x-decorator":"Form","x-component":"Action.Drawer",properties:F(g({},n.properties),{footer:{type:"void","x-component":"Action.Drawer.Footer",properties:{cancel:{type:"void",title:'{{t("Cancel")}}',"x-component":"Action","x-component-props":{useAction(){const l=b.useForm();return{run(){return E(this,null,function*(){i(null),r(null),l.reset()})}}}}},submit:{type:"void",title:'{{t("Submit")}}',"x-component":"Action","x-component-props":{type:"primary",useAction(){const{values:l,query:h}=b.useForm(),y=[A("Field name existed in form")];return{run(){return E(this,null,function*(){var B,O,D,w;const{default:m}=n,v=T.uid();if(m.name=(B=l.name)!=null?B:v,m.uiSchema.title=(D=(O=l.uiSchema)==null?void 0:O.title)!=null?D:v,m.interface=n.name,(w=c.fields)==null?void 0:w.find(z=>z.name===m.name)){h("name").take().setFeedback({type:"error",messages:y});return}const I=T.merge(m,l);d([...c.fields,I]),t({name:m.name,type:m.uiSchema.type,"x-decorator":"FormItem","x-component":"CollectionField","x-component-props":{field:I},"x-collection-field":`${c.name}.${m.name}`,"x-designer":"FormItem.Designer"}),i(null),r(null)})}}}}}}}})},components:{ArrayTable:U.ArrayTable}}):null})]})},he=new e.SchemaInitializer({name:"AddCustomFormField",wrap:e.gridRowColWrap,insertPosition:"beforeEnd",title:"{{t('Configure fields')}}",ItemsComponent:fe});function xe(){const o=e.useSchemaInitializerItem(),{insert:n,setVisible:r}=e.useSchemaInitializer(),{onAddField:t,setCallback:i}=u.useContext(W),{getInterface:a}=e.useCollectionManager(),c=a(o.fieldInterface);return s.jsx(e.SchemaInitializerItem,g({onClick:()=>{i(()=>n),t(c),r(!1)}},o),o.fieldInterface)}const R={title:`{{t("Custom form", { ns: "${C}" })}}`,config:{useInitializer(){return{name:"customForm",type:"item",title:`{{t("Custom form", { ns: "${C}" })}}`,Component:de}},initializers:{},components:{CustomFormBlockProvider:X},parseFormOptions(o){const n={};return P(o,t=>t["x-decorator"]==="CustomFormBlockProvider").forEach(t=>{var d;const[i]=Object.keys(t.properties),a=t.properties[i],c=P(a.properties.grid,l=>l["x-component"]==="CollectionField",!0);t["x-decorator-props"].collection.fields=c.map(l=>{var h,y;return(y=(h=l["x-component-props"])==null?void 0:h.field)!=null?y:l["x-interface-options"]}),n[i]={type:"custom",title:((d=t["x-component-props"])==null?void 0:d.title)||i,actions:P(a.properties.actions,l=>l["x-component"]==="Action").map(l=>{var h,y;return{status:l["x-decorator-props"].value,values:(y=(h=l["x-action-settings"])==null?void 0:h.assignedValues)==null?void 0:y.values,key:l.name}}),collection:t["x-decorator-props"].collection}}),n}},block:{scope:{},components:{CustomFormBlockProvider:X}}};function Ce(){const{name:o,title:n}=e.useCollection(),r=b.useFieldSchema(),{t}=j.useTranslation(),{dn:i}=e.useDesignable();return s.jsxs(e.GeneralSchemaDesigner,{title:n||o,children:[s.jsx(e.SchemaSettingsBlockTitleItem,{}),s.jsx(e.SchemaSettingsActionModalItem,{title:t("Filter settings",{ns:C}),schema:{name:"filter",type:"object",title:'{{t("Filter")}}',"x-component":"Filter","x-component-props":{useProps(){var c;return{options:e.useCollectionFilterOptions((c=r==null?void 0:r["x-decorator-props"])==null?void 0:c.collection)}},dynamicComponent:"FilterDynamicComponent"}},initialValues:r==null?void 0:r["x-decorator-props"],onSubmit:({filter:a})=>{r["x-decorator-props"].filter=a,i.emit("patch",{schema:{"x-decorator-props":r["x-decorator-props"]}}),i.refresh()}}),s.jsx(e.SchemaSettingsLinkageRules,{collectionName:o}),s.jsx(e.SchemaSettingsDivider,{}),s.jsx(e.SchemaSettingsRemove,{removeParentsIfNoChildren:!0,breakRemoveOn:{"x-component":"Grid"}})]})}const ge={title:`{{t("Update record form", { ns: "${C}" })}}`,config:{useInitializer({collections:o}){const n=u.useMemo(()=>o.map(a=>({name:G.camelCase(`updateRecordForm-child-${a.name}`),type:"item",title:a.title,label:a.label,schema:{collection:a.name,title:`{{t("Update record", { ns: "${C}" })}}`,formType:"update","x-designer":"UpdateFormDesigner"},Component:H})),[o]),[r,t]=u.useState(!1),i=e.useMenuSearch(n,r,!0);return{name:"updateRecordForm",key:"updateRecordForm",type:"subMenu",title:`{{t("Update record form", { ns: "${C}" })}}`,componentProps:{onOpenChange(a){t(a.length>0)}},children:i}},initializers:{},components:{FilterDynamicComponent:p.FilterDynamicComponent,UpdateFormDesigner:Ce},parseFormOptions(o){const n={};return P(o,t=>t["x-decorator"]==="FormBlockProvider"&&t["x-decorator-props"].formType==="update").forEach(t=>{var c;const[i]=Object.keys(t.properties),a=t.properties[i];n[i]=F(g({},t["x-decorator-props"]),{type:"update",title:((c=t["x-component-props"])==null?void 0:c.title)||i,actions:P(a.properties.actions,d=>d["x-component"]==="Action").map(d=>{var l,h;return{status:d["x-decorator-props"].value,values:(h=(l=d["x-action-settings"])==null?void 0:l.assignedValues)==null?void 0:h.values,key:d.name}})})}),n}},block:{scope:{},components:{}}},V=new T.Registry;V.register("customForm",R),V.register("createForm",pe),V.register("updateForm",ge);function ye(){const{workflow:o}=p.useFlowContext(),n=p.useTrigger();return n.useInitializers?n.useInitializers(o.config):null}const be={customForm:R.title,record:`{{t("Data record", { ns: "${C}" })}}`};function Se(){var t,i;const o=b.useFieldSchema(),n=(i=be[(t=o["x-designer-props"])==null?void 0:t.type])!=null?i:'{{t("Block")}}',r=e.useCompile();return s.jsxs(e.GeneralSchemaDesigner,{title:r(n),children:[s.jsx(e.SchemaSettingsBlockTitleItem,{}),s.jsx(e.SchemaSettingsDivider,{}),s.jsx(e.SchemaSettingsRemove,{removeParentsIfNoChildren:!0,breakRemoveOn:{"x-component":"Grid"}})]})}const ve=new e.SchemaInitializer({name:"AddBlockButton",wrap:e.gridRowColWrap,title:'{{t("Add block")}}',items:[{type:"itemGroup",name:"dataBlocks",title:'{{t("Data blocks")}}',checkChildrenLength:!0,useChildren(){const o=e.usePlugin(p),n=p.useNodeContext(),r=p.useAvailableUpstreams(n),t=[ye()].filter(Boolean),i=r.map(c=>{var l;const d=o.instructions.get(c.type);return(l=d==null?void 0:d.useInitializers)==null?void 0:l.call(d,c)}).filter(Boolean);return[...t,...i.length?[{name:"nodes",type:"subMenu",title:`{{t("Node result", { ns: "${C}" })}}`,children:i}]:[]].filter(Boolean)}},{type:"itemGroup",name:"form",title:'{{t("Form")}}',useChildren(){const{collections:o}=e.useCollectionManager();return Array.from(V.getValues()).map(n=>{const{useInitializer:r}=n.config;return r({collections:o})})}},{type:"itemGroup",name:"otherBlocks",title:'{{t("Other blocks")}}',children:[{name:"markdown",title:'{{t("Markdown")}}',Component:"MarkdownBlockInitializer"}]}]});function Fe(){var B,O,D;const o=u.useContext(e.SchemaComponentContext),{t:n}=j.useTranslation(),r=b.useFieldSchema(),t=p.useWorkflowVariableOptions(),[i,a]=u.useState(!1),[c,d]=u.useState((D=(O=(B=r==null?void 0:r["x-action-settings"])==null?void 0:B.assignedValues)==null?void 0:O.schema)!=null?D:{type:"void","x-component":"Grid","x-initializer":"CustomFormItemInitializers",properties:{}}),[l,h]=u.useState(null),{components:y}=e.useSchemaOptionsContext();u.useEffect(()=>{h(new b.Schema({properties:{grid:c}}))},[c]);const f=u.useMemo(()=>{var z,N;const w=(N=(z=r==null?void 0:r["x-action-settings"])==null?void 0:z.assignedValues)==null?void 0:N.values;return q.createForm({initialValues:T.lodash.cloneDeep(w),values:T.lodash.cloneDeep(w)})},[r]),m=e.useFormActiveFields(),v=n("Assign field values");function k(){a(!1)}function I(){r["x-action-settings"]||(r["x-action-settings"]={}),r["x-action-settings"].assignedValues||(r["x-action-settings"].assignedValues={}),r["x-action-settings"].assignedValues.schema=c,r["x-action-settings"].assignedValues.values=f.values,a(!1),setTimeout(()=>{var w;(w=o.refresh)==null||w.call(o)},300)}return s.jsxs(s.Fragment,{children:[s.jsx(e.SchemaSettingsItem,{title:v,onClick:()=>a(!0),children:v}),s.jsx(S.Modal,{width:"50%",title:v,open:i,onCancel:k,footer:s.jsxs(S.Space,{children:[s.jsx(S.Button,{onClick:k,children:n("Cancel")}),s.jsx(S.Button,{type:"primary",onClick:I,children:n("Submit")})]}),children:s.jsx(e.DefaultValueProvider,{isAllowToSetDefaultValue:()=>!1,children:s.jsx(e.VariableScopeProvider,{scope:t,children:s.jsx(e.FormActiveFieldsProvider,{name:"form",getActiveFieldsName:m==null?void 0:m.getActiveFieldsName,children:s.jsx(b.FormProvider,{form:f,children:s.jsxs(U.FormLayout,{layout:"vertical",children:[s.jsx(S.Alert,{message:A("Values preset in this form will override user submitted ones when continue or reject.")}),s.jsx("br",{}),i&&l&&s.jsx(e.SchemaComponentContext.Provider,{value:F(g({},o),{refresh(){d(T.lodash.get(l.toJSON(),"properties.grid"))}}),children:s.jsx(e.SchemaComponent,{schema:l,components:y})})]})})})})})})]})}function ke(o){return s.jsxs(e.GeneralSchemaDesigner,F(g({},o),{disableInitializer:!0,children:[s.jsx(e.Action.Designer.ButtonEditor,{}),s.jsx(Fe,{}),s.jsx(e.SchemaSettingsDivider,{}),s.jsx(e.SchemaSettingsRemove,{removeParentsIfNoChildren:!0,breakRemoveOn:{"x-component":"ActionBar"}})]}))}function Ie(){const a=e.useSchemaInitializerItem(),{action:n,actionProps:r}=a,t=M(a,["action","actionProps"]),{insert:i}=e.useSchemaInitializer();return s.jsx(e.SchemaInitializerItem,F(g({},t),{onClick:()=>{i({type:"void",title:t.title,"x-decorator":"ManualActionStatusProvider","x-decorator-props":{value:n},"x-component":"Action","x-component-props":F(g({},r),{useAction:"{{ useSubmit }}"}),"x-designer":"ManualActionDesigner","x-action-settings":{}})}}))}function ee(){const o=e.useSchemaInitializerItem(),i=o,{action:n,actionProps:r}=i,t=M(i,["action","actionProps"]);return s.jsx(e.InitializerWithSwitch,F(g({},t),{item:o,schema:{type:"void",title:t.title,"x-decorator":"ManualActionStatusProvider","x-decorator-props":{value:n},"x-component":"Action","x-component-props":F(g({},r),{useAction:"{{ useSubmit }}"}),"x-designer":"Action.Designer","x-action":`${n}`},type:"x-action"}))}const we=new e.SchemaInitializer({name:"AddActionButton",title:'{{t("Configure actions")}}',items:[{name:"jobStatusResolved",title:`{{t("Continue the process", { ns: "${C}" })}}`,Component:Ie,action:p.JOB_STATUS.RESOLVED,actionProps:{type:"primary"}},{name:"jobStatusRejected",title:`{{t("Terminate the process", { ns: "${C}" })}}`,Component:ee,action:p.JOB_STATUS.REJECTED,actionProps:{danger:!0}},{name:"jobStatusPending",title:`{{t("Save temporarily", { ns: "${C}" })}}`,Component:ee,action:p.JOB_STATUS.PENDING}]});function Ae(){return{run(){}}}function Be({value:o,onChange:n}){const r=e.usePlugin(p),t=u.useContext(e.SchemaComponentContext),i=p.useNodeContext(),a=p.useAvailableUpstreams(i),c=b.useForm(),{workflow:d}=p.useFlowContext(),l={};a.forEach(f=>{const m=r.instructions.get(f.type);Object.assign(l,m.components)});const h=u.useMemo(()=>new b.Schema({properties:{drawer:{type:"void",title:`{{t("User interface", { ns: "${C}" })}}`,"x-decorator":"Form","x-component":"Action.Drawer","x-component-props":{className:e.css`
|
|
2
2
|
.ant-drawer-body {
|
|
3
3
|
background: var(--nb-box-bg);
|
|
4
4
|
}
|
|
5
|
-
`},properties:{tabs:{type:"void","x-component":"Tabs","x-component-props":{},"x-initializer":"TabPaneInitializers","x-initializer-props":{gridInitializer:"AddBlockButton"},properties:o!=null?o:{tab1:{type:"void",title:`{{t("Manual", { ns: "${C}" })}}`,"x-component":"Tabs.TabPane","x-designer":"Tabs.Designer",properties:{grid:{type:"void","x-component":"Grid","x-initializer":"AddBlockButton",properties:{}}}}}}}}}}),[]),
|
|
5
|
+
`},properties:{tabs:{type:"void","x-component":"Tabs","x-component-props":{},"x-initializer":"TabPaneInitializers","x-initializer-props":{gridInitializer:"AddBlockButton"},properties:o!=null?o:{tab1:{type:"void",title:`{{t("Manual", { ns: "${C}" })}}`,"x-component":"Tabs.TabPane","x-designer":"Tabs.Designer",properties:{grid:{type:"void","x-component":"Grid","x-initializer":"AddBlockButton",properties:{}}}}}}}}}}),[]),y=u.useCallback(function(){const{tabs:m}=T.lodash.get(h.toJSON(),"properties.drawer.properties"),v=Array.from(V.getValues()).reduce((k,I)=>Object.assign(k,I.config.parseFormOptions(m)),{});c.setValuesIn("forms",v),n(m.properties)},[c,n,h]);return s.jsx(e.SchemaComponentContext.Provider,{value:F(g({},t),{designable:!d.executed,refresh:y}),children:s.jsx(e.SchemaComponent,{schema:h,components:F(g(g({},l),Array.from(V.getValues()).reduce((f,m)=>Object.assign(f,m.config.components),{})),{FormBlockProvider:Y,DetailsBlockProvider:Q,ManualActionStatusProvider(f){return f.children},ActionBarProvider(f){return f.children},SimpleDesigner:Se,ManualActionDesigner:ke}),scope:{useSubmit:Ae,useDetailsBlockProps:e.useFormBlockContext}})})}function Te(o){const{workflow:n}=p.useFlowContext(),[r,t]=u.useState(!1);return s.jsxs(s.Fragment,{children:[s.jsx(S.Button,{type:"primary",onClick:()=>t(!0),disabled:!1,children:A(n.executed?"View user interface":"Configure user interface")}),s.jsx(e.ActionContextProvider,{value:{visible:r,setVisible:t,formValueChanged:!1},children:o.children})]})}function Oe({value:o,onChange:n}){const r=s.jsx("fieldset",{children:s.jsx(U.FormLayout,{layout:"vertical",children:s.jsx(e.FormItem,{label:A("Negotiation"),children:s.jsxs(S.Radio.Group,{value:o,onChange:n,children:[s.jsx(S.Radio,{value:1,children:s.jsxs(S.Tooltip,{title:A("Everyone should pass"),placement:"bottom",children:[s.jsx("span",{children:A("All pass")}),s.jsx(_.QuestionCircleOutlined,{style:{color:"#999"}})]})}),s.jsx(S.Radio,{value:-1,children:s.jsxs(S.Tooltip,{title:A("Anyone pass"),placement:"bottom",children:[s.jsx("span",{children:A("Any pass")}),s.jsx(_.QuestionCircleOutlined,{style:{color:"#999"}})]})})]})})})});return s.jsxs("fieldset",{className:e.css`
|
|
6
6
|
.ant-radio-group {
|
|
7
7
|
.anticon {
|
|
8
8
|
margin-left: 0.5em;
|
|
9
9
|
}
|
|
10
10
|
}
|
|
11
|
-
`,children:[s.jsx(v.Form.Item,{children:s.jsxs(v.Radio.Group,{value:!!o,onChange:({target:{value:t}})=>{console.log(t),n(Number(t))},children:[s.jsx(v.Radio,{value:!0,children:s.jsxs(v.Tooltip,{title:B("Each user has own task"),placement:"bottom",children:[s.jsx("span",{children:B("Separately")}),s.jsx(_.QuestionCircleOutlined,{style:{color:"#999"}})]})}),s.jsx(v.Radio,{value:!1,children:s.jsxs(v.Tooltip,{title:B("Everyone shares one task"),placement:"bottom",children:[s.jsx("span",{children:B("Collaboratively")}),s.jsx(_.QuestionCircleOutlined,{style:{color:"#999"}})]})})]})}),o?r:null]})}function ze(o){return o.isForeignKey?o.target==="users":o.collectionName==="users"&&o.name==="id"}function De({multiple:o=!1,value:n=[],onChange:r}){const t=p.useWorkflowVariableOptions({types:[ze]});return s.jsx(e.Variable.Input,{scope:t,value:n[0],onChange:i=>{r([i])},children:s.jsx(e.RemoteSelect,{fieldNames:{label:"nickname",value:"id"},service:{resource:"users"},manual:!1,value:n[0],onChange:i=>{r(i!=null?[i]:[])}})})}class Me extends p.Instruction{constructor(){super(...arguments);$(this,"title",`{{t("Manual", { ns: "${C}" })}}`);$(this,"type","manual");$(this,"group","manual");$(this,"description",`{{t("Could be used for manually submitting data, and determine whether to continue or exit. Workflow will generate a todo item for assigned user when it reaches a manual node, and continue processing after user submits the form.", { ns: "${C}" })}}`);$(this,"fieldset",{assignees:{type:"array",title:`{{t("Assignees", { ns: "${C}" })}}`,"x-decorator":"FormItem","x-component":"AssigneesSelect","x-component-props":{},required:!0,default:[]},mode:{type:"number",title:`{{t("Mode", { ns: "${C}" })}}`,"x-decorator":"FormItem","x-component":"ModeConfig",default:1,"x-reactions":{dependencies:["assignees"],fulfill:{state:{visible:"{{$deps[0].length > 1}}"}}}},schema:{type:"void",title:`{{t("User interface", { ns: "${C}" })}}`,"x-decorator":"FormItem","x-component":"SchemaConfigButton",properties:{schema:{type:"object","x-component":"SchemaConfig",default:null}}},forms:{type:"object",default:{}}});$(this,"components",{SchemaConfigButton:Te,SchemaConfig:Be,ModeConfig:Oe,AssigneesSelect:De})}useVariables({key:r,title:t,config:i},{types:a,fieldNames:c=p.defaultFieldNames}){var x;const d=e.useCompile(),{getCollectionFields:l}=e.useCollectionManager(),f=Object.keys((x=i.forms)!=null?x:{});if(!f.length)return null;const g=f.map(m=>{var w;const b=i.forms[m],k=p.getCollectionFieldOptions({fields:(w=b.collection)==null?void 0:w.fields,collection:b.collection,types:a,compile:d,getCollectionFields:l}),I=d(b.title)||m;return k.length?{key:m,value:m,label:I,title:I,children:k}:null}).filter(Boolean);return g.length?{[c.value]:r,[c.label]:t,[c.children]:g}:null}useInitializers(r){var c;const{getCollection:t}=e.useCollectionManager(),i=Object.keys((c=r.config.forms)!=null?c:{});if(!i.length||r.config.mode)return null;const a=i.map(d=>{var g,x;const l=r.config.forms[d],{fields:f=[]}=t(l.collection);return f.length?{name:(g=l.title)!=null?g:d,type:"item",title:(x=l.title)!=null?x:d,Component:p.CollectionBlockInitializer,collection:l.collection,dataSource:`{{$jobsMapByNodeKey.${r.key}.${d}}}`}:null}).filter(Boolean);return a.length?{name:`#${r.id}`,key:"forms",type:"subMenu",title:r.title,children:a}:null}}const Pe={title:`{{t("Task", { ns: "${C}" })}}`,name:"flow_nodes",fields:[{type:"bigInt",name:"id",interface:"m2o",uiSchema:{type:"number",title:"ID","x-component":"RemoteSelect","x-component-props":{fieldNames:{label:"title",value:"id"},service:{resource:"flow_nodes",params:{filter:{type:"manual"}}}}}},{type:"string",name:"title",interface:"input",uiSchema:{type:"string",title:'{{t("Title")}}',"x-component":"Input"}}]},Ve={title:`{{t("Workflow", { ns: "${C}" })}}`,name:"workflows",fields:[{type:"string",name:"title",interface:"input",uiSchema:{title:'{{t("Name")}}',type:"string","x-component":"Input",required:!0}}]},je={title:`{{t("Workflow todos", { ns: "${C}" })}}`,name:"users_jobs",fields:[{type:"belongsTo",name:"user",target:"users",foreignKey:"userId",interface:"m2o",uiSchema:{type:"number",title:'{{t("User")}}',"x-component":"RemoteSelect","x-component-props":{fieldNames:{label:"nickname",value:"id"},service:{resource:"users"}}}},{type:"belongsTo",name:"node",target:"flow_nodes",foreignKey:"nodeId",interface:"m2o",isAssociation:!0,uiSchema:{type:"number",title:`{{t("Task", { ns: "${C}" })}}`,"x-component":"RemoteSelect","x-component-props":{fieldNames:{label:"title",value:"id"},service:{resource:"flow_nodes"}}}},{type:"belongsTo",name:"workflow",target:"workflows",foreignKey:"workflowId",interface:"m2o",uiSchema:{type:"number",title:`{{t("Workflow", { ns: "${C}" })}}`,"x-component":"RemoteSelect","x-component-props":{fieldNames:{label:"title",value:"id"},service:{resource:"workflows"}}}},{type:"integer",name:"status",interface:"select",uiSchema:{type:"number",title:`{{t("Status", { ns: "${C}" })}}`,"x-component":"Select",enum:p.JobStatusOptions}},{name:"createdAt",type:"date",interface:"createdAt",uiSchema:{type:"datetime",title:'{{t("Created at")}}',"x-component":"DatePicker","x-component-props":{showTime:!0}}}]},Ne=S.observer(()=>{var n,r,t;const o=S.useField();return(t=(n=o==null?void 0:o.value)==null?void 0:n.title)!=null?t:`#${(r=o.value)==null?void 0:r.id}`},{displayName:"NodeColumn"}),$e=S.observer(()=>{var n,r,t;const o=S.useField();return(t=(n=o==null?void 0:o.value)==null?void 0:n.title)!=null?t:`#${(r=o.value)==null?void 0:r.id}`},{displayName:"WorkflowColumn"}),Ee=S.observer(()=>{var n,r,t;const o=S.useField();return(t=(n=o==null?void 0:o.value)==null?void 0:n.nickname)!=null?t:(r=o.value)==null?void 0:r.id},{displayName:"UserColumn"}),K=()=>s.jsx(e.SchemaComponent,{components:{NodeColumn:Ne,WorkflowColumn:$e,UserColumn:Ee},schema:{type:"void",properties:{actions:{type:"void","x-component":"ActionBar","x-component-props":{style:{marginBottom:16}},properties:{filter:{type:"void",title:'{{ t("Filter") }}',"x-action":"filter","x-designer":"Filter.Action.Designer","x-component":"Filter.Action","x-component-props":{icon:"FilterOutlined",useProps:"{{ useFilterActionProps }}"},"x-align":"left"},refresher:{type:"void",title:'{{ t("Refresh") }}',"x-action":"refresh","x-component":"Action","x-designer":"Action.Designer","x-component-props":{icon:"ReloadOutlined",useProps:"{{ useRefreshActionProps }}"},"x-align":"right"}}},table:{type:"array","x-component":"TableV2","x-component-props":{rowKey:"id",useProps:"{{ useTableBlockProps }}"},properties:{actions:{type:"void","x-decorator":"TableV2.Column.Decorator","x-component":"TableV2.Column","x-component-props":{width:60},title:'{{t("Actions")}}',properties:{view:{type:"void","x-component":"Action.Link",title:'{{t("View")}}',properties:{drawer:{"x-component":"WorkflowTodo.Drawer"}}}}},node:{type:"void","x-decorator":"TableV2.Column.Decorator","x-component":"TableV2.Column","x-component-props":{width:null},title:`{{t("Task node", { ns: "${C}" })}}`,properties:{node:{"x-component":"NodeColumn","x-read-pretty":!0}}},workflow:{type:"void","x-decorator":"TableV2.Column.Decorator","x-component":"TableV2.Column","x-component-props":{width:null},title:'{{t("Workflow", { ns: "workflow" })}}',properties:{workflow:{"x-component":"WorkflowColumn","x-read-pretty":!0}}},status:{type:"void","x-decorator":"TableV2.Column.Decorator","x-component":"TableV2.Column","x-component-props":{width:100},title:'{{t("Status", { ns: "workflow" })}}',properties:{status:{"x-component":"CollectionField","x-read-pretty":!0}}},user:{type:"void","x-decorator":"TableV2.Column.Decorator","x-component":"TableV2.Column","x-component-props":{width:140},title:`{{t("Assignee", { ns: "${C}" })}}`,properties:{user:{"x-component":"UserColumn","x-read-pretty":!0}}},createdAt:{type:"void","x-decorator":"TableV2.Column.Decorator","x-component":"TableV2.Column","x-component-props":{width:160},properties:{createdAt:{type:"string","x-component":"CollectionField","x-read-pretty":!0}}}}}}}});function qe(o){var f;const{data:n}=e.useCurrentUserContext(),{userJob:r}=p.useFlowContext(),{status:t,result:i,userId:a}=r,c=S.useFieldSchema(),{name:d}=c.parent.toJSON();let{children:l}=o;return t?i[d]||(l=null):((f=n==null?void 0:n.data)==null?void 0:f.id)!==a&&(l=null),l}const Ue=u.createContext(null);function _e({value:o,children:n}){const{userJob:r}=p.useFlowContext(),t=S.useField(),i=S.useFieldSchema();return u.useEffect(()=>{r.status&&(t.disabled=!0,t.visible=r.status===o&&r.result._===i.name)},[r,o,t,i.name]),s.jsx(Ue.Provider,{value:o,children:n})}function Ge(){const o=e.useAPIClient(),{setVisible:n}=e.useActionContext(),{values:r,submit:t}=S.useForm(),i=S.useFieldSchema(),{service:a}=e.useTableBlockContext(),{userJob:c}=p.useFlowContext(),{name:d}=i,{name:l}=i.parent.parent;return{run(){return E(this,null,function*(){c.status||(yield t(),yield o.resource("users_jobs").submit({filterByTk:c.id,values:{result:{[l]:r,_:d}}}),n(!1),a.refresh())})}}}function Je(o){var g;const n=e.usePlugin(p),r=e.useAPIClient(),{id:t}=e.useRecord(),[i,a]=u.useState(null),[c,d]=u.useState(null);u.useEffect(()=>{var x,m;t&&((m=(x=r.resource("users_jobs")).get)==null||m.call(x,{filterByTk:t,appends:["node","workflow","workflow.nodes","execution","execution.jobs"]}).then(({data:b})=>{var A;const D=(A=b==null?void 0:b.data)!=null?A:{},{node:k,workflow:N={}}=D,oe=N,{nodes:I=[]}=oe,w=M(oe,["nodes"]),te=D,{execution:O}=te,z=M(te,["node","workflow","execution"]);p.linkNodes(I),d(k),a({userJob:z,workflow:w,nodes:I,execution:O})}))},[r,t]);const f=p.useAvailableUpstreams(i==null?void 0:i.nodes.find(x=>x.id===c.id)).reduce((x,{type:m})=>Object.assign(x,n.instructions.get(m).components),{});return c&&i?s.jsx(p.FlowContext.Provider,{value:i,children:s.jsx(e.SchemaComponent,{components:y(y({FormBlockProvider:Y,DetailsBlockProvider:Q,ActionBarProvider:qe,ManualActionStatusProvider:_e},Array.from(V.getValues()).reduce((x,m)=>Object.assign(x,m.block.components),{})),f),scope:y({useSubmit:Ge,useFormBlockProps:Ke,useDetailsBlockProps:Le},Array.from(V.getValues()).reduce((x,m)=>Object.assign(x,m.block.scope),{})),schema:{type:"void",name:"tabs","x-component":"Tabs",properties:(g=c.config)==null?void 0:g.schema}})}):s.jsx(v.Spin,{})}function Ke(){var a;const{userJob:o}=p.useFlowContext(),n=e.useRecord(),{data:r}=e.useCurrentUserContext(),{form:t}=e.useFormBlockContext(),i=o.status?n?"readPretty":"disabled":((a=r==null?void 0:r.data)==null?void 0:a.id)!==o.userId?"disabled":"editable";return u.useEffect(()=>{t==null||t.setPattern(i)},[i,t]),{form:t}}function Le(){const{form:o}=e.useFormBlockContext();return{form:o}}function Qe(){const o=e.useCompile(),{status:n,updatedAt:r}=e.useRecord(),t=p.JobStatusOptionsMap[n];return n?s.jsxs(v.Space,{children:[s.jsx("time",{className:e.css`
|
|
11
|
+
`,children:[s.jsx(S.Form.Item,{children:s.jsxs(S.Radio.Group,{value:!!o,onChange:({target:{value:t}})=>{console.log(t),n(Number(t))},children:[s.jsx(S.Radio,{value:!0,children:s.jsxs(S.Tooltip,{title:A("Each user has own task"),placement:"bottom",children:[s.jsx("span",{children:A("Separately")}),s.jsx(_.QuestionCircleOutlined,{style:{color:"#999"}})]})}),s.jsx(S.Radio,{value:!1,children:s.jsxs(S.Tooltip,{title:A("Everyone shares one task"),placement:"bottom",children:[s.jsx("span",{children:A("Collaboratively")}),s.jsx(_.QuestionCircleOutlined,{style:{color:"#999"}})]})})]})}),o?r:null]})}function De(o){return o.isForeignKey?o.target==="users":o.collectionName==="users"&&o.name==="id"}function ze({multiple:o=!1,value:n=[],onChange:r}){const t=p.useWorkflowVariableOptions({types:[De]});return s.jsx(e.Variable.Input,{scope:t,value:n[0],onChange:i=>{r([i])},children:s.jsx(e.RemoteSelect,{fieldNames:{label:"nickname",value:"id"},service:{resource:"users"},manual:!1,value:n[0],onChange:i=>{r(i!=null?[i]:[])}})})}class Me extends p.Instruction{constructor(){super(...arguments);$(this,"title",`{{t("Manual", { ns: "${C}" })}}`);$(this,"type","manual");$(this,"group","manual");$(this,"description",`{{t("Could be used for manually submitting data, and determine whether to continue or exit. Workflow will generate a todo item for assigned user when it reaches a manual node, and continue processing after user submits the form.", { ns: "${C}" })}}`);$(this,"fieldset",{assignees:{type:"array",title:`{{t("Assignees", { ns: "${C}" })}}`,"x-decorator":"FormItem","x-component":"AssigneesSelect","x-component-props":{},required:!0,default:[]},mode:{type:"number",title:`{{t("Mode", { ns: "${C}" })}}`,"x-decorator":"FormItem","x-component":"ModeConfig",default:1,"x-reactions":{dependencies:["assignees"],fulfill:{state:{visible:"{{$deps[0].length > 1}}"}}}},schema:{type:"void",title:`{{t("User interface", { ns: "${C}" })}}`,"x-decorator":"FormItem","x-component":"SchemaConfigButton",properties:{schema:{type:"object","x-component":"SchemaConfig",default:null}}},forms:{type:"object",default:{}}});$(this,"components",{SchemaConfigButton:Te,SchemaConfig:Be,ModeConfig:Oe,AssigneesSelect:ze})}useVariables({key:r,title:t,config:i},{types:a,fieldNames:c=p.defaultFieldNames}){var f;const d=e.useCompile(),{getCollectionFields:l}=e.useCollectionManager(),h=Object.keys((f=i.forms)!=null?f:{});if(!h.length)return null;const y=h.map(m=>{var B;const v=i.forms[m],k=p.getCollectionFieldOptions({fields:(B=v.collection)==null?void 0:B.fields,collection:v.collection,types:a,compile:d,getCollectionFields:l}),I=d(v.title)||m;return k.length?{key:m,value:m,label:I,title:I,children:k}:null}).filter(Boolean);return y.length?{[c.value]:r,[c.label]:t,[c.children]:y}:null}useInitializers(r){var c;const{getCollection:t}=e.useCollectionManager(),i=Object.keys((c=r.config.forms)!=null?c:{});if(!i.length||r.config.mode)return null;const a=i.map(d=>{var y,f;const l=r.config.forms[d],{fields:h=[]}=t(l.collection);return h.length?{name:(y=l.title)!=null?y:d,type:"item",title:(f=l.title)!=null?f:d,Component:p.CollectionBlockInitializer,collection:l.collection,dataSource:`{{$jobsMapByNodeKey.${r.key}.${d}}}`}:null}).filter(Boolean);return a.length?{name:`#${r.id}`,key:"forms",type:"subMenu",title:r.title,children:a}:null}isAvailable({engine:r,workflow:t,upstream:i,branchIndex:a}){return!r.isWorkflowSync(t)}}const Pe={title:`{{t("Task", { ns: "${C}" })}}`,name:"flow_nodes",fields:[{type:"bigInt",name:"id",interface:"m2o",uiSchema:{type:"number",title:"ID","x-component":"RemoteSelect","x-component-props":{fieldNames:{label:"title",value:"id"},service:{resource:"flow_nodes",params:{filter:{type:"manual"}}}}}},{type:"string",name:"title",interface:"input",uiSchema:{type:"string",title:'{{t("Title")}}',"x-component":"Input"}}]},Ve={title:`{{t("Workflow", { ns: "${C}" })}}`,name:"workflows",fields:[{type:"string",name:"title",interface:"input",uiSchema:{title:'{{t("Name")}}',type:"string","x-component":"Input",required:!0}}]},je={title:`{{t("Workflow todos", { ns: "${C}" })}}`,name:"users_jobs",fields:[{type:"belongsTo",name:"user",target:"users",foreignKey:"userId",interface:"m2o",uiSchema:{type:"number",title:'{{t("User")}}',"x-component":"RemoteSelect","x-component-props":{fieldNames:{label:"nickname",value:"id"},service:{resource:"users"}}}},{type:"belongsTo",name:"node",target:"flow_nodes",foreignKey:"nodeId",interface:"m2o",isAssociation:!0,uiSchema:{type:"number",title:`{{t("Task", { ns: "${C}" })}}`,"x-component":"RemoteSelect","x-component-props":{fieldNames:{label:"title",value:"id"},service:{resource:"flow_nodes"}}}},{type:"belongsTo",name:"workflow",target:"workflows",foreignKey:"workflowId",interface:"m2o",uiSchema:{type:"number",title:`{{t("Workflow", { ns: "${C}" })}}`,"x-component":"RemoteSelect","x-component-props":{fieldNames:{label:"title",value:"id"},service:{resource:"workflows"}}}},{type:"integer",name:"status",interface:"select",uiSchema:{type:"number",title:`{{t("Status", { ns: "${C}" })}}`,"x-component":"Select",enum:p.JobStatusOptions}},{name:"createdAt",type:"date",interface:"createdAt",uiSchema:{type:"datetime",title:'{{t("Created at")}}',"x-component":"DatePicker","x-component-props":{showTime:!0}}}]},Ne=b.observer(()=>{var n,r,t;const o=b.useField();return(t=(n=o==null?void 0:o.value)==null?void 0:n.title)!=null?t:`#${(r=o.value)==null?void 0:r.id}`},{displayName:"NodeColumn"}),$e=b.observer(()=>{var n,r,t;const o=b.useField();return(t=(n=o==null?void 0:o.value)==null?void 0:n.title)!=null?t:`#${(r=o.value)==null?void 0:r.id}`},{displayName:"WorkflowColumn"}),Ee=b.observer(()=>{var n,r,t;const o=b.useField();return(t=(n=o==null?void 0:o.value)==null?void 0:n.nickname)!=null?t:(r=o.value)==null?void 0:r.id},{displayName:"UserColumn"});function Ue(o){const n=e.useRecord(),r=A("Unprocessed");return n.execution.status&&!n.status?s.jsx(S.Tag,{children:r}):o.children}const K=()=>s.jsx(e.SchemaComponent,{components:{NodeColumn:Ne,WorkflowColumn:$e,UserColumn:Ee,UserJobStatusColumn:Ue},schema:{type:"void",properties:{actions:{type:"void","x-component":"ActionBar","x-component-props":{style:{marginBottom:16}},properties:{filter:{type:"void",title:'{{ t("Filter") }}',"x-action":"filter","x-designer":"Filter.Action.Designer","x-component":"Filter.Action","x-component-props":{icon:"FilterOutlined",useProps:"{{ useFilterActionProps }}"},"x-align":"left"},refresher:{type:"void",title:'{{ t("Refresh") }}',"x-action":"refresh","x-component":"Action","x-designer":"Action.Designer","x-component-props":{icon:"ReloadOutlined",useProps:"{{ useRefreshActionProps }}"},"x-align":"right"}}},table:{type:"array","x-component":"TableV2","x-component-props":{rowKey:"id",useProps:"{{ useTableBlockProps }}"},properties:{actions:{type:"void","x-decorator":"TableV2.Column.Decorator","x-component":"TableV2.Column","x-component-props":{width:60},title:'{{t("Actions")}}',properties:{view:{type:"void","x-component":"Action.Link",title:'{{t("View")}}',properties:{drawer:{"x-component":"WorkflowTodo.Drawer"}}}}},node:{type:"void","x-decorator":"TableV2.Column.Decorator","x-component":"TableV2.Column","x-component-props":{width:null},title:`{{t("Task node", { ns: "${C}" })}}`,properties:{node:{"x-component":"NodeColumn","x-read-pretty":!0}}},workflow:{type:"void","x-decorator":"TableV2.Column.Decorator","x-component":"TableV2.Column","x-component-props":{width:null},title:'{{t("Workflow", { ns: "workflow" })}}',properties:{workflow:{"x-component":"WorkflowColumn","x-read-pretty":!0}}},status:{type:"void","x-decorator":"TableV2.Column.Decorator","x-component":"TableV2.Column","x-component-props":{width:100},title:'{{t("Status", { ns: "workflow" })}}',properties:{status:{type:"number","x-decorator":"UserJobStatusColumn","x-component":"CollectionField","x-read-pretty":!0}}},user:{type:"void","x-decorator":"TableV2.Column.Decorator","x-component":"TableV2.Column","x-component-props":{width:140},title:`{{t("Assignee", { ns: "${C}" })}}`,properties:{user:{"x-component":"UserColumn","x-read-pretty":!0}}},createdAt:{type:"void","x-decorator":"TableV2.Column.Decorator","x-component":"TableV2.Column","x-component-props":{width:160},properties:{createdAt:{type:"string","x-component":"CollectionField","x-read-pretty":!0}}}}}}}});function qe(o){var h;const{data:n}=e.useCurrentUserContext(),{userJob:r}=p.useFlowContext(),{status:t,result:i,userId:a}=r,c=b.useFieldSchema(),{name:d}=c.parent.toJSON();let{children:l}=o;return t?i[d]||(l=null):((h=n==null?void 0:n.data)==null?void 0:h.id)!==a&&(l=null),l}const _e=u.createContext(null);function Ge({value:o,children:n}){const{userJob:r,execution:t}=p.useFlowContext(),i=b.useField(),a=b.useFieldSchema();return u.useEffect(()=>{(t.status||r.status)&&(i.disabled=!0,i.visible=r.status===o&&r.result._===a.name)},[t,r,o,i,a.name]),s.jsx(_e.Provider,{value:o,children:n})}function Je(){const o=e.useAPIClient(),{setVisible:n}=e.useActionContext(),{values:r,submit:t}=b.useForm(),i=b.useFieldSchema(),{service:a}=e.useTableBlockContext(),{userJob:c,execution:d}=p.useFlowContext(),{name:l}=i,{name:h}=i.parent.parent;return{run(){return E(this,null,function*(){d.status||c.status||(yield t(),yield o.resource("users_jobs").submit({filterByTk:c.id,values:{result:{[h]:r,_:l}}}),n(!1),a.refresh())})}}}function Ke(o){var y;const n=e.usePlugin(p),r=e.useAPIClient(),{id:t}=e.useRecord(),[i,a]=u.useState(null),[c,d]=u.useState(null);u.useEffect(()=>{var f,m;t&&((m=(f=r.resource("users_jobs")).get)==null||m.call(f,{filterByTk:t,appends:["node","job","workflow","workflow.nodes","execution","execution.jobs"]}).then(({data:v})=>{var w;const z=(w=v==null?void 0:v.data)!=null?w:{},{node:k,workflow:N={}}=z,oe=N,{nodes:I=[]}=oe,B=M(oe,["nodes"]),te=z,{execution:O}=te,D=M(te,["node","workflow","execution"]);p.linkNodes(I),d(k),a({userJob:D,workflow:B,nodes:I,execution:O})}))},[r,t]);const h=p.useAvailableUpstreams(i==null?void 0:i.nodes.find(f=>f.id===c.id)).reduce((f,{type:m})=>Object.assign(f,n.instructions.get(m).components),{});return c&&i?s.jsx(p.FlowContext.Provider,{value:i,children:s.jsx(e.SchemaComponent,{components:g(g({FormBlockProvider:Y,DetailsBlockProvider:Q,ActionBarProvider:qe,ManualActionStatusProvider:Ge},Array.from(V.getValues()).reduce((f,m)=>Object.assign(f,m.block.components),{})),h),scope:g({useSubmit:Je,useFormBlockProps:Le,useDetailsBlockProps:Qe},Array.from(V.getValues()).reduce((f,m)=>Object.assign(f,m.block.scope),{})),schema:{type:"void",name:"tabs","x-component":"Tabs",properties:(y=c.config)==null?void 0:y.schema}})}):s.jsx(S.Spin,{})}function Le(){var c;const{userJob:o,execution:n}=p.useFlowContext(),r=e.useRecord(),{data:t}=e.useCurrentUserContext(),{form:i}=e.useFormBlockContext(),a=n.status||o.status?r?"readPretty":"disabled":((c=t==null?void 0:t.data)==null?void 0:c.id)!==o.userId?"disabled":"editable";return u.useEffect(()=>{i==null||i.setPattern(a)},[a,i]),{form:i}}function Qe(){const{form:o}=e.useFormBlockContext();return{form:o}}function Ye(){const o=e.useCompile(),{status:n,updatedAt:r}=e.useRecord(),t=p.JobStatusOptionsMap[n];return n?s.jsxs(S.Space,{children:[s.jsx("time",{className:e.css`
|
|
12
12
|
margin-right: 0.5em;
|
|
13
|
-
`,children:se(r).format("YYYY-MM-DD HH:mm:ss")}),s.jsx(
|
|
13
|
+
`,children:se(r).format("YYYY-MM-DD HH:mm:ss")}),s.jsx(S.Tag,{icon:t.icon,color:t.color,children:o(t.label)})]}):null}function He(){var a;const o=u.useContext(e.SchemaComponentContext),{id:n,node:r,workflow:t,status:i}=e.useRecord();return s.jsx(e.SchemaComponentContext.Provider,{value:F(g({},o),{reset(){},designable:!1}),children:s.jsx(e.SchemaComponent,{components:{FooterStatus:Ye,FlowContextProvider:Ke},schema:{type:"void",name:`drawer-${n}-${i}`,"x-component":"Action.Drawer","x-component-props":{className:"nb-action-popup"},title:`${t.title} - ${(a=r.title)!=null?a:`#${r.id}`}`,properties:{tabs:{type:"void","x-component":"FlowContextProvider"},footer:{type:"void","x-component":"Action.Drawer.Footer",properties:{content:{type:"void","x-component":"FooterStatus"}}}}}})})}function Xe({params:o={},children:n}){const a=e.useCollectionManager(),{collections:r}=a,t=M(a,["collections"]),i={collection:"users_jobs",resource:"users_jobs",action:"list",params:F(g({pageSize:20,sort:["-createdAt"]},o),{appends:["user","node","workflow","execution.status"],except:["node.config","workflow.config","workflow.options"]}),rowKey:"id",showIndex:!0,dragSort:!1};return s.jsx(e.CollectionManagerProvider,F(g({},t),{collections:[...r,Pe,Ve,je],children:s.jsx(e.TableBlockProvider,F(g({name:"workflow-todo"},i),{children:n}))}))}K.Drawer=He,K.Decorator=Xe;const Ze=()=>{const o=e.useSchemaInitializerItem(),{insert:n}=e.useSchemaInitializer();return s.jsx(e.SchemaInitializerItem,F(g({icon:s.jsx(_.TableOutlined,{})},o),{onClick:()=>{n({type:"void","x-decorator":"WorkflowTodo.Decorator","x-decorator-props":{},"x-component":"CardItem","x-designer":"TableBlockDesigner",properties:{todos:{type:"void","x-component":"WorkflowTodo"}}})}}))};class We extends e.Plugin{afterAdd(){return E(this,null,function*(){})}load(){return E(this,null,function*(){this.addComponents(),this.app.pm.get("workflow").registerInstruction("manual",Me),this.app.schemaInitializerManager.add(ve),this.app.schemaInitializerManager.add(we),this.app.schemaInitializerManager.add(he),this.app.schemaInitializerManager.get("BlockInitializers").add("otherBlocks.workflowTodos",{title:`{{t("Workflow todos", { ns: "${C}" })}}`,Component:"WorkflowTodoBlockInitializer",icon:"CheckSquareOutlined"})})}addComponents(){this.app.addComponents({WorkflowTodo:K,WorkflowTodoBlockInitializer:Ze})}}x.default=We,Object.defineProperties(x,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}})});
|
|
@@ -80,4 +80,10 @@ export default class extends Instruction {
|
|
|
80
80
|
}[];
|
|
81
81
|
};
|
|
82
82
|
useInitializers(node: any): SchemaInitializerItemType | null;
|
|
83
|
+
isAvailable({ engine, workflow, upstream, branchIndex }: {
|
|
84
|
+
engine: any;
|
|
85
|
+
workflow: any;
|
|
86
|
+
upstream: any;
|
|
87
|
+
branchIndex: any;
|
|
88
|
+
}): boolean;
|
|
83
89
|
}
|
package/dist/externalVersion.js
CHANGED
|
@@ -3,16 +3,16 @@ module.exports = {
|
|
|
3
3
|
"@formily/react": "2.3.0",
|
|
4
4
|
"antd": "5.12.8",
|
|
5
5
|
"dayjs": "1.11.10",
|
|
6
|
-
"@nocobase/client": "0.19.0-alpha.
|
|
7
|
-
"@nocobase/plugin-workflow": "0.19.0-alpha.
|
|
6
|
+
"@nocobase/client": "0.19.0-alpha.4",
|
|
7
|
+
"@nocobase/plugin-workflow": "0.19.0-alpha.4",
|
|
8
8
|
"@ant-design/icons": "5.2.6",
|
|
9
9
|
"react-i18next": "11.18.6",
|
|
10
|
-
"@nocobase/utils": "0.19.0-alpha.
|
|
11
|
-
"@nocobase/server": "0.19.0-alpha.
|
|
12
|
-
"@nocobase/actions": "0.19.0-alpha.
|
|
13
|
-
"@nocobase/resourcer": "0.19.0-alpha.
|
|
10
|
+
"@nocobase/utils": "0.19.0-alpha.4",
|
|
11
|
+
"@nocobase/server": "0.19.0-alpha.4",
|
|
12
|
+
"@nocobase/actions": "0.19.0-alpha.4",
|
|
13
|
+
"@nocobase/resourcer": "0.19.0-alpha.4",
|
|
14
14
|
"@formily/core": "2.3.0",
|
|
15
15
|
"@formily/antd-v5": "1.1.9",
|
|
16
|
-
"@nocobase/database": "0.19.0-alpha.
|
|
16
|
+
"@nocobase/database": "0.19.0-alpha.4",
|
|
17
17
|
"lodash": "4.17.21"
|
|
18
18
|
};
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
{
|
|
2
|
+
"Manual": "수동",
|
|
3
|
+
"Could be used for manually submitting data, and determine whether to continue or exit. Workflow will generate a todo item for assigned user when it reaches a manual node, and continue processing after user submits the form.":
|
|
4
|
+
"수동으로 데이터를 제출하고 계속 진행할지 종료할지를 결정하는 데 사용될 수 있습니다. 워크플로우가 수동 노드에 도달하면 지정된 사용자에 대해 할 일 항목을 생성하고 사용자가 양식을 제출한 후 처리를 계속합니다.",
|
|
5
|
+
"Values preset in this form will override user submitted ones when continue or reject.":
|
|
6
|
+
"이 양식에 사전 설정된 값은 계속 또는 거부될 때 사용자가 제출한 값이 덮어씁니다.",
|
|
7
|
+
"Assignee": "담당자",
|
|
8
|
+
"Assignees": "담당자",
|
|
9
|
+
"User interface": "사용자 인터페이스",
|
|
10
|
+
"Configure user interface": "사용자 인터페이스 구성",
|
|
11
|
+
"View user interface": "사용자 인터페이스 보기",
|
|
12
|
+
"Separately": "별도로",
|
|
13
|
+
"Each user has own task": "각 사용자는 고유한 작업을 갖습니다.",
|
|
14
|
+
"Collaboratively": "협력하여",
|
|
15
|
+
"Everyone shares one task": "모두가 하나의 작업을 공유합니다.",
|
|
16
|
+
"Negotiation": "협상",
|
|
17
|
+
"All pass": "모두 통과",
|
|
18
|
+
"Everyone should pass": "모든 사람이 통과해야 합니다.",
|
|
19
|
+
"Any pass": "어떤 통과",
|
|
20
|
+
"Anyone pass": "누구든 통과하면 됩니다.",
|
|
21
|
+
"Field name existed in form": "양식에 이미 존재하는 필드 이름",
|
|
22
|
+
"Continue the process": "프로세스 계속 진행",
|
|
23
|
+
"Terminate the process": "프로세스 종료",
|
|
24
|
+
"Save temporarily": "임시로 저장",
|
|
25
|
+
"Custom form": "사용자 정의 양식",
|
|
26
|
+
"Data record": "데이터 레코드",
|
|
27
|
+
"Create record form": "레코드 생성 양식",
|
|
28
|
+
"Update record form": "레코드 업데이트 양식",
|
|
29
|
+
"Filter settings": "필터 설정",
|
|
30
|
+
"Workflow todos": "워크플로우 할 일",
|
|
31
|
+
"Task node": "작업 노드"
|
|
32
|
+
}
|
package/dist/locale/zh-CN.json
CHANGED
|
@@ -105,6 +105,7 @@ class ManualInstruction_default extends import_plugin_workflow.Instruction {
|
|
|
105
105
|
status: import_plugin_workflow.JOB_STATUS.PENDING,
|
|
106
106
|
result: mode ? [] : null,
|
|
107
107
|
nodeId: node.id,
|
|
108
|
+
nodeKey: node.key,
|
|
108
109
|
upstreamId: (prevJob == null ? void 0 : prevJob.id) ?? null
|
|
109
110
|
});
|
|
110
111
|
const UserJobModel = this.workflow.app.db.getModel("users_jobs");
|
package/package.json
CHANGED
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
"displayName.zh-CN": "工作流:人工处理节点",
|
|
5
5
|
"description": "Could be used for workflows which some of decisions are made by users.",
|
|
6
6
|
"description.zh-CN": "用于人工控制部分决策的流程。",
|
|
7
|
-
"version": "0.19.0-alpha.
|
|
7
|
+
"version": "0.19.0-alpha.4",
|
|
8
8
|
"license": "AGPL-3.0",
|
|
9
9
|
"main": "./dist/server/index.js",
|
|
10
10
|
"devDependencies": {
|
|
@@ -28,5 +28,5 @@
|
|
|
28
28
|
"@nocobase/test": "0.x",
|
|
29
29
|
"@nocobase/utils": "0.x"
|
|
30
30
|
},
|
|
31
|
-
"gitHead": "
|
|
31
|
+
"gitHead": "9583023f7bea828da5192384a5c002782c341b65"
|
|
32
32
|
}
|
|
@@ -31,7 +31,7 @@ import WorkflowPlugin, {
|
|
|
31
31
|
import { DetailsBlockProvider } from './instruction/DetailsBlockProvider';
|
|
32
32
|
import { FormBlockProvider } from './instruction/FormBlockProvider';
|
|
33
33
|
import { ManualFormType, manualFormTypes } from './instruction/SchemaConfig';
|
|
34
|
-
import { NAMESPACE } from '../locale';
|
|
34
|
+
import { NAMESPACE, useLang } from '../locale';
|
|
35
35
|
|
|
36
36
|
const nodeCollection = {
|
|
37
37
|
title: `{{t("Task", { ns: "${NAMESPACE}" })}}`,
|
|
@@ -211,6 +211,15 @@ const UserColumn = observer(
|
|
|
211
211
|
{ displayName: 'UserColumn' },
|
|
212
212
|
);
|
|
213
213
|
|
|
214
|
+
function UserJobStatusColumn(props) {
|
|
215
|
+
const record = useRecord();
|
|
216
|
+
const labelUnprocessed = useLang('Unprocessed');
|
|
217
|
+
if (record.execution.status && !record.status) {
|
|
218
|
+
return <Tag>{labelUnprocessed}</Tag>;
|
|
219
|
+
}
|
|
220
|
+
return props.children;
|
|
221
|
+
}
|
|
222
|
+
|
|
214
223
|
export const WorkflowTodo: React.FC & { Drawer: React.FC; Decorator: React.FC } = () => {
|
|
215
224
|
return (
|
|
216
225
|
<SchemaComponent
|
|
@@ -218,6 +227,7 @@ export const WorkflowTodo: React.FC & { Drawer: React.FC; Decorator: React.FC }
|
|
|
218
227
|
NodeColumn,
|
|
219
228
|
WorkflowColumn,
|
|
220
229
|
UserColumn,
|
|
230
|
+
UserJobStatusColumn,
|
|
221
231
|
}}
|
|
222
232
|
schema={{
|
|
223
233
|
type: 'void',
|
|
@@ -326,6 +336,8 @@ export const WorkflowTodo: React.FC & { Drawer: React.FC; Decorator: React.FC }
|
|
|
326
336
|
title: `{{t("Status", { ns: "workflow" })}}`,
|
|
327
337
|
properties: {
|
|
328
338
|
status: {
|
|
339
|
+
type: 'number',
|
|
340
|
+
'x-decorator': 'UserJobStatusColumn',
|
|
329
341
|
'x-component': 'CollectionField',
|
|
330
342
|
'x-read-pretty': true,
|
|
331
343
|
},
|
|
@@ -400,16 +412,16 @@ function ActionBarProvider(props) {
|
|
|
400
412
|
const ManualActionStatusContext = createContext<number | null>(null);
|
|
401
413
|
|
|
402
414
|
function ManualActionStatusProvider({ value, children }) {
|
|
403
|
-
const { userJob } = useFlowContext();
|
|
415
|
+
const { userJob, execution } = useFlowContext();
|
|
404
416
|
const button = useField();
|
|
405
417
|
const buttonSchema = useFieldSchema();
|
|
406
418
|
|
|
407
419
|
useEffect(() => {
|
|
408
|
-
if (userJob.status) {
|
|
420
|
+
if (execution.status || userJob.status) {
|
|
409
421
|
button.disabled = true;
|
|
410
422
|
button.visible = userJob.status === value && userJob.result._ === buttonSchema.name;
|
|
411
423
|
}
|
|
412
|
-
}, [userJob, value, button, buttonSchema.name]);
|
|
424
|
+
}, [execution, userJob, value, button, buttonSchema.name]);
|
|
413
425
|
|
|
414
426
|
return <ManualActionStatusContext.Provider value={value}>{children}</ManualActionStatusContext.Provider>;
|
|
415
427
|
}
|
|
@@ -420,12 +432,12 @@ function useSubmit() {
|
|
|
420
432
|
const { values, submit } = useForm();
|
|
421
433
|
const buttonSchema = useFieldSchema();
|
|
422
434
|
const { service } = useTableBlockContext();
|
|
423
|
-
const { userJob } = useFlowContext();
|
|
435
|
+
const { userJob, execution } = useFlowContext();
|
|
424
436
|
const { name: actionKey } = buttonSchema;
|
|
425
437
|
const { name: formKey } = buttonSchema.parent.parent;
|
|
426
438
|
return {
|
|
427
439
|
async run() {
|
|
428
|
-
if (userJob.status) {
|
|
440
|
+
if (execution.status || userJob.status) {
|
|
429
441
|
return;
|
|
430
442
|
}
|
|
431
443
|
await submit();
|
|
@@ -456,7 +468,7 @@ function FlowContextProvider(props) {
|
|
|
456
468
|
.resource('users_jobs')
|
|
457
469
|
.get?.({
|
|
458
470
|
filterByTk: id,
|
|
459
|
-
appends: ['node', 'workflow', 'workflow.nodes', 'execution', 'execution.jobs'],
|
|
471
|
+
appends: ['node', 'job', 'workflow', 'workflow.nodes', 'execution', 'execution.jobs'],
|
|
460
472
|
})
|
|
461
473
|
.then(({ data }) => {
|
|
462
474
|
const { node, workflow: { nodes = [], ...workflow } = {}, execution, ...userJob } = data?.data ?? {};
|
|
@@ -517,18 +529,19 @@ function FlowContextProvider(props) {
|
|
|
517
529
|
}
|
|
518
530
|
|
|
519
531
|
function useFormBlockProps() {
|
|
520
|
-
const { userJob } = useFlowContext();
|
|
532
|
+
const { userJob, execution } = useFlowContext();
|
|
521
533
|
const record = useRecord();
|
|
522
534
|
const { data: user } = useCurrentUserContext();
|
|
523
535
|
const { form } = useFormBlockContext();
|
|
524
536
|
|
|
525
|
-
const pattern =
|
|
526
|
-
|
|
527
|
-
?
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
|
|
531
|
-
|
|
537
|
+
const pattern =
|
|
538
|
+
execution.status || userJob.status
|
|
539
|
+
? record
|
|
540
|
+
? 'readPretty'
|
|
541
|
+
: 'disabled'
|
|
542
|
+
: user?.data?.id !== userJob.userId
|
|
543
|
+
? 'disabled'
|
|
544
|
+
: 'editable';
|
|
532
545
|
|
|
533
546
|
useEffect(() => {
|
|
534
547
|
form?.setPattern(pattern);
|
|
@@ -613,7 +626,7 @@ function Decorator({ params = {}, children }) {
|
|
|
613
626
|
pageSize: 20,
|
|
614
627
|
sort: ['-createdAt'],
|
|
615
628
|
...params,
|
|
616
|
-
appends: ['user', 'node', 'workflow'],
|
|
629
|
+
appends: ['user', 'node', 'workflow', 'execution.status'],
|
|
617
630
|
except: ['node.config', 'workflow.config', 'workflow.options'],
|
|
618
631
|
},
|
|
619
632
|
rowKey: 'id',
|
package/src/client/index.ts
CHANGED
|
@@ -20,8 +20,7 @@ export default class extends Plugin {
|
|
|
20
20
|
|
|
21
21
|
// this.app.addProvider(Provider);
|
|
22
22
|
const workflow = this.app.pm.get('workflow') as WorkflowPlugin;
|
|
23
|
-
|
|
24
|
-
workflow.instructions.register(manualInstruction.type, manualInstruction);
|
|
23
|
+
workflow.registerInstruction('manual', Manual);
|
|
25
24
|
|
|
26
25
|
this.app.schemaInitializerManager.add(addBlockButton);
|
|
27
26
|
this.app.schemaInitializerManager.add(addActionButton);
|
|
@@ -416,7 +416,6 @@ export function SchemaConfig({ value, onChange }) {
|
|
|
416
416
|
const nodeComponents = {};
|
|
417
417
|
nodes.forEach((item) => {
|
|
418
418
|
const instruction = workflowPlugin.instructions.get(item.type);
|
|
419
|
-
Object.assign(nodeInitializers, instruction.initializers);
|
|
420
419
|
Object.assign(nodeComponents, instruction.components);
|
|
421
420
|
});
|
|
422
421
|
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { SchemaInitializerItemType, useCollectionManager, useCompile } from '@nocobase/client';
|
|
1
|
+
import { SchemaInitializerItemType, useCollectionManager, useCompile, usePlugin } from '@nocobase/client';
|
|
2
2
|
|
|
3
|
-
import {
|
|
3
|
+
import WorkflowPlugin, {
|
|
4
4
|
defaultFieldNames,
|
|
5
5
|
getCollectionFieldOptions,
|
|
6
6
|
CollectionBlockInitializer,
|
|
@@ -154,4 +154,7 @@ export default class extends Instruction {
|
|
|
154
154
|
}
|
|
155
155
|
: null;
|
|
156
156
|
}
|
|
157
|
+
isAvailable({ engine, workflow, upstream, branchIndex }) {
|
|
158
|
+
return !engine.isWorkflowSync(workflow);
|
|
159
|
+
}
|
|
157
160
|
}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
{
|
|
2
|
+
"Manual": "수동",
|
|
3
|
+
"Could be used for manually submitting data, and determine whether to continue or exit. Workflow will generate a todo item for assigned user when it reaches a manual node, and continue processing after user submits the form.":
|
|
4
|
+
"수동으로 데이터를 제출하고 계속 진행할지 종료할지를 결정하는 데 사용될 수 있습니다. 워크플로우가 수동 노드에 도달하면 지정된 사용자에 대해 할 일 항목을 생성하고 사용자가 양식을 제출한 후 처리를 계속합니다.",
|
|
5
|
+
"Values preset in this form will override user submitted ones when continue or reject.":
|
|
6
|
+
"이 양식에 사전 설정된 값은 계속 또는 거부될 때 사용자가 제출한 값이 덮어씁니다.",
|
|
7
|
+
"Assignee": "담당자",
|
|
8
|
+
"Assignees": "담당자",
|
|
9
|
+
"User interface": "사용자 인터페이스",
|
|
10
|
+
"Configure user interface": "사용자 인터페이스 구성",
|
|
11
|
+
"View user interface": "사용자 인터페이스 보기",
|
|
12
|
+
"Separately": "별도로",
|
|
13
|
+
"Each user has own task": "각 사용자는 고유한 작업을 갖습니다.",
|
|
14
|
+
"Collaboratively": "협력하여",
|
|
15
|
+
"Everyone shares one task": "모두가 하나의 작업을 공유합니다.",
|
|
16
|
+
"Negotiation": "협상",
|
|
17
|
+
"All pass": "모두 통과",
|
|
18
|
+
"Everyone should pass": "모든 사람이 통과해야 합니다.",
|
|
19
|
+
"Any pass": "어떤 통과",
|
|
20
|
+
"Anyone pass": "누구든 통과하면 됩니다.",
|
|
21
|
+
"Field name existed in form": "양식에 이미 존재하는 필드 이름",
|
|
22
|
+
"Continue the process": "프로세스 계속 진행",
|
|
23
|
+
"Terminate the process": "프로세스 종료",
|
|
24
|
+
"Save temporarily": "임시로 저장",
|
|
25
|
+
"Custom form": "사용자 정의 양식",
|
|
26
|
+
"Data record": "데이터 레코드",
|
|
27
|
+
"Create record form": "레코드 생성 양식",
|
|
28
|
+
"Update record form": "레코드 업데이트 양식",
|
|
29
|
+
"Filter settings": "필터 설정",
|
|
30
|
+
"Workflow todos": "워크플로우 할 일",
|
|
31
|
+
"Task node": "작업 노드"
|
|
32
|
+
}
|
package/src/locale/zh-CN.json
CHANGED