@asaleh37/ui-base 1.2.26 → 1.2.27

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/index.mjs CHANGED
@@ -28,7 +28,7 @@ object-assign
28
28
  * This source code is licensed under the MIT license found in the
29
29
  * LICENSE file in the root directory of this source tree.
30
30
  */
31
- function(e,i){const t=Mi(e,i);return"production"!==process.env.NODE_ENV?(...i)=>{const o=`"${e}"`;return 0===i.length?console.error([`MUI: Seems like you called \`styled(${o})()\` without a \`style\` argument.`,'You must provide a `styles` argument: `styled("div")(styleYouForgotToPass)`.'].join("\n")):i.some((e=>void 0===e))&&console.error(`MUI: the styled(${o})(...args) API requires all its args to be defined.`),t(...i)}:t}("div",{shouldForwardProp:e=>"theme"!==e&&"sx"!==e&&"as"!==e})(Ea),n=j.forwardRef((function(e,n){const l=function(e=Na){return Oa(e)}(o),{className:s,component:p="div",...c}=ya(e);return i(d,{as:p,ref:n,className:Ca(s,r?r(a):a),theme:t&&l[t]||l,...c})}));return n}({defaultClassName:function(e,i,t="Mui"){const o={};return i.forEach((i=>{o[i]=function(e,i,t="Mui"){const o=Da[i];return o?`${t}-${o}`:`${Ra.generate(e)}-${i}`}(e,i,t)})),o}("MuiBox",["root"]).root,generateClassName:Ra.generate});function Ma(e){return/^\d+$/.test(e)}function ba(e){return"number"==typeof e&&!isNaN(e)}function ga(e){return"string"==typeof e&&""!==e.trim()&&!isNaN(Number(e))}function Sa(e){return e?e.charAt(0).toUpperCase()+e.slice(1):""}function Ua(e){return/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(e)}function va(e,i){const t=new Date(e),o=new Date,a=Math.floor((t-o)/1e3),r="rtl"===i?"ar":"en",d=new Intl.RelativeTimeFormat(r,{numeric:"auto"}),n=[{unit:"year",seconds:31536e3},{unit:"month",seconds:2592e3},{unit:"week",seconds:604800},{unit:"day",seconds:86400},{unit:"hour",seconds:3600},{unit:"minute",seconds:60},{unit:"second",seconds:1}];for(const{unit:e,seconds:i}of n){const t=Math.floor(a/i);if(Math.abs(t)>1)return d.format(t,e)}return"ar"===r?"الآن":"just now"}"production"!==process.env.NODE_ENV&&(Pa.propTypes={children:oo.node,component:oo.elementType,sx:oo.oneOfType([oo.arrayOf(oo.oneOfType([oo.func,oo.object,oo.bool])),oo.func,oo.object])});const wa=e=>{const t=a((e=>e.AppLayout)),o=Ji(),[r,d]=X([]),{handleGetRequest:n}=Hi();return J((()=>{e.lookupType&&(async()=>{await n({endPointURI:"api/v1/public/system/lookup",showMask:!0,parameters:{lookupType:e.lookupType},successCallBkFn:e=>{d(e.data)},failureCallBkFn:()=>{d([])}})})()}),[e.lookupType,o.UserSession]),i(Et,{...e,options:r,displayField:"ltr"===t.appDirection?"lookupEnDisplay":"lookupArDisplay",valueField:"lookupValue"})},xa=e=>{if(e?.fieldInfo){const o=e.fieldInfo,a=e?.formManager||null,r=e?.formActions||null,d=e?.formValues||null,n=e?.fieldInfo?.fieldName||null,l=e?.fieldInfo?.fieldType||null;return o&&a&&d&&n&&l?e.hiddenFields.includes(n)?i(t,{}):i(R,{size:o?.formProps?.fieldSize||{lg:12,md:12,sm:12},sx:{padding:1,width:"100%"},children:"text"===l||"number"===l?i(dt,{...o.muiTextFieldProps,fullWidth:!0,type:l,disabled:!(!o?.disabled&&!e.disabledFields.includes(n)),hidden:o?.hidden||!1,label:o?.fieldLabel,value:d[n],onChange:e=>{let i=null;""!=e.target.value&&(i="number"===l&&ga(e.target.value)?Number(e.target.value):e.target.value),a.setValue(n,i),o?.formProps?.onValueChangeCallBack&&o?.formProps?.onValueChangeCallBack(i,a,r)},sx:{"& .MuiInputBase-root":{height:`${o?.formProps?.fieldHeight}px`||void 0},"& .MuiInputBase-input":{height:"100% !important"},...o?.formProps?.style},error:null!=a.formState.errors[n],helperText:a?.formState?.errors[n]?.message?.toString()}):"date"===o?.fieldType?i(Lt,{format:o?.dateFormat||It,sx:o?.formProps?.style||{width:"100%"},disabled:!(!o?.disabled&&!e.disabledFields.includes(n)),label:o?.fieldLabel,onChangeCallBack:e=>{a.setValue(n,e),o?.formProps?.onValueChangeCallBack&&o?.formProps?.onValueChangeCallBack(e,a,r)},value:d[n],error:null!=a.formState.errors[n],errorMessage:a?.formState?.errors[n]?.message?.toString()}):"datetime"===o?.fieldType?i(Ct,{format:o?.dateFormat||Ot,sx:o?.formProps?.style||{width:"100%"},disabled:!(!o?.disabled&&!e.disabledFields.includes(n)),label:o?.fieldLabel,onChangeCallBack:e=>{a.setValue(n,e),o?.formProps?.onValueChangeCallBack&&o?.formProps?.onValueChangeCallBack(e,a,r)},value:d[n],error:null!=a.formState.errors[n],errorMessage:a?.formState?.errors[n]?.message?.toString()}):"checkbox"===o?.fieldType?i(ft,{label:o?.fieldLabel,onChangeCallBack:e=>{a.setValue(n,e),o?.formProps?.onValueChangeCallBack&&o?.formProps?.onValueChangeCallBack(e,a,r)},value:d[n],checkedValue:o?.checkedValue||!0,unCheckedValue:o?.unCheckedValue||!1,disabled:!(!o?.disabled&&!e.disabledFields.includes(n)),sx:o?.formProps?.style}):"combobox"===o?.fieldType?i(Et,{sx:o?.formProps?.style||{width:"100%"},label:o?.fieldLabel,disabled:!(!o?.disabled&&!e.disabledFields.includes(n)),onChangeCallBack:(e,i)=>{let t=null;e&&(t=e+""),a.setValue(n,t),o?.formProps?.onValueChangeCallBack&&o?.formProps?.onValueChangeCallBack(t,a,r,i)},options:o?.options||[],displayField:o?.optionDisplayField||"",valueField:o?.optionValueField||"",value:d[n],errorMessage:a?.formState?.errors[n]?.message?.toString()}):"lookup"===o?.fieldType?i(wa,{sx:o?.formProps?.style||{width:"100%"},label:o?.fieldLabel,disabled:!(!o?.disabled&&!e.disabledFields.includes(n)),onChangeCallBack:(e,i)=>{let t=null;e&&(t=e+""),a.setValue(n,t),o?.formProps?.onValueChangeCallBack&&o?.formProps?.onValueChangeCallBack(t,a,r,i)},lookupType:o.lookupType,value:d[n],errorMessage:a?.formState?.errors[n]?.message?.toString()}):null}):i(t,{})}return i(t,{})},Fa=o=>{const a=Ji(),{ConfirmationWindow:r,setOpen:d}=Xi({body:o?.confirmationMessage||"",title:"Confirmation",onConfirmationCallBk:()=>{o?.actionFn(o?.record)}});return null==o?.authority||a.isUserAuthorized(o.authority)?e(t,{children:[i(r,{}),e(A,{variant:o?.formActionProps?.actionButtonVariant,color:o?.formActionProps?.actionButtonColor,onClick:()=>{if(o?.actionFn){if(o?.preActionValidation&&!o.preActionValidation(o.record))return;!0===o?.isConfirmationRequired?d(!0):o?.actionFn(o.record)}},children:[o?.icon?i(le,{icon:o.icon,style:{marginRight:5,marginLeft:5}}):i(t,{}),i("div",{children:o?.label})]})]}):i(t,{})},Ba=o=>{const{t:a}=_e();return i(t,{children:e(R,{container:!0,sx:o?.style,alignItems:"flex-start",children:[o?.label?i(R,{size:12,sx:{padding:1,fontWeight:"bold",display:"flex",alignItems:"center",justifyContent:"flex-start"},children:o?.icon?e(t,{children:[i(le,{icon:o.icon,style:{marginRight:5,marginLeft:5}}),i("div",{children:a(o.label)})]}):i(t,{children:a(o.label)})}):i(t,{}),o?.elements?o.elements.map((e=>"group"===e.type?i(Ba,{...e.props,formManager:o.formManager,formValues:o.formValues,formActions:o.formActions,hiddenFields:o.hiddenFields,disabledFields:o.disabledFields}):"field"===e.type&&"props"===e.mode?i(xa,{fieldInfo:e.props,formManager:o.formManager,formValues:o.formValues,formActions:o.formActions,hiddenFields:o.hiddenFields,disabledFields:o.disabledFields}):"field"===e.type&&"node"===e.mode?i(R,{size:e?.props?.formProps?.fieldSize||{lg:3,md:6,sm:12},sx:{padding:1,width:"100%"},children:i(e.node,{formManager:o.formManager,formValues:o.formValues,formActions:o.formActions})}):void 0)):null,o?.actions?i(R,{size:{sm:12},sx:{padding:1},children:o.actions.map((e=>i(Fa,{...e,record:o.formValues})))}):i(t,{})]})})},ka=e=>({...e,type:"string",renderEditCell:e=>i(Ct,{sx:{width:"100%"},label:"",value:e.value,onChangeCallBack:i=>{e.api.setEditCellValue({id:e.id,field:e.field,value:i})}}),valueParser:(e,i,t)=>{let o=null;return null!==e&&(o=xe(e).format(Ot)),o},valueFormatter:(e,i,t)=>i[t.field]}),Wa=e=>({...e,type:"custom",valueGetter:e=>e?e+"":e,renderCell:e=>{let t=null;try{t=e.colDef.options.find((i=>i[e.colDef.valueField]==e.value))}catch(e){}return i("div",{children:null!=t?t[e.colDef.displayField]:e.value})},renderEditCell:e=>i(Et,{...e,sx:{width:"100%"},options:e.colDef.options,valueField:e.colDef.valueField,displayField:e.colDef.displayField,onChangeCallBack:(i,t)=>{null===i&&e.api.setEditCellValue({id:e.id,field:e.field,value:null}),e.api.setEditCellValue({id:e.id,field:e.field,value:i+""})}})}),Ga=e=>({...e,type:"custom",valueGetter:e=>null==e||null==e?null:e,renderCell:t=>{const o=t?.value;return o===e.checkedValue||"true"===o||1===o||!0===o?i(le,{icon:"check",color:"green"}):i(le,{icon:"xmark",color:"red"})},renderEditCell:t=>i(ft,{...t,checkedValue:e?.checkedValue||!0,unCheckedValue:e?.unCheckedValue||!1,onChangeCallBack:e=>{t.api.setEditCellValue({id:t.id,field:t.field,value:e})}})}),Ya=e=>{const i=[];if("field"===e.type&&"props"===e.mode&&e?.props)i.push(e.props);else if("group"===e.type&&e?.props&&e?.props?.elements)for(const t of e.props.elements)i.push(...Ya(t));return i},Va=e=>{const i=[];for(const t of e)i.push(...Ya(t));return i},qa=e=>{const i={};for(const t of e)if(t?.fieldName){const e=t.fieldName;"number"===t.fieldType?i[e]=!0===t?.required?Fe.number({required_error:"This field is required",invalid_type_error:"This field must be a number"}):Fe.number().optional().nullable():"checkbox"===t.fieldType?i[e]=!0===t?.required?Fe.boolean({required_error:"This field is required"}):Fe.boolean().optional().nullable():i[e]=!0===t?.required?Fe.string({message:"This field is required"}).min(1,"This field is required"):Fe.string().optional().nullable()}return i},Ka=e=>{let t=a((e=>e.AppInfo.value.apiBaseUrl))+"/api/v1/attachment/";e?.attachmentId?t+="download?attachmentId="+e.attachmentId:(t+=`downloadImage?attachmentCode=${e.attachmentCode}&refKey=${e.refKey}`,e?.category&&(t+=`&category=${e.category}`));const[o,r]=X(t);return e?.showAsAvatar?i(b,{src:o,sx:e.style}):i("img",{src:o,alt:"image",onError:()=>r("/no_image.png"),style:{width:"100%",height:"100%",objectFit:"cover",display:"block"}})},Ha=o=>{const{handleGetRequest:a,handleDeleteRequest:r}=Hi(),{isUserAuthorized:d}=Ji();let n=!0;o?.downloadAuthorityKey&&(n=d(o.downloadAuthorityKey));const{ConfirmationWindow:l,setOpen:s}=Xi({title:"Confirmation",body:"Are you sure you want to delete this attachment?",onConfirmationCallBk:()=>{(async()=>{await r({endPointURI:"api/v1/attachment/archive",parameters:{attachmentCode:o.attachmentCode,refKey:o.refKey,attachmentId:o.id},successCallBkFn:e=>{o.setAttachmentConfig(e.data)},showMask:!0})})()}});return e(t,{children:[i(l,{}),e(Ee,{sx:{width:300,border:"0.5px solid gray"},children:[i(Qe,{sx:{height:140,width:300,display:"flex",alignItems:"center",justifyContent:"center"},children:o?.docType.toLocaleLowerCase().includes("image")?i(Ka,{attachmentId:o.id}):i(le,{icon:"file",size:"3x"})}),e(ze,{children:[i(Me,{gutterBottom:!0,variant:"h6",component:"div",children:o.fileName}),i(Me,{variant:"body2",sx:{color:"text.secondary"},children:`File Size: ${o?.attachmentSize||"unknown"} kb`}),i(Me,{variant:"body2",sx:{color:"text.secondary"},children:`File Type: ${o?.category||"NA"}`}),i(Me,{variant:"body2",sx:{color:"text.secondary"},children:o.remark})]}),e(He,{children:[o?.allowDelete?i(N,{size:"small",onClick:()=>{s(!0)},children:i(g,{title:"Delete Attachment",children:i(le,{icon:"trash"})})}):i(t,{}),i("div",{style:{flex:1}}),n?i(N,{size:"small",onClick:async()=>{await a({endPointURI:"api/v1/attachment/download",parameters:{attachmentId:o.id},showMask:!0,responseType:"blob",successCallBkFn:e=>{const i=window.URL.createObjectURL(new Blob([e.data])),t=document.createElement("a");t.href=i,t.setAttribute("download",o.fileName),document.body.appendChild(t),t.click(),t.remove()}})},children:i(g,{title:"Download Attachment",children:i(le,{icon:"download"})})}):i(t,{})]})]})]})},za=o=>{const{handleUploadRequest:a,handleGetRequest:r}=Hi(),[d,n]=X(null),[l,s]=X([]),[p,c]=X(null),[m,T]=X(null),[u,_]=X([]),[f,E]=X(null),{isUserAuthorized:I}=Ji(),O=e=>e.split(".").pop()?.toLowerCase()||"";J((()=>{(async()=>{await r({endPointURI:"api/v1/attachment/info",showMask:!0,parameters:{attachmentCode:o.attachmentCode,refKey:o.refKey},successCallBkFn:e=>{E(e.data)}})})()}),[o.refKey,o.attachmentCode]),J((()=>{if(_(f?.allowedFileTypes?f.allowedFileTypes.split(","):[]),f?.attachmentCategories){const e=[];for(const i of f.attachmentCategories.split(","))e.push({value:i});s(e)}else s([])}),[f]);let N=!0;f?.downloadAuthorityKey&&!I(f?.downloadAuthorityKey)&&(N=!1);let h=!0;return!1===o?.enableAttachment&&(h=!1),f?.uploadAuthorityKey&&!I(f.uploadAuthorityKey)&&(h=!1),e(y,{sx:{display:"flex",flexDirection:"column",width:"100%",alignItems:"center",justifyContent:"flex-start",overflow:"hidden",flexGrow:1},children:[i(t,h?{children:null==f?.maxAllowedNumberOfFiles||f?.maxAllowedNumberOfFiles>f.refKeyAttachments.length?e(t,{children:[e("h3",{children:[i(le,{icon:"paperclip",style:{marginRight:10,marginLeft:10}}),"Attachment Uploader"]}),i("input",{type:"file",style:{margin:20},accept:f?.allowedFileTypes,multiple:!0,onChange:e=>{if(e.target.files)for(const i of e.target.files){const e=O(i.name);if(u.length>0&&!u.includes(e))return void ce.error(e+" is not allowed")}n(e.target.files)}}),l.length>0?i(Et,{label:"Attachment Type",sx:{width:300,m:1},options:l,displayField:"value",valueField:"value",value:m,onChangeCallBack:e=>{T(e)}}):i(t,{}),i(dt,{label:"Remark",value:p,onChange:e=>c(e.target.value),multiline:!0,sx:{width:300,m:1},rows:3}),i(A,{sx:{m:1},variant:"contained",onClick:async()=>{let e=f?.refKeyAttachments.length||0;f?.maxAllowedNumberOfFiles&&d.length+e>f.maxAllowedNumberOfFiles?ce.error("Maximum number of attachments is "+f.maxAllowedNumberOfFiles):!0===f?.isCategoryRequired&&l.length>0&&(null==m||void 0===m||""===m)?ce.error("You must selected document type to process your request"):d?await a({endPointURI:"api/v1/attachment/upload",showMask:!0,loadingMessage:"Uploading files ... please wait",parameters:{refKey:o.refKey,attachmentCode:o.attachmentCode,remark:p,category:m},files:d,successCallBkFn:e=>{E(e.data),n(null),T(null),c(null),ce.success("Your request has been process successfully")}}):ce.error("You must add files to upload")},children:"Upload"})]}):i(t,{})}:{}),N&&f?.refKeyAttachments?.length>0?e(t,{children:[e("h3",{children:[i(le,{style:{marginRight:10,marginLeft:10},icon:"paperclip"}),"Attachments"]}),i(R,{container:!0,spacing:2,sx:{overflow:"auto",padding:1,justifyContent:"center"},children:f?.refKeyAttachments.map((e=>i(R,{sx:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center"},children:i(Ha,{...e,attachmentCode:o.attachmentCode,setAttachmentConfig:E,downloadAuthorityKey:f.downloadAuthorityKey,allowDelete:h})})))})]}):i(t,{})]})},Qa=o=>{const r=a((e=>e.AppLayout)),{t:d}=_e();return e(y,{sx:{display:"flex",flexDirection:"column",flexGrow:1,padding:1,margin:1,alignItems:"center",justifyContent:"center"},children:[e(f,{sx:{width:"100%",display:"flex",alignItems:"center",justifyContent:"center",fontSize:18,fontWeight:"bold"},children:[i(le,{icon:"history",style:{marginRight:10,marginLeft:10}}),d("WF_ACTION_HISTORY_LABEL")]}),i(f,{sx:{flexGrow:1,width:"100%",display:"flex",flexDirection:"column",overflowY:"auto",alignItems:"center",justifyContent:"flex-start"},children:o.actionHistory.map(((a,d)=>i(t,{children:e(f,{sx:{display:"flex",alignItems:"center",justifyContent:"center",width:"100%",marginBottom:2},children:[e(f,{sx:{display:"flex",flex:1,flexDirection:"column",alignItems:"flex-end",justifyContent:"center"},children:[i(f,{sx:{marginBottom:.2},children:a.actionTime}),e(Me,{children:["via ",a.actionMethod]})]}),e(f,{sx:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",position:"relative",marginRight:2,marginLeft:2},children:[i(Ka,{showAsAvatar:!0,attachmentCode:"EMPLOYEE_PHOTOS",refKey:a?.personId+""||"0",style:{m:1,width:70,height:70}}),d!==o.actionHistory.length-1?i(f,{sx:{marginTop:11,position:"absolute"},children:"|"}):i(t,{})]}),e(f,{sx:{display:"flex",flex:1,flexDirection:"column",alignItems:"flex-start",justifyContent:"center"},children:[e(f,{sx:{width:"100%"},children:["ltr"===r.appDirection?`${a?.documentActionEnName}`:`${a?.documentActionArName}`,a?.actionComment?" - "+a.actionComment:""]}),i(f,{sx:{width:"100%"},children:"ltr"===r.appDirection?`${a?.employeeEnName}`:`${a?.employeeArName}`})]})]})})))})]})},Za=o=>{const{t:a}=_e(),r=Ji(),{ConfirmationWindow:d,setOpen:n}=Xi({body:a(o?.confirmationMessage||"ACTION_CONFIRMATION"),title:a("CONFIRMATION"),onConfirmationCallBk:async()=>{await(o?.actionFn(o.recordsToProcessActionOn,o.recordIdsToProcessActionOn)),o?.reloadData&&o.reloadData()}});let l=!0;if(o.authority&&(l=r.isUserAuthorized(o.authority)),l)return e(t,{children:[i(d,{}),e(A,{onClick:async()=>{if(o?.recordsToProcessActionOn&&o?.recordsToProcessActionOn.length>0){if(o?.preActionValidation)for(const e of o.recordsToProcessActionOn)if(!o.preActionValidation(e))return;!0===o?.isConfirmationRequired?n(!0):(await o.actionFn(o.recordsToProcessActionOn,o.recordIdsToProcessActionOn),o?.reloadData&&o.reloadData())}else ce.error(a("AT_LEAST_ONE_RECORD_SELECTED_MESSAGE"))},variant:o?.label?"outlined":o?.formActionProps?.actionButtonVariant?o.formActionProps.actionButtonVariant:"text",size:"small",color:o?.formActionProps?.actionButtonColor||"primary",children:[o?.icon?i(le,{style:{marginRight:5,marginLeft:5},icon:o.icon}):i(t,{}),o?.label?a(o.label):i(t,{})]})]})},ja=S(Ze)({display:"grid",alignItems:"center"}),$a=S(je)((({theme:e,ownerState:i})=>({gridArea:"1 / 1",width:"min-content",height:"min-content",zIndex:1,opacity:i.expanded?0:1,pointerEvents:i.expanded?"none":"auto",transition:e.transitions.create(["opacity"])}))),Xa=S(h)((({theme:e,ownerState:i})=>({gridArea:"1 / 1",overflowX:"clip",width:i.expanded?260:"var(--trigger-width)",opacity:i.expanded?1:0,transition:e.transitions.create(["width","opacity"])}))),Ja=o=>{const{t:a}=_e(),r=Ji(),d=!o?.templateProps?.editAction?.authority||r.isUserAuthorized(o.templateProps.editAction.authority),n=((e,i,t)=>{const o=[],a=[];if("exclude"===e.type&&0===e.ids.size)for(const e of i)o.push(e),a.push(e[t]);else if(e?.ids)for(const r of e.ids){const e=i.find((e=>e[t]===r));o.push(e),a.push(r)}return{selectedRecords:o,selectedRecordIds:a}})(o?.templateProps?.rowSelectionModel||{ids:new Set,type:"include"},o?.templateProps?.data||[],o?.templateProps?.keyColumnName||"id");return e($e,{children:[d&&"none"!=o?.templateProps?.editMode?.editMode?e(A,{onClick:o?.handleCreateNewRecord,children:[i(le,{icon:"add",style:{marginRight:5,marginLeft:5}}),a("ADD_BTN_LABEL")]}):i(t,{}),o?.templateProps?.rowActions?o.templateProps.rowActions.map(((e,i)=>!0===e?.gridActionProps?.multiRecord?ee(Za,{...e,key:i,reloadData:async()=>{o.templateProps.apiActions.reloadData(o?.templateProps?.gridLoadParametersValues)},recordIdsToProcessActionOn:n.selectedRecordIds,recordsToProcessActionOn:n.selectedRecords}):null)):i(t,{}),i(f,{sx:{flex:1,mx:.5},children:o?.templateProps?.tBar}),i(g,{title:"Columns",children:i(Xe,{render:i(je,{}),children:i(Je,{fontSize:"small"})})}),i(g,{title:"Filters",children:i(ei,{render:(e,t)=>i(je,{...e,color:"default",children:i(U,{badgeContent:t.filterCount,color:"primary",variant:"dot",children:i(ii,{fontSize:"small"})})})})}),o?.templateProps?.gridStateKey?i(g,{title:a("RESET_GRID_STATE"),children:i(N,{onClick:o?.clearGridState,children:i(le,{icon:"eraser"})})}):i(t,{}),i(v,{orientation:"vertical",variant:"middle",flexItem:!0,sx:{mx:.5}}),i(g,{title:a("EXPORT_EXECL_LABEL"),children:i(ti,{render:i(w,{}),children:i(le,{icon:"file-excel",color:"green"})})}),e(ja,{children:[i(oi,{render:(e,t)=>i(g,{title:a("SEARCH_BTN_LABEL"),enterDelay:0,children:i($a,{...e,ownerState:{expanded:t.expanded},color:"default","aria-disabled":t.expanded,children:i(le,{icon:"search"})})})}),i(ai,{render:({ref:e,...t},o)=>i(Xa,{...t,ownerState:{expanded:o.expanded},inputRef:e,"aria-label":"Search",placeholder:`${a("SEARCH_BTN_LABEL")}...`,size:"small",slotProps:{input:{startAdornment:i(x,{position:"start",children:i(le,{icon:"search"})}),endAdornment:o.value?i(x,{position:"end",children:i(ri,{edge:"end",size:"small","aria-label":"Clear search",children:i(le,{icon:"xmark"})})}):null,...t.slotProps?.input},...t.slotProps}})})]}),i(N,{onClick:()=>{o.templateProps.apiActions.reloadData(o?.templateProps?.gridLoadParametersValues)},children:i(le,{icon:"refresh"})})]})},er=o=>{const{t:a}=_e(),r=Ji(),{ConfirmationWindow:d,setOpen:n}=Xi({body:a(o?.confirmationMessage||"ACTION_CONFIRMATION"),title:a("CONFIRMATION"),onConfirmationCallBk:async()=>{await(o?.actionFn(o.record)),o?.reloadData&&o.reloadData()}});let l=!0;o.authority&&(l=r.isUserAuthorized(o.authority));let s={};o?.getActionIconStyleForRecord&&(s=o.getActionIconStyleForRecord(o.record));let p=!0;o?.isActionVisibleForRecord&&(p=o?.isActionVisibleForRecord(o.record));let c=!1;if(o?.isActionDisabledForRecord&&(c=o.isActionDisabledForRecord(o.record)),l&&p)return e(t,{children:[i(d,{}),i(di,{disabled:c,icon:i(g,{title:o?.label?a(o.label):"",children:i(le,{icon:o.icon,style:{...s,color:c?"gray":null!=s?.color?s.color:void 0}})}),showInMenu:o?.gridActionProps?.showInMenu||!1,label:"",className:"textPrimary",color:"inherit",onClick:async()=>{if(!c){if(o?.preActionValidation&&!o.preActionValidation(o.record))return;!0===o?.isConfirmationRequired?n(!0):(await o.actionFn(o.record),!0===o?.gridActionProps?.reloadGridAfterAction&&o?.reloadData&&o.reloadData())}}})]})};let ir=-1;const tr=e=>{try{const i=localStorage.getItem(e);return i?JSON.parse(i):{}}catch(e){return console.error("Failed to load grid state",e),{}}},or=(e,i)=>{const t=tr(e);localStorage.setItem(e,JSON.stringify({...t,...i}))},ar=["__check__","actions"],rr=o=>{const{t:r}=_e(),d=a((e=>e.AppLayout)),[n,l]=X({}),[s,p]=X(!0),{getLookupOptions:c}=(()=>{const{handleGetRequest:e}=Hi(),i=a((e=>e.AppLayout)),t=async i=>{let t=[];return await e({endPointURI:"api/v1/public/system/lookup",showMask:!0,parameters:{lookupType:i},successCallBkFn:e=>{t=e.data}}),t};return{generateLookupGridColumn:async e=>{let o=await t(e.lookupType);return{...e,options:o,displayField:"ltr"===i.appDirection?"lookupEnDisplay":"lookupArDisplay",valueField:"lookupValue"}},getLookupOptions:t}})(),{Window:m,setWindowState:T}=et({windowTitle:r(o.gridTitle)+" Attachments",windowIcon:"paperclip",width:"fit-content",height:"fit-content",minHeight:500,minWidth:"50%",onCloseCallBack:()=>{o?.apiActions?.reloadData(o.gridLoadParametersValues)}}),{Window:u,setWindowState:A}=et({windowTitle:r(o.gridTitle)+" Approvals",windowIcon:"stamp",width:"fit-content",height:"fit-content",minHeight:500,minWidth:"80%",onCloseCallBack:()=>{o?.apiActions?.reloadData(o.gridLoadParametersValues)}}),[_,E]=X([]),I=Va(o.formElements),y=[],h=$.useMemo((()=>o?.gridStateKey?tr(o.gridStateKey):{}),[]);for(const e of I)!0===e?.gridProps?.hidden&&y.push(e.fieldName);let R={};if(h?.columnVisibilityModel){R=h.columnVisibilityModel;const e=Object.keys(R);for(const i of y)e.includes(i)||(R[i]=!1)}else for(const e of y)R[e]=!1;const L=a((e=>e.AppLayout.appDirection)),[C,D]=$.useState(R),[P,M]=$.useState(h.columnOrder||[]),[b,S]=$.useState(h.columnWidths||{}),[U,w]=X(h.columnGroupingModel||[]);let x=h?.pinnedColumns?.left||[];x=x.filter((e=>!ar.includes(e)));let W=h?.pinnedColumns?.right||[]||[];W=W.filter((e=>!ar.includes(e)));const[G,Y]=X({left:[..."ltr"===L?ar:[],...x],right:[..."rtl"===L?ar:[],...W]}),V=Ji(),q=Ge(),[K,H]=X(null),[z,Q]=X(null),[Z,j]=X({}),ee=async()=>{let e=((e,t,o)=>{const a=[];for(const d of e)if("text"===d?.fieldType||"number"===d?.fieldType){const e={...d?.gridProps?.muiProps,editable:null!=d?.gridProps?.muiProps?.editable?d?.gridProps?.muiProps?.editable:t,type:"number"==d?.fieldType?"number":"string",field:d?.fieldName,headerName:o(d?.fieldLabel||d?.fieldName),headerAlign:"center",align:"center",hidden:d?.hidden,searchable:d?.gridProps?.searchable,flex:1,minWidth:200};a.push(e)}else if("date"===d?.fieldType){const e=(r={...d?.gridProps?.muiProps,editable:null!=d?.gridProps?.muiProps?.editable?d?.gridProps?.muiProps?.editable:t,field:d?.fieldName,headerName:o(d?.fieldLabel||d?.fieldName),headerAlign:"center",align:"center",hidden:d?.hidden,searchable:d?.gridProps?.searchable,flex:1,minWidth:200},{...r,type:"string",renderEditCell:e=>i(Lt,{sx:{width:"100%"},label:"",value:e.value,onChangeCallBack:i=>{e.api.setEditCellValue({id:e.id,field:e.field,value:i})}}),valueParser:(e,i,t)=>{let o=null;return null!==e&&(o=xe(e).format(It)),o},valueFormatter:(e,i,t)=>i[t.field]});a.push(e)}else if("datetime"===d?.fieldType){const e=ka({...d?.gridProps?.muiProps,editable:null!=d?.gridProps?.muiProps?.editable?d?.gridProps?.muiProps?.editable:t,field:d?.fieldName,headerName:o(d?.fieldLabel||d?.fieldName),headerAlign:"center",align:"center",hidden:d?.hidden,searchable:d?.gridProps?.searchable,flex:1,minWidth:200});a.push(e)}else if("checkbox"===d?.fieldType){const e=Ga({...d?.gridProps?.muiProps,editable:null!=d?.gridProps?.muiProps?.editable?d?.gridProps?.muiProps?.editable:t,field:d?.fieldName,headerName:o(d?.fieldLabel||d?.fieldName),headerAlign:"center",align:"center",hidden:d?.hidden,searchable:d?.gridProps?.searchable,checkedValue:d?.checkedValue,unCheckedValue:d?.unCheckedValue,width:150});a.push(e)}else if("combobox"===d?.fieldType){const e=Wa({...d?.gridProps?.muiProps,editable:null!=d?.gridProps?.muiProps?.editable?d?.gridProps?.muiProps?.editable:t,field:d?.fieldName,headerName:o(d?.fieldLabel||d?.fieldName),headerAlign:"center",align:"center",hidden:d?.hidden,searchable:d?.gridProps?.searchable,valueField:d?.optionValueField||"value",displayField:d?.optionDisplayField||"display",options:d?.options||[],flex:1,minWidth:200});a.push(e)}else if("lookup"===d?.fieldType){const e=Wa({...d?.gridProps?.muiProps,editable:null!=d?.gridProps?.muiProps?.editable?d?.gridProps?.muiProps?.editable:t,lookupType:d?.lookupType,field:d?.fieldName,headerName:o(d?.fieldLabel||d?.fieldName),headerAlign:"center",align:"center",hidden:d?.hidden,searchable:d?.gridProps?.searchable,valueField:d?.optionValueField||"value",displayField:d?.optionDisplayField||"display",options:d?.options||[],flex:1,minWidth:200});a.push(e)}else{const e={field:d.fieldName,...d?.gridProps?.muiProps};a.push(e)}var r;return a})(I,"row"===o?.editMode?.editMode||!1,r);for(let i of e)i?.lookupType&&(i.displayField="ltr"===d.appDirection?"lookupEnDisplay":"lookupArDisplay",i.options=await c(i.lookupType),i.valueField="lookupValue");E(e)},[ie,te]=X({ids:new Set,type:"include"});let oe="id";o?.keyColumnName&&(oe=o?.keyColumnName);const ae=o.setData,re=Be.object(qa(I));let de=!0;o?.editAction?.authority&&(de=V.isUserAuthorized(o.editAction.authority));let ne=!0;o?.deleteAction?.authority&&(ne=V.isUserAuthorized(o.deleteAction.authority));const{ConfirmationWindow:se,setOpen:pe}=Xi({title:"Confirmation",body:"Are you sure you want to delete this record ?",onConfirmationCallBk:async()=>{let e=!0;K&&!0===K?.isNew||(e=await o.apiActions.deleteRecordById(K[oe])),e&&(o?.deleteAction?.postActionCallBack&&await o.deleteAction.postActionCallBack(K),ae((e=>e.filter((e=>e[oe]!=K[oe])))))}});let me,Te,ue,Ae,fe,Ee;"modal"===o?.editMode?.editMode&&(me=o?.editMode?.specs?.modalHeight||"fit-content",Te=o?.editMode?.specs?.modalWidth||"300",ue=o?.editMode?.specs?.modalMinHeight,Ae=o?.editMode?.specs?.modalMinWidth,fe=o?.editMode?.specs?.modalIcon||"window",Ee=o?.editMode?.specs?.modalTitle||"Record Form");const{Window:Ie,setWindowState:Oe}=et({height:me,minHeight:ue,minWidth:Ae,onCloseCallBack:()=>{o.apiActions.reloadData(o?.gridLoadParametersValues)},width:Te,windowIcon:fe,windowTitle:Ee}),Ne={type:"actions",field:"actions",headerName:"",headerAlign:"center",width:(o?.rowActions?30*o.rowActions.length:0)+(o?.editAction&&o?.editAction?.isEnabled?30:0)+(o?.deleteAction&&o?.deleteAction?.isEnabled?30:0)+(o?.attachment?30:0)+(o?.workFlowDocumentCode?30:0),getActions:e=>{const t=e.row,a=[];if("none"!=o?.editMode?.editMode&&(void 0===o?.disableDefaultAction||!o.disableDefaultAction)){const e=Z[t[oe]]?.mode===si.Edit;if("row"===o.editMode.editMode&&e)de&&(a.push(i(di,{icon:i(le,{icon:"save"}),label:r("SAVE_BTN_LABEL"),onClick:()=>{(e=>{const i=e[oe];j({...Z,[i]:{mode:si.View}})})(t)}})),a.push(i(di,{icon:i(le,{icon:"cancel"}),label:r("CANCEL_BTN_LABEL"),onClick:()=>{(e=>{const i=e[oe];i&&ba(i)&&i<0?(j({...Z,[i]:{mode:si.View,ignoreModifications:!0}}),ae((e=>{const t=e.filter((e=>e[oe]!=i));return t}))):j({...Z,[i]:{mode:si.View,ignoreModifications:!0}})})(t)},color:"inherit"})));else{if(o?.editAction&&!0===o?.editAction?.isEnabled){let e=!0;o?.editAction?.isActionVisibleForRecord&&(e=o?.editAction?.isActionVisibleForRecord(t));let d=!1;o?.editAction?.isActionDisabledForRecord&&(d=o?.editAction?.isActionDisabledForRecord(t)),de&&e&&a.push(i(di,{disabled:d,icon:i(g,{title:r("EDIT_BTN_LABEL"),children:i(le,{icon:"edit",style:{color:d?"gray":void 0}})}),showInMenu:o?.editAction?.gridActionProps?.showInMenu||!1,label:r("EDIT_BTN_LABEL"),className:"textPrimary",color:"inherit",onClick:()=>{de&&!d&&(async e=>{if(e)if(Q(e),"form"===o.editMode.editMode)q(o.editMode.specs.formRoute+"/"+e[oe]);else if("modal"===o.editMode.editMode)Oe(!0);else if("row"===o?.editMode?.editMode){const i=e[oe];j({...Z,[i]:{mode:si.Edit}})}})(t)}}))}if(o?.deleteAction&&!0===o?.deleteAction?.isEnabled){let e=!0;o?.deleteAction?.isActionVisibleForRecord&&(e=o?.deleteAction?.isActionVisibleForRecord(t));let d=!1;o?.deleteAction?.isActionDisabledForRecord&&(d=o?.deleteAction?.isActionDisabledForRecord(t)),ne&&e&&a.push(i(di,{disabled:d,icon:i(g,{title:r("DELETE_BTN_LABEL"),children:i(le,{icon:"trash",style:{color:d?"gray":void 0}})}),showInMenu:o?.deleteAction?.gridActionProps?.showInMenu||!1,label:r("DELETE_BTN_LABEL"),className:"textPrimary",color:"inherit",onClick:()=>{if(ne&&!d){if(o?.deleteAction?.preActionValidation&&!o.deleteAction.preActionValidation(t))return;H(t),pe(!0)}}}))}}}if(t[o?.keyColumnName||"id"]&&t[o?.keyColumnName||"id"]>0&&o?.attachment&&a?.push(i(di,{icon:i(g,{title:"Attachments",children:i(le,{icon:"paperclip"})}),label:"Attachments",className:"textPrimary",color:"inherit",onClick:()=>{l(t),p(!o?.attachment?.enableAttachFn||o.attachment.enableAttachFn(t)),T(!0)}})),t[o?.keyColumnName||"id"]&&t[o?.keyColumnName||"id"]>0&&o?.workFlowDocumentCode&&a?.push(i(di,{icon:i(g,{title:"Approvals",children:i(le,{icon:"stamp"})}),label:"Approvals",className:"textPrimary",color:"inherit",onClick:()=>{l(t),A(!0)}})),t[o?.keyColumnName||"id"]&&t[o?.keyColumnName||"id"]>0&&o?.rowActions)for(const e of o.rowActions)e?.gridActionProps?.multiRecord&&!0===e?.gridActionProps?.multiRecord||a.push(i(er,{...e,record:t,reloadData:async()=>{o.apiActions.reloadData(o?.gridLoadParametersValues)}}));return a}};let ye=[];(void 0===o?.disableDefaultAction||!o.disableDefaultAction||o?.rowActions&&o?.rowActions.length>0)&&ye.push(Ne),ye=[...ye,..._];J((()=>{void 0!==o?.autoLoad&&!0!==o.autoLoad||o.apiActions.reloadData(o?.gridLoadParametersValues),ee()}),[]),J((()=>{o.apiActions.reloadData(o?.gridLoadParametersValues)}),[V.UserInfo?.currentOrganization]),J((()=>{ee()}),[L,o.formElements]);const he=$.useMemo((()=>{const e=ye.map((e=>({...e,width:b[e.field]||e.width})));if(P.length){const i=new Map(e.map((e=>[e.field,e])));return P.map((e=>i.get(e))).filter(Boolean)}return e}),[P,b,ye]);return e(t,{children:[i(se,{}),"modal"===o?.editMode?.editMode?i(Ie,{children:o?.editMode?.specs?.formComponent?i(o.editMode.specs.formComponent,{recordIdToEdit:z?z[oe]:void 0,formCloseCallBk:()=>{Oe(!1),o.apiActions.reloadData(o?.gridLoadParametersValues)}}):i(pr,{keyColumnName:o.keyColumnName,attachment:o.attachment,formLoadCallBk:o.formLoadCallBk,recordIdToEdit:z?z[oe]:void 0,formCloseCallBk:()=>{Oe(!1),o.apiActions.reloadData(o?.gridLoadParametersValues)},elements:o.formElements,apiActions:o.apiActions,editAuthorityKey:o?.editAction?.authority,formSavedSuccessfullyCallBk:o?.editAction?.postActionCallBack,preSaveValidation:o?.editAction?.preActionValidation,actions:o?.rowActions})}):i(t,{}),void 0!==o?.hideInfoBar||o?.hideInfoBar?i(t,{}):e(f,{sx:{display:"flex"},children:[void 0!==o?.hideBackButton||o?.hideBackButton?i(t,{}):i(N,{onClick:()=>{q(-1,{replace:!0})},children:i(le,{icon:"arrow-left"})}),e(f,{sx:{flex:1,display:"flex",alignItems:"center",justifyContent:"center"},children:[o?.girdIcon?i(le,{icon:o.girdIcon,style:{marginRight:5,marginLeft:5}}):i(t,{}),i(O,{variant:"h5",children:o?.gridTitle?Sa(r(o?.gridTitle)):""})]})]}),o?.gridLoadParameters&&o?.gridLoadParameters.length>0&&o?.gridLoadParametersValues&&o?.setGridLoadParametersValues?e(F,{defaultExpanded:!0,sx:{width:"100%"},children:[i(B,{expandIcon:i(ni,{}),children:e(f,{sx:{display:"flex",alignItems:"center",justifyContent:"center"},children:[i(le,{style:{marginLeft:5,marginRight:5},icon:"search"}),i(O,{component:"span",children:"Filters"})]})}),i(k,{children:i(f,{children:i(pr,{saveButtonSpecs:{label:r("SEARCH_BTN_LABEL"),icon:"search",actionButtonVariant:"outlined",actionButtonColor:"success"},cancelButtonSpecs:{label:r("RESET_BTN_LABEL"),icon:"eraser",actionButtonVariant:"outlined",actionButtonColor:"error"},apiActions:{deleteRecordById:async()=>!0,saveRecord:async e=>{null!=e?o.setGridLoadParametersValues(e):o.setGridLoadParametersValues({}),o.apiActions.reloadData(e)},reloadData:async()=>{},loadRecordById:async()=>{}},elements:o.gridLoadParameters})})})]}):i(t,{}),o?.attachment?i(m,{children:i(za,{attachmentCode:o.attachment.attachmentCode,refKey:n[o?.keyColumnName||"id"],enableAttachment:s})}):i(t,{}),o?.workFlowDocumentCode?i(u,{children:i(sr,{workFlowDocumentCode:o.workFlowDocumentCode,refDocumentId:n[o?.keyColumnName||"id"],postActionCallBk:()=>{A(!1),o.apiActions.reloadData(o.gridLoadParametersValues)},cancelActionCallBk:()=>{A(!1),o.apiActions.reloadData(o.gridLoadParametersValues)}})}):i(t,{}),i(li,{...o?.muiProps,slots:{toolbar:Ja},slotProps:{toolbar:{templateProps:{...o,rowSelectionModel:ie,data:o?.data},handleCreateNewRecord:()=>{if("form"===o?.editMode?.editMode)q(o.editMode.specs.formRoute);else if("modal"===o?.editMode?.editMode)Q(null),Oe(!0);else if("row"===o?.editMode?.editMode){ir-=1;const e={};e[oe]=ir,e.isNew=!0;for(const i of _)"actions"!=i?.type&&i?.field!=oe&&i?.field&&(e[i.field]=null);ae((i=>[e,...i])),j((e=>({...e,[ir]:{mode:si.Edit}})))}},clearGridState:()=>{o?.gridStateKey&&localStorage.removeItem(o.gridStateKey),D({}),M([]),S({}),w([]),Y({left:[..."ltr"===L?ar:[]],right:[..."rtl"===L?ar:[]]})}}},getRowId:e=>e[oe],showToolbar:!0,rows:o?.data,columns:he,checkboxSelection:!0,editMode:"row",onRowEditStop:(e,i)=>{"rowFocusOut"===e.reason&&(i.defaultMuiPrevented=!0)},rowModesModel:"row"==o.editMode.editMode?Z:void 0,onRowModesModelChange:"row"==o.editMode.editMode?e=>{j(e)}:void 0,rowGroupingColumnMode:"multiple",processRowUpdate:async a=>{if("row"===o.editMode.editMode){let r=null;const d=(e=>{try{re.parse(e)}catch(e){console.log("validateRecord err",e);let i=null;return i=e instanceof Be.ZodError?e.errors.map((e=>"Error in field ("+e.path+") : "+e.message)).join(","):"invalid record data",i}})(a);if(d){const o=d.split(",");throw ce.error(i("div",{style:{},children:o.map((o=>e(t,{children:[i("div",{children:o}),i(v,{})]})))})),new Error(d)}if(o?.editAction?.preActionValidation&&!o.editAction.preActionValidation(a))throw new Error("error on the configured presave validation");const n={...a};if(a[oe]&&ba(a[oe])&&Number(a[oe])<0&&(n[oe]=null),r=await o.apiActions.saveRecord(n),null==r)throw new Error("Failed to process your request, contact your administrator");return o?.editAction?.postActionCallBack&&await o.editAction.postActionCallBack(a),!0===a?.isNew&&ae((e=>{const i=e.filter((e=>e[oe]!==a[oe]));return[r,...i]})),!0===o?.editMode?.reloadAfterSave&&o?.apiActions?.reloadData&&o?.apiActions?.reloadData(o?.gridLoadParametersValues),r}},rowSelectionModel:ie,onRowSelectionModelChange:e=>{te(e)},columnVisibilityModel:C,onColumnVisibilityModelChange:e=>{D(e),o?.gridStateKey&&or(o.gridStateKey,{columnVisibilityModel:e})},onColumnOrderChange:e=>{const{column:i,targetIndex:t}=e;M((e=>{const a=e.length?[...e]:ye.map((e=>e.field)),r=a.indexOf(i.field);return-1===r||(a.splice(r,1),a.splice(t,0,i.field),o?.gridStateKey&&or(o.gridStateKey,{columnOrder:a})),a}))},onColumnWidthChange:e=>{const i={...b,[e.colDef.field]:e.width};S(i),o?.gridStateKey&&or(o.gridStateKey,{columnWidths:i})},rowGroupingModel:U,onRowGroupingModelChange:e=>{(e=>{w(e),o?.gridStateKey&&or(o.gridStateKey,{columnGroupingModel:e})})(e)},pinnedColumns:G,onPinnedColumnsChange:e=>{let i=e?.left||[];i=i.filter((e=>!ar.includes(e)));let t=e?.right||[];t=t.filter((e=>!ar.includes(e)));const a={left:[..."ltr"===L?ar:[],...i],right:[..."rtl"===L?ar:[],...t]};Y(a),o?.gridStateKey&&or(o.gridStateKey,{pinnedColumns:a})},sx:{width:"100%"}})]})},dr=e=>{if(0===e.length)return[];const i=[];for(const t of Object.keys(e[0])){const e={type:"field",mode:"props",props:{fieldLabel:t,fieldName:t,fieldType:"text"}};i.push(e)}return console.log("formElements",i),i},nr=e=>(console.log("reportdata",e.reportData),i(rr,{data:e.reportData,disableDefaultAction:!0,setData:e.setReportData,formElements:dr(e.reportData),gridLoadParameters:e.gridLoadParameters,gridLoadParametersValues:e.gridLoadParametersValues,setGridLoadParametersValues:e.setGridLoadParametersValues,editMode:{editMode:"none"},girdIcon:"file-excel",gridTitle:"Report",autoLoad:!0,hideInfoBar:!0,apiActions:{deleteRecordById:async()=>!0,loadRecordById:async()=>{},reloadData:async()=>{e.reloadReport()},saveRecord:async()=>{}}})),lr=o=>{const[a,r]=X(null),[d,n]=X(null),[l,s]=X([]),[p,c]=X("WAITING_REPORT_CODE"),{handleGetRequest:m,handlePostRequest:T,HandleDownloadHTTPPostPDF:u}=Hi(),[A,_]=X(null),[E,I]=X({...o?.reportParametersValues}),[y,h]=X([]),{t:R}=_e(),L=e=>{const i=[];for(const t of e){const e={type:"field",mode:"props",props:{fieldLabel:t?.parameterLabel,fieldName:t?.parameterCode,fieldType:t?.parameterType,hidden:t?.hidden,formProps:{fieldSize:{lg:4,md:6,sm:12}},required:t?.mandatory,defaultValue:E[t?.parameterCode]||t?.defaultValue}};i.push(e)}return i},C=async(e,i)=>{c("WAITING_RESULT"),"Excel"===e?.reportType?await T({endPointURI:"api/v1/public/report/run",showMask:!0,data:{reportCode:o.reportCode,parameters:i,resultMode:o.resultMode,jasperOutPutFileType:o.jasperOutPutFileType},successCallBkFn:e=>{c("SHOWING_RESULT"),s(e.data)}}):e?.reportType&&await u({endPointURI:"api/v1/public/report/run",showMask:!0,data:{reportCode:o.reportCode,parameters:i,resultMode:o.resultMode,jasperOutPutFileType:o.jasperOutPutFileType},successCallBkFn:e=>{c("SHOWING_RESULT");const i=e.headers["content-disposition"];let t="downloaded_file";if(i&&-1!==i.indexOf("filename=")){const e=i.match(/filename="?([^"]+)"?/);e&&e[1]&&(t=e[1])}if(t.includes("pdf")){const i=new Blob([e.data],{type:"application/pdf"}),t=URL.createObjectURL(i);r(t)}else{const i=new Blob([e.data],{type:e.headers["content-type"]}),o=window.URL.createObjectURL(i),a=document.createElement("a");a.href=o,a.download=t,document.body.appendChild(a),a.click(),document.body.removeChild(a),window.URL.revokeObjectURL(o)}console.log(e)},failureCallBkFn:e=>{n("Failed To run report ... contact your administrator"),c("ERROR")}})};return J((()=>{o?.reportCode&&(async()=>{c("LOADING_METADATA"),await m({endPointURI:"api/v1/public/report/metadata",showMask:!0,parameters:{reportCode:o.reportCode},successCallBkFn:e=>{_(e.data),h(L(e.data.reportParameters)),!0===o?.byPassParameterEntry||0==e.data.reportParameters.length?(C(e.data,E),c("WAITING_RESULT")):c("WAITING_PARAMETER_INPUT")},failureCallBkFn:e=>{n("Failed loading report metadata ... contact your administrator"),c("ERROR")}})})()}),[o.reportCode,o.byPassParameterEntry,o.reportParametersValues,o.jasperOutPutFileType,o.resultMode]),e(t,{children:[e(f,{sx:{display:"flex",alignItems:"center",justifyContent:"center",width:"100%"},children:[e(f,{sx:{flex:1,textAlign:"center",marginBottom:1},children:[i(le,{icon:"Excel"===A?.reportType?"file-excel":"file-pdf",color:"Excel"===A?.reportType?"darkgreen":"darkred",style:{marginRight:10,marginLeft:10}}),A?.reportName]}),"Excel"!=A?.reportType&&"SHOWING_RESULT"===p?e(t,{children:[!0===o?.byPassParameterEntry?i(t,{}):y.length>0?i(N,{onClick:()=>{h(L(A.reportParameters)),c("WAITING_PARAMETER_INPUT")},children:i(le,{icon:"filter"})}):i(t,{}),i(N,{children:i(le,{icon:"refresh",onClick:()=>{C(A,E)}})})]}):i(t,{})]}),i(f,{sx:{flexGrow:1,width:"100%",display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"flex-start"},children:"WAITING_PARAMETER_INPUT"===p&&"Excel"!=A?.reportType?e(F,{defaultExpanded:!0,sx:{width:"100%"},expanded:!0,children:[i(B,{children:e(f,{sx:{display:"flex",alignItems:"center",justifyContent:"center"},children:[i(le,{style:{marginLeft:5,marginRight:5},icon:"search"}),i(O,{component:"span",children:"Filters"})]})}),i(k,{children:i(f,{children:i(pr,{saveButtonSpecs:{label:R("SHOW_REPORT_BTN_LABEL"),icon:"search",actionButtonVariant:"outlined",actionButtonColor:"success",hidden:!0},cancelButtonSpecs:{label:R("RESET_BTN_LABEL"),icon:"eraser",actionButtonVariant:"outlined",actionButtonColor:"error"},apiActions:{deleteRecordById:async()=>!0,saveRecord:async e=>{I(null!=e?e:{}),C(A,e)},reloadData:async()=>{},loadRecordById:async()=>{}},elements:y})})})]}):"SHOWING_RESULT"===p||("WAITING_PARAMETER_INPUT"===p||"WAITING_RESULT"===p)&&"Excel"===A?.reportType?"Excel"===A?.reportType?i(nr,{reportData:l,setReportData:s,reloadReport:async()=>{C(A,E)},gridLoadParameters:y,gridLoadParametersValues:E,setGridLoadParametersValues:I}):i("iframe",{src:a,width:"100%",height:"100%",title:"PDF Preview",style:{border:"1px solid #ccc",marginTop:"20px"}}):"ERROR"===p?e(f,{sx:{display:"flex",flex:1,alignItems:"center",justifyContent:"center"},children:[i(le,{icon:"circle-exclamation",color:"darkred",style:{marginRight:10,marginLeft:10}}),d]}):i(t,{})})]})},sr=o=>{const r=Ge(),d=a((e=>e.AppLayout)),{isUserAuthorized:n,UserInfo:l}=Ji(),{handleGetRequest:s,handlePostRequest:p}=Hi(),[c,m]=X(null),[T,u]=X([]),{t:_}=_e(),[E,I]=X(null),[O,h]=X({referencedDocument:null,workflowDocumentReport:null,workflowDocument:null,workflowDocumentStatus:null,actionsHistory:[],nextActionTakers:null,nextActions:[]}),{Window:R,setWindowState:L}=et({windowTitle:"ltr"===d.appDirection?O?.workflowDocument&&O?.referencedDocument?`${O?.workflowDocument?.documentEnName} # ${O?.referencedDocument[O?.workflowDocument?.documentNumberField]}`:"Document":O?.workflowDocument&&O?.referencedDocument?`${O?.workflowDocument?.documentArName} # ${O?.referencedDocument[O?.workflowDocument?.documentNumberField]}`:"وثيقة",windowIcon:"eye",width:"80%"}),C=async()=>{await s({endPointURI:"api/v1/public/workflow/doc/info",showMask:!0,parameters:{workflowDocumentCode:o.workFlowDocumentCode,refDocumentId:o.refDocumentId},successCallBkFn:e=>{h(e.data)},failureCallBkFn:()=>{h({referencedDocument:null,workflowDocumentReport:null,workflowDocument:null,workflowDocumentStatus:null,actionsHistory:[],nextActions:[],nextActionTakers:null})}})},D=async()=>{await p({endPointURI:"api/v1/public/workflow/doc/action",showMask:!0,data:{workflowDocumentId:O?.workflowDocument?.id,refDocumentId:o.refDocumentId,actionId:c.id,refDocumentStatus:O?.workflowDocumentStatus?.documentStatusCode,actionComment:E},successCallBkFn:async e=>{c?.post_action_endpoint?await p({endPointURI:c.post_action_endpoint,showMask:!0,loadingMessage:"Processing post action process ... please wait",parameters:{refDocumentId:o.refDocumentId,actionId:c.id},successCallBkFn:()=>{C(),o?.postActionCallBk&&o.postActionCallBk()}}):C()}})};return J((()=>{o.refDocumentId&&o.workFlowDocumentCode&&C()}),[o.refDocumentId,o.workFlowDocumentCode]),J((()=>{u(O?.nextActions&&O?.nextActions?.length>0?O.nextActions.filter((e=>{if(!O?.workflowDocumentStatus?.nextActionTakersAuthority&&!O?.nextActionTakers)return!0;if(O?.workflowDocumentStatus?.nextActionTakersAuthority&&n(O.workflowDocumentStatus.nextActionTakersAuthority))return!0;if(O?.nextActionTakers)for(const e of O.nextActionTakers)if(l?.username===e?.username||l?.username===e?.USERNAME)return!0;return!1})):[])}),[O.nextActions,O.nextActionTakers]),e(t,{children:[O?.workflowDocumentReport?.id?i(R,{children:i(lr,{reportCode:O?.workflowDocumentReport?.reportCode,resultMode:"App",byPassParameterEntry:!0,reportParametersValues:{doc_id:o.refDocumentId+""}})}):i(t,{}),O?.workflowDocument?e(f,{sx:{width:"100%",textAlign:"center",fontSize:20,fontWeight:"bold",display:"flex",alignItems:"center",justifyContent:"center"},children:[i(N,{onClick:()=>{r(-1,{replace:!0})},children:i(le,{icon:"arrow-left"})}),i(f,{sx:{flex:1}}),i(le,{icon:"file",style:{marginRight:10,marginLeft:10}}),"ltr"===d.appDirection?`${O?.workflowDocument?.documentEnName} # ${O?.referencedDocument[O?.workflowDocument?.documentNumberField]}`:`${O?.workflowDocument?.documentArName} # ${O?.referencedDocument[O?.workflowDocument?.documentNumberField]}`,O?.workflowDocumentStatus?"ltr"===d.appDirection?` ( ${O?.workflowDocumentStatus?.documentStatusEnName} )`:` ( ${O?.workflowDocumentStatus?.documentStatusArName} )`:"",i(f,{sx:{flex:1}}),O?.workflowDocumentReport?.id?i(A,{onClick:()=>{L(!0)},variant:"outlined",startIcon:i(le,{icon:"eye"}),children:_("VIEW_LABEL")}):i(t,{})]}):i(t,{}),e(f,{sx:{flex:1,width:"100%",overflow:"hidden",display:"flex"},children:[T?.length>0?e(y,{sx:{padding:2,display:"flex",flex:1,margin:1,flexDirection:"column",alignItems:"center",justifyContent:"flex-start",overflow:"hidden"},children:[i(Et,{sx:{marginBottom:2,width:400},label:_("WE_AVAILABLE_ACTIONS_LABEL"),displayField:"ltr"===d.appDirection?"document_action_en_name":"document_action_ar_name",valueField:"id",value:c?.id,options:T,onChangeCallBack:(e,i)=>{m(i)}}),i(dt,{sx:{width:400},rows:3,value:E,onChange:e=>{I(e.target.value)},multiline:!0,label:_("WF_COMMENT_LABEL")}),e(f,{sx:{display:"flex",alignItems:"center",justifyContent:"center"},children:[i(A,{color:"success",variant:"contained",sx:{width:200,m:1},onClick:async()=>{null!=c&&null!=c?.id?!0!==c.require_comment&&1!==c.require_comment&&"true"!==c.require_comment||null!==E&&""!==E?c?.pre_action_endpoint?await p({endPointURI:c.pre_action_endpoint,showMask:!0,loadingMessage:"Processing pre action validation ... please wait",parameters:{refDocumentId:o.refDocumentId,actionId:c.id},successCallBkFn:()=>{D()}}):D():ce.error("You must enter comment for the action to be processed"):ce.error("You must select action to process")},children:_("WF_TAKE_ACTION_BTN_LABEL")}),o?.cancelActionCallBk?i(A,{variant:"contained",sx:{width:200,m:1},color:"error",onClick:()=>{o?.cancelActionCallBk&&o.cancelActionCallBk()},children:_("WF_CANCEL_BTN_LABEL")}):i(t,{})]}),O?.nextActionTakers&&O.nextActionTakers.length>0?e(t,{children:[i(v,{variant:"fullWidth",flexItem:!0,sx:{marginTop:1,marginBottom:1},children:e(f,{sx:{width:"100%",display:"flex",alignItems:"center",justifyContent:"center",fontSize:18,fontWeight:"bold"},children:[i(le,{icon:"users",style:{marginRight:10,marginLeft:10}})," ",_("WF_WAITING_FOR_LABEL")]})}),i(f,{sx:{flex:1,display:"flex",flexDirection:"column",alignItems:"center",overflow:"auto",padding:1,width:"100%"},children:O.nextActionTakers.map((o=>e(f,{sx:{display:"flex",alignItems:"center",justifyContent:"center",border:"1px dotted black",width:400,marginBottom:2,padding:2},children:[i(Ka,{showAsAvatar:!0,attachmentCode:"EMPLOYEE_PHOTOS",refKey:o?.id||"0",style:{marginRight:2,marginLeft:2,width:60,height:60}}),e(f,{sx:{flex:2,display:"flex",flexDirection:"column",alignItems:"flex-start",justifyContent:"center"},children:[i("div",{children:"ltr"===d.appDirection?o?.employee_en_name:o?.employee_ar_name}),i("div",{children:o?.email?e(t,{children:[i(le,{icon:"envelope",style:{marginRight:10,marginLeft:10}}),o?.email]}):i(t,{})}),i("div",{children:o?.mobile_number?e(t,{children:[i(le,{icon:"mobile",style:{marginRight:10,marginLeft:10}}),o?.mobile_number]}):i(t,{})})]})]})))})]}):i(t,{})]}):i(t,{}),O?.actionsHistory.length>0?i(Qa,{actionHistory:O.actionsHistory}):e(y,{sx:{display:"flex",flexDirection:"column",flexGrow:1,padding:2,margin:1,alignItems:"center",justifyContent:"center"},children:[e(f,{sx:{width:"100%",display:"flex",alignItems:"center",justifyContent:"center",fontSize:18,fontWeight:"bold"},children:[i(le,{icon:"history",style:{marginRight:10,marginLeft:10}}),_("WF_ACTION_HISTORY_LABEL")]}),i(f,{sx:{flex:1,display:"flex",alignItems:"center",justifyContent:"center"},children:"No Action Log available"})]})]})]})},pr=o=>{const{Window:a,setWindowState:r}=et({windowTitle:"Attachments",windowIcon:"paperclip",width:"fit-content",height:"fit-content",minHeight:500,minWidth:400}),{Window:d,setWindowState:n}=et({windowTitle:"Approvals",windowIcon:"stamp",width:"fit-content",height:"fit-content",minHeight:500,minWidth:400}),[l,s]=X(!0),{t:p}=_e(),c=Va(o.elements),m=[];for(const e of c)e?.hidden&&m.push(e.fieldName);const[T,u]=X(m),_={};for(const e of o.elements)"field"===e?.type&&"props"===e?.mode&&e?.props?.defaultValue&&(_[e.props.fieldName]=e.props.defaultValue);const[f,E]=X([]),I=Fe.object(qa(c)),O=ke({resolver:We(I),defaultValues:_}),y=O.watch(),h=Ye(),L=o?.formRouteRecordIdParamName,C=async()=>{let e=null;if(o?.recordIdToEdit?e=o.recordIdToEdit:L&&h[L]&&(e=h[L]),e){const i=await o.apiActions.loadRecordById(e);if(i){O.reset({...i}),o?.formLoadCallBk&&o?.formLoadCallBk(D,O,i);for(const e of c)"combobox"===e?.fieldType&&i[e.fieldName]&&O.setValue(e.fieldName,i[e.fieldName]+"")}}else O.reset({})},D={setFieldValue:(e,i)=>{O.setValue(e,i)},hideField:e=>{u((i=>[...i,e]))},showField:e=>{u((i=>i.filter((i=>i!==e))))},disableField:e=>{E((i=>[...i,e]))},enableField:e=>{E((i=>i.filter((i=>i!==e))))}};return J((()=>{C()}),[o?.recordIdToEdit]),J((()=>{s(!o?.attachment||!o?.attachment?.enableAttachFn||o.attachment.enableAttachFn(y))}),[y]),e(t,{children:[o?.attachment?i(a,{children:i(za,{attachmentCode:o.attachment.attachmentCode,refKey:y[o?.keyColumnName||"id"],enableAttachment:l})}):i(t,{}),o?.workFlowDocumentCode?i(d,{children:i(sr,{workFlowDocumentCode:o.workFlowDocumentCode,refDocumentId:y[o?.keyColumnName||"id"],postActionCallBk:()=>{n(!1),C()},cancelActionCallBk:()=>{n(!1)}})}):i(t,{}),i(Pa,{sx:{display:"flex",flex:1,width:"100%",height:"fit-content",flexDirection:"column",alignItems:"center",overflow:"auto"},children:i(R,{sx:{width:"100%"},container:!0,children:o.elements.map(((e,t)=>"group"===e.type?i(Ba,{...e.props,formManager:O,formValues:y,formActions:D,hiddenFields:T,disabledFields:f},t):"field"===e.type&&"props"===e.mode?i(xa,{fieldInfo:e.props,formManager:O,formValues:y,formActions:D,hiddenFields:T,disabledFields:f},t):"field"===e.type&&"node"===e.mode?i(R,{size:e?.props?.formProps?.fieldSize||{lg:3,md:6,xs:12},sx:{padding:1,width:"100%"},children:i(e.node,{formManager:O,formValues:y})},t):void 0))})}),e(Pa,{sx:{display:"flex",width:"100%",alignItems:"center",justifyContent:"flex-start"},children:[y[o?.keyColumnName||"id"]&&o?.attachment?i(g,{title:"Attachments",children:i(N,{onClick:()=>{r(!0)},children:i(le,{icon:"paperclip"})})}):null,y[o?.keyColumnName||"id"]&&o?.workFlowDocumentCode?i(g,{title:"Approvals",children:i(N,{onClick:()=>{n(!0)},children:i(le,{icon:"stamp"})})}):null,o?.actions&&y[o?.keyColumnName||"id"]?o.actions.map((e=>!0===e?.formActionProps?.enabled?i(Fa,{...e,record:y}):i(t,{}))):i(t,{}),i("div",{style:{flex:1}}),i(A,{variant:o?.saveButtonSpecs?.actionButtonVariant?o.saveButtonSpecs.actionButtonVariant:"contained",sx:{m:1},startIcon:o?.saveButtonSpecs?.icon?i(le,{icon:o.saveButtonSpecs.icon}):null,color:o?.saveButtonSpecs?.actionButtonColor?o.saveButtonSpecs.actionButtonColor:"primary",onClick:O.handleSubmit((e=>{console.log("form values",e),(async e=>{if((!o?.preSaveValidation||o.preSaveValidation(e))&&e){const i=await o.apiActions.saveRecord(e);i&&(O.reset({...i}),o?.formSavedSuccessfullyCallBk&&o.formSavedSuccessfullyCallBk(i),o?.formCloseCallBk&&o.formCloseCallBk())}})(e)}),(e=>{ce.error("Form Data is not valid, make sure you have all field with valid data"),console.log("form validation error",e)})),children:p(o?.saveButtonSpecs?.label||"SAVE_BTN_LABEL")}),i(A,{variant:o?.cancelButtonSpecs?.actionButtonVariant?o.cancelButtonSpecs.actionButtonVariant:"contained",startIcon:o?.cancelButtonSpecs?.icon?i(le,{icon:o.cancelButtonSpecs.icon}):null,color:o?.cancelButtonSpecs?.actionButtonColor?o.cancelButtonSpecs.actionButtonColor:"error",sx:{m:1},onClick:()=>{o?.formCloseCallBk&&o.formCloseCallBk(),O.reset(_)},children:p(o?.cancelButtonSpecs?.label||"CANCEL_BTN_LABEL")})]})]})},cr=()=>{const{workflowDocumentCode:e,refDocumentId:t}=Ye();return i(sr,{workFlowDocumentCode:e,refDocumentId:t})},mr=t=>{const{UserSession:r}=Ji(),d=a((e=>e.AppLayout)),n=o(),{handlePostRequest:l}=Hi(),[s,p]=X(r.value.currentOrganization.id);return e(f,{sx:{display:"flex",flexDirection:"column",width:"100%",alignItems:"center",justifyContent:"center",padding:1},children:[i(Et,{sx:{width:"100%"},displayField:"ltr"===d.appDirection?"organizationEnName":"organizationArName",valueField:"id",label:"",options:r.value.userOrganizations,value:s,onChangeCallBack:e=>{p(e)}}),i(A,{sx:{m:1},variant:"contained",disabled:null==s||s===r.value.currentOrganization.id,onClick:async()=>{await l({endPointURI:"api/auth/changeCurrentOrg",showMask:!0,parameters:{username:r.value.username,orgId:s},data:{},successCallBkFn:e=>{const i={...e.data,isAuthenticated:!0};n(qi.setAuthenticated(i)),t.successChangeCallBackFn&&t.successChangeCallBackFn()}})},children:"Change Organization"})]})},Tr=se({name:"SideBar",initialState:{isOpened:!1},reducers:{toggleSideBarState:e=>{e.isOpened=!e.isOpened},setSideBarState:(e,i)=>{e.isOpened=i.payload}}}),{toggleSideBarState:ur,setSideBarState:Ar}=Tr.actions;var _r=Tr.reducer;function fr(e,i){const t=ie(e);J((()=>{t.current=e}),[e]),J((()=>{const e=setInterval((()=>t.current?.()),i);return()=>clearInterval(e)}),[i])}const Er=W`
31
+ function(e,i){const t=Mi(e,i);return"production"!==process.env.NODE_ENV?(...i)=>{const o=`"${e}"`;return 0===i.length?console.error([`MUI: Seems like you called \`styled(${o})()\` without a \`style\` argument.`,'You must provide a `styles` argument: `styled("div")(styleYouForgotToPass)`.'].join("\n")):i.some((e=>void 0===e))&&console.error(`MUI: the styled(${o})(...args) API requires all its args to be defined.`),t(...i)}:t}("div",{shouldForwardProp:e=>"theme"!==e&&"sx"!==e&&"as"!==e})(Ea),n=j.forwardRef((function(e,n){const l=function(e=Na){return Oa(e)}(o),{className:s,component:p="div",...c}=ya(e);return i(d,{as:p,ref:n,className:Ca(s,r?r(a):a),theme:t&&l[t]||l,...c})}));return n}({defaultClassName:function(e,i,t="Mui"){const o={};return i.forEach((i=>{o[i]=function(e,i,t="Mui"){const o=Da[i];return o?`${t}-${o}`:`${Ra.generate(e)}-${i}`}(e,i,t)})),o}("MuiBox",["root"]).root,generateClassName:Ra.generate});function Ma(e){return/^\d+$/.test(e)}function ba(e){return"number"==typeof e&&!isNaN(e)}function ga(e){return"string"==typeof e&&""!==e.trim()&&!isNaN(Number(e))}function Sa(e){return e?e.charAt(0).toUpperCase()+e.slice(1):""}function Ua(e){return/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(e)}function va(e,i){const t=new Date(e),o=new Date,a=Math.floor((t-o)/1e3),r="rtl"===i?"ar":"en",d=new Intl.RelativeTimeFormat(r,{numeric:"auto"}),n=[{unit:"year",seconds:31536e3},{unit:"month",seconds:2592e3},{unit:"week",seconds:604800},{unit:"day",seconds:86400},{unit:"hour",seconds:3600},{unit:"minute",seconds:60},{unit:"second",seconds:1}];for(const{unit:e,seconds:i}of n){const t=Math.floor(a/i);if(Math.abs(t)>1)return d.format(t,e)}return"ar"===r?"الآن":"just now"}"production"!==process.env.NODE_ENV&&(Pa.propTypes={children:oo.node,component:oo.elementType,sx:oo.oneOfType([oo.arrayOf(oo.oneOfType([oo.func,oo.object,oo.bool])),oo.func,oo.object])});const wa=e=>{const t=a((e=>e.AppLayout)),o=Ji(),[r,d]=X([]),{handleGetRequest:n}=Hi();return J((()=>{e.lookupType&&(async()=>{await n({endPointURI:"api/v1/public/system/lookup",showMask:!0,parameters:{lookupType:e.lookupType},successCallBkFn:e=>{d(e.data)},failureCallBkFn:()=>{d([])}})})()}),[e.lookupType,o.UserSession]),i(Et,{...e,options:r,displayField:"ltr"===t.appDirection?"lookupEnDisplay":"lookupArDisplay",valueField:"lookupValue"})},xa=e=>{if(e?.fieldInfo){const o=e.fieldInfo,a=e?.formManager||null,r=e?.formActions||null,d=e?.formValues||null,n=e?.fieldInfo?.fieldName||null,l=e?.fieldInfo?.fieldType||null;return o&&a&&d&&n&&l?e.hiddenFields.includes(n)?i(t,{}):i(R,{size:o?.formProps?.fieldSize||{lg:12,md:12,sm:12},sx:{padding:1,width:"100%"},children:"text"===l||"number"===l?i(dt,{...o.muiTextFieldProps,fullWidth:!0,type:l,disabled:!(!o?.disabled&&!e.disabledFields.includes(n)),hidden:o?.hidden||!1,label:o?.fieldLabel,value:d[n],onChange:e=>{let i=null;""!=e.target.value&&(i="number"===l&&ga(e.target.value)?Number(e.target.value):e.target.value),a.setValue(n,i),o?.formProps?.onValueChangeCallBack&&o?.formProps?.onValueChangeCallBack(i,a,r)},sx:{"& .MuiInputBase-root":{height:`${o?.formProps?.fieldHeight}px`||void 0},"& .MuiInputBase-input":{height:"100% !important"},...o?.formProps?.style},error:null!=a.formState.errors[n],helperText:a?.formState?.errors[n]?.message?.toString()}):"date"===o?.fieldType?i(Lt,{format:o?.dateFormat||It,sx:o?.formProps?.style||{width:"100%"},disabled:!(!o?.disabled&&!e.disabledFields.includes(n)),label:o?.fieldLabel,onChangeCallBack:e=>{a.setValue(n,e),o?.formProps?.onValueChangeCallBack&&o?.formProps?.onValueChangeCallBack(e,a,r)},value:d[n],error:null!=a.formState.errors[n],errorMessage:a?.formState?.errors[n]?.message?.toString()}):"datetime"===o?.fieldType?i(Ct,{format:o?.dateFormat||Ot,sx:o?.formProps?.style||{width:"100%"},disabled:!(!o?.disabled&&!e.disabledFields.includes(n)),label:o?.fieldLabel,onChangeCallBack:e=>{a.setValue(n,e),o?.formProps?.onValueChangeCallBack&&o?.formProps?.onValueChangeCallBack(e,a,r)},value:d[n],error:null!=a.formState.errors[n],errorMessage:a?.formState?.errors[n]?.message?.toString()}):"checkbox"===o?.fieldType?i(ft,{label:o?.fieldLabel,onChangeCallBack:e=>{a.setValue(n,e),o?.formProps?.onValueChangeCallBack&&o?.formProps?.onValueChangeCallBack(e,a,r)},value:d[n],checkedValue:o?.checkedValue||!0,unCheckedValue:o?.unCheckedValue||!1,disabled:!(!o?.disabled&&!e.disabledFields.includes(n)),sx:o?.formProps?.style}):"combobox"===o?.fieldType?i(Et,{sx:o?.formProps?.style||{width:"100%"},label:o?.fieldLabel,disabled:!(!o?.disabled&&!e.disabledFields.includes(n)),onChangeCallBack:(e,i)=>{let t=null;e&&(t=e+""),a.setValue(n,t),o?.formProps?.onValueChangeCallBack&&o?.formProps?.onValueChangeCallBack(t,a,r,i)},options:o?.options||[],displayField:o?.optionDisplayField||"",valueField:o?.optionValueField||"",value:d[n],errorMessage:a?.formState?.errors[n]?.message?.toString()}):"lookup"===o?.fieldType?i(wa,{sx:o?.formProps?.style||{width:"100%"},label:o?.fieldLabel,disabled:!(!o?.disabled&&!e.disabledFields.includes(n)),onChangeCallBack:(e,i)=>{let t=null;e&&(t=e+""),a.setValue(n,t),o?.formProps?.onValueChangeCallBack&&o?.formProps?.onValueChangeCallBack(t,a,r,i)},lookupType:o.lookupType,value:d[n],errorMessage:a?.formState?.errors[n]?.message?.toString()}):null}):i(t,{})}return i(t,{})},Fa=o=>{const a=Ji(),{ConfirmationWindow:r,setOpen:d}=Xi({body:o?.confirmationMessage||"",title:"Confirmation",onConfirmationCallBk:()=>{o?.actionFn(o?.record)}});return null==o?.authority||a.isUserAuthorized(o.authority)?e(t,{children:[i(r,{}),e(A,{variant:o?.formActionProps?.actionButtonVariant,color:o?.formActionProps?.actionButtonColor,onClick:()=>{if(o?.actionFn){if(o?.preActionValidation&&!o.preActionValidation(o.record))return;!0===o?.isConfirmationRequired?d(!0):o?.actionFn(o.record)}},children:[o?.icon?i(le,{icon:o.icon,style:{marginRight:5,marginLeft:5}}):i(t,{}),i("div",{children:o?.label})]})]}):i(t,{})},Ba=o=>{const{t:a}=_e();return i(t,{children:e(R,{container:!0,sx:o?.style,alignItems:"flex-start",children:[o?.label?i(R,{size:12,sx:{padding:1,fontWeight:"bold",display:"flex",alignItems:"center",justifyContent:"flex-start"},children:o?.icon?e(t,{children:[i(le,{icon:o.icon,style:{marginRight:5,marginLeft:5}}),i("div",{children:a(o.label)})]}):i(t,{children:a(o.label)})}):i(t,{}),o?.elements?o.elements.map((e=>"group"===e.type?i(Ba,{...e.props,formManager:o.formManager,formValues:o.formValues,formActions:o.formActions,hiddenFields:o.hiddenFields,disabledFields:o.disabledFields}):"field"===e.type&&"props"===e.mode?i(xa,{fieldInfo:e.props,formManager:o.formManager,formValues:o.formValues,formActions:o.formActions,hiddenFields:o.hiddenFields,disabledFields:o.disabledFields}):"field"===e.type&&"node"===e.mode?i(R,{size:e?.props?.formProps?.fieldSize||{lg:3,md:6,sm:12},sx:{padding:1,width:"100%"},children:i(e.node,{formManager:o.formManager,formValues:o.formValues,formActions:o.formActions})}):void 0)):null,o?.actions?i(R,{size:{sm:12},sx:{padding:1},children:o.actions.map((e=>i(Fa,{...e,record:o.formValues})))}):i(t,{})]})})},ka=e=>({...e,type:"string",renderEditCell:e=>i(Ct,{sx:{width:"100%"},label:"",value:e.value,onChangeCallBack:i=>{e.api.setEditCellValue({id:e.id,field:e.field,value:i})}}),valueParser:(e,i,t)=>{let o=null;return null!==e&&(o=xe(e).format(Ot)),o},valueFormatter:(e,i,t)=>i[t.field]}),Wa=e=>({...e,type:"custom",valueGetter:e=>e?e+"":e,renderCell:e=>{let t=null;try{t=e.colDef.options.find((i=>i[e.colDef.valueField]==e.value))}catch(e){}return i("div",{children:null!=t?t[e.colDef.displayField]:e.value})},renderEditCell:e=>i(Et,{...e,sx:{width:"100%"},options:e.colDef.options,valueField:e.colDef.valueField,displayField:e.colDef.displayField,onChangeCallBack:(i,t)=>{null===i&&e.api.setEditCellValue({id:e.id,field:e.field,value:null}),e.api.setEditCellValue({id:e.id,field:e.field,value:i+""})}})}),Ga=e=>({...e,type:"custom",valueGetter:e=>null==e||null==e?null:e,renderCell:t=>{const o=t?.value;return o===e.checkedValue||"true"===o||1===o||!0===o?i(le,{icon:"check",color:"green"}):i(le,{icon:"xmark",color:"red"})},renderEditCell:t=>i(ft,{...t,checkedValue:e?.checkedValue||!0,unCheckedValue:e?.unCheckedValue||!1,onChangeCallBack:e=>{t.api.setEditCellValue({id:t.id,field:t.field,value:e})}})}),Ya=e=>{const i=[];if("field"===e.type&&"props"===e.mode&&e?.props)i.push(e.props);else if("group"===e.type&&e?.props&&e?.props?.elements)for(const t of e.props.elements)i.push(...Ya(t));return i},Va=e=>{const i=[];for(const t of e)i.push(...Ya(t));return i},qa=e=>{const i={};for(const t of e)if(t?.fieldName){const e=t.fieldName;"number"===t.fieldType?i[e]=!0===t?.required?Fe.number({required_error:"This field is required",invalid_type_error:"This field must be a number"}):Fe.number().optional().nullable():"checkbox"===t.fieldType?i[e]=!0===t?.required?Fe.boolean({required_error:"This field is required"}):Fe.boolean().optional().nullable():i[e]=!0===t?.required?Fe.string({message:"This field is required"}).min(1,"This field is required"):Fe.string().optional().nullable()}return i},Ka=e=>{let t=a((e=>e.AppInfo.value.apiBaseUrl))+"/api/v1/attachment/";e?.attachmentId?t+="download?attachmentId="+e.attachmentId:(t+=`downloadImage?attachmentCode=${e.attachmentCode}&refKey=${e.refKey}`,e?.category&&(t+=`&category=${e.category}`));const[o,r]=X(t);return e?.showAsAvatar?i(b,{src:o,sx:e.style}):i("img",{src:o,alt:"image",onError:()=>r("/no_image.png"),style:{width:"100%",height:"100%",objectFit:"cover",display:"block"}})},Ha=o=>{const{handleGetRequest:a,handleDeleteRequest:r}=Hi(),{isUserAuthorized:d}=Ji();let n=!0;o?.downloadAuthorityKey&&(n=d(o.downloadAuthorityKey));const{ConfirmationWindow:l,setOpen:s}=Xi({title:"Confirmation",body:"Are you sure you want to delete this attachment?",onConfirmationCallBk:()=>{(async()=>{await r({endPointURI:"api/v1/attachment/archive",parameters:{attachmentCode:o.attachmentCode,refKey:o.refKey,attachmentId:o.id},successCallBkFn:e=>{o.setAttachmentConfig(e.data)},showMask:!0})})()}});return e(t,{children:[i(l,{}),e(Ee,{sx:{width:300,border:"0.5px solid gray"},children:[i(Qe,{sx:{height:140,width:300,display:"flex",alignItems:"center",justifyContent:"center"},children:o?.docType.toLocaleLowerCase().includes("image")?i(Ka,{attachmentId:o.id}):i(le,{icon:"file",size:"3x"})}),e(ze,{children:[i(Me,{gutterBottom:!0,variant:"h6",component:"div",children:o.fileName}),i(Me,{variant:"body2",sx:{color:"text.secondary"},children:`File Size: ${o?.attachmentSize||"unknown"} kb`}),i(Me,{variant:"body2",sx:{color:"text.secondary"},children:`File Type: ${o?.category||"NA"}`}),i(Me,{variant:"body2",sx:{color:"text.secondary"},children:o.remark})]}),e(He,{children:[o?.allowDelete?i(N,{size:"small",onClick:()=>{s(!0)},children:i(g,{title:"Delete Attachment",children:i(le,{icon:"trash"})})}):i(t,{}),i("div",{style:{flex:1}}),n?i(N,{size:"small",onClick:async()=>{await a({endPointURI:"api/v1/attachment/download",parameters:{attachmentId:o.id},showMask:!0,responseType:"blob",successCallBkFn:e=>{const i=window.URL.createObjectURL(new Blob([e.data])),t=document.createElement("a");t.href=i,t.setAttribute("download",o.fileName),document.body.appendChild(t),t.click(),t.remove()}})},children:i(g,{title:"Download Attachment",children:i(le,{icon:"download"})})}):i(t,{})]})]})]})},za=o=>{const{handleUploadRequest:a,handleGetRequest:r}=Hi(),[d,n]=X(null),[l,s]=X([]),[p,c]=X(null),[m,T]=X(null),[u,_]=X([]),[f,E]=X(null),{isUserAuthorized:I}=Ji(),O=e=>e.split(".").pop()?.toLowerCase()||"";J((()=>{(async()=>{await r({endPointURI:"api/v1/attachment/info",showMask:!0,parameters:{attachmentCode:o.attachmentCode,refKey:o.refKey},successCallBkFn:e=>{E(e.data)}})})()}),[o.refKey,o.attachmentCode]),J((()=>{if(_(f?.allowedFileTypes?f.allowedFileTypes.split(","):[]),f?.attachmentCategories){const e=[];for(const i of f.attachmentCategories.split(","))e.push({value:i});s(e)}else s([])}),[f]);let N=!0;f?.downloadAuthorityKey&&!I(f?.downloadAuthorityKey)&&(N=!1);let h=!0;return!1===o?.enableAttachment&&(h=!1),f?.uploadAuthorityKey&&!I(f.uploadAuthorityKey)&&(h=!1),e(y,{sx:{display:"flex",flexDirection:"column",width:"100%",alignItems:"center",justifyContent:"flex-start",overflow:"hidden",flexGrow:1},children:[i(t,h?{children:null==f?.maxAllowedNumberOfFiles||f?.maxAllowedNumberOfFiles>f.refKeyAttachments.length?e(t,{children:[e("h3",{children:[i(le,{icon:"paperclip",style:{marginRight:10,marginLeft:10}}),"Attachment Uploader"]}),i("input",{type:"file",style:{margin:20},accept:f?.allowedFileTypes,multiple:!0,onChange:e=>{if(e.target.files)for(const i of e.target.files){const e=O(i.name);if(u.length>0&&!u.includes(e))return void ce.error(e+" is not allowed")}n(e.target.files)}}),l.length>0?i(Et,{label:"Attachment Type",sx:{width:300,m:1},options:l,displayField:"value",valueField:"value",value:m,onChangeCallBack:e=>{T(e)}}):i(t,{}),i(dt,{label:"Remark",value:p,onChange:e=>c(e.target.value),multiline:!0,sx:{width:300,m:1},rows:3}),i(A,{sx:{m:1},variant:"contained",onClick:async()=>{let e=f?.refKeyAttachments.length||0;f?.maxAllowedNumberOfFiles&&d.length+e>f.maxAllowedNumberOfFiles?ce.error("Maximum number of attachments is "+f.maxAllowedNumberOfFiles):!0===f?.isCategoryRequired&&l.length>0&&(null==m||void 0===m||""===m)?ce.error("You must selected document type to process your request"):d?await a({endPointURI:"api/v1/attachment/upload",showMask:!0,loadingMessage:"Uploading files ... please wait",parameters:{refKey:o.refKey,attachmentCode:o.attachmentCode,remark:p,category:m},files:d,successCallBkFn:e=>{E(e.data),n(null),T(null),c(null),ce.success("Your request has been process successfully")}}):ce.error("You must add files to upload")},children:"Upload"})]}):i(t,{})}:{}),N&&f?.refKeyAttachments?.length>0?e(t,{children:[e("h3",{children:[i(le,{style:{marginRight:10,marginLeft:10},icon:"paperclip"}),"Attachments"]}),i(R,{container:!0,spacing:2,sx:{overflow:"auto",padding:1,justifyContent:"center"},children:f?.refKeyAttachments.map((e=>i(R,{sx:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center"},children:i(Ha,{...e,attachmentCode:o.attachmentCode,setAttachmentConfig:E,downloadAuthorityKey:f.downloadAuthorityKey,allowDelete:h})})))})]}):i(t,{})]})},Qa=o=>{const r=a((e=>e.AppLayout)),{t:d}=_e();return e(y,{sx:{display:"flex",flexDirection:"column",flexGrow:1,padding:1,margin:1,alignItems:"center",justifyContent:"center"},children:[e(f,{sx:{width:"100%",display:"flex",alignItems:"center",justifyContent:"center",fontSize:18,fontWeight:"bold"},children:[i(le,{icon:"history",style:{marginRight:10,marginLeft:10}}),d("WF_ACTION_HISTORY_LABEL")]}),i(f,{sx:{flexGrow:1,width:"100%",display:"flex",flexDirection:"column",overflowY:"auto",alignItems:"center",justifyContent:"flex-start"},children:o.actionHistory.map(((a,d)=>i(t,{children:e(f,{sx:{display:"flex",alignItems:"center",justifyContent:"center",width:"100%",marginBottom:2},children:[e(f,{sx:{display:"flex",flex:1,flexDirection:"column",alignItems:"flex-end",justifyContent:"center"},children:[i(f,{sx:{marginBottom:.2},children:a.actionTime}),e(Me,{children:["via ",a.actionMethod]})]}),e(f,{sx:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",position:"relative",marginRight:2,marginLeft:2},children:[i(Ka,{showAsAvatar:!0,attachmentCode:"EMPLOYEE_PHOTOS",refKey:a?.personId+""||"0",style:{m:1,width:70,height:70}}),d!==o.actionHistory.length-1?i(f,{sx:{marginTop:11,position:"absolute"},children:"|"}):i(t,{})]}),e(f,{sx:{display:"flex",flex:1,flexDirection:"column",alignItems:"flex-start",justifyContent:"center"},children:[e(f,{sx:{width:"100%"},children:["ltr"===r.appDirection?`${a?.documentActionEnName}`:`${a?.documentActionArName}`,a?.actionComment?" - "+a.actionComment:""]}),i(f,{sx:{width:"100%"},children:"ltr"===r.appDirection?`${a?.employeeEnName}`:`${a?.employeeArName}`})]})]})})))})]})},Za=o=>{const{t:a}=_e(),r=Ji(),{ConfirmationWindow:d,setOpen:n}=Xi({body:a(o?.confirmationMessage||"ACTION_CONFIRMATION"),title:a("CONFIRMATION"),onConfirmationCallBk:async()=>{await(o?.actionFn(o.recordsToProcessActionOn,o.recordIdsToProcessActionOn)),o?.reloadData&&o.reloadData()}});let l=!0;if(o.authority&&(l=r.isUserAuthorized(o.authority)),l)return e(t,{children:[i(d,{}),e(A,{onClick:async()=>{if(o?.recordsToProcessActionOn&&o?.recordsToProcessActionOn.length>0){if(o?.preActionValidation)for(const e of o.recordsToProcessActionOn)if(!o.preActionValidation(e))return;!0===o?.isConfirmationRequired?n(!0):(await o.actionFn(o.recordsToProcessActionOn,o.recordIdsToProcessActionOn),o?.reloadData&&o.reloadData())}else ce.error(a("AT_LEAST_ONE_RECORD_SELECTED_MESSAGE"))},variant:o?.label?"outlined":o?.formActionProps?.actionButtonVariant?o.formActionProps.actionButtonVariant:"text",size:"small",color:o?.formActionProps?.actionButtonColor||"primary",children:[o?.icon?i(le,{style:{marginRight:5,marginLeft:5},icon:o.icon}):i(t,{}),o?.label?a(o.label):i(t,{})]})]})},ja=S(Ze)({display:"grid",alignItems:"center"}),$a=S(je)((({theme:e,ownerState:i})=>({gridArea:"1 / 1",width:"min-content",height:"min-content",zIndex:1,opacity:i.expanded?0:1,pointerEvents:i.expanded?"none":"auto",transition:e.transitions.create(["opacity"])}))),Xa=S(h)((({theme:e,ownerState:i})=>({gridArea:"1 / 1",overflowX:"clip",width:i.expanded?260:"var(--trigger-width)",opacity:i.expanded?1:0,transition:e.transitions.create(["width","opacity"])}))),Ja=o=>{const{t:a}=_e(),r=Ji(),d=!o?.templateProps?.editAction?.authority||r.isUserAuthorized(o.templateProps.editAction.authority),n=((e,i,t)=>{const o=[],a=[];if("exclude"===e.type&&0===e.ids.size)for(const e of i)o.push(e),a.push(e[t]);else if(e?.ids)for(const r of e.ids){const e=i.find((e=>e[t]===r));o.push(e),a.push(r)}return{selectedRecords:o,selectedRecordIds:a}})(o?.templateProps?.rowSelectionModel||{ids:new Set,type:"include"},o?.templateProps?.data||[],o?.templateProps?.keyColumnName||"id");return e($e,{children:[d&&"none"!=o?.templateProps?.editMode?.editMode?e(A,{onClick:o?.handleCreateNewRecord,children:[i(le,{icon:"add",style:{marginRight:5,marginLeft:5}}),a("ADD_BTN_LABEL")]}):i(t,{}),o?.templateProps?.rowActions?o.templateProps.rowActions.map(((e,i)=>!0===e?.gridActionProps?.multiRecord?ee(Za,{...e,key:i,reloadData:async()=>{o.templateProps.apiActions.reloadData(o?.templateProps?.gridLoadParametersValues)},recordIdsToProcessActionOn:n.selectedRecordIds,recordsToProcessActionOn:n.selectedRecords}):null)):i(t,{}),i(f,{sx:{flex:1,mx:.5},children:o?.templateProps?.tBar}),i(g,{title:"Columns",children:i(Xe,{render:i(je,{}),children:i(Je,{fontSize:"small"})})}),i(g,{title:"Filters",children:i(ei,{render:(e,t)=>i(je,{...e,color:"default",children:i(U,{badgeContent:t.filterCount,color:"primary",variant:"dot",children:i(ii,{fontSize:"small"})})})})}),o?.templateProps?.gridStateKey?i(g,{title:a("RESET_GRID_STATE"),children:i(N,{onClick:o?.clearGridState,children:i(le,{icon:"eraser"})})}):i(t,{}),i(v,{orientation:"vertical",variant:"middle",flexItem:!0,sx:{mx:.5}}),i(g,{title:a("EXPORT_EXECL_LABEL"),children:i(ti,{render:i(w,{}),children:i(le,{icon:"file-excel",color:"green"})})}),e(ja,{children:[i(oi,{render:(e,t)=>i(g,{title:a("SEARCH_BTN_LABEL"),enterDelay:0,children:i($a,{...e,ownerState:{expanded:t.expanded},color:"default","aria-disabled":t.expanded,children:i(le,{icon:"search"})})})}),i(ai,{render:({ref:e,...t},o)=>i(Xa,{...t,ownerState:{expanded:o.expanded},inputRef:e,"aria-label":"Search",placeholder:`${a("SEARCH_BTN_LABEL")}...`,size:"small",slotProps:{input:{startAdornment:i(x,{position:"start",children:i(le,{icon:"search"})}),endAdornment:o.value?i(x,{position:"end",children:i(ri,{edge:"end",size:"small","aria-label":"Clear search",children:i(le,{icon:"xmark"})})}):null,...t.slotProps?.input},...t.slotProps}})})]}),i(N,{onClick:()=>{o.templateProps.apiActions.reloadData(o?.templateProps?.gridLoadParametersValues)},children:i(le,{icon:"refresh"})})]})},er=o=>{const{t:a}=_e(),r=Ji(),{ConfirmationWindow:d,setOpen:n}=Xi({body:a(o?.confirmationMessage||"ACTION_CONFIRMATION"),title:a("CONFIRMATION"),onConfirmationCallBk:async()=>{await(o?.actionFn(o.record)),o?.reloadData&&o.reloadData()}});let l=!0;o.authority&&(l=r.isUserAuthorized(o.authority));let s={};o?.getActionIconStyleForRecord&&(s=o.getActionIconStyleForRecord(o.record));let p=!0;o?.isActionVisibleForRecord&&(p=o?.isActionVisibleForRecord(o.record));let c=!1;if(o?.isActionDisabledForRecord&&(c=o.isActionDisabledForRecord(o.record)),l&&p)return e(t,{children:[i(d,{}),i(di,{disabled:c,icon:i(g,{title:o?.label?a(o.label):"",children:i(le,{icon:o.icon,style:{...s,color:c?"gray":null!=s?.color?s.color:void 0}})}),showInMenu:o?.gridActionProps?.showInMenu||!1,label:"",className:"textPrimary",color:"inherit",onClick:async()=>{if(!c){if(o?.preActionValidation&&!o.preActionValidation(o.record))return;!0===o?.isConfirmationRequired?n(!0):(await o.actionFn(o.record),!0===o?.gridActionProps?.reloadGridAfterAction&&o?.reloadData&&o.reloadData())}}})]})};let ir=-1;const tr=e=>{try{const i=localStorage.getItem(e);return i?JSON.parse(i):{}}catch(e){return console.error("Failed to load grid state",e),{}}},or=(e,i)=>{const t=tr(e);localStorage.setItem(e,JSON.stringify({...t,...i}))},ar=["__check__","actions"],rr=o=>{const{t:r}=_e(),d=a((e=>e.AppLayout)),[n,l]=X({}),[s,p]=X(!0),{getLookupOptions:c}=(()=>{const{handleGetRequest:e}=Hi(),i=a((e=>e.AppLayout)),t=async i=>{let t=[];return await e({endPointURI:"api/v1/public/system/lookup",showMask:!0,parameters:{lookupType:i},successCallBkFn:e=>{t=e.data}}),t};return{generateLookupGridColumn:async e=>{let o=await t(e.lookupType);return{...e,options:o,displayField:"ltr"===i.appDirection?"lookupEnDisplay":"lookupArDisplay",valueField:"lookupValue"}},getLookupOptions:t}})(),{Window:m,setWindowState:T}=et({windowTitle:r(o.gridTitle)+" Attachments",windowIcon:"paperclip",width:"fit-content",height:"fit-content",minHeight:500,minWidth:"50%",onCloseCallBack:()=>{o?.apiActions?.reloadData(o.gridLoadParametersValues)}}),{Window:u,setWindowState:A}=et({windowTitle:r(o.gridTitle)+" Approvals",windowIcon:"stamp",width:"fit-content",height:"fit-content",minHeight:500,minWidth:"80%",onCloseCallBack:()=>{o?.apiActions?.reloadData(o.gridLoadParametersValues)}}),[_,E]=X([]),I=Va(o.formElements),y=[],h=$.useMemo((()=>o?.gridStateKey?tr(o.gridStateKey):{}),[]);for(const e of I)!0===e?.gridProps?.hidden&&y.push(e.fieldName);let R={};if(h?.columnVisibilityModel){R=h.columnVisibilityModel;const e=Object.keys(R);for(const i of y)e.includes(i)||(R[i]=!1)}else for(const e of y)R[e]=!1;const L=a((e=>e.AppLayout.appDirection)),[C,D]=$.useState(R),[P,M]=$.useState(h.columnOrder||[]),[b,S]=$.useState(h.columnWidths||{}),[U,w]=X(h.columnGroupingModel||[]);let x=h?.pinnedColumns?.left||[];x=x.filter((e=>!ar.includes(e)));let W=h?.pinnedColumns?.right||[]||[];W=W.filter((e=>!ar.includes(e)));const[G,Y]=X({left:[..."ltr"===L?ar:[],...x],right:[..."rtl"===L?ar:[],...W]}),V=Ji(),q=Ge(),[K,H]=X(null),[z,Q]=X(null),[Z,j]=X({}),ee=async()=>{let e=((e,t,o)=>{const a=[];for(const d of e)if("text"===d?.fieldType||"number"===d?.fieldType){const e={...d?.gridProps?.muiProps,editable:null!=d?.gridProps?.muiProps?.editable?d?.gridProps?.muiProps?.editable:t,type:"number"==d?.fieldType?"number":"string",field:d?.fieldName,headerName:o(d?.fieldLabel||d?.fieldName),headerAlign:"center",align:"center",hidden:d?.hidden,searchable:d?.gridProps?.searchable,flex:1,minWidth:200};a.push(e)}else if("date"===d?.fieldType){const e=(r={...d?.gridProps?.muiProps,editable:null!=d?.gridProps?.muiProps?.editable?d?.gridProps?.muiProps?.editable:t,field:d?.fieldName,headerName:o(d?.fieldLabel||d?.fieldName),headerAlign:"center",align:"center",hidden:d?.hidden,searchable:d?.gridProps?.searchable,flex:1,minWidth:200},{...r,type:"string",renderEditCell:e=>i(Lt,{sx:{width:"100%"},label:"",value:e.value,onChangeCallBack:i=>{e.api.setEditCellValue({id:e.id,field:e.field,value:i})}}),valueParser:(e,i,t)=>{let o=null;return null!==e&&(o=xe(e).format(It)),o},valueFormatter:(e,i,t)=>i[t.field]});a.push(e)}else if("datetime"===d?.fieldType){const e=ka({...d?.gridProps?.muiProps,editable:null!=d?.gridProps?.muiProps?.editable?d?.gridProps?.muiProps?.editable:t,field:d?.fieldName,headerName:o(d?.fieldLabel||d?.fieldName),headerAlign:"center",align:"center",hidden:d?.hidden,searchable:d?.gridProps?.searchable,flex:1,minWidth:200});a.push(e)}else if("checkbox"===d?.fieldType){const e=Ga({...d?.gridProps?.muiProps,editable:null!=d?.gridProps?.muiProps?.editable?d?.gridProps?.muiProps?.editable:t,field:d?.fieldName,headerName:o(d?.fieldLabel||d?.fieldName),headerAlign:"center",align:"center",hidden:d?.hidden,searchable:d?.gridProps?.searchable,checkedValue:d?.checkedValue,unCheckedValue:d?.unCheckedValue,width:150});a.push(e)}else if("combobox"===d?.fieldType){const e=Wa({...d?.gridProps?.muiProps,editable:null!=d?.gridProps?.muiProps?.editable?d?.gridProps?.muiProps?.editable:t,field:d?.fieldName,headerName:o(d?.fieldLabel||d?.fieldName),headerAlign:"center",align:"center",hidden:d?.hidden,searchable:d?.gridProps?.searchable,valueField:d?.optionValueField||"value",displayField:d?.optionDisplayField||"display",options:d?.options||[],flex:1,minWidth:200});a.push(e)}else if("lookup"===d?.fieldType){const e=Wa({...d?.gridProps?.muiProps,editable:null!=d?.gridProps?.muiProps?.editable?d?.gridProps?.muiProps?.editable:t,lookupType:d?.lookupType,field:d?.fieldName,headerName:o(d?.fieldLabel||d?.fieldName),headerAlign:"center",align:"center",hidden:d?.hidden,searchable:d?.gridProps?.searchable,valueField:d?.optionValueField||"value",displayField:d?.optionDisplayField||"display",options:d?.options||[],flex:1,minWidth:200});a.push(e)}else{const e={field:d.fieldName,...d?.gridProps?.muiProps};a.push(e)}var r;return a})(I,"row"===o?.editMode?.editMode||!1,r);for(let i of e)i?.lookupType&&(i.displayField="ltr"===d.appDirection?"lookupEnDisplay":"lookupArDisplay",i.options=await c(i.lookupType),i.valueField="lookupValue");E(e)},[ie,te]=X({ids:new Set,type:"include"});let oe="id";o?.keyColumnName&&(oe=o?.keyColumnName);const ae=o.setData,re=Be.object(qa(I));let de=!0;o?.editAction?.authority&&(de=V.isUserAuthorized(o.editAction.authority));let ne=!0;o?.deleteAction?.authority&&(ne=V.isUserAuthorized(o.deleteAction.authority));const{ConfirmationWindow:se,setOpen:pe}=Xi({title:"Confirmation",body:"Are you sure you want to delete this record ?",onConfirmationCallBk:async()=>{let e=!0;K&&!0===K?.isNew||(e=await o.apiActions.deleteRecordById(K[oe])),e&&(o?.deleteAction?.postActionCallBack&&await o.deleteAction.postActionCallBack(K),ae((e=>e.filter((e=>e[oe]!=K[oe])))))}});let me,Te,ue,Ae,fe,Ee;"modal"===o?.editMode?.editMode&&(me=o?.editMode?.specs?.modalHeight||"fit-content",Te=o?.editMode?.specs?.modalWidth||"300",ue=o?.editMode?.specs?.modalMinHeight,Ae=o?.editMode?.specs?.modalMinWidth,fe=o?.editMode?.specs?.modalIcon||"window",Ee=o?.editMode?.specs?.modalTitle||"Record Form");const{Window:Ie,setWindowState:Oe}=et({height:me,minHeight:ue,minWidth:Ae,onCloseCallBack:()=>{o.apiActions.reloadData(o?.gridLoadParametersValues)},width:Te,windowIcon:fe,windowTitle:Ee}),Ne={type:"actions",field:"actions",headerName:"",headerAlign:"center",width:(o?.rowActions?30*o.rowActions.length:0)+(o?.editAction&&o?.editAction?.isEnabled?30:0)+(o?.deleteAction&&o?.deleteAction?.isEnabled?30:0)+(o?.attachment?30:0)+(o?.workFlowDocumentCode?30:0),getActions:e=>{const t=e.row,a=[];if("none"!=o?.editMode?.editMode&&(void 0===o?.disableDefaultAction||!o.disableDefaultAction)){const e=Z[t[oe]]?.mode===si.Edit;if("row"===o.editMode.editMode&&e)de&&(a.push(i(di,{icon:i(le,{icon:"save"}),label:r("SAVE_BTN_LABEL"),onClick:()=>{(e=>{const i=e[oe];j({...Z,[i]:{mode:si.View}})})(t)}})),a.push(i(di,{icon:i(le,{icon:"cancel"}),label:r("CANCEL_BTN_LABEL"),onClick:()=>{(e=>{const i=e[oe];i&&ba(i)&&i<0?(j({...Z,[i]:{mode:si.View,ignoreModifications:!0}}),ae((e=>{const t=e.filter((e=>e[oe]!=i));return t}))):j({...Z,[i]:{mode:si.View,ignoreModifications:!0}})})(t)},color:"inherit"})));else{if(o?.editAction&&!0===o?.editAction?.isEnabled){let e=!0;o?.editAction?.isActionVisibleForRecord&&(e=o?.editAction?.isActionVisibleForRecord(t));let d=!1;o?.editAction?.isActionDisabledForRecord&&(d=o?.editAction?.isActionDisabledForRecord(t)),de&&e&&a.push(i(di,{disabled:d,icon:i(g,{title:r("EDIT_BTN_LABEL"),children:i(le,{icon:"edit",style:{color:d?"gray":void 0}})}),showInMenu:o?.editAction?.gridActionProps?.showInMenu||!1,label:r("EDIT_BTN_LABEL"),className:"textPrimary",color:"inherit",onClick:()=>{de&&!d&&(async e=>{if(e)if(Q(e),"form"===o.editMode.editMode)q(o.editMode.specs.formRoute+"/"+e[oe]);else if("modal"===o.editMode.editMode)Oe(!0);else if("row"===o?.editMode?.editMode){const i=e[oe];j({...Z,[i]:{mode:si.Edit}})}})(t)}}))}if(o?.deleteAction&&!0===o?.deleteAction?.isEnabled){let e=!0;o?.deleteAction?.isActionVisibleForRecord&&(e=o?.deleteAction?.isActionVisibleForRecord(t));let d=!1;o?.deleteAction?.isActionDisabledForRecord&&(d=o?.deleteAction?.isActionDisabledForRecord(t)),ne&&e&&a.push(i(di,{disabled:d,icon:i(g,{title:r("DELETE_BTN_LABEL"),children:i(le,{icon:"trash",style:{color:d?"gray":void 0}})}),showInMenu:o?.deleteAction?.gridActionProps?.showInMenu||!1,label:r("DELETE_BTN_LABEL"),className:"textPrimary",color:"inherit",onClick:()=>{if(ne&&!d){if(o?.deleteAction?.preActionValidation&&!o.deleteAction.preActionValidation(t))return;H(t),pe(!0)}}}))}}}if(t[o?.keyColumnName||"id"]&&t[o?.keyColumnName||"id"]>0&&o?.attachment&&a?.push(i(di,{icon:i(g,{title:"Attachments",children:i(le,{icon:"paperclip"})}),label:"Attachments",className:"textPrimary",color:"inherit",onClick:()=>{l(t),p(!o?.attachment?.enableAttachFn||o.attachment.enableAttachFn(t)),T(!0)}})),t[o?.keyColumnName||"id"]&&t[o?.keyColumnName||"id"]>0&&o?.workFlowDocumentCode&&a?.push(i(di,{icon:i(g,{title:"Approvals",children:i(le,{icon:"stamp"})}),label:"Approvals",className:"textPrimary",color:"inherit",onClick:()=>{l(t),A(!0)}})),t[o?.keyColumnName||"id"]&&t[o?.keyColumnName||"id"]>0&&o?.rowActions)for(const e of o.rowActions)e?.gridActionProps?.multiRecord&&!0===e?.gridActionProps?.multiRecord||a.push(i(er,{...e,record:t,reloadData:async()=>{o.apiActions.reloadData(o?.gridLoadParametersValues)}}));return a}};let ye=[];(void 0===o?.disableDefaultAction||!o.disableDefaultAction||o?.rowActions&&o?.rowActions.length>0)&&ye.push(Ne),ye=[...ye,..._];J((()=>{void 0!==o?.autoLoad&&!0!==o.autoLoad||o.apiActions.reloadData(o?.gridLoadParametersValues),ee()}),[]),J((()=>{o.apiActions.reloadData(o?.gridLoadParametersValues)}),[V.UserInfo?.currentOrganization]),J((()=>{ee()}),[L,o.formElements]);const he=$.useMemo((()=>{const e=ye.map((e=>({...e,width:b[e.field]||e.width})));if(P.length){const i=new Map(e.map((e=>[e.field,e])));return P.map((e=>i.get(e))).filter(Boolean)}return e}),[P,b,ye]);return e(t,{children:[i(se,{}),"modal"===o?.editMode?.editMode?i(Ie,{children:o?.editMode?.specs?.formComponent?i(o.editMode.specs.formComponent,{recordIdToEdit:z?z[oe]:void 0,formCloseCallBk:()=>{Oe(!1),o.apiActions.reloadData(o?.gridLoadParametersValues)}}):i(pr,{keyColumnName:o.keyColumnName,attachment:o.attachment,formLoadCallBk:o.formLoadCallBk,recordIdToEdit:z?z[oe]:void 0,formCloseCallBk:()=>{Oe(!1),o.apiActions.reloadData(o?.gridLoadParametersValues)},elements:o.formElements,apiActions:o.apiActions,editAuthorityKey:o?.editAction?.authority,formSavedSuccessfullyCallBk:o?.editAction?.postActionCallBack,preSaveValidation:o?.editAction?.preActionValidation,actions:o?.rowActions})}):i(t,{}),void 0!==o?.hideInfoBar||o?.hideInfoBar?i(t,{}):e(f,{sx:{display:"flex"},children:[void 0!==o?.hideBackButton||o?.hideBackButton?i(t,{}):i(N,{onClick:()=>{q(-1,{replace:!0})},children:i(le,{icon:"arrow-left"})}),e(f,{sx:{flex:1,display:"flex",alignItems:"center",justifyContent:"center"},children:[o?.girdIcon?i(le,{icon:o.girdIcon,style:{marginRight:5,marginLeft:5}}):i(t,{}),i(O,{variant:"h5",children:o?.gridTitle?Sa(r(o?.gridTitle)):""})]})]}),o?.gridLoadParameters&&o?.gridLoadParameters.length>0&&o?.gridLoadParametersValues&&o?.setGridLoadParametersValues?e(F,{defaultExpanded:!0,sx:{width:"100%"},children:[i(B,{expandIcon:i(ni,{}),children:e(f,{sx:{display:"flex",alignItems:"center",justifyContent:"center"},children:[i(le,{style:{marginLeft:5,marginRight:5},icon:"search"}),i(O,{component:"span",children:"Filters"})]})}),i(k,{children:i(f,{children:i(pr,{saveButtonSpecs:{label:r("SEARCH_BTN_LABEL"),icon:"search",actionButtonVariant:"outlined",actionButtonColor:"success"},cancelButtonSpecs:{label:r("RESET_BTN_LABEL"),icon:"eraser",actionButtonVariant:"outlined",actionButtonColor:"error"},apiActions:{deleteRecordById:async()=>!0,saveRecord:async e=>{null!=e?o.setGridLoadParametersValues(e):o.setGridLoadParametersValues({}),o.apiActions.reloadData(e)},reloadData:async()=>{},loadRecordById:async()=>{}},elements:o.gridLoadParameters})})})]}):i(t,{}),o?.attachment?i(m,{children:i(za,{attachmentCode:o.attachment.attachmentCode,refKey:n[o?.keyColumnName||"id"],enableAttachment:s})}):i(t,{}),o?.workFlowDocumentCode?i(u,{children:i(sr,{workFlowDocumentCode:o.workFlowDocumentCode,refDocumentId:n[o?.keyColumnName||"id"],postActionCallBk:()=>{A(!1),o.apiActions.reloadData(o.gridLoadParametersValues)},cancelActionCallBk:()=>{A(!1),o.apiActions.reloadData(o.gridLoadParametersValues)}})}):i(t,{}),i(li,{...o?.muiProps,slots:{toolbar:Ja},slotProps:{toolbar:{templateProps:{...o,rowSelectionModel:ie,data:o?.data},handleCreateNewRecord:()=>{if("form"===o?.editMode?.editMode)q(o.editMode.specs.formRoute);else if("modal"===o?.editMode?.editMode)Q(null),Oe(!0);else if("row"===o?.editMode?.editMode){ir-=1;const e={};e[oe]=ir,e.isNew=!0;for(const i of _)"actions"!=i?.type&&i?.field!=oe&&i?.field&&(e[i.field]=null);ae((i=>[e,...i])),j((e=>({...e,[ir]:{mode:si.Edit}})))}},clearGridState:()=>{o?.gridStateKey&&localStorage.removeItem(o.gridStateKey),D({}),M([]),S({}),w([]),Y({left:[..."ltr"===L?ar:[]],right:[..."rtl"===L?ar:[]]})}}},getRowId:e=>e[oe],showToolbar:!0,rows:o?.data,columns:he,checkboxSelection:!0,editMode:"row",onRowEditStop:(e,i)=>{"rowFocusOut"===e.reason&&(i.defaultMuiPrevented=!0)},rowModesModel:"row"==o.editMode.editMode?Z:void 0,onRowModesModelChange:"row"==o.editMode.editMode?e=>{j(e)}:void 0,rowGroupingColumnMode:"multiple",processRowUpdate:async a=>{if("row"===o.editMode.editMode){let r=null;const d=(e=>{try{re.parse(e)}catch(e){console.log("validateRecord err",e);let i=null;return i=e instanceof Be.ZodError?e.errors.map((e=>"Error in field ("+e.path+") : "+e.message)).join(","):"invalid record data",i}})(a);if(d){const o=d.split(",");throw ce.error(i("div",{style:{},children:o.map((o=>e(t,{children:[i("div",{children:o}),i(v,{})]})))})),new Error(d)}if(o?.editAction?.preActionValidation&&!o.editAction.preActionValidation(a))throw new Error("error on the configured presave validation");const n={...a};if(a[oe]&&ba(a[oe])&&Number(a[oe])<0&&(n[oe]=null),r=await o.apiActions.saveRecord(n),null==r)throw new Error("Failed to process your request, contact your administrator");return o?.editAction?.postActionCallBack&&await o.editAction.postActionCallBack(a),!0===a?.isNew&&ae((e=>{const i=e.filter((e=>e[oe]!==a[oe]));return[r,...i]})),!0===o?.editMode?.reloadAfterSave&&o?.apiActions?.reloadData&&o?.apiActions?.reloadData(o?.gridLoadParametersValues),r}},rowSelectionModel:ie,onRowSelectionModelChange:e=>{te(e)},columnVisibilityModel:C,onColumnVisibilityModelChange:e=>{D(e),o?.gridStateKey&&or(o.gridStateKey,{columnVisibilityModel:e})},onColumnOrderChange:e=>{const{column:i,targetIndex:t}=e;M((e=>{const a=e.length?[...e]:ye.map((e=>e.field)),r=a.indexOf(i.field);return-1===r||(a.splice(r,1),a.splice(t,0,i.field),o?.gridStateKey&&or(o.gridStateKey,{columnOrder:a})),a}))},onColumnWidthChange:e=>{const i={...b,[e.colDef.field]:e.width};S(i),o?.gridStateKey&&or(o.gridStateKey,{columnWidths:i})},rowGroupingModel:U,onRowGroupingModelChange:e=>{(e=>{w(e),o?.gridStateKey&&or(o.gridStateKey,{columnGroupingModel:e})})(e)},pinnedColumns:G,onPinnedColumnsChange:e=>{let i=e?.left||[];i=i.filter((e=>!ar.includes(e)));let t=e?.right||[];t=t.filter((e=>!ar.includes(e)));const a={left:[..."ltr"===L?ar:[],...i],right:[..."rtl"===L?ar:[],...t]};Y(a),o?.gridStateKey&&or(o.gridStateKey,{pinnedColumns:a})},sx:{width:"100%"}})]})},dr=e=>{if(0===e.length)return[];const i=[];for(const t of Object.keys(e[0])){const e={type:"field",mode:"props",props:{fieldLabel:t,fieldName:t,fieldType:"text"}};i.push(e)}return console.log("formElements",i),i},nr=e=>{const[t,o]=X([]);return J((()=>{const i=e.reportData.map(((e,i)=>({...e,report_record_data_key:i})));o(i)}),[e.reportData]),i(rr,{data:t,disableDefaultAction:!0,setData:e.setReportData,formElements:dr(e.reportData),gridLoadParameters:e.gridLoadParameters,gridLoadParametersValues:e.gridLoadParametersValues,setGridLoadParametersValues:e.setGridLoadParametersValues,editMode:{editMode:"none"},girdIcon:"file-excel",gridTitle:"Report",autoLoad:!0,keyColumnName:"report_record_data_key",hideInfoBar:!0,apiActions:{deleteRecordById:async()=>!0,loadRecordById:async()=>{},reloadData:async()=>{e.reloadReport()},saveRecord:async()=>{}}})},lr=o=>{const[a,r]=X(null),[d,n]=X(null),[l,s]=X([]),[p,c]=X("WAITING_REPORT_CODE"),{handleGetRequest:m,handlePostRequest:T,HandleDownloadHTTPPostPDF:u}=Hi(),[A,_]=X(null),[E,I]=X({...o?.reportParametersValues}),[y,h]=X([]),{t:R}=_e(),L=e=>{const i=[];for(const t of e){const e={type:"field",mode:"props",props:{fieldLabel:t?.parameterLabel,fieldName:t?.parameterCode,fieldType:t?.parameterType,hidden:t?.hidden,formProps:{fieldSize:{lg:4,md:6,sm:12}},required:t?.mandatory,defaultValue:E[t?.parameterCode]||t?.defaultValue}};i.push(e)}return i},C=async(e,i)=>{c("WAITING_RESULT"),"Excel"===e?.reportType?await T({endPointURI:"api/v1/public/report/run",showMask:!0,data:{reportCode:o.reportCode,parameters:i,resultMode:o.resultMode,jasperOutPutFileType:o.jasperOutPutFileType},successCallBkFn:e=>{c("SHOWING_RESULT"),s(e.data)}}):e?.reportType&&await u({endPointURI:"api/v1/public/report/run",showMask:!0,data:{reportCode:o.reportCode,parameters:i,resultMode:o.resultMode,jasperOutPutFileType:o.jasperOutPutFileType},successCallBkFn:e=>{c("SHOWING_RESULT");const i=e.headers["content-disposition"];let t="downloaded_file";if(i&&-1!==i.indexOf("filename=")){const e=i.match(/filename="?([^"]+)"?/);e&&e[1]&&(t=e[1])}if(t.includes("pdf")){const i=new Blob([e.data],{type:"application/pdf"}),t=URL.createObjectURL(i);r(t)}else{const i=new Blob([e.data],{type:e.headers["content-type"]}),o=window.URL.createObjectURL(i),a=document.createElement("a");a.href=o,a.download=t,document.body.appendChild(a),a.click(),document.body.removeChild(a),window.URL.revokeObjectURL(o)}console.log(e)},failureCallBkFn:e=>{n("Failed To run report ... contact your administrator"),c("ERROR")}})};return J((()=>{o?.reportCode&&(async()=>{c("LOADING_METADATA"),await m({endPointURI:"api/v1/public/report/metadata",showMask:!0,parameters:{reportCode:o.reportCode},successCallBkFn:e=>{_(e.data),h(L(e.data.reportParameters)),!0===o?.byPassParameterEntry||0==e.data.reportParameters.length?(C(e.data,E),c("WAITING_RESULT")):c("WAITING_PARAMETER_INPUT")},failureCallBkFn:e=>{n("Failed loading report metadata ... contact your administrator"),c("ERROR")}})})()}),[o.reportCode,o.byPassParameterEntry,o.reportParametersValues,o.jasperOutPutFileType,o.resultMode]),e(t,{children:[e(f,{sx:{display:"flex",alignItems:"center",justifyContent:"center",width:"100%"},children:[e(f,{sx:{flex:1,textAlign:"center",marginBottom:1},children:[i(le,{icon:"Excel"===A?.reportType?"file-excel":"file-pdf",color:"Excel"===A?.reportType?"darkgreen":"darkred",style:{marginRight:10,marginLeft:10}}),A?.reportName]}),"Excel"!=A?.reportType&&"SHOWING_RESULT"===p?e(t,{children:[!0===o?.byPassParameterEntry?i(t,{}):y.length>0?i(N,{onClick:()=>{h(L(A.reportParameters)),c("WAITING_PARAMETER_INPUT")},children:i(le,{icon:"filter"})}):i(t,{}),i(N,{children:i(le,{icon:"refresh",onClick:()=>{C(A,E)}})})]}):i(t,{})]}),i(f,{sx:{flexGrow:1,width:"100%",display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"flex-start"},children:"WAITING_PARAMETER_INPUT"===p&&"Excel"!=A?.reportType?e(F,{defaultExpanded:!0,sx:{width:"100%"},expanded:!0,children:[i(B,{children:e(f,{sx:{display:"flex",alignItems:"center",justifyContent:"center"},children:[i(le,{style:{marginLeft:5,marginRight:5},icon:"search"}),i(O,{component:"span",children:"Filters"})]})}),i(k,{children:i(f,{children:i(pr,{saveButtonSpecs:{label:R("SHOW_REPORT_BTN_LABEL"),icon:"search",actionButtonVariant:"outlined",actionButtonColor:"success",hidden:!0},cancelButtonSpecs:{label:R("RESET_BTN_LABEL"),icon:"eraser",actionButtonVariant:"outlined",actionButtonColor:"error"},apiActions:{deleteRecordById:async()=>!0,saveRecord:async e=>{I(null!=e?e:{}),C(A,e)},reloadData:async()=>{},loadRecordById:async()=>{}},elements:y})})})]}):"SHOWING_RESULT"===p||("WAITING_PARAMETER_INPUT"===p||"WAITING_RESULT"===p)&&"Excel"===A?.reportType?"Excel"===A?.reportType?i(nr,{reportData:l,setReportData:s,reloadReport:async()=>{C(A,E)},gridLoadParameters:y,gridLoadParametersValues:E,setGridLoadParametersValues:I}):i("iframe",{src:a,width:"100%",height:"100%",title:"PDF Preview",style:{border:"1px solid #ccc",marginTop:"20px"}}):"ERROR"===p?e(f,{sx:{display:"flex",flex:1,alignItems:"center",justifyContent:"center"},children:[i(le,{icon:"circle-exclamation",color:"darkred",style:{marginRight:10,marginLeft:10}}),d]}):i(t,{})})]})},sr=o=>{const r=Ge(),d=a((e=>e.AppLayout)),{isUserAuthorized:n,UserInfo:l}=Ji(),{handleGetRequest:s,handlePostRequest:p}=Hi(),[c,m]=X(null),[T,u]=X([]),{t:_}=_e(),[E,I]=X(null),[O,h]=X({referencedDocument:null,workflowDocumentReport:null,workflowDocument:null,workflowDocumentStatus:null,actionsHistory:[],nextActionTakers:null,nextActions:[]}),{Window:R,setWindowState:L}=et({windowTitle:"ltr"===d.appDirection?O?.workflowDocument&&O?.referencedDocument?`${O?.workflowDocument?.documentEnName} # ${O?.referencedDocument[O?.workflowDocument?.documentNumberField]}`:"Document":O?.workflowDocument&&O?.referencedDocument?`${O?.workflowDocument?.documentArName} # ${O?.referencedDocument[O?.workflowDocument?.documentNumberField]}`:"وثيقة",windowIcon:"eye",width:"80%"}),C=async()=>{await s({endPointURI:"api/v1/public/workflow/doc/info",showMask:!0,parameters:{workflowDocumentCode:o.workFlowDocumentCode,refDocumentId:o.refDocumentId},successCallBkFn:e=>{h(e.data)},failureCallBkFn:()=>{h({referencedDocument:null,workflowDocumentReport:null,workflowDocument:null,workflowDocumentStatus:null,actionsHistory:[],nextActions:[],nextActionTakers:null})}})},D=async()=>{await p({endPointURI:"api/v1/public/workflow/doc/action",showMask:!0,data:{workflowDocumentId:O?.workflowDocument?.id,refDocumentId:o.refDocumentId,actionId:c.id,refDocumentStatus:O?.workflowDocumentStatus?.documentStatusCode,actionComment:E},successCallBkFn:async e=>{c?.post_action_endpoint?await p({endPointURI:c.post_action_endpoint,showMask:!0,loadingMessage:"Processing post action process ... please wait",parameters:{refDocumentId:o.refDocumentId,actionId:c.id},successCallBkFn:()=>{C(),o?.postActionCallBk&&o.postActionCallBk()}}):C()}})};return J((()=>{o.refDocumentId&&o.workFlowDocumentCode&&C()}),[o.refDocumentId,o.workFlowDocumentCode]),J((()=>{u(O?.nextActions&&O?.nextActions?.length>0?O.nextActions.filter((e=>{if(!O?.workflowDocumentStatus?.nextActionTakersAuthority&&!O?.nextActionTakers)return!0;if(O?.workflowDocumentStatus?.nextActionTakersAuthority&&n(O.workflowDocumentStatus.nextActionTakersAuthority))return!0;if(O?.nextActionTakers)for(const e of O.nextActionTakers)if(l?.username===e?.username||l?.username===e?.USERNAME)return!0;return!1})):[])}),[O.nextActions,O.nextActionTakers]),e(t,{children:[O?.workflowDocumentReport?.id?i(R,{children:i(lr,{reportCode:O?.workflowDocumentReport?.reportCode,resultMode:"App",byPassParameterEntry:!0,reportParametersValues:{doc_id:o.refDocumentId+""}})}):i(t,{}),O?.workflowDocument?e(f,{sx:{width:"100%",textAlign:"center",fontSize:20,fontWeight:"bold",display:"flex",alignItems:"center",justifyContent:"center"},children:[i(N,{onClick:()=>{r(-1,{replace:!0})},children:i(le,{icon:"arrow-left"})}),i(f,{sx:{flex:1}}),i(le,{icon:"file",style:{marginRight:10,marginLeft:10}}),"ltr"===d.appDirection?`${O?.workflowDocument?.documentEnName} # ${O?.referencedDocument[O?.workflowDocument?.documentNumberField]}`:`${O?.workflowDocument?.documentArName} # ${O?.referencedDocument[O?.workflowDocument?.documentNumberField]}`,O?.workflowDocumentStatus?"ltr"===d.appDirection?` ( ${O?.workflowDocumentStatus?.documentStatusEnName} )`:` ( ${O?.workflowDocumentStatus?.documentStatusArName} )`:"",i(f,{sx:{flex:1}}),O?.workflowDocumentReport?.id?i(A,{onClick:()=>{L(!0)},variant:"outlined",startIcon:i(le,{icon:"eye"}),children:_("VIEW_LABEL")}):i(t,{})]}):i(t,{}),e(f,{sx:{flex:1,width:"100%",overflow:"hidden",display:"flex"},children:[T?.length>0?e(y,{sx:{padding:2,display:"flex",flex:1,margin:1,flexDirection:"column",alignItems:"center",justifyContent:"flex-start",overflow:"hidden"},children:[i(Et,{sx:{marginBottom:2,width:400},label:_("WE_AVAILABLE_ACTIONS_LABEL"),displayField:"ltr"===d.appDirection?"document_action_en_name":"document_action_ar_name",valueField:"id",value:c?.id,options:T,onChangeCallBack:(e,i)=>{m(i)}}),i(dt,{sx:{width:400},rows:3,value:E,onChange:e=>{I(e.target.value)},multiline:!0,label:_("WF_COMMENT_LABEL")}),e(f,{sx:{display:"flex",alignItems:"center",justifyContent:"center"},children:[i(A,{color:"success",variant:"contained",sx:{width:200,m:1},onClick:async()=>{null!=c&&null!=c?.id?!0!==c.require_comment&&1!==c.require_comment&&"true"!==c.require_comment||null!==E&&""!==E?c?.pre_action_endpoint?await p({endPointURI:c.pre_action_endpoint,showMask:!0,loadingMessage:"Processing pre action validation ... please wait",parameters:{refDocumentId:o.refDocumentId,actionId:c.id},successCallBkFn:()=>{D()}}):D():ce.error("You must enter comment for the action to be processed"):ce.error("You must select action to process")},children:_("WF_TAKE_ACTION_BTN_LABEL")}),o?.cancelActionCallBk?i(A,{variant:"contained",sx:{width:200,m:1},color:"error",onClick:()=>{o?.cancelActionCallBk&&o.cancelActionCallBk()},children:_("WF_CANCEL_BTN_LABEL")}):i(t,{})]}),O?.nextActionTakers&&O.nextActionTakers.length>0?e(t,{children:[i(v,{variant:"fullWidth",flexItem:!0,sx:{marginTop:1,marginBottom:1},children:e(f,{sx:{width:"100%",display:"flex",alignItems:"center",justifyContent:"center",fontSize:18,fontWeight:"bold"},children:[i(le,{icon:"users",style:{marginRight:10,marginLeft:10}})," ",_("WF_WAITING_FOR_LABEL")]})}),i(f,{sx:{flex:1,display:"flex",flexDirection:"column",alignItems:"center",overflow:"auto",padding:1,width:"100%"},children:O.nextActionTakers.map((o=>e(f,{sx:{display:"flex",alignItems:"center",justifyContent:"center",border:"1px dotted black",width:400,marginBottom:2,padding:2},children:[i(Ka,{showAsAvatar:!0,attachmentCode:"EMPLOYEE_PHOTOS",refKey:o?.id||"0",style:{marginRight:2,marginLeft:2,width:60,height:60}}),e(f,{sx:{flex:2,display:"flex",flexDirection:"column",alignItems:"flex-start",justifyContent:"center"},children:[i("div",{children:"ltr"===d.appDirection?o?.employee_en_name:o?.employee_ar_name}),i("div",{children:o?.email?e(t,{children:[i(le,{icon:"envelope",style:{marginRight:10,marginLeft:10}}),o?.email]}):i(t,{})}),i("div",{children:o?.mobile_number?e(t,{children:[i(le,{icon:"mobile",style:{marginRight:10,marginLeft:10}}),o?.mobile_number]}):i(t,{})})]})]})))})]}):i(t,{})]}):i(t,{}),O?.actionsHistory.length>0?i(Qa,{actionHistory:O.actionsHistory}):e(y,{sx:{display:"flex",flexDirection:"column",flexGrow:1,padding:2,margin:1,alignItems:"center",justifyContent:"center"},children:[e(f,{sx:{width:"100%",display:"flex",alignItems:"center",justifyContent:"center",fontSize:18,fontWeight:"bold"},children:[i(le,{icon:"history",style:{marginRight:10,marginLeft:10}}),_("WF_ACTION_HISTORY_LABEL")]}),i(f,{sx:{flex:1,display:"flex",alignItems:"center",justifyContent:"center"},children:"No Action Log available"})]})]})]})},pr=o=>{const{Window:a,setWindowState:r}=et({windowTitle:"Attachments",windowIcon:"paperclip",width:"fit-content",height:"fit-content",minHeight:500,minWidth:400}),{Window:d,setWindowState:n}=et({windowTitle:"Approvals",windowIcon:"stamp",width:"fit-content",height:"fit-content",minHeight:500,minWidth:400}),[l,s]=X(!0),{t:p}=_e(),c=Va(o.elements),m=[];for(const e of c)e?.hidden&&m.push(e.fieldName);const[T,u]=X(m),_={};for(const e of o.elements)"field"===e?.type&&"props"===e?.mode&&e?.props?.defaultValue&&(_[e.props.fieldName]=e.props.defaultValue);const[f,E]=X([]),I=Fe.object(qa(c)),O=ke({resolver:We(I),defaultValues:_}),y=O.watch(),h=Ye(),L=o?.formRouteRecordIdParamName,C=async()=>{let e=null;if(o?.recordIdToEdit?e=o.recordIdToEdit:L&&h[L]&&(e=h[L]),e){const i=await o.apiActions.loadRecordById(e);if(i){O.reset({...i}),o?.formLoadCallBk&&o?.formLoadCallBk(D,O,i);for(const e of c)"combobox"===e?.fieldType&&i[e.fieldName]&&O.setValue(e.fieldName,i[e.fieldName]+"")}}else O.reset({})},D={setFieldValue:(e,i)=>{O.setValue(e,i)},hideField:e=>{u((i=>[...i,e]))},showField:e=>{u((i=>i.filter((i=>i!==e))))},disableField:e=>{E((i=>[...i,e]))},enableField:e=>{E((i=>i.filter((i=>i!==e))))}};return J((()=>{C()}),[o?.recordIdToEdit]),J((()=>{s(!o?.attachment||!o?.attachment?.enableAttachFn||o.attachment.enableAttachFn(y))}),[y]),e(t,{children:[o?.attachment?i(a,{children:i(za,{attachmentCode:o.attachment.attachmentCode,refKey:y[o?.keyColumnName||"id"],enableAttachment:l})}):i(t,{}),o?.workFlowDocumentCode?i(d,{children:i(sr,{workFlowDocumentCode:o.workFlowDocumentCode,refDocumentId:y[o?.keyColumnName||"id"],postActionCallBk:()=>{n(!1),C()},cancelActionCallBk:()=>{n(!1)}})}):i(t,{}),i(Pa,{sx:{display:"flex",flex:1,width:"100%",height:"fit-content",flexDirection:"column",alignItems:"center",overflow:"auto"},children:i(R,{sx:{width:"100%"},container:!0,children:o.elements.map(((e,t)=>"group"===e.type?i(Ba,{...e.props,formManager:O,formValues:y,formActions:D,hiddenFields:T,disabledFields:f},t):"field"===e.type&&"props"===e.mode?i(xa,{fieldInfo:e.props,formManager:O,formValues:y,formActions:D,hiddenFields:T,disabledFields:f},t):"field"===e.type&&"node"===e.mode?i(R,{size:e?.props?.formProps?.fieldSize||{lg:3,md:6,xs:12},sx:{padding:1,width:"100%"},children:i(e.node,{formManager:O,formValues:y})},t):void 0))})}),e(Pa,{sx:{display:"flex",width:"100%",alignItems:"center",justifyContent:"flex-start"},children:[y[o?.keyColumnName||"id"]&&o?.attachment?i(g,{title:"Attachments",children:i(N,{onClick:()=>{r(!0)},children:i(le,{icon:"paperclip"})})}):null,y[o?.keyColumnName||"id"]&&o?.workFlowDocumentCode?i(g,{title:"Approvals",children:i(N,{onClick:()=>{n(!0)},children:i(le,{icon:"stamp"})})}):null,o?.actions&&y[o?.keyColumnName||"id"]?o.actions.map((e=>!0===e?.formActionProps?.enabled?i(Fa,{...e,record:y}):i(t,{}))):i(t,{}),i("div",{style:{flex:1}}),i(A,{variant:o?.saveButtonSpecs?.actionButtonVariant?o.saveButtonSpecs.actionButtonVariant:"contained",sx:{m:1},startIcon:o?.saveButtonSpecs?.icon?i(le,{icon:o.saveButtonSpecs.icon}):null,color:o?.saveButtonSpecs?.actionButtonColor?o.saveButtonSpecs.actionButtonColor:"primary",onClick:O.handleSubmit((e=>{console.log("form values",e),(async e=>{if((!o?.preSaveValidation||o.preSaveValidation(e))&&e){const i=await o.apiActions.saveRecord(e);i&&(O.reset({...i}),o?.formSavedSuccessfullyCallBk&&o.formSavedSuccessfullyCallBk(i),o?.formCloseCallBk&&o.formCloseCallBk())}})(e)}),(e=>{ce.error("Form Data is not valid, make sure you have all field with valid data"),console.log("form validation error",e)})),children:p(o?.saveButtonSpecs?.label||"SAVE_BTN_LABEL")}),i(A,{variant:o?.cancelButtonSpecs?.actionButtonVariant?o.cancelButtonSpecs.actionButtonVariant:"contained",startIcon:o?.cancelButtonSpecs?.icon?i(le,{icon:o.cancelButtonSpecs.icon}):null,color:o?.cancelButtonSpecs?.actionButtonColor?o.cancelButtonSpecs.actionButtonColor:"error",sx:{m:1},onClick:()=>{o?.formCloseCallBk&&o.formCloseCallBk(),O.reset(_)},children:p(o?.cancelButtonSpecs?.label||"CANCEL_BTN_LABEL")})]})]})},cr=()=>{const{workflowDocumentCode:e,refDocumentId:t}=Ye();return i(sr,{workFlowDocumentCode:e,refDocumentId:t})},mr=t=>{const{UserSession:r}=Ji(),d=a((e=>e.AppLayout)),n=o(),{handlePostRequest:l}=Hi(),[s,p]=X(r.value.currentOrganization.id);return e(f,{sx:{display:"flex",flexDirection:"column",width:"100%",alignItems:"center",justifyContent:"center",padding:1},children:[i(Et,{sx:{width:"100%"},displayField:"ltr"===d.appDirection?"organizationEnName":"organizationArName",valueField:"id",label:"",options:r.value.userOrganizations,value:s,onChangeCallBack:e=>{p(e)}}),i(A,{sx:{m:1},variant:"contained",disabled:null==s||s===r.value.currentOrganization.id,onClick:async()=>{await l({endPointURI:"api/auth/changeCurrentOrg",showMask:!0,parameters:{username:r.value.username,orgId:s},data:{},successCallBkFn:e=>{const i={...e.data,isAuthenticated:!0};n(qi.setAuthenticated(i)),t.successChangeCallBackFn&&t.successChangeCallBackFn()}})},children:"Change Organization"})]})},Tr=se({name:"SideBar",initialState:{isOpened:!1},reducers:{toggleSideBarState:e=>{e.isOpened=!e.isOpened},setSideBarState:(e,i)=>{e.isOpened=i.payload}}}),{toggleSideBarState:ur,setSideBarState:Ar}=Tr.actions;var _r=Tr.reducer;function fr(e,i){const t=ie(e);J((()=>{t.current=e}),[e]),J((()=>{const e=setInterval((()=>t.current?.()),i);return()=>clearInterval(e)}),[i])}const Er=W`
32
32
  0% { transform: scale(1); opacity: 1; }
33
33
  25% { transform: scale(1); opacity: 0.6; }
34
34
  50% { transform: scale(1); opacity: 1; }