@asaleh37/ui-base 1.2.2 → 1.2.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../node_modules/style-inject/dist/style-inject.es.js","../src/hooks/UseMobile.tsx","../src/redux/features/common/AppLayoutSlice.ts","../src/redux/features/common/LoadingMaskSlice.ts","../src/hooks/useLoadingMask.tsx","../src/hooks/useAxios.tsx","../src/redux/features/common/UserSessionSlice.ts","../src/locales/english/index.ts","../src/locales/index.ts","../src/locales/arabic/index.ts","../src/locales/i18n.ts","../src/layout/TopBar.tsx","../src/layout/DrawerHeader.tsx","../node_modules/clsx/dist/clsx.mjs","../src/hooks/UseSession.tsx","../src/navigationItems/index.tsx","../src/navigationItems/Administration/index.tsx","../src/navigationItems/Administration/adminNavigationItems.tsx","../src/layout/NavigationTree.tsx","../src/layout/SideBar.tsx","../src/components/common/LayoutHandlers.tsx","../src/hooks/UseConfirmationWindow.tsx","../src/components/templates/DataEntryTemplates/TemplateDataGrid/TemplateGridMultiRecordAction.tsx","../src/util/constants.ts","../src/components/templates/DataEntryTemplates/TemplateDataForm/FormFields/Datefield.tsx","../src/components/templates/DataEntryTemplates/TemplateDataForm/FormFields/DatetimeField.tsx","../src/components/templates/DataEntryTemplates/TemplateDataForm/FormFields/ComboBox.tsx","../src/components/templates/DataEntryTemplates/TemplateDataForm/FormFields/CheckBox.tsx","../src/components/templates/DataEntryTemplates/TemplateDataGrid/DataGridColumnsUtil.tsx","../src/components/templates/DataEntryTemplates/DataEntryUtil.ts","../src/components/templates/DataEntryTemplates/TemplateDataGrid/TemplateGridTopBar.tsx","../src/util/AppUtils.ts","../src/components/templates/DataEntryTemplates/TemplateDataGrid/TemplateGridRecordAction.tsx","../node_modules/@mui/system/node_modules/@mui/utils/esm/formatMuiErrorMessage/formatMuiErrorMessage.js","../node_modules/prop-types/node_modules/react-is/index.js","../node_modules/prop-types/node_modules/react-is/cjs/react-is.production.min.js","../node_modules/prop-types/node_modules/react-is/cjs/react-is.development.js","../node_modules/object-assign/index.js","../node_modules/prop-types/lib/ReactPropTypesSecret.js","../node_modules/prop-types/lib/has.js","../node_modules/prop-types/checkPropTypes.js","../node_modules/prop-types/factoryWithTypeCheckers.js","../node_modules/prop-types/factoryWithThrowingShims.js","../node_modules/prop-types/index.js","../node_modules/react-is/cjs/react-is.production.js","../node_modules/react-is/cjs/react-is.development.js","../node_modules/react-is/index.js","../node_modules/@mui/system/node_modules/@mui/utils/esm/deepmerge/deepmerge.js","../node_modules/@mui/system/esm/createBreakpoints/createBreakpoints.js","../node_modules/@mui/system/esm/createTheme/shape.js","../node_modules/@mui/system/esm/responsivePropType/responsivePropType.js","../node_modules/@mui/system/esm/merge/merge.js","../node_modules/@mui/system/esm/breakpoints/breakpoints.js","../node_modules/@mui/system/esm/cssContainerQueries/cssContainerQueries.js","../node_modules/@mui/system/node_modules/@mui/utils/esm/capitalize/capitalize.js","../node_modules/@mui/system/esm/style/style.js","../node_modules/@mui/system/esm/spacing/spacing.js","../node_modules/@mui/system/esm/memoize/memoize.js","../node_modules/@mui/system/esm/compose/compose.js","../node_modules/@mui/system/esm/borders/borders.js","../node_modules/@mui/system/esm/cssGrid/cssGrid.js","../node_modules/@mui/system/esm/palette/palette.js","../node_modules/@mui/system/esm/sizing/sizing.js","../node_modules/@mui/system/esm/styleFunctionSx/defaultSxConfig.js","../node_modules/@mui/system/esm/styleFunctionSx/styleFunctionSx.js","../node_modules/@mui/system/esm/createTheme/applyStyles.js","../node_modules/@mui/system/esm/useThemeWithoutDefault/useThemeWithoutDefault.js","../node_modules/@mui/system/esm/useTheme/useTheme.js","../node_modules/@mui/system/esm/createTheme/createTheme.js","../node_modules/@mui/system/esm/createTheme/createSpacing.js","../node_modules/@mui/system/esm/styleFunctionSx/extendSxProp.js","../node_modules/@mui/system/node_modules/@mui/utils/esm/ClassNameGenerator/ClassNameGenerator.js","../node_modules/@mui/system/node_modules/@mui/utils/esm/generateUtilityClass/generateUtilityClass.js","../node_modules/@mui/system/esm/Box/boxClasses.js","../node_modules/@mui/system/esm/Box/Box.js","../node_modules/@mui/system/esm/createBox/createBox.js","../node_modules/@mui/styled-engine/esm/index.js","../node_modules/@mui/system/node_modules/@mui/utils/esm/generateUtilityClasses/generateUtilityClasses.js","../src/components/templates/DataEntryTemplates/TemplateDataForm/FormFields/TemplateTextField.tsx","../src/components/templates/DataEntryTemplates/TemplateDataForm/FormElementField.tsx","../src/components/templates/DataEntryTemplates/TemplateDataForm/FormAction.tsx","../src/components/templates/DataEntryTemplates/TemplateDataForm/FormElementGroup.tsx","../src/components/templates/DataEntryTemplates/TemplateDataForm/TemplateForm.tsx","../src/hooks/UseWindow.tsx","../src/components/templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid.tsx","../src/redux/features/common/CommonStoreSlice.ts","../src/hooks/useApiActions.ts","../src/components/templates/TransferList.tsx","../src/components/templates/visuals/charts/TemplatePieChart.tsx","../src/components/templates/visuals/charts/TemplateBarChart.tsx","../src/components/templates/visuals/charts/TemplateLineChart.tsx","../src/components/templates/visuals/charts/TemplateGauge.tsx","../src/components/templates/visuals/charts/TemplateDataCard.tsx","../src/components/templates/visuals/charts/TemplateLineProgress.tsx","../src/components/templates/visuals/TemplateDashboard.tsx","../src/components/admin/RoleAuthoritiesForm.tsx","../src/routes/index.ts","../src/components/common/Home.tsx","../src/routes/administration/index.ts","../src/routes/administration/adminRoutes.tsx","../src/components/admin/AttachmentGrid.tsx","../src/components/admin/AuthorityGrid.tsx","../src/components/admin/BluePrintGrid.tsx","../src/components/admin/BluePrintPageGrid.tsx","../src/components/admin/BluePrintPointGrid.tsx","../src/components/admin/DashboardGrid.tsx","../src/components/admin/DashboardWidgetGrid.tsx","../src/components/admin/DataQueryGrid.tsx","../src/components/admin/DataQueryParameterGrid.tsx","../src/components/admin/DatasourceConnectionGrid.tsx","../src/components/admin/EmployeeGrid.tsx","../src/components/admin/EntityParameterGrid.tsx","../src/components/admin/ExcelUploaderDetailGrid.tsx","../src/components/admin/ExcelUploaderHeaderGrid.tsx","../src/components/admin/LookupGrid.tsx","../src/components/admin/MailAttachmentGrid.tsx","../src/components/admin/MailBodyGrid.tsx","../src/components/admin/MailNotificationQueueGrid.tsx","../src/components/admin/MailRecipientGrid.tsx","../src/components/admin/MailTemplateGrid.tsx","../src/components/admin/NewTableGrid.tsx","../src/components/admin/NotificationGrid.tsx","../src/components/admin/NotificationQueueGrid.tsx","../src/components/admin/OrganizationGrid.tsx","../src/components/admin/OrganizationApplicationGrid.tsx","../src/components/admin/OrganizationRankGrid.tsx","../src/components/admin/OrganizationUnitGrid.tsx","../src/components/admin/OrganizationUserGrid.tsx","../src/components/admin/OrganizationUserRoleGrid.tsx","../src/components/admin/ReportGrid.tsx","../src/components/admin/ReportParameterGrid.tsx","../src/components/admin/RoleGrid.tsx","../src/components/admin/RoleAuthorityGrid.tsx","../src/components/admin/UserAccountGrid.tsx","../src/components/admin/UserRequestGrid.tsx","../src/components/admin/WidgetGrid.tsx","../src/components/admin/WorkflowDocumentGrid.tsx","../src/components/admin/WorkflowDocumentActionGrid.tsx","../src/components/admin/WorkflowDocumentActionHistoryGrid.tsx","../src/components/admin/WorkflowDocumentActionMailGrid.tsx","../src/components/admin/WorkflowDocumentMailLogGrid.tsx","../src/components/admin/WorkflowDocumentStatusGrid.tsx","../src/layout/MainContent.tsx","../src/layout/MobileDrawer.tsx","../src/components/common/LoadingMask.tsx","../src/components/common/Login.tsx","../src/layout/Layout.tsx","../src/redux/features/common/AppInfoSlice.ts","../src/redux/features/administration/AdministrationStoresMetaData.ts","../src/components/App.tsx","../src/components/BaseApp.tsx"],"sourcesContent":["function styleInject(css, ref) {\n if ( ref === void 0 ) ref = {};\n var insertAt = ref.insertAt;\n\n if (!css || typeof document === 'undefined') { return; }\n\n var head = document.head || document.getElementsByTagName('head')[0];\n var style = document.createElement('style');\n style.type = 'text/css';\n\n if (insertAt === 'top') {\n if (head.firstChild) {\n head.insertBefore(style, head.firstChild);\n } else {\n head.appendChild(style);\n }\n } else {\n head.appendChild(style);\n }\n\n if (style.styleSheet) {\n style.styleSheet.cssText = css;\n } else {\n style.appendChild(document.createTextNode(css));\n }\n}\n\nexport default styleInject;\n","import { useEffect, useState } from \"react\";\r\n\r\nexport const useIsMobile = (breakpoint = 768) => {\r\n const [isMobile, setIsMobile] = useState(window.innerWidth < breakpoint);\r\n\r\n useEffect(() => {\r\n const handleResize = () => setIsMobile(window.innerWidth < breakpoint);\r\n window.addEventListener(\"resize\", handleResize);\r\n return () => window.removeEventListener(\"resize\", handleResize);\r\n }, [breakpoint]);\r\n\r\n return isMobile;\r\n};\r\n","import { createSlice } from \"@reduxjs/toolkit\";\r\n\r\nexport const DRAWER_WIDTH = 350;\r\n\r\ninterface AppLayoutState {\r\n sideBarOpened: boolean;\r\n themeMode: \"light\" | \"dark\" | string;\r\n appDirection: \"ltr\" | \"rtl\";\r\n}\r\n\r\nconst initialState: AppLayoutState = {\r\n sideBarOpened: false,\r\n themeMode: localStorage.getItem(\"themeMode\") || \"light\",\r\n appDirection: localStorage.getItem(\"language\") == \"ar\" ? \"rtl\" : \"ltr\",\r\n};\r\n\r\nconst AppLayoutSlice = createSlice({\r\n name: \"AppLayout\",\r\n initialState,\r\n reducers: {\r\n toggleSideBarState: (state) => {\r\n state.sideBarOpened = !state.sideBarOpened;\r\n },\r\n setSideBarState: (state, action) => {\r\n state.sideBarOpened = action.payload;\r\n },\r\n setThemeMode: (state, action) => {\r\n state.themeMode = action.payload;\r\n },\r\n setAppDirection: (state, action) => {\r\n state.appDirection = action.payload;\r\n },\r\n },\r\n});\r\n\r\nexport const AppLayoutActions = AppLayoutSlice.actions;\r\nexport default AppLayoutSlice.reducer;\r\n","import { createSlice, PayloadAction } from \"@reduxjs/toolkit\";\r\n\r\ninterface LoadingMaskStateValue {\r\n value: { isOpened: boolean; message?: string | null };\r\n}\r\n\r\nconst initialState: LoadingMaskStateValue = {\r\n value: { isOpened: false, message: null },\r\n};\r\n\r\nconst loadingMaskSlice = createSlice({\r\n name: \"loadingMask\",\r\n initialState,\r\n reducers: {\r\n showLoadingMask: (\r\n state,\r\n action: PayloadAction<string | null | undefined>\r\n ) => {\r\n state.value.isOpened = true;\r\n state.value.message = action.payload;\r\n },\r\n hideLoadingMask: (state) => {\r\n state.value.isOpened = false;\r\n state.value.message = null;\r\n },\r\n },\r\n});\r\n\r\nexport const { showLoadingMask, hideLoadingMask } = loadingMaskSlice.actions;\r\nexport default loadingMaskSlice.reducer;\r\n","import { useDispatch } from \"react-redux\";\r\nimport { hideLoadingMask, showLoadingMask } from \"../redux/features/common/LoadingMaskSlice\";\r\n\r\n\r\nconst useLoadingMask = () => {\r\n const dispatch = useDispatch();\r\n const show = (message?: string) => {\r\n dispatch(showLoadingMask(message));\r\n };\r\n const hide = () => {\r\n dispatch(hideLoadingMask());\r\n };\r\n return { show, hide };\r\n};\r\n\r\nexport default useLoadingMask;\r\n","import { toast } from \"react-toastify\";\r\nimport axios from \"axios\";\r\nimport { useSelector } from \"react-redux\";\r\nimport { RootState } from \"../redux/store\";\r\nimport useLoadingMask from \"./useLoadingMask\";\r\n\r\nexport interface APIRequest {\r\n endPointURI: string;\r\n parameters?: any;\r\n data?: any;\r\n showMask?: Boolean;\r\n loadingMessage?: string;\r\n successCallBkFn?: Function;\r\n failureCallBkFn?: Function;\r\n}\r\n\r\nconst useAxios = () => {\r\n const mask = useLoadingMask();\r\n const apiBaseUrl = useSelector(\r\n (state: RootState) => state.AppInfo.value.apiBaseUrl\r\n );\r\n const axiosInstance = axios.create({\r\n baseURL: apiBaseUrl,\r\n timeout: 600000,\r\n withCredentials: true,\r\n });\r\n\r\n axiosInstance.defaults.withCredentials = true;\r\n axiosInstance.interceptors.response.use(\r\n (response: any) => {\r\n return response;\r\n },\r\n (error: any) => {\r\n if (\r\n error\r\n ? error.response\r\n ? error.response.status\r\n ? error.response.status === 401\r\n : false\r\n : false\r\n : false\r\n ) {\r\n toast.error(\"your session is now expired, you need to login again\", {\r\n autoClose: false,\r\n });\r\n } else if (\r\n error\r\n ? error.response\r\n ? error.response.status\r\n ? error.response.status === 403\r\n : false\r\n : false\r\n : false\r\n ) {\r\n toast.error(\"you aren't authorized to process this request\");\r\n } else if (\r\n error\r\n ? error.response\r\n ? error.response.status\r\n ? error.response.status === 500\r\n : false\r\n : false\r\n : false\r\n ) {\r\n toast.error(error.response.data);\r\n } else {\r\n toast.error(\r\n \"failed to communicate with the server ... try again later\"\r\n );\r\n }\r\n return \"ERROR\";\r\n }\r\n );\r\n const handleGetRequest = async (\r\n props: APIRequest = { endPointURI: \"\", parameters: {} }\r\n ) => {\r\n if (\r\n props.showMask !== undefined &&\r\n props.showMask != null &&\r\n props.showMask === true\r\n ) {\r\n mask.show(props.loadingMessage);\r\n }\r\n const response: any = await axiosInstance.get(props.endPointURI, {\r\n params: { ...props.parameters },\r\n withCredentials: true,\r\n // withCredentials: true,\r\n });\r\n if (\r\n props.showMask !== undefined &&\r\n props.showMask != null &&\r\n props.showMask === true\r\n ) {\r\n mask.hide();\r\n }\r\n if (response !== \"ERROR\") {\r\n if (\r\n props.successCallBkFn !== undefined &&\r\n props.successCallBkFn != null\r\n ) {\r\n props.successCallBkFn(response);\r\n }\r\n return response;\r\n } else {\r\n if (\r\n props.failureCallBkFn !== undefined &&\r\n props.failureCallBkFn != null\r\n ) {\r\n props.failureCallBkFn(response);\r\n }\r\n return \"ERROR\";\r\n }\r\n };\r\n\r\n const HandleDownloadHTTPPostPDF = async (\r\n props: APIRequest = { endPointURI: \"\", parameters: {}, data: {} }\r\n ) => {\r\n if (\r\n props.showMask !== undefined &&\r\n props.showMask != null &&\r\n props.showMask === true\r\n ) {\r\n mask.show(props.loadingMessage);\r\n }\r\n const response: any = await axiosInstance.post(\r\n props.endPointURI,\r\n props.data,\r\n {\r\n responseType: \"blob\",\r\n }\r\n );\r\n if (\r\n props.showMask !== undefined &&\r\n props.showMask != null &&\r\n props.showMask === true\r\n ) {\r\n mask.hide();\r\n }\r\n if (response !== \"ERROR\") {\r\n if (\r\n props.successCallBkFn !== undefined &&\r\n props.successCallBkFn != null\r\n ) {\r\n props.successCallBkFn(response);\r\n }\r\n return response;\r\n } else {\r\n if (\r\n props.failureCallBkFn !== undefined &&\r\n props.failureCallBkFn != null\r\n ) {\r\n props.failureCallBkFn(response);\r\n }\r\n return \"ERROR\";\r\n }\r\n // axiosInstance\r\n // .request({\r\n // url: props.endPointURI,\r\n // method: \"POST\",\r\n // data: props.data,\r\n // responseType: \"blob\",\r\n // })\r\n // .then((response) => {\r\n // const url = window.URL.createObjectURL(\r\n // new Blob([response.data], { type: \"application/pdf\" })\r\n // );\r\n // const link = document.createElement(\"a\");\r\n // link.href = url;\r\n // link.setAttribute(\"download\", \"example.pdf\"); // specify download filename\r\n // document.body.appendChild(link);\r\n // link.click();\r\n // link.remove();\r\n // })\r\n // .catch((error) => {\r\n // console.error(\"Download error:\", error);\r\n // })\r\n // .finally(() => {\r\n\r\n // });\r\n };\r\n const handlePostRequest = async (\r\n props: APIRequest = { endPointURI: \"\", parameters: {}, data: {} }\r\n ) => {\r\n if (\r\n props.showMask !== undefined &&\r\n props.showMask != null &&\r\n props.showMask === true\r\n ) {\r\n mask.show(props.loadingMessage);\r\n }\r\n let response: any = await axiosInstance.post(\r\n props.endPointURI,\r\n props.data,\r\n {\r\n params: props.parameters,\r\n }\r\n );\r\n if (\r\n props.showMask !== undefined &&\r\n props.showMask != null &&\r\n props.showMask === true\r\n ) {\r\n mask.hide();\r\n }\r\n if (response !== \"ERROR\") {\r\n if (\r\n props.successCallBkFn !== undefined &&\r\n props.successCallBkFn != null\r\n ) {\r\n props.successCallBkFn(response);\r\n }\r\n return response;\r\n } else {\r\n if (\r\n props.failureCallBkFn !== undefined &&\r\n props.failureCallBkFn != null\r\n ) {\r\n props.failureCallBkFn(response);\r\n }\r\n return \"ERROR\";\r\n }\r\n };\r\n const handleDeleteRequest = async (\r\n props: APIRequest = { endPointURI: \"\", parameters: {} }\r\n ) => {\r\n if (\r\n props.showMask !== undefined &&\r\n props.showMask != null &&\r\n props.showMask === true\r\n ) {\r\n mask.show(props.loadingMessage);\r\n }\r\n let response: any = await axiosInstance.delete(props.endPointURI, {\r\n params: {\r\n ...props.parameters,\r\n },\r\n });\r\n if (\r\n props.showMask !== undefined &&\r\n props.showMask != null &&\r\n props.showMask === true\r\n ) {\r\n mask.hide();\r\n }\r\n if (response !== \"ERROR\") {\r\n if (\r\n props.successCallBkFn !== undefined &&\r\n props.successCallBkFn != null\r\n ) {\r\n props.successCallBkFn(response);\r\n }\r\n return response;\r\n } else {\r\n if (\r\n props.failureCallBkFn !== undefined &&\r\n props.failureCallBkFn != null\r\n ) {\r\n props.failureCallBkFn(response);\r\n }\r\n return \"ERROR\";\r\n }\r\n };\r\n return {\r\n handleGetRequest,\r\n handlePostRequest,\r\n handleDeleteRequest,\r\n HandleDownloadHTTPPostPDF,\r\n };\r\n};\r\n\r\nexport default useAxios;\r\n","import { createSlice } from \"@reduxjs/toolkit\";\r\n\r\nexport interface OrganizationProps {\r\n organizationCode?: string;\r\n organizationName?: string;\r\n}\r\nexport interface UserProfileProps {\r\n username?: string;\r\n currentOrganizationCode?: string;\r\n userOrganizations?: Array<OrganizationProps>;\r\n employeeNumber?: string;\r\n employeeName?: string;\r\n divisionCode?: string;\r\n divisionName?: string;\r\n departmentCode?: string;\r\n departmentName?: string;\r\n rankCode?: string;\r\n rankName?: string;\r\n sectionCode?: string;\r\n sectionName?: string;\r\n subsectionCode?: string;\r\n subsectionName?: string;\r\n extNumber?: string;\r\n mobileNumber?: string;\r\n email?: string;\r\n}\r\n\r\nexport interface UserSessionProps {\r\n value: {\r\n isAuthenticated: boolean | null;\r\n userProfile: UserProfileProps | null;\r\n authorities: Array<{ authority: string }>;\r\n };\r\n}\r\n\r\nconst initialState: UserSessionProps = {\r\n value: {\r\n isAuthenticated: null,\r\n authorities: [],\r\n userProfile: null,\r\n },\r\n};\r\n\r\nconst UserSessionSlice = createSlice({\r\n name: \"UserSession\",\r\n initialState,\r\n reducers: {\r\n setAuthenticated: (state, action) => {\r\n state.value = action.payload;\r\n },\r\n setUnAuthenticated: (state) => {\r\n state.value = {\r\n isAuthenticated: false,\r\n authorities: [],\r\n userProfile: null,\r\n };\r\n },\r\n },\r\n});\r\n\r\nexport const UserSessionActions = UserSessionSlice.actions;\r\nexport default UserSessionSlice.reducer;\r\n","import common from \"./common.json\";\r\nimport AdminLocalsEn from \"./adminLocalsEn.json\";\r\nexport const ENGLISH_TRANS = {\r\n ...common,\r\n ...AdminLocalsEn,\r\n};\r\n","import { ARABIC_TRANS } from \"./arabic\";\r\nimport { ENGLISH_TRANS } from \"./english\";\r\n\r\nconst resources = {\r\n en: { translation: ENGLISH_TRANS },\r\n ar: { translation: ARABIC_TRANS },\r\n};\r\n\r\nexport default resources;\r\n","import common from \"./common.json\";\r\nimport adminLocalsAr from \"./adminLocalsAr.json\";\r\n\r\nexport const ARABIC_TRANS = {\r\n ...common,\r\n ...adminLocalsAr,\r\n};\r\n","import i18n from \"i18next\";\r\nimport { initReactI18next } from \"react-i18next\";\r\nimport resources from \".\";\r\ni18n.use(initReactI18next).init({\r\n resources: resources, // Where we're gonna put translations' files\r\n lng: localStorage.getItem(\"language\") || \"en\", // Set the initial language of the App\r\n fallbackLng: \"en\",\r\n});\r\n\r\nexport const changeLanguage = (lng: string) => {\r\n i18n.changeLanguage(lng);\r\n localStorage.setItem(\"language\", lng); // Persist user choice\r\n};\r\n\r\nexport default i18n;\r\n","import { Avatar, IconButton, styled, Typography } from \"@mui/material\";\r\nimport MuiAppBar, { AppBarProps as MuiAppBarProps } from \"@mui/material/AppBar\";\r\nimport Toolbar from \"@mui/material/Toolbar\";\r\nimport { useDispatch, useSelector } from \"react-redux\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport { RootState } from \"../redux/store\";\r\nimport { useIsMobile } from \"../hooks/UseMobile\";\r\nimport {\r\n AppLayoutActions,\r\n DRAWER_WIDTH,\r\n} from \"../redux/features/common/AppLayoutSlice\";\r\nimport useAxios from \"../hooks/useAxios\";\r\nimport { UserSessionActions } from \"../redux/features/common/UserSessionSlice\";\r\nimport i18n, { changeLanguage } from \"../locales/i18n\";\r\n\r\ninterface AppBarProps extends MuiAppBarProps {\r\n open?: boolean;\r\n}\r\n\r\nconst AppBar = styled(MuiAppBar, {\r\n shouldForwardProp: (prop) => prop !== \"open\",\r\n})<AppBarProps>(({ theme }) => {\r\n const AppLayout = useSelector((state: RootState) => state.AppLayout);\r\n const isMobile = useIsMobile();\r\n return {\r\n transition: theme.transitions.create([\"margin\", \"width\"], {\r\n easing: theme.transitions.easing.sharp,\r\n duration: theme.transitions.duration.leavingScreen,\r\n }),\r\n variants: [\r\n {\r\n props: ({ open }) => open,\r\n style: {\r\n width: !isMobile ? `calc(100% - ${DRAWER_WIDTH}px)` : undefined,\r\n marginLeft:\r\n !isMobile && AppLayout.appDirection === \"ltr\"\r\n ? `${DRAWER_WIDTH}px`\r\n : undefined,\r\n marginRight:\r\n !isMobile && AppLayout.appDirection === \"rtl\"\r\n ? `${DRAWER_WIDTH}px`\r\n : undefined,\r\n transition: theme.transitions.create([\"margin\", \"width\"], {\r\n easing: theme.transitions.easing.easeOut,\r\n duration: theme.transitions.duration.enteringScreen,\r\n }),\r\n },\r\n },\r\n ],\r\n };\r\n});\r\n\r\nconst TopBar: React.FC = () => {\r\n const AppInfo = useSelector((state: RootState) => state.AppInfo.value);\r\n const AppLayout = useSelector((state: RootState) => state.AppLayout);\r\n const UserSession = useSelector((state: RootState) => state.UserSession);\r\n const { handleGetRequest } = useAxios();\r\n const isMobile = useIsMobile();\r\n const dispatch = useDispatch();\r\n const handleLogout = async () => {\r\n try {\r\n await handleGetRequest({ endPointURI: \"api/auth/logout\" });\r\n } catch (error) {\r\n console.log(\"logout error\", error);\r\n }\r\n dispatch(UserSessionActions.setUnAuthenticated());\r\n };\r\n const toggleSideBar = () => {\r\n dispatch(AppLayoutActions.toggleSideBarState());\r\n };\r\n return (\r\n <AppBar position=\"fixed\" open={AppLayout.sideBarOpened}>\r\n <Toolbar>\r\n <IconButton\r\n color=\"inherit\"\r\n aria-label=\"open drawer\"\r\n onClick={toggleSideBar}\r\n edge=\"start\"\r\n sx={[\r\n {\r\n mr: AppLayout.appDirection === \"ltr\" ? 2 : undefined,\r\n ml: AppLayout.appDirection === \"rtl\" ? 2 : undefined,\r\n },\r\n AppLayout.sideBarOpened && { display: \"none\" },\r\n ]}\r\n >\r\n <FontAwesomeIcon icon=\"bars\" />\r\n </IconButton>\r\n <Avatar src={AppInfo.appLogo} sx={{ marginRight: 1, marginLeft: 1 }} />\r\n <Typography variant=\"h6\" noWrap component=\"div\" sx={{ flex: 1 }}>\r\n {isMobile ? \"\" : AppInfo.appName}\r\n </Typography>\r\n <IconButton\r\n color=\"inherit\"\r\n onClick={() => {\r\n dispatch(\r\n AppLayoutActions.setThemeMode(\r\n AppLayout.themeMode === \"light\" ? \"dark\" : \"light\"\r\n )\r\n );\r\n localStorage.setItem(\r\n \"themeMode\",\r\n AppLayout.themeMode === \"light\" ? \"dark\" : \"light\"\r\n );\r\n }}\r\n >\r\n {AppLayout.themeMode === \"light\" ? (\r\n <FontAwesomeIcon icon=\"moon\" />\r\n ) : (\r\n <FontAwesomeIcon icon={{ prefix: \"far\", iconName: \"sun\" }} />\r\n )}\r\n </IconButton>\r\n <IconButton\r\n color=\"inherit\"\r\n onClick={() => {\r\n let nextLanguage = i18n.language === \"ar\" ? \"en\" : \"ar\";\r\n changeLanguage(nextLanguage);\r\n dispatch(\r\n AppLayoutActions.setAppDirection(\r\n nextLanguage === \"ar\" ? \"rtl\" : \"ltr\"\r\n )\r\n );\r\n }}\r\n >\r\n <FontAwesomeIcon icon=\"language\" />\r\n </IconButton>\r\n <Avatar />\r\n <div style={{ marginLeft: 5, marginRight: 5 }}>\r\n {isMobile ? \"\" : UserSession.value?.userProfile?.username}\r\n </div>\r\n <IconButton color=\"inherit\" onClick={handleLogout}>\r\n <FontAwesomeIcon\r\n rotation={AppLayout.appDirection === \"rtl\" ? 180 : undefined}\r\n icon=\"arrow-right-from-bracket\"\r\n />\r\n </IconButton>\r\n </Toolbar>\r\n </AppBar>\r\n );\r\n};\r\n\r\nexport default TopBar;\r\n","import { styled } from \"@mui/material\";\r\n\r\nexport const DrawerHeader = styled(\"div\")(({ theme }) => ({\r\n display: \"flex\",\r\n alignItems: \"center\", \r\n // padding: theme.spacing(0, 1),\r\n // necessary for content to be below app bar\r\n ...theme.mixins.toolbar,\r\n justifyContent: \"flex-end\",\r\n}));\r\n","function r(e){var t,f,n=\"\";if(\"string\"==typeof e||\"number\"==typeof e)n+=e;else if(\"object\"==typeof e)if(Array.isArray(e)){var o=e.length;for(t=0;t<o;t++)e[t]&&(f=r(e[t]))&&(n&&(n+=\" \"),n+=f)}else for(f in e)e[f]&&(n&&(n+=\" \"),n+=f);return n}export function clsx(){for(var e,t,f=0,n=\"\",o=arguments.length;f<o;f++)(e=arguments[f])&&(t=r(e))&&(n&&(n+=\" \"),n+=t);return n}export default clsx;","import { useSelector } from \"react-redux\";\r\nimport { RootState } from \"../redux/store\";\r\n\r\n\r\nconst useSession = () => {\r\n const UserSession = useSelector((state: RootState) => state.UserSession);\r\n const isUserAuthorized = (authorityCode: string): boolean => {\r\n if (UserSession?.value?.authorities) {\r\n // if (UserSession.value.authorities.includes(\"DEVELOPMENT_ADMIN\")) {\r\n // return true;\r\n // }\r\n for (let grantedAuthority of UserSession.value.authorities) {\r\n if (\r\n grantedAuthority?.authority === \"DEVELOPMENT_ADMIN\" ||\r\n grantedAuthority?.authority === authorityCode\r\n ) {\r\n return true;\r\n }\r\n }\r\n }\r\n return false;\r\n };\r\n return { UserSession, isUserAuthorized };\r\n};\r\n\r\nexport default useSession;\r\n","import { TreeViewBaseItem } from \"@mui/x-tree-view/models\";\r\nimport { AdministrationItems } from \"./Administration\";\r\nimport { IconProp } from \"@fortawesome/fontawesome-svg-core\";\r\n\r\nexport type ExtendedTreeItemProps = {\r\n icon: IconProp;\r\n id: string;\r\n label: string;\r\n action?: \"NAVIGATION\";\r\n authority?: string;\r\n actionPayload?: {\r\n path?: string;\r\n parameters?: object;\r\n };\r\n children?: ExtendedTreeItemProps[];\r\n};\r\n\r\nexport const findNavigationItemById = (\r\n id: string,\r\n nodes: ExtendedTreeItemProps[]\r\n): ExtendedTreeItemProps | undefined => {\r\n for (const node of nodes) {\r\n if (node.id === id) return node;\r\n if (node.children) {\r\n const found = findNavigationItemById(id, node.children);\r\n if (found) return found;\r\n }\r\n }\r\n return undefined;\r\n};\r\n\r\nexport const NavigationItems: TreeViewBaseItem<ExtendedTreeItemProps>[] = [\r\n ...AdministrationItems, \r\n];\r\n","import { TreeViewBaseItem } from \"@mui/x-tree-view/models\";\r\nimport { ExtendedTreeItemProps } from \"..\";\r\nimport { adminNavigationItems } from \"./adminNavigationItems\";\r\n\r\nexport const AdministrationItems: TreeViewBaseItem<ExtendedTreeItemProps>[] = [\r\n ...adminNavigationItems\r\n// {\r\n// id: \"1\",\r\n// label: \"System Administration\",\r\n// icon: \"gears\",\r\n// authority: \"DEVELOPMENT_ADMIN\",\r\n// children: [\r\n// {\r\n// id: \"1.1\",\r\n// label: \"Security\",\r\n// icon: \"shield\",\r\n// action: \"NAVIGATION\",\r\n// actionPayload: { path: \"Security\" },\r\n// children: [\r\n// {\r\n// id: \"1.1.1\",\r\n// label: \"Roles\",\r\n// icon: \"tag\",\r\n// action: \"NAVIGATION\",\r\n// actionPayload: { path: \"admin/security/roles\" },\r\n// },\r\n// {\r\n// id: \"1.1.2\",\r\n// label: \"Authorities\",\r\n// icon: \"key\",\r\n// action: \"NAVIGATION\",\r\n// actionPayload: { path: \"admin/security/authorities\" },\r\n// children: [],\r\n// },\r\n// ],\r\n// },\r\n// {\r\n// id: \"1.2\",\r\n// label: \"Development Tools\",\r\n// icon: \"code\",\r\n// authority: \"DEVELOPMENT_ADMIN\",\r\n// children: [\r\n// {\r\n// id: \"1.2.1\",\r\n// label: \"Datasources\",\r\n// icon: \"database\",\r\n// authority: \"DEVELOPMENT_ADMIN\",\r\n// action: \"NAVIGATION\",\r\n// actionPayload: { path: \"admin/datasources\" },\r\n// },\r\n// {\r\n// id: \"1.2.2\",\r\n// label: \"Parameters\",\r\n// icon: \"p\",\r\n// authority: \"DEVELOPMENT_ADMIN\",\r\n// action: \"NAVIGATION\",\r\n// actionPayload: { path: \"admin/parameters\" },\r\n// },\r\n// {\r\n// id: \"1.2.3\",\r\n// label: \"System Queries\",\r\n// icon: \"file-code\",\r\n// authority: \"DEVELOPMENT_ADMIN\",\r\n// action: \"NAVIGATION\",\r\n// actionPayload: { path: \"admin/queries\" },\r\n// },\r\n// ],\r\n// },\r\n// ],\r\n// },\r\n];\r\n","import { TreeViewBaseItem } from \"@mui/x-tree-view/models\";\r\nimport { ExtendedTreeItemProps } from \"..\";\r\n\r\nexport const adminNavigationItems: TreeViewBaseItem<ExtendedTreeItemProps>[] = [\r\n {\r\n id: \"admin\",\r\n label: \"SYSTEM_ADMINISTRATION\",\r\n authority: \"DEVELOPMENT_ADMIN\",\r\n icon: \"cogs\",\r\n children: [\r\n {\r\n id: \"admin.systemManagement\",\r\n label: \"SYSTEM_MANAGEMENT\",\r\n icon: \"gear\",\r\n children: [\r\n {\r\n id: \"admin.systemManagement.Organization\",\r\n label: \"ORGANIZATION_PLURAL\",\r\n icon: \"globe\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/organizations\" },\r\n },\r\n {\r\n id: \"admin.systemManagement.OrganizationApplication\",\r\n label: \"ORGANIZATION_APPLICATION_PLURAL\",\r\n icon: \"diagram-project\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/organizationapplications\" },\r\n },\r\n ],\r\n },\r\n {\r\n id: \"admin.security\",\r\n label: \"SECURITY_ADMINISTRATION\",\r\n icon: \"shield\",\r\n children: [\r\n {\r\n id: \"admin.security.Authority\",\r\n label: \"AUTHORITY_PLURAL\",\r\n icon: \"key\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/authorities\" },\r\n },\r\n {\r\n id: \"admin.Role\",\r\n label: \"ROLE_PLURAL\",\r\n icon: \"tag\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/roles\" },\r\n },\r\n {\r\n id: \"admin.security.Employee\",\r\n label: \"EMPLOYEE_PLURAL\",\r\n icon: \"user\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/employees\" },\r\n },\r\n ],\r\n },\r\n {\r\n id: \"admin.devtools\",\r\n label: \"DEVELOPMENT_TOOLS\",\r\n icon: \"code\",\r\n children: [\r\n {\r\n id: \"admin.devtools.DatasourceConnection\",\r\n label: \"DATASOURCE_CONNECTION_PLURAL\",\r\n icon: \"plug\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/datasourceconnections\" },\r\n },\r\n {\r\n id: \"admin.devtools.EntityParameter\",\r\n label: \"ENTITY_PARAMETER_PLURAL\",\r\n icon: \"p\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/entityparameters\" },\r\n },\r\n {\r\n id: \"admin.devtools.DataQuery\",\r\n label: \"DATA_QUERY_PLURAL\",\r\n icon: \"file-code\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/dataqueries\" },\r\n },\r\n {\r\n id: \"admin.devtools.ExcelUploaderHeader\",\r\n label: \"EXCEL_UPLOADER_HEADER_PLURAL\",\r\n icon: \"file-excel\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/exceluploaderheaders\" },\r\n },\r\n {\r\n id: \"admin.devtools.Report\",\r\n label: \"REPORT_PLURAL\",\r\n icon: \"file\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/reports\" },\r\n },\r\n {\r\n id: \"admin.devtools.WorkflowDocument\",\r\n label: \"WORKFLOW_DOCUMENT_PLURAL\",\r\n icon: \"chart-diagram\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/workflowdocuments\" },\r\n },\r\n {\r\n id: \"admin.devtools.BluePrint\",\r\n label: \"BLUE_PRINT_PLURAL\",\r\n icon: \"fingerprint\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/blueprints\" },\r\n },\r\n {\r\n id: \"admin.devtools.Widget\",\r\n label: \"WIDGET_PLURAL\",\r\n icon: \"chart-pie\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/widgets\" },\r\n },\r\n {\r\n id: \"admin.devtools.Dashboard\",\r\n label: \"DASHBOARD_PLURAL\",\r\n icon: \"square-poll-vertical\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/dashboards\" },\r\n },\r\n {\r\n id: \"admin.devtools.MailTemplate\",\r\n label: \"MAIL_TEMPLATE_PLURAL\",\r\n icon: \"envelope\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/mailtemplates\" },\r\n },\r\n {\r\n id: \"admin.devtools.Notification\",\r\n label: \"NOTIFICATION_PLURAL\",\r\n icon: \"bell\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/notifications\" },\r\n },\r\n ],\r\n },\r\n {\r\n id: \"admin.followup\",\r\n label: \"SYSTEM_MONITORING\",\r\n icon: \"tv\",\r\n children: [\r\n {\r\n id: \"admin.WorkflowDocumentMailLog\",\r\n label: \"WORKFLOW_DOCUMENT_MAIL_LOG_PLURAL\",\r\n icon: \"envelopes-bulk\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/workflowdocumentmaillogs\" },\r\n },\r\n {\r\n id: \"admin.MailNotificationQueue\",\r\n label: \"MAIL_NOTIFICATION_QUEUE_PLURAL\",\r\n icon: \"envelope-open-text\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/mailnotificationqueues\" },\r\n },\r\n {\r\n id: \"admin.NotificationQueue\",\r\n label: \"NOTIFICATION_QUEUE_PLURAL\",\r\n icon: \"bell\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/notificationqueues\" },\r\n },\r\n ],\r\n },\r\n\r\n {\r\n id: \"admin.Lookup\",\r\n label: \"LOOKUP_PLURAL\",\r\n icon: \"list-check\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/lookups\" },\r\n },\r\n ],\r\n },\r\n];\r\n","import * as React from \"react\";\r\nimport clsx from \"clsx\";\r\nimport { animated, useSpring } from \"@react-spring/web\";\r\nimport { styled, alpha } from \"@mui/material/styles\";\r\nimport { TransitionProps } from \"@mui/material/transitions\";\r\nimport Box from \"@mui/material/Box\";\r\nimport Collapse from \"@mui/material/Collapse\";\r\nimport Typography from \"@mui/material/Typography\";\r\nimport { RichTreeView } from \"@mui/x-tree-view/RichTreeView\";\r\nimport { treeItemClasses } from \"@mui/x-tree-view/TreeItem\";\r\nimport {\r\n useTreeItem2,\r\n UseTreeItem2Parameters,\r\n} from \"@mui/x-tree-view/useTreeItem2\";\r\nimport {\r\n TreeItem2Checkbox,\r\n TreeItem2Content,\r\n TreeItem2IconContainer,\r\n TreeItem2Label,\r\n TreeItem2Root,\r\n} from \"@mui/x-tree-view/TreeItem2\";\r\nimport { TreeItem2Icon } from \"@mui/x-tree-view/TreeItem2Icon\";\r\nimport { TreeItem2Provider } from \"@mui/x-tree-view/TreeItem2Provider\";\r\nimport { TreeItem2DragAndDropOverlay } from \"@mui/x-tree-view/TreeItem2DragAndDropOverlay\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport { useNavigate } from \"react-router-dom\";\r\nimport { useTranslation } from \"react-i18next\";\r\nimport { useDispatch, useSelector } from \"react-redux\";\r\nimport { RootState } from \"../redux/store\";\r\nimport { IconProp } from \"@fortawesome/fontawesome-svg-core\";\r\nimport { useIsMobile } from \"../hooks/UseMobile\";\r\nimport useSession from \"../hooks/UseSession\";\r\nimport { findNavigationItemById, NavigationItems } from \"../navigationItems\";\r\nimport { DRAWER_WIDTH } from \"../redux/features/common/AppLayoutSlice\";\r\n\r\nfunction DotIcon() {\r\n return (\r\n <Box\r\n sx={{\r\n width: 6,\r\n height: 6,\r\n borderRadius: \"70%\",\r\n bgcolor: \"warning.main\",\r\n display: \"inline-block\",\r\n verticalAlign: \"middle\",\r\n zIndex: 1,\r\n mx: 1,\r\n }}\r\n />\r\n );\r\n}\r\ndeclare module \"react\" {\r\n interface CSSProperties {\r\n \"--tree-view-color\"?: string;\r\n \"--tree-view-bg-color\"?: string;\r\n }\r\n}\r\n\r\nconst StyledTreeItemRoot = styled(TreeItem2Root)(({ theme }) => ({\r\n color: theme.palette.grey[400],\r\n position: \"relative\",\r\n [`& .${treeItemClasses.groupTransition}`]: {\r\n marginLeft: theme.spacing(2.5),\r\n },\r\n ...theme.applyStyles(\"light\", {\r\n color: theme.palette.grey[800],\r\n }),\r\n})) as unknown as typeof TreeItem2Root;\r\n\r\nconst CustomTreeItemContent = styled(TreeItem2Content)(({ theme }) => ({\r\n flexDirection: \"row-reverse\",\r\n borderRadius: theme.spacing(0.7),\r\n marginBottom: theme.spacing(0.5),\r\n marginTop: theme.spacing(0.5),\r\n padding: theme.spacing(0.5),\r\n paddingRight: theme.spacing(1),\r\n [`&.Mui-expanded `]: {\r\n \"&:not(.Mui-focused, .Mui-selected, .Mui-selected.Mui-focused) .labelIcon\":\r\n {\r\n color: theme.palette.primary.dark,\r\n ...theme.applyStyles(\"light\", {\r\n color: theme.palette.primary.main,\r\n }),\r\n },\r\n \"&::before\": {\r\n content: '\"\"',\r\n display: \"block\",\r\n position: \"absolute\",\r\n left: \"16px\",\r\n top: \"44px\",\r\n height: \"calc(100% - 48px)\",\r\n width: \"1.5px\",\r\n backgroundColor: theme.palette.grey[700],\r\n ...theme.applyStyles(\"light\", {\r\n backgroundColor: theme.palette.grey[300],\r\n }),\r\n },\r\n },\r\n \"&:hover\": {\r\n backgroundColor: alpha(theme.palette.primary.main, 0.1),\r\n color: \"white\",\r\n ...theme.applyStyles(\"light\", {\r\n color: theme.palette.primary.main,\r\n }),\r\n },\r\n [`&.Mui-focused, &.Mui-selected, &.Mui-selected.Mui-focused`]: {\r\n backgroundColor: theme.palette.primary.dark,\r\n color: theme.palette.primary.contrastText,\r\n ...theme.applyStyles(\"light\", {\r\n backgroundColor: theme.palette.primary.main,\r\n }),\r\n },\r\n}));\r\n\r\nconst AnimatedCollapse = animated(Collapse);\r\n\r\nfunction TransitionComponent(props: TransitionProps) {\r\n const style = useSpring({\r\n to: {\r\n opacity: props.in ? 1 : 0,\r\n transform: `translate3d(0,${props.in ? 0 : 20}px,0)`,\r\n },\r\n });\r\n\r\n return <AnimatedCollapse style={style} {...props} />;\r\n}\r\n\r\nconst StyledTreeItemLabelText = styled(Typography)({\r\n color: \"inherit\",\r\n fontWeight: 500,\r\n}) as unknown as typeof Typography;\r\n\r\ninterface CustomLabelProps {\r\n children: any;\r\n icon: IconProp;\r\n expandable?: boolean;\r\n}\r\n\r\nfunction CustomLabel({\r\n icon,\r\n expandable,\r\n children,\r\n ...other\r\n}: CustomLabelProps) {\r\n const { t } = useTranslation();\r\n const appLayoutState = useSelector((state: RootState) => state.AppLayout);\r\n return (\r\n <TreeItem2Label\r\n {...other}\r\n sx={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n padding: 1,\r\n }}\r\n >\r\n <FontAwesomeIcon\r\n style={{\r\n marginRight: appLayoutState.appDirection === \"ltr\" ? 7 : undefined,\r\n marginLeft: appLayoutState.appDirection === \"rtl\" ? 7 : undefined,\r\n fontSize: \"1.2rem\",\r\n }}\r\n icon={icon}\r\n />\r\n <StyledTreeItemLabelText variant=\"body2\" sx={{ fontSize: 16 }}>\r\n {t(children)}\r\n </StyledTreeItemLabelText>\r\n {expandable && <DotIcon />}\r\n </TreeItem2Label>\r\n );\r\n}\r\n\r\nconst isExpandable = (reactChildren: React.ReactNode) => {\r\n if (Array.isArray(reactChildren)) {\r\n return reactChildren.length > 0 && reactChildren.some(isExpandable);\r\n }\r\n return Boolean(reactChildren);\r\n};\r\n\r\ninterface CustomTreeItemProps\r\n extends Omit<UseTreeItem2Parameters, \"rootRef\">,\r\n Omit<React.HTMLAttributes<HTMLLIElement>, \"onFocus\"> {}\r\n\r\nconst CustomTreeItem = React.forwardRef(function CustomTreeItem(\r\n props: CustomTreeItemProps,\r\n ref: React.Ref<HTMLLIElement>\r\n) {\r\n const { id, itemId, label, disabled, children, ...other } = props;\r\n const {\r\n getRootProps,\r\n getContentProps,\r\n getIconContainerProps,\r\n getCheckboxProps,\r\n getLabelProps,\r\n getGroupTransitionProps,\r\n getDragAndDropOverlayProps,\r\n status,\r\n publicAPI,\r\n } = useTreeItem2({ id, itemId, children, label, disabled, rootRef: ref });\r\n const item = publicAPI.getItem(itemId);\r\n const expandable = isExpandable(children);\r\n return (\r\n <TreeItem2Provider itemId={itemId}>\r\n <StyledTreeItemRoot {...getRootProps(other)}>\r\n <CustomTreeItemContent\r\n {...getContentProps({\r\n className: clsx(\"content\", {\r\n \"Mui-expanded\": status.expanded,\r\n \"Mui-selected\": status.selected,\r\n \"Mui-focused\": status.focused,\r\n \"Mui-disabled\": status.disabled,\r\n }),\r\n })}\r\n >\r\n <TreeItem2IconContainer {...getIconContainerProps()}>\r\n <TreeItem2Icon status={status} />\r\n </TreeItem2IconContainer>\r\n <TreeItem2Checkbox {...getCheckboxProps()} />\r\n <CustomLabel\r\n {...getLabelProps({\r\n icon: item?.icon || \"book\",\r\n expandable: expandable && status.expanded,\r\n })}\r\n />\r\n <TreeItem2DragAndDropOverlay {...getDragAndDropOverlayProps()} />\r\n </CustomTreeItemContent>\r\n {children && <TransitionComponent {...getGroupTransitionProps()} />}\r\n </StyledTreeItemRoot>\r\n </TreeItem2Provider>\r\n );\r\n});\r\n\r\nexport default function NavigationTree() {\r\n const navigate = useNavigate();\r\n const appLayoutState = useSelector((state: RootState) => state.AppLayout);\r\n const AppInfo = useSelector((state: RootState) => state.AppInfo.value);\r\n const dispatch = useDispatch();\r\n const isMobile = useIsMobile();\r\n const { isUserAuthorized } = useSession();\r\n const filterData = (data) => {\r\n return data\r\n .filter(\r\n (item: any) =>\r\n item.authority === undefined ||\r\n item.authority == null ||\r\n isUserAuthorized(item.authority)\r\n )\r\n .map((item: any) => {\r\n if (item.children) {\r\n item.children = filterData(item.children);\r\n }\r\n return item;\r\n });\r\n };\r\n\r\n const mergedNavigationItems = [];\r\n if (AppInfo.enableAdministrationModule) {\r\n mergedNavigationItems.push(...NavigationItems);\r\n }\r\n mergedNavigationItems.push(...AppInfo.businessNavigationItems);\r\n const authoriedNavigationItems = filterData(mergedNavigationItems);\r\n\r\n return (\r\n <RichTreeView\r\n items={authoriedNavigationItems}\r\n onItemClick={(event, itemId) => {\r\n const navigationItem = findNavigationItemById(\r\n itemId,\r\n mergedNavigationItems\r\n );\r\n if (\r\n navigationItem?.action === \"NAVIGATION\" &&\r\n navigationItem?.actionPayload != null &&\r\n (navigationItem.children === undefined ||\r\n navigationItem.children === null ||\r\n navigationItem.children.length == 0)\r\n ) {\r\n navigate(navigationItem?.actionPayload?.path || \"\");\r\n // dispatch(AppLayoutActions.toggleSideBarState());\r\n }\r\n }}\r\n sx={{\r\n height: \"fit-content\",\r\n flexGrow: 1,\r\n maxWidth: DRAWER_WIDTH,\r\n direction: appLayoutState.appDirection,\r\n maxHeight: isMobile ? 300 : undefined,\r\n overflowY: \"auto\",\r\n overflowX: \"auto\",\r\n }}\r\n slots={{ item: CustomTreeItem }}\r\n />\r\n );\r\n}\r\n","import Divider from \"@mui/material/Divider\";\r\nimport IconButton from \"@mui/material/IconButton\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport Drawer from \"@mui/material/Drawer\";\r\nimport { useDispatch, useSelector } from \"react-redux\";\r\nimport { DrawerHeader } from \"./DrawerHeader\";\r\nimport { Box, Typography, useTheme } from \"@mui/material\";\r\nimport { RootState } from \"../redux/store\";\r\nimport {\r\n AppLayoutActions,\r\n DRAWER_WIDTH,\r\n} from \"../redux/features/common/AppLayoutSlice\";\r\nimport NavigationTree from \"./NavigationTree\";\r\n\r\nconst SideBar: React.FC = () => {\r\n const AppInfo = useSelector((state: RootState) => state.AppInfo.value);\r\n const theme = useTheme();\r\n const AppLayout = useSelector((state: RootState) => state.AppLayout);\r\n const dispatch = useDispatch();\r\n const toggleSideBar = () => {\r\n dispatch(AppLayoutActions.toggleSideBarState());\r\n };\r\n return (\r\n <Drawer\r\n sx={{\r\n width: DRAWER_WIDTH,\r\n flexShrink: 0,\r\n \"& .MuiDrawer-paper\": {\r\n width: DRAWER_WIDTH,\r\n boxSizing: \"border-box\",\r\n },\r\n }}\r\n variant=\"persistent\"\r\n anchor={AppLayout.appDirection === \"ltr\" ? \"left\" : \"right\"}\r\n open={AppLayout.sideBarOpened}\r\n >\r\n <DrawerHeader>\r\n <Box sx={{ width: \"100%\" }}>\r\n <Typography\r\n color=\"primary\"\r\n sx={{\r\n width: \"100%\",\r\n textAlign: \"center\",\r\n fontSize: 18,\r\n fontWeight: \"bold\",\r\n }}\r\n >\r\n System Content\r\n </Typography>\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"space-around\",\r\n marginTop: 1,\r\n }}\r\n >\r\n <Typography sx={{ fontSize: 12 }} color=\"textDisabled\">\r\n {AppInfo.appName}\r\n </Typography>\r\n <Typography sx={{ fontSize: 12 }} color=\"textDisabled\">\r\n V.{AppInfo.appVersion}\r\n </Typography>\r\n </Box>\r\n </Box>\r\n <IconButton onClick={toggleSideBar}>\r\n {theme.direction === \"ltr\" ? (\r\n <FontAwesomeIcon icon=\"angle-left\" />\r\n ) : (\r\n <FontAwesomeIcon icon=\"angle-right\" />\r\n )}\r\n </IconButton>\r\n </DrawerHeader>\r\n <Divider />\r\n <NavigationTree />\r\n </Drawer>\r\n );\r\n};\r\n\r\nexport default SideBar;\r\n","import rtlPlugin from \"stylis-plugin-rtl\";\r\nimport { prefixer } from \"stylis\";\r\nimport createCache from \"@emotion/cache\";\r\n\r\nexport const cacheRtl = createCache({\r\n key: \"muirtl\",\r\n stylisPlugins: [prefixer, rtlPlugin],\r\n});\r\n\r\nexport const cacheLtr = createCache({\r\n key: \"mui\",\r\n});","import {\r\n Button,\r\n Dialog,\r\n DialogActions,\r\n DialogContent,\r\n DialogContentText,\r\n DialogTitle,\r\n} from \"@mui/material\";\r\nimport { useState } from \"react\";\r\nimport { useTranslation } from \"react-i18next\";\r\n\r\ninterface ConfirmationWindowProps {\r\n title: string;\r\n body: string;\r\n onConfirmationCallBk: () => void;\r\n}\r\n\r\nexport const useConfirmationWindow = (props: ConfirmationWindowProps) => {\r\n const [open, setOpen] = useState<boolean>(false);\r\n const { t } = useTranslation();\r\n const ConfirmationWindow: React.FC = () => {\r\n return (\r\n <Dialog open={open}>\r\n <DialogTitle>{props.title}</DialogTitle>\r\n <DialogContent>\r\n <DialogContentText>{props.body}</DialogContentText>\r\n </DialogContent>\r\n <DialogActions>\r\n <Button\r\n variant=\"contained\"\r\n color=\"primary\"\r\n onClick={() => {\r\n setOpen(false);\r\n }}\r\n >\r\n {t(\"NO_LABEL\")}\r\n </Button>\r\n <Button\r\n variant=\"contained\"\r\n color=\"error\"\r\n onClick={() => {\r\n props.onConfirmationCallBk();\r\n setOpen(false);\r\n }}\r\n autoFocus\r\n >\r\n {t(\"YES_LABEL\")}\r\n </Button>\r\n </DialogActions>\r\n </Dialog>\r\n );\r\n };\r\n return { ConfirmationWindow, open, setOpen };\r\n};\r\n","import { Button } from \"@mui/material\";\r\nimport { RecordAction } from \"../DataEntryTypes\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport { toast } from \"react-toastify\";\r\nimport { useTranslation } from \"react-i18next\";\r\nimport useSession from \"../../../../hooks/UseSession\";\r\nimport { useConfirmationWindow } from \"../../../../hooks/UseConfirmationWindow\";\r\n\r\nconst TemplateGridMultiRecordAction: React.FC<RecordAction> = (\r\n rowAction: RecordAction\r\n) => {\r\n const { t } = useTranslation();\r\n const session = useSession();\r\n const { ConfirmationWindow, setOpen } = useConfirmationWindow({\r\n body: t(rowAction?.confirmationMessage || \"ACTION_CONFIRMATION\"),\r\n title: t(\"CONFIRMATION\"),\r\n onConfirmationCallBk: async () => {\r\n await rowAction?.actionFn(\r\n rowAction.recordsToProcessActionOn,\r\n rowAction.recordIdsToProcessActionOn\r\n );\r\n if (rowAction?.reloadData) {\r\n rowAction.reloadData();\r\n }\r\n },\r\n });\r\n let isActionAllowed = true;\r\n if (rowAction.authority) {\r\n isActionAllowed = session.isUserAuthorized(rowAction.authority);\r\n }\r\n\r\n if (isActionAllowed) {\r\n return (\r\n <>\r\n <ConfirmationWindow />\r\n <Button\r\n onClick={async () => {\r\n if (\r\n rowAction?.recordsToProcessActionOn &&\r\n rowAction?.recordsToProcessActionOn.length > 0\r\n ) {\r\n if (rowAction?.preActionValidation) {\r\n for (const record of rowAction.recordsToProcessActionOn) {\r\n if (!rowAction.preActionValidation(record)) {\r\n return;\r\n }\r\n }\r\n }\r\n if (rowAction?.isConfirmationRequired === true) {\r\n setOpen(true);\r\n } else {\r\n await rowAction.actionFn(\r\n rowAction.recordsToProcessActionOn,\r\n rowAction.recordIdsToProcessActionOn\r\n );\r\n if (rowAction?.reloadData) {\r\n rowAction.reloadData();\r\n }\r\n }\r\n } else {\r\n toast.error(t(\"AT_LEAST_ONE_RECORD_SELECTED_MESSAGE\"));\r\n }\r\n }}\r\n variant={\r\n rowAction?.label\r\n ? \"outlined\"\r\n : rowAction?.formActionProps?.actionButtonVariant\r\n ? rowAction.formActionProps.actionButtonVariant\r\n : \"text\"\r\n }\r\n size=\"small\"\r\n color={rowAction?.formActionProps?.actionButtonColor || \"primary\"}\r\n >\r\n {rowAction?.icon ? (\r\n <FontAwesomeIcon\r\n style={{ marginRight: 5, marginLeft: 5 }}\r\n icon={rowAction.icon}\r\n />\r\n ) : (\r\n <></>\r\n )}\r\n {rowAction?.label ? t(rowAction.label) : <></>}\r\n </Button>\r\n </>\r\n );\r\n }\r\n};\r\n\r\nexport default TemplateGridMultiRecordAction;\r\n","export const DATE_FORMAT = \"YYYY-MM-DD\";\r\nexport const DATE_TIME_FORMAT = \"YYYY-MM-DD HH:mm:ss\";\r\nexport const LIGHT_THEME_INITIAL_MAIN_COLOR = \"#37505C\";\r\nexport const LIGHT_THEME_INITIAL_SECANDARY_COLOR = \"#ff6d00\";\r\nexport const DARK_THEME_INITIAL_MAIN_COLOR = \"#ea690e\";\r\nexport const DARK_THEME_INITIAL_SECANDARY_COLOR = \"#74776B\";\r\n","import { DatePicker, LocalizationProvider } from \"@mui/x-date-pickers\";\r\nimport { AdapterMoment } from \"@mui/x-date-pickers/AdapterMoment\";\r\nimport moment from \"moment\";\r\nimport { DATE_FORMAT } from \"../../../../../util/constants\";\r\nimport { useTranslation } from \"react-i18next\";\r\n\r\ninterface DatefieldProps {\r\n value: string | null;\r\n label: string;\r\n disabled?: boolean;\r\n required?: boolean;\r\n sx?: any;\r\n format?: string;\r\n errorMessage?: any;\r\n onChangeCallBack: Function;\r\n [x: string | number | symbol]: unknown;\r\n}\r\n\r\nconst Datefield: React.FC<DatefieldProps> = (props) => {\r\n const { t } = useTranslation();\r\n return (\r\n <LocalizationProvider dateAdapter={AdapterMoment}>\r\n <DatePicker\r\n value={\r\n props.value != null && props.value !== undefined && props.value !== \"\"\r\n ? moment(props.value, props?.format || DATE_FORMAT)\r\n : null\r\n }\r\n sx={props.sx}\r\n label={t(props.label)}\r\n format={props?.format || DATE_FORMAT}\r\n disabled={props.disabled}\r\n onChange={(momentValue) => {\r\n let v = null;\r\n if (momentValue != null && momentValue.isValid()) {\r\n v = momentValue.format(props?.format || DATE_FORMAT);\r\n }\r\n if (\r\n props.onChangeCallBack !== undefined &&\r\n props.onChangeCallBack != null\r\n ) {\r\n props.onChangeCallBack(v);\r\n }\r\n }}\r\n slotProps={{\r\n textField: {\r\n InputLabelProps: { shrink: true },\r\n variant: \"outlined\",\r\n required: props.required,\r\n error:\r\n props.errorMessage !== undefined && props.errorMessage != null,\r\n helperText:\r\n props.errorMessage !== undefined && props.errorMessage != null ? (\r\n <>{t(props.errorMessage)}</>\r\n ) : (\r\n <></>\r\n ),\r\n },\r\n }}\r\n />\r\n </LocalizationProvider>\r\n );\r\n};\r\n\r\nexport default Datefield;\r\n","import { DateTimePicker, LocalizationProvider } from \"@mui/x-date-pickers\";\r\nimport { AdapterMoment } from \"@mui/x-date-pickers/AdapterMoment\";\r\nimport moment from \"moment\";\r\nimport { useTranslation } from \"react-i18next\";\r\nimport { DATE_TIME_FORMAT } from \"../../../../../util/constants\";\r\n\r\ninterface DatetimeFieldProps {\r\n value: string | null;\r\n label: string;\r\n disabled?: boolean;\r\n required?: boolean;\r\n format?: string;\r\n sx?: any;\r\n errorMessage?: any;\r\n onChangeCallBack: Function;\r\n [x: string | number | symbol]: unknown;\r\n}\r\n\r\nconst DatetimeField: React.FC<DatetimeFieldProps> = (props) => {\r\n const { t } = useTranslation();\r\n return (\r\n <LocalizationProvider dateAdapter={AdapterMoment}>\r\n <DateTimePicker\r\n value={\r\n props.value != null && props.value !== undefined && props.value !== \"\"\r\n ? moment(props.value, props?.format || DATE_TIME_FORMAT)\r\n : null\r\n }\r\n label={t(props.label)}\r\n sx={props.sx}\r\n format={props?.format || DATE_TIME_FORMAT}\r\n disabled={props.disabled}\r\n onChange={(momentValue) => {\r\n let v = null;\r\n if (momentValue != null && momentValue.isValid()) {\r\n v = momentValue.format(props?.format || DATE_TIME_FORMAT);\r\n }\r\n if (\r\n props.onChangeCallBack !== undefined &&\r\n props.onChangeCallBack != null\r\n ) {\r\n props.onChangeCallBack(v);\r\n }\r\n }}\r\n slotProps={{\r\n textField: {\r\n variant: \"outlined\",\r\n required: props.required,\r\n error:\r\n props.errorMessage !== undefined && props.errorMessage != null,\r\n helperText:\r\n props.errorMessage !== undefined && props.errorMessage != null ? (\r\n <>{t(props.errorMessage)}</>\r\n ) : (\r\n <></>\r\n ),\r\n },\r\n }}\r\n />\r\n </LocalizationProvider>\r\n );\r\n};\r\n\r\nexport default DatetimeField;\r\n","import { useSelector } from \"react-redux\";\r\nimport { RootState } from \"../../../../../redux/store\";\r\nimport { Autocomplete, Popper, TextField } from \"@mui/material\";\r\nimport { useTranslation } from \"react-i18next\";\r\n\r\ninterface ComboBoxProps {\r\n value: any;\r\n onChangeCallBack: Function;\r\n label: string;\r\n disabled?: boolean;\r\n required?: boolean;\r\n options: Array<any>;\r\n errorMessage?: any;\r\n displayField: string;\r\n valueField: string;\r\n sx?: any;\r\n}\r\n\r\nconst ComboBox: React.FC<ComboBoxProps> = (props) => {\r\n const AppLayoutState = useSelector((state: RootState) => state.AppLayout);\r\n const { t } = useTranslation();\r\n const getValue = (v: string) => {\r\n for (let option of props.options) {\r\n if (option[props.valueField] == v) {\r\n return option;\r\n }\r\n }\r\n return null;\r\n };\r\n return (\r\n <Autocomplete\r\n sx={props.sx}\r\n value={getValue(props.value)}\r\n options={props.options}\r\n disabled={props.disabled}\r\n onChange={(event, newValue) => {\r\n if (\r\n props.onChangeCallBack !== undefined &&\r\n props.onChangeCallBack != null\r\n ) {\r\n if (newValue != null) {\r\n let v = newValue[props.valueField];\r\n props.onChangeCallBack(v, newValue);\r\n } else {\r\n props.onChangeCallBack(null, null);\r\n }\r\n }\r\n }}\r\n clearOnBlur\r\n handleHomeEndKeys\r\n getOptionLabel={(option) => {\r\n return option != null ? t(option[props.displayField]) : \"\";\r\n }}\r\n renderOption={(props1, option) => {\r\n return (\r\n <li {...props1}>\r\n {option != null ? t(option[props.displayField]) : \"\"}\r\n </li>\r\n );\r\n }}\r\n slots={{\r\n popper: (props: any) => (\r\n <Popper\r\n {...props}\r\n style={{ ...props.style, direction: AppLayoutState.appDirection }}\r\n />\r\n ),\r\n }}\r\n renderInput={(params) => {\r\n return (\r\n <TextField\r\n {...params}\r\n required={props.required || false}\r\n variant=\"outlined\"\r\n InputLabelProps={{ shrink: true }}\r\n label={t(props.label)}\r\n error={\r\n props.errorMessage != null && props.errorMessage !== undefined\r\n ? true\r\n : false\r\n }\r\n helperText={\r\n props.errorMessage != null && props.errorMessage !== undefined\r\n ? t(props.errorMessage)\r\n : \"\"\r\n }\r\n />\r\n );\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default ComboBox;\r\n","import { Checkbox, FormControlLabel } from \"@mui/material\";\r\nimport { useTranslation } from \"react-i18next\";\r\n\r\ninterface CheckBoxProps {\r\n value: any;\r\n disabled?: boolean;\r\n required?: boolean;\r\n label: string;\r\n checkedValue?: any;\r\n unCheckedValue?: any;\r\n onChangeCallBack: Function;\r\n sx?: any;\r\n}\r\n\r\nconst CheckBox: React.FC<CheckBoxProps> = (props) => {\r\n const { t } = useTranslation();\r\n return (\r\n <FormControlLabel\r\n sx={props.sx}\r\n disabled={props.disabled || false}\r\n required={props.required || false}\r\n control={\r\n <Checkbox\r\n checked={\r\n props?.checkedValue == props.value ||\r\n props.value === \"true\" ||\r\n props.value == \"1\"\r\n ? true\r\n : false\r\n }\r\n onChange={(e) => {\r\n if (\r\n props.onChangeCallBack !== undefined &&\r\n props.onChangeCallBack != null\r\n ) {\r\n if (e.target.checked) {\r\n if (\r\n props.checkedValue !== undefined &&\r\n props.checkedValue != null\r\n ) {\r\n props.onChangeCallBack(props.checkedValue);\r\n } else {\r\n props.onChangeCallBack(\"true\");\r\n }\r\n } else {\r\n if (\r\n props.unCheckedValue !== undefined &&\r\n props.unCheckedValue != null\r\n ) {\r\n props.onChangeCallBack(props.unCheckedValue);\r\n } else {\r\n props.onChangeCallBack(\"false\");\r\n }\r\n }\r\n }\r\n }}\r\n />\r\n }\r\n label={t(props.label)}\r\n />\r\n );\r\n};\r\n\r\nexport default CheckBox;\r\n","import moment from \"moment\";\r\nimport { TemplateGridColDef } from \"../DataEntryTypes\";\r\nimport Datefield from \"../TemplateDataForm/FormFields/Datefield\";\r\nimport { DATE_FORMAT, DATE_TIME_FORMAT } from \"../../../../util/constants\";\r\nimport DatetimeField from \"../TemplateDataForm/FormFields/DatetimeField\";\r\nimport ComboBox from \"../TemplateDataForm/FormFields/ComboBox\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport CheckBox from \"../TemplateDataForm/FormFields/CheckBox\";\r\n\r\nexport const generateDateColumn: any = (colDef: TemplateGridColDef) => {\r\n const column: TemplateGridColDef = {\r\n ...colDef,\r\n type: \"string\",\r\n renderEditCell: (params: any) => {\r\n return (\r\n <Datefield\r\n sx={{ width: \"100%\" }}\r\n label=\"\"\r\n value={params.value}\r\n onChangeCallBack={(v: any) => {\r\n params.api.setEditCellValue({\r\n id: params.id,\r\n field: params.field,\r\n value: v,\r\n });\r\n }}\r\n />\r\n );\r\n },\r\n valueParser: (value: any, row: any, column: any) => {\r\n let v = null;\r\n if (value !== null) {\r\n v = moment(value).format(DATE_FORMAT);\r\n }\r\n return v;\r\n },\r\n valueFormatter: (value: any, row: any, column: any) => {\r\n return row[column.field];\r\n },\r\n };\r\n return column;\r\n};\r\n\r\nexport const generateDateTimeColumn: any = (colDef: TemplateGridColDef) => {\r\n const column: TemplateGridColDef = {\r\n ...colDef,\r\n type: \"string\",\r\n renderEditCell: (params: any) => {\r\n return (\r\n <DatetimeField\r\n sx={{ width: \"100%\" }}\r\n label=\"\"\r\n value={params.value}\r\n onChangeCallBack={(v: any) => {\r\n params.api.setEditCellValue({\r\n id: params.id,\r\n field: params.field,\r\n value: v,\r\n });\r\n }}\r\n />\r\n );\r\n },\r\n valueParser: (value: any, row: any, column: any) => {\r\n let v = null;\r\n if (value !== null) {\r\n v = moment(value).format(DATE_TIME_FORMAT);\r\n }\r\n return v;\r\n },\r\n valueFormatter: (value: any, row: any, column: any) => {\r\n return row[column.field];\r\n },\r\n };\r\n return column;\r\n};\r\n\r\ntype ComboBoxColumnProps = TemplateGridColDef & {\r\n options: Array<any>;\r\n displayField: string;\r\n valueField: string;\r\n};\r\nexport const generateComboColumn: (\r\n props: ComboBoxColumnProps\r\n) => TemplateGridColDef = (colDef: ComboBoxColumnProps) => {\r\n const column: TemplateGridColDef = {\r\n ...colDef,\r\n type: \"custom\",\r\n valueGetter: (value) => {\r\n if (value) {\r\n return value + \"\";\r\n }\r\n return value;\r\n },\r\n renderCell: (parameters: any) => {\r\n let record = null;\r\n try {\r\n record = parameters.colDef.options.find(\r\n (item: any) => item[parameters.colDef.valueField] == parameters.value\r\n );\r\n } catch (e) {}\r\n return (\r\n <div>\r\n {record != null\r\n ? record[parameters.colDef.displayField]\r\n : parameters.value}\r\n </div>\r\n );\r\n },\r\n\r\n renderEditCell: (params: any) => {\r\n return (\r\n <ComboBox\r\n {...params}\r\n sx={{ width: \"100%\" }}\r\n options={colDef.options}\r\n valueField={colDef.valueField}\r\n displayField={colDef.displayField}\r\n onChangeCallBack={(v: any, selectedRecord: any) => {\r\n if (v === null) {\r\n params.api.setEditCellValue({\r\n id: params.id,\r\n field: params.field,\r\n value: null,\r\n });\r\n }\r\n params.api.setEditCellValue({\r\n id: params.id,\r\n field: params.field,\r\n value: v + \"\",\r\n });\r\n }}\r\n />\r\n );\r\n },\r\n };\r\n return column;\r\n};\r\n\r\ntype CheckBoxColumnProps = TemplateGridColDef & {\r\n checkedValue?: string;\r\n unCheckedValue?: string;\r\n};\r\n\r\nexport const generateCheckBoxColumn: (\r\n props: CheckBoxColumnProps\r\n) => TemplateGridColDef = (colDef: CheckBoxColumnProps) => {\r\n return {\r\n ...colDef,\r\n type: \"custom\",\r\n valueGetter: (value) => {\r\n if (value == null || value == undefined) {\r\n return null;\r\n } else {\r\n return value + \"\";\r\n }\r\n },\r\n renderCell: (parameters: any) => {\r\n const value = parameters?.value;\r\n if (\r\n value === colDef.checkedValue ||\r\n value === \"true\" ||\r\n value === 1 ||\r\n value === true\r\n ) {\r\n return <FontAwesomeIcon icon=\"check\" color=\"green\" />;\r\n } else {\r\n return <FontAwesomeIcon icon=\"xmark\" color=\"red\" />;\r\n }\r\n },\r\n renderEditCell: (params: any) => {\r\n return (\r\n <CheckBox\r\n {...params}\r\n checkedValue={colDef?.checkedValue || \"true\"}\r\n unCheckedValue={colDef?.unCheckedValue || \"false\"}\r\n onChangeCallBack={(v: any) => {\r\n params.api.setEditCellValue({\r\n id: params.id,\r\n field: params.field,\r\n value: v + \"\",\r\n });\r\n }}\r\n />\r\n );\r\n },\r\n };\r\n};\r\n","import { GridRowSelectionModel } from \"@mui/x-data-grid-premium\";\r\nimport {\r\n FormElementProps,\r\n RecordFieldProps,\r\n TemplateGridColDef,\r\n} from \"./DataEntryTypes\";\r\nimport {\r\n generateCheckBoxColumn,\r\n generateComboColumn,\r\n generateDateColumn,\r\n generateDateTimeColumn,\r\n} from \"./TemplateDataGrid/DataGridColumnsUtil\";\r\nimport * as z from \"zod\";\r\nimport { TFunction } from \"i18next\";\r\n\r\nexport const getElementFields: (\r\n element: FormElementProps\r\n) => Array<RecordFieldProps> = (element: FormElementProps) => {\r\n const fields: Array<RecordFieldProps> = [];\r\n if (element.type === \"field\" && element.mode === \"props\" && element?.props) {\r\n fields.push(element.props);\r\n } else if (\r\n element.type === \"group\" &&\r\n element?.props &&\r\n element?.props?.elements\r\n ) {\r\n for (const childElement of element.props.elements) {\r\n fields.push(...getElementFields(childElement));\r\n }\r\n }\r\n return fields;\r\n};\r\n\r\nexport const getAllFields: (\r\n elements: Array<FormElementProps>\r\n) => Array<RecordFieldProps> = (elements: Array<FormElementProps>) => {\r\n const fields: Array<RecordFieldProps> = [];\r\n for (const element of elements) {\r\n fields.push(...getElementFields(element));\r\n }\r\n return fields;\r\n};\r\n\r\nexport const constructGridColumnsFromFields: (\r\n fields: Array<RecordFieldProps>,\r\n isDefaultEditable: boolean,\r\n t: TFunction<\"translation\", undefined>\r\n) => Array<TemplateGridColDef> = (fields, isDefaultEditable, t) => {\r\n const columns: Array<TemplateGridColDef> = [];\r\n for (const tableField of fields) {\r\n if (\r\n tableField?.fieldType === \"text\" ||\r\n tableField?.fieldType === \"number\"\r\n ) {\r\n const column: TemplateGridColDef = {\r\n ...tableField?.gridProps?.muiProps,\r\n editable:\r\n tableField?.gridProps?.muiProps?.editable || isDefaultEditable,\r\n type: tableField?.fieldType == \"number\" ? \"number\" : \"string\",\r\n field: tableField?.fieldName,\r\n headerName: t(tableField?.fieldLabel || tableField?.fieldName),\r\n headerAlign: \"center\",\r\n align: \"center\",\r\n hidden: tableField?.hidden,\r\n searchable: tableField?.gridProps?.searchable,\r\n flex: 1,\r\n minWidth: 200,\r\n };\r\n columns.push(column);\r\n } else if (tableField?.fieldType === \"date\") {\r\n const column: TemplateGridColDef = generateDateColumn({\r\n ...tableField?.gridProps?.muiProps,\r\n editable:\r\n tableField?.gridProps?.muiProps?.editable || isDefaultEditable,\r\n field: tableField?.fieldName,\r\n headerName: t(tableField?.fieldLabel || tableField?.fieldName),\r\n headerAlign: \"center\",\r\n align: \"center\",\r\n hidden: tableField?.hidden,\r\n searchable: tableField?.gridProps?.searchable,\r\n flex: 1,\r\n minWidth: 200,\r\n });\r\n columns.push(column);\r\n } else if (tableField?.fieldType === \"datetime\") {\r\n const column: TemplateGridColDef = generateDateTimeColumn({\r\n ...tableField?.gridProps?.muiProps,\r\n editable:\r\n tableField?.gridProps?.muiProps?.editable || isDefaultEditable,\r\n field: tableField?.fieldName,\r\n headerName: t(tableField?.fieldLabel || tableField?.fieldName),\r\n headerAlign: \"center\",\r\n align: \"center\",\r\n hidden: tableField?.hidden,\r\n searchable: tableField?.gridProps?.searchable,\r\n flex: 1,\r\n minWidth: 200,\r\n });\r\n columns.push(column);\r\n } else if (tableField?.fieldType === \"checkbox\") {\r\n const column = generateCheckBoxColumn({\r\n ...tableField?.gridProps?.muiProps,\r\n editable:\r\n tableField?.gridProps?.muiProps?.editable || isDefaultEditable,\r\n field: tableField?.fieldName,\r\n headerName: t(tableField?.fieldLabel || tableField?.fieldName),\r\n headerAlign: \"center\",\r\n align: \"center\",\r\n hidden: tableField?.hidden,\r\n searchable: tableField?.gridProps?.searchable,\r\n checkedValue: tableField?.checkedValue,\r\n unCheckedValue: tableField?.unCheckedValue,\r\n width: 150,\r\n });\r\n columns.push(column);\r\n } else if (tableField?.fieldType === \"combobox\") {\r\n const column: TemplateGridColDef = generateComboColumn({\r\n ...tableField?.gridProps?.muiProps,\r\n editable:\r\n tableField?.gridProps?.muiProps?.editable || isDefaultEditable,\r\n field: tableField?.fieldName,\r\n headerName: t(tableField?.fieldLabel || tableField?.fieldName),\r\n headerAlign: \"center\",\r\n align: \"center\",\r\n hidden: tableField?.hidden,\r\n searchable: tableField?.gridProps?.searchable,\r\n valueField: tableField?.optionValueField || \"value\",\r\n displayField: tableField?.optionDisplayField || \"display\",\r\n options: tableField?.options || [],\r\n flex: 1,\r\n minWidth: 200,\r\n });\r\n columns.push(column);\r\n }\r\n }\r\n return columns;\r\n};\r\n\r\nexport const constructValidationSchema = (fields: Array<RecordFieldProps>) => {\r\n const validationSchemaObj: any = {};\r\n for (const field of fields) {\r\n if (field?.fieldName) {\r\n const fieldName = field.fieldName;\r\n if (field.fieldType === \"number\") {\r\n if (field?.required === true) {\r\n validationSchemaObj[fieldName] = z.number({\r\n required_error: \"This field is required\",\r\n invalid_type_error: \"This field must be a number\",\r\n });\r\n } else {\r\n validationSchemaObj[fieldName] = z.number().optional().nullable();\r\n }\r\n } else {\r\n if (field?.required === true) {\r\n validationSchemaObj[fieldName] = z\r\n .string({ message: \"This field is required\" })\r\n .min(1, \"This field is required\");\r\n } else {\r\n validationSchemaObj[fieldName] = z.string().optional().nullable();\r\n }\r\n }\r\n }\r\n }\r\n return validationSchemaObj;\r\n};\r\n\r\nexport type GridSelection = {\r\n selectedRecords: Array<any>;\r\n selectedRecordIds: Array<any>;\r\n};\r\n\r\nexport const getGridSelection: (\r\n rowSelectionModel: GridRowSelectionModel,\r\n data: Array<any>,\r\n keyColumnName: string\r\n) => GridSelection = (\r\n rowSelectionModel: GridRowSelectionModel,\r\n data: Array<any>,\r\n keyColumnName: string\r\n) => {\r\n const sRecords = [];\r\n const sRecordIds = [];\r\n if (\r\n rowSelectionModel.type === \"exclude\" &&\r\n rowSelectionModel.ids.size === 0\r\n ) {\r\n for (const record of data) {\r\n sRecords.push(record);\r\n sRecordIds.push(record[keyColumnName]);\r\n }\r\n } else {\r\n if (rowSelectionModel?.ids) {\r\n for (const selectedId of rowSelectionModel.ids) {\r\n const record = data.find((x) => x[keyColumnName] === selectedId);\r\n sRecords.push(record);\r\n sRecordIds.push(selectedId);\r\n }\r\n }\r\n }\r\n return { selectedRecords: sRecords, selectedRecordIds: sRecordIds };\r\n};\r\n","import {\r\n Badge,\r\n Box,\r\n Button,\r\n Divider,\r\n IconButton,\r\n InputAdornment,\r\n MenuItem,\r\n styled,\r\n TextField,\r\n Tooltip,\r\n} from \"@mui/material\";\r\nimport {\r\n Toolbar,\r\n ToolbarButton,\r\n ColumnsPanelTrigger,\r\n FilterPanelTrigger,\r\n QuickFilter,\r\n QuickFilterControl,\r\n QuickFilterClear,\r\n QuickFilterTrigger,\r\n GridViewColumnIcon,\r\n GridFilterListIcon,\r\n ExportExcel,\r\n} from \"@mui/x-data-grid-premium\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport TemplateGridMultiRecordAction from \"./TemplateGridMultiRecordAction\";\r\nimport { getGridSelection } from \"../DataEntryUtil\";\r\nimport { useTranslation } from \"react-i18next\";\r\nimport { TemplateGridTopBarProps } from \"../DataEntryTypes\";\r\nimport useSession from \"../../../../hooks/UseSession\";\r\n\r\ntype OwnerState = {\r\n expanded: boolean;\r\n};\r\n\r\nconst StyledQuickFilter = styled(QuickFilter)({\r\n display: \"grid\",\r\n alignItems: \"center\",\r\n});\r\n\r\nconst StyledToolbarButton = styled(ToolbarButton)<{ ownerState: OwnerState }>(\r\n ({ theme, ownerState }) => ({\r\n gridArea: \"1 / 1\",\r\n width: \"min-content\",\r\n height: \"min-content\",\r\n zIndex: 1,\r\n opacity: ownerState.expanded ? 0 : 1,\r\n pointerEvents: ownerState.expanded ? \"none\" : \"auto\",\r\n transition: theme.transitions.create([\"opacity\"]),\r\n })\r\n);\r\n\r\nconst StyledTextField = styled(TextField)<{\r\n ownerState: OwnerState;\r\n}>(({ theme, ownerState }) => ({\r\n gridArea: \"1 / 1\",\r\n overflowX: \"clip\",\r\n width: ownerState.expanded ? 260 : \"var(--trigger-width)\",\r\n opacity: ownerState.expanded ? 1 : 0,\r\n transition: theme.transitions.create([\"width\", \"opacity\"]),\r\n}));\r\n\r\nconst TemplateGridTopBar: React.FC<TemplateGridTopBarProps> = (\r\n props: TemplateGridTopBarProps\r\n) => {\r\n const { t } = useTranslation();\r\n const session = useSession();\r\n const isCreationAuthorized = props?.templateProps?.editAction?.authority\r\n ? session.isUserAuthorized(props.templateProps.editAction.authority)\r\n : true;\r\n const isCreationEnabled = props?.templateProps?.disableDefaultAction || true;\r\n const gridSelection = getGridSelection(\r\n props?.templateProps?.rowSelectionModel || {\r\n ids: new Set(),\r\n type: \"include\",\r\n },\r\n props?.templateProps?.data || [],\r\n props?.templateProps?.keyColumnName || \"id\"\r\n );\r\n return (\r\n <Toolbar>\r\n {isCreationEnabled &&\r\n isCreationAuthorized &&\r\n props?.templateProps?.editMode?.editMode != \"none\" ? (\r\n <Button onClick={props?.handleCreateNewRecord}>\r\n <FontAwesomeIcon\r\n icon=\"add\"\r\n style={{ marginRight: 5, marginLeft: 5 }}\r\n />\r\n {t(\"ADD_BTN_LABEL\")}\r\n </Button>\r\n ) : (\r\n <></>\r\n )}\r\n {props?.templateProps?.rowActions ? (\r\n props.templateProps.rowActions.map((rowAction) =>\r\n rowAction?.gridActionProps?.multiRecord === true ? (\r\n <TemplateGridMultiRecordAction\r\n {...rowAction}\r\n reloadData={async () => {\r\n props.templateProps.apiActions.reloadData(\r\n props?.templateProps?.gridLoadParametersValues\r\n );\r\n }}\r\n recordIdsToProcessActionOn={gridSelection.selectedRecordIds}\r\n recordsToProcessActionOn={gridSelection.selectedRecords}\r\n />\r\n ) : (\r\n <></>\r\n )\r\n )\r\n ) : (\r\n <></>\r\n )}\r\n <Box sx={{ flex: 1, mx: 0.5 }}>{props?.templateProps?.tBar}</Box>\r\n\r\n <Tooltip title=\"Columns\">\r\n <ColumnsPanelTrigger render={<ToolbarButton />}>\r\n <GridViewColumnIcon fontSize=\"small\" />\r\n </ColumnsPanelTrigger>\r\n </Tooltip>\r\n\r\n <Tooltip title=\"Filters\">\r\n <FilterPanelTrigger\r\n render={(props, state) => (\r\n <ToolbarButton {...props} color=\"default\">\r\n <Badge\r\n badgeContent={state.filterCount}\r\n color=\"primary\"\r\n variant=\"dot\"\r\n >\r\n <GridFilterListIcon fontSize=\"small\" />\r\n </Badge>\r\n </ToolbarButton>\r\n )}\r\n />\r\n </Tooltip>\r\n\r\n {props?.templateProps?.gridStateKey ? (\r\n <Tooltip title={t(\"RESET_GRID_STATE\")}>\r\n <IconButton onClick={props?.clearGridState}>\r\n <FontAwesomeIcon icon=\"eraser\" />\r\n </IconButton>\r\n </Tooltip>\r\n ) : (\r\n <></>\r\n )}\r\n\r\n <Divider\r\n orientation=\"vertical\"\r\n variant=\"middle\"\r\n flexItem\r\n sx={{ mx: 0.5 }}\r\n />\r\n\r\n <Tooltip title={t(\"EXPORT_EXECL_LABEL\")}>\r\n <ExportExcel render={<MenuItem />}>\r\n <FontAwesomeIcon icon=\"file-excel\" color=\"green\" />\r\n </ExportExcel>\r\n </Tooltip>\r\n\r\n <StyledQuickFilter>\r\n <QuickFilterTrigger\r\n render={(triggerProps, state) => (\r\n <Tooltip title={t(\"SEARCH_BTN_LABEL\")} enterDelay={0}>\r\n <StyledToolbarButton\r\n {...triggerProps}\r\n ownerState={{ expanded: state.expanded }}\r\n color=\"default\"\r\n aria-disabled={state.expanded}\r\n >\r\n <FontAwesomeIcon icon=\"search\" />\r\n </StyledToolbarButton>\r\n </Tooltip>\r\n )}\r\n />\r\n <QuickFilterControl\r\n render={({ ref, ...controlProps }, state) => (\r\n <StyledTextField\r\n {...controlProps}\r\n ownerState={{ expanded: state.expanded }}\r\n inputRef={ref}\r\n aria-label=\"Search\"\r\n placeholder={`${t(\"SEARCH_BTN_LABEL\")}...`}\r\n size=\"small\"\r\n slotProps={{\r\n input: {\r\n startAdornment: (\r\n <InputAdornment position=\"start\">\r\n <FontAwesomeIcon icon=\"search\" />\r\n </InputAdornment>\r\n ),\r\n endAdornment: state.value ? (\r\n <InputAdornment position=\"end\">\r\n <QuickFilterClear\r\n edge=\"end\"\r\n size=\"small\"\r\n aria-label=\"Clear search\"\r\n // material={{ sx: { marginRight: -0.75 } }}\r\n >\r\n <FontAwesomeIcon icon=\"xmark\" />\r\n </QuickFilterClear>\r\n </InputAdornment>\r\n ) : null,\r\n ...controlProps.slotProps?.input,\r\n },\r\n ...controlProps.slotProps,\r\n }}\r\n />\r\n )}\r\n />\r\n </StyledQuickFilter>\r\n\r\n <IconButton\r\n onClick={() => {\r\n props.templateProps.apiActions.reloadData(\r\n props?.templateProps?.gridLoadParametersValues\r\n );\r\n }}\r\n >\r\n <FontAwesomeIcon icon=\"refresh\" />\r\n </IconButton>\r\n </Toolbar>\r\n );\r\n};\r\n\r\nexport default TemplateGridTopBar;\r\n","export function hasDigitsOnly(str: string) {\r\n return /^\\d+$/.test(str);\r\n}\r\n\r\nexport function isNumber(value: any) {\r\n return typeof value === \"number\" && !isNaN(value);\r\n}\r\n\r\nexport function isNumeric(value: string) {\r\n return (\r\n typeof value === \"string\" && value.trim() !== \"\" && !isNaN(Number(value))\r\n );\r\n}\r\n\r\nexport function capitalizeFirstLetter(str: string) {\r\n if (!str) return \"\";\r\n return str.charAt(0).toUpperCase() + str.slice(1);\r\n}\r\n","import { Tooltip } from \"@mui/material\";\r\nimport { GridActionsCellItem } from \"@mui/x-data-grid-premium\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport { RecordAction } from \"../DataEntryTypes\";\r\nimport { useTranslation } from \"react-i18next\";\r\nimport useSession from \"../../../../hooks/UseSession\";\r\nimport { useConfirmationWindow } from \"../../../../hooks/UseConfirmationWindow\";\r\n\r\nconst TemplateGridRecordAction: React.FC<RecordAction> = (\r\n rowAction: RecordAction\r\n) => {\r\n const { t } = useTranslation();\r\n const session = useSession();\r\n const { ConfirmationWindow, setOpen } = useConfirmationWindow({\r\n body: t(rowAction?.confirmationMessage || \"ACTION_CONFIRMATION\"),\r\n title: t(\"CONFIRMATION\"),\r\n onConfirmationCallBk: async () => {\r\n await rowAction?.actionFn(rowAction.record);\r\n if (rowAction?.reloadData) {\r\n rowAction.reloadData();\r\n }\r\n },\r\n });\r\n let isActionAllowed = true;\r\n if (rowAction.authority) {\r\n isActionAllowed = session.isUserAuthorized(rowAction.authority);\r\n }\r\n let iconStyle: any = {};\r\n if (rowAction?.getActionIconStyleForRecord) {\r\n iconStyle = rowAction.getActionIconStyleForRecord(rowAction.record);\r\n }\r\n let isActionVisibleForRecord = true;\r\n if (rowAction?.isActionVisibleForRecord) {\r\n isActionVisibleForRecord = rowAction?.isActionVisibleForRecord(\r\n rowAction.record\r\n );\r\n }\r\n let isActionDisabledForRecord = false;\r\n if (rowAction?.isActionDisabledForRecord) {\r\n isActionDisabledForRecord = rowAction.isActionDisabledForRecord(\r\n rowAction.record\r\n );\r\n }\r\n if (isActionAllowed && isActionVisibleForRecord) {\r\n return (\r\n <>\r\n <ConfirmationWindow />\r\n <GridActionsCellItem\r\n disabled={isActionDisabledForRecord}\r\n icon={\r\n <Tooltip title={rowAction?.label ? t(rowAction.label) : \"\"}>\r\n <FontAwesomeIcon\r\n icon={rowAction.icon}\r\n style={{\r\n ...iconStyle,\r\n color: isActionDisabledForRecord\r\n ? \"gray\"\r\n : iconStyle?.color != undefined\r\n ? iconStyle.color\r\n : undefined,\r\n }}\r\n />\r\n </Tooltip>\r\n }\r\n showInMenu={rowAction?.gridActionProps?.showInMenu || false}\r\n label={\"\"}\r\n className=\"textPrimary\"\r\n color=\"inherit\"\r\n onClick={async () => {\r\n if (!isActionDisabledForRecord) {\r\n if (rowAction?.preActionValidation) {\r\n if (!rowAction.preActionValidation(rowAction.record)) {\r\n return;\r\n }\r\n }\r\n if (rowAction?.isConfirmationRequired === true) {\r\n setOpen(true);\r\n } else {\r\n await rowAction.actionFn(rowAction.record);\r\n if (rowAction?.reloadData) {\r\n rowAction.reloadData();\r\n }\r\n }\r\n }\r\n }}\r\n />\r\n </>\r\n );\r\n }\r\n};\r\n\r\nexport default TemplateGridRecordAction;\r\n","/**\n * WARNING: Don't import this directly. It's imported by the code generated by\n * `@mui/interal-babel-plugin-minify-errors`. Make sure to always use string literals in `Error`\n * constructors to ensure the plugin works as expected. Supported patterns include:\n * throw new Error('My message');\n * throw new Error(`My message: ${foo}`);\n * throw new Error(`My message: ${foo}` + 'another string');\n * ...\n * @param {number} code\n */\nexport default function formatMuiErrorMessage(code, ...args) {\n const url = new URL(`https://mui.com/production-error/?code=${code}`);\n args.forEach(arg => url.searchParams.append('args[]', arg));\n return `Minified MUI error #${code}; visit ${url} for the full message.`;\n}","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-is.production.min.js');\n} else {\n module.exports = require('./cjs/react-is.development.js');\n}\n","/** @license React v16.13.1\n * react-is.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';var b=\"function\"===typeof Symbol&&Symbol.for,c=b?Symbol.for(\"react.element\"):60103,d=b?Symbol.for(\"react.portal\"):60106,e=b?Symbol.for(\"react.fragment\"):60107,f=b?Symbol.for(\"react.strict_mode\"):60108,g=b?Symbol.for(\"react.profiler\"):60114,h=b?Symbol.for(\"react.provider\"):60109,k=b?Symbol.for(\"react.context\"):60110,l=b?Symbol.for(\"react.async_mode\"):60111,m=b?Symbol.for(\"react.concurrent_mode\"):60111,n=b?Symbol.for(\"react.forward_ref\"):60112,p=b?Symbol.for(\"react.suspense\"):60113,q=b?\nSymbol.for(\"react.suspense_list\"):60120,r=b?Symbol.for(\"react.memo\"):60115,t=b?Symbol.for(\"react.lazy\"):60116,v=b?Symbol.for(\"react.block\"):60121,w=b?Symbol.for(\"react.fundamental\"):60117,x=b?Symbol.for(\"react.responder\"):60118,y=b?Symbol.for(\"react.scope\"):60119;\nfunction z(a){if(\"object\"===typeof a&&null!==a){var u=a.$$typeof;switch(u){case c:switch(a=a.type,a){case l:case m:case e:case g:case f:case p:return a;default:switch(a=a&&a.$$typeof,a){case k:case n:case t:case r:case h:return a;default:return u}}case d:return u}}}function A(a){return z(a)===m}exports.AsyncMode=l;exports.ConcurrentMode=m;exports.ContextConsumer=k;exports.ContextProvider=h;exports.Element=c;exports.ForwardRef=n;exports.Fragment=e;exports.Lazy=t;exports.Memo=r;exports.Portal=d;\nexports.Profiler=g;exports.StrictMode=f;exports.Suspense=p;exports.isAsyncMode=function(a){return A(a)||z(a)===l};exports.isConcurrentMode=A;exports.isContextConsumer=function(a){return z(a)===k};exports.isContextProvider=function(a){return z(a)===h};exports.isElement=function(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===c};exports.isForwardRef=function(a){return z(a)===n};exports.isFragment=function(a){return z(a)===e};exports.isLazy=function(a){return z(a)===t};\nexports.isMemo=function(a){return z(a)===r};exports.isPortal=function(a){return z(a)===d};exports.isProfiler=function(a){return z(a)===g};exports.isStrictMode=function(a){return z(a)===f};exports.isSuspense=function(a){return z(a)===p};\nexports.isValidElementType=function(a){return\"string\"===typeof a||\"function\"===typeof a||a===e||a===m||a===g||a===f||a===p||a===q||\"object\"===typeof a&&null!==a&&(a.$$typeof===t||a.$$typeof===r||a.$$typeof===h||a.$$typeof===k||a.$$typeof===n||a.$$typeof===w||a.$$typeof===x||a.$$typeof===y||a.$$typeof===v)};exports.typeOf=z;\n","/** @license React v16.13.1\n * react-is.development.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\n\n\nif (process.env.NODE_ENV !== \"production\") {\n (function() {\n'use strict';\n\n// The Symbol used to tag the ReactElement-like types. If there is no native Symbol\n// nor polyfill, then a plain number is used for performance.\nvar hasSymbol = typeof Symbol === 'function' && Symbol.for;\nvar REACT_ELEMENT_TYPE = hasSymbol ? Symbol.for('react.element') : 0xeac7;\nvar REACT_PORTAL_TYPE = hasSymbol ? Symbol.for('react.portal') : 0xeaca;\nvar REACT_FRAGMENT_TYPE = hasSymbol ? Symbol.for('react.fragment') : 0xeacb;\nvar REACT_STRICT_MODE_TYPE = hasSymbol ? Symbol.for('react.strict_mode') : 0xeacc;\nvar REACT_PROFILER_TYPE = hasSymbol ? Symbol.for('react.profiler') : 0xead2;\nvar REACT_PROVIDER_TYPE = hasSymbol ? Symbol.for('react.provider') : 0xeacd;\nvar REACT_CONTEXT_TYPE = hasSymbol ? Symbol.for('react.context') : 0xeace; // TODO: We don't use AsyncMode or ConcurrentMode anymore. They were temporary\n// (unstable) APIs that have been removed. Can we remove the symbols?\n\nvar REACT_ASYNC_MODE_TYPE = hasSymbol ? Symbol.for('react.async_mode') : 0xeacf;\nvar REACT_CONCURRENT_MODE_TYPE = hasSymbol ? Symbol.for('react.concurrent_mode') : 0xeacf;\nvar REACT_FORWARD_REF_TYPE = hasSymbol ? Symbol.for('react.forward_ref') : 0xead0;\nvar REACT_SUSPENSE_TYPE = hasSymbol ? Symbol.for('react.suspense') : 0xead1;\nvar REACT_SUSPENSE_LIST_TYPE = hasSymbol ? Symbol.for('react.suspense_list') : 0xead8;\nvar REACT_MEMO_TYPE = hasSymbol ? Symbol.for('react.memo') : 0xead3;\nvar REACT_LAZY_TYPE = hasSymbol ? Symbol.for('react.lazy') : 0xead4;\nvar REACT_BLOCK_TYPE = hasSymbol ? Symbol.for('react.block') : 0xead9;\nvar REACT_FUNDAMENTAL_TYPE = hasSymbol ? Symbol.for('react.fundamental') : 0xead5;\nvar REACT_RESPONDER_TYPE = hasSymbol ? Symbol.for('react.responder') : 0xead6;\nvar REACT_SCOPE_TYPE = hasSymbol ? Symbol.for('react.scope') : 0xead7;\n\nfunction isValidElementType(type) {\n return typeof type === 'string' || typeof type === 'function' || // Note: its typeof might be other than 'symbol' or 'number' if it's a polyfill.\n type === REACT_FRAGMENT_TYPE || type === REACT_CONCURRENT_MODE_TYPE || type === REACT_PROFILER_TYPE || type === REACT_STRICT_MODE_TYPE || type === REACT_SUSPENSE_TYPE || type === REACT_SUSPENSE_LIST_TYPE || typeof type === 'object' && type !== null && (type.$$typeof === REACT_LAZY_TYPE || type.$$typeof === REACT_MEMO_TYPE || type.$$typeof === REACT_PROVIDER_TYPE || type.$$typeof === REACT_CONTEXT_TYPE || type.$$typeof === REACT_FORWARD_REF_TYPE || type.$$typeof === REACT_FUNDAMENTAL_TYPE || type.$$typeof === REACT_RESPONDER_TYPE || type.$$typeof === REACT_SCOPE_TYPE || type.$$typeof === REACT_BLOCK_TYPE);\n}\n\nfunction typeOf(object) {\n if (typeof object === 'object' && object !== null) {\n var $$typeof = object.$$typeof;\n\n switch ($$typeof) {\n case REACT_ELEMENT_TYPE:\n var type = object.type;\n\n switch (type) {\n case REACT_ASYNC_MODE_TYPE:\n case REACT_CONCURRENT_MODE_TYPE:\n case REACT_FRAGMENT_TYPE:\n case REACT_PROFILER_TYPE:\n case REACT_STRICT_MODE_TYPE:\n case REACT_SUSPENSE_TYPE:\n return type;\n\n default:\n var $$typeofType = type && type.$$typeof;\n\n switch ($$typeofType) {\n case REACT_CONTEXT_TYPE:\n case REACT_FORWARD_REF_TYPE:\n case REACT_LAZY_TYPE:\n case REACT_MEMO_TYPE:\n case REACT_PROVIDER_TYPE:\n return $$typeofType;\n\n default:\n return $$typeof;\n }\n\n }\n\n case REACT_PORTAL_TYPE:\n return $$typeof;\n }\n }\n\n return undefined;\n} // AsyncMode is deprecated along with isAsyncMode\n\nvar AsyncMode = REACT_ASYNC_MODE_TYPE;\nvar ConcurrentMode = REACT_CONCURRENT_MODE_TYPE;\nvar ContextConsumer = REACT_CONTEXT_TYPE;\nvar ContextProvider = REACT_PROVIDER_TYPE;\nvar Element = REACT_ELEMENT_TYPE;\nvar ForwardRef = REACT_FORWARD_REF_TYPE;\nvar Fragment = REACT_FRAGMENT_TYPE;\nvar Lazy = REACT_LAZY_TYPE;\nvar Memo = REACT_MEMO_TYPE;\nvar Portal = REACT_PORTAL_TYPE;\nvar Profiler = REACT_PROFILER_TYPE;\nvar StrictMode = REACT_STRICT_MODE_TYPE;\nvar Suspense = REACT_SUSPENSE_TYPE;\nvar hasWarnedAboutDeprecatedIsAsyncMode = false; // AsyncMode should be deprecated\n\nfunction isAsyncMode(object) {\n {\n if (!hasWarnedAboutDeprecatedIsAsyncMode) {\n hasWarnedAboutDeprecatedIsAsyncMode = true; // Using console['warn'] to evade Babel and ESLint\n\n console['warn']('The ReactIs.isAsyncMode() alias has been deprecated, ' + 'and will be removed in React 17+. Update your code to use ' + 'ReactIs.isConcurrentMode() instead. It has the exact same API.');\n }\n }\n\n return isConcurrentMode(object) || typeOf(object) === REACT_ASYNC_MODE_TYPE;\n}\nfunction isConcurrentMode(object) {\n return typeOf(object) === REACT_CONCURRENT_MODE_TYPE;\n}\nfunction isContextConsumer(object) {\n return typeOf(object) === REACT_CONTEXT_TYPE;\n}\nfunction isContextProvider(object) {\n return typeOf(object) === REACT_PROVIDER_TYPE;\n}\nfunction isElement(object) {\n return typeof object === 'object' && object !== null && object.$$typeof === REACT_ELEMENT_TYPE;\n}\nfunction isForwardRef(object) {\n return typeOf(object) === REACT_FORWARD_REF_TYPE;\n}\nfunction isFragment(object) {\n return typeOf(object) === REACT_FRAGMENT_TYPE;\n}\nfunction isLazy(object) {\n return typeOf(object) === REACT_LAZY_TYPE;\n}\nfunction isMemo(object) {\n return typeOf(object) === REACT_MEMO_TYPE;\n}\nfunction isPortal(object) {\n return typeOf(object) === REACT_PORTAL_TYPE;\n}\nfunction isProfiler(object) {\n return typeOf(object) === REACT_PROFILER_TYPE;\n}\nfunction isStrictMode(object) {\n return typeOf(object) === REACT_STRICT_MODE_TYPE;\n}\nfunction isSuspense(object) {\n return typeOf(object) === REACT_SUSPENSE_TYPE;\n}\n\nexports.AsyncMode = AsyncMode;\nexports.ConcurrentMode = ConcurrentMode;\nexports.ContextConsumer = ContextConsumer;\nexports.ContextProvider = ContextProvider;\nexports.Element = Element;\nexports.ForwardRef = ForwardRef;\nexports.Fragment = Fragment;\nexports.Lazy = Lazy;\nexports.Memo = Memo;\nexports.Portal = Portal;\nexports.Profiler = Profiler;\nexports.StrictMode = StrictMode;\nexports.Suspense = Suspense;\nexports.isAsyncMode = isAsyncMode;\nexports.isConcurrentMode = isConcurrentMode;\nexports.isContextConsumer = isContextConsumer;\nexports.isContextProvider = isContextProvider;\nexports.isElement = isElement;\nexports.isForwardRef = isForwardRef;\nexports.isFragment = isFragment;\nexports.isLazy = isLazy;\nexports.isMemo = isMemo;\nexports.isPortal = isPortal;\nexports.isProfiler = isProfiler;\nexports.isStrictMode = isStrictMode;\nexports.isSuspense = isSuspense;\nexports.isValidElementType = isValidElementType;\nexports.typeOf = typeOf;\n })();\n}\n","/*\nobject-assign\n(c) Sindre Sorhus\n@license MIT\n*/\n\n'use strict';\n/* eslint-disable no-unused-vars */\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nfunction toObject(val) {\n\tif (val === null || val === undefined) {\n\t\tthrow new TypeError('Object.assign cannot be called with null or undefined');\n\t}\n\n\treturn Object(val);\n}\n\nfunction shouldUseNative() {\n\ttry {\n\t\tif (!Object.assign) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Detect buggy property enumeration order in older V8 versions.\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=4118\n\t\tvar test1 = new String('abc'); // eslint-disable-line no-new-wrappers\n\t\ttest1[5] = 'de';\n\t\tif (Object.getOwnPropertyNames(test1)[0] === '5') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test2 = {};\n\t\tfor (var i = 0; i < 10; i++) {\n\t\t\ttest2['_' + String.fromCharCode(i)] = i;\n\t\t}\n\t\tvar order2 = Object.getOwnPropertyNames(test2).map(function (n) {\n\t\t\treturn test2[n];\n\t\t});\n\t\tif (order2.join('') !== '0123456789') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test3 = {};\n\t\t'abcdefghijklmnopqrst'.split('').forEach(function (letter) {\n\t\t\ttest3[letter] = letter;\n\t\t});\n\t\tif (Object.keys(Object.assign({}, test3)).join('') !==\n\t\t\t\t'abcdefghijklmnopqrst') {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t} catch (err) {\n\t\t// We don't expect any of the above to throw, but better to be safe.\n\t\treturn false;\n\t}\n}\n\nmodule.exports = shouldUseNative() ? Object.assign : function (target, source) {\n\tvar from;\n\tvar to = toObject(target);\n\tvar symbols;\n\n\tfor (var s = 1; s < arguments.length; s++) {\n\t\tfrom = Object(arguments[s]);\n\n\t\tfor (var key in from) {\n\t\t\tif (hasOwnProperty.call(from, key)) {\n\t\t\t\tto[key] = from[key];\n\t\t\t}\n\t\t}\n\n\t\tif (getOwnPropertySymbols) {\n\t\t\tsymbols = getOwnPropertySymbols(from);\n\t\t\tfor (var i = 0; i < symbols.length; i++) {\n\t\t\t\tif (propIsEnumerable.call(from, symbols[i])) {\n\t\t\t\t\tto[symbols[i]] = from[symbols[i]];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n","module.exports = Function.call.bind(Object.prototype.hasOwnProperty);\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar printWarning = function() {};\n\nif (process.env.NODE_ENV !== 'production') {\n var ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n var loggedTypeFailures = {};\n var has = require('./lib/has');\n\n printWarning = function(text) {\n var message = 'Warning: ' + text;\n if (typeof console !== 'undefined') {\n console.error(message);\n }\n try {\n // --- Welcome to debugging React ---\n // This error was thrown as a convenience so that you can use this stack\n // to find the callsite that caused this warning to fire.\n throw new Error(message);\n } catch (x) { /**/ }\n };\n}\n\n/**\n * Assert that the values match with the type specs.\n * Error messages are memorized and will only be shown once.\n *\n * @param {object} typeSpecs Map of name to a ReactPropType\n * @param {object} values Runtime values that need to be type-checked\n * @param {string} location e.g. \"prop\", \"context\", \"child context\"\n * @param {string} componentName Name of the component for error messages.\n * @param {?Function} getStack Returns the component stack.\n * @private\n */\nfunction checkPropTypes(typeSpecs, values, location, componentName, getStack) {\n if (process.env.NODE_ENV !== 'production') {\n for (var typeSpecName in typeSpecs) {\n if (has(typeSpecs, typeSpecName)) {\n var error;\n // Prop type validation may throw. In case they do, we don't want to\n // fail the render phase where it didn't fail before. So we log it.\n // After these have been cleaned up, we'll let them throw.\n try {\n // This is intentionally an invariant that gets caught. It's the same\n // behavior as without this statement except with a better message.\n if (typeof typeSpecs[typeSpecName] !== 'function') {\n var err = Error(\n (componentName || 'React class') + ': ' + location + ' type `' + typeSpecName + '` is invalid; ' +\n 'it must be a function, usually from the `prop-types` package, but received `' + typeof typeSpecs[typeSpecName] + '`.' +\n 'This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.'\n );\n err.name = 'Invariant Violation';\n throw err;\n }\n error = typeSpecs[typeSpecName](values, typeSpecName, componentName, location, null, ReactPropTypesSecret);\n } catch (ex) {\n error = ex;\n }\n if (error && !(error instanceof Error)) {\n printWarning(\n (componentName || 'React class') + ': type specification of ' +\n location + ' `' + typeSpecName + '` is invalid; the type checker ' +\n 'function must return `null` or an `Error` but returned a ' + typeof error + '. ' +\n 'You may have forgotten to pass an argument to the type checker ' +\n 'creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and ' +\n 'shape all require an argument).'\n );\n }\n if (error instanceof Error && !(error.message in loggedTypeFailures)) {\n // Only monitor this failure once because there tends to be a lot of the\n // same error.\n loggedTypeFailures[error.message] = true;\n\n var stack = getStack ? getStack() : '';\n\n printWarning(\n 'Failed ' + location + ' type: ' + error.message + (stack != null ? stack : '')\n );\n }\n }\n }\n }\n}\n\n/**\n * Resets warning cache when testing.\n *\n * @private\n */\ncheckPropTypes.resetWarningCache = function() {\n if (process.env.NODE_ENV !== 'production') {\n loggedTypeFailures = {};\n }\n}\n\nmodule.exports = checkPropTypes;\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactIs = require('react-is');\nvar assign = require('object-assign');\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\nvar has = require('./lib/has');\nvar checkPropTypes = require('./checkPropTypes');\n\nvar printWarning = function() {};\n\nif (process.env.NODE_ENV !== 'production') {\n printWarning = function(text) {\n var message = 'Warning: ' + text;\n if (typeof console !== 'undefined') {\n console.error(message);\n }\n try {\n // --- Welcome to debugging React ---\n // This error was thrown as a convenience so that you can use this stack\n // to find the callsite that caused this warning to fire.\n throw new Error(message);\n } catch (x) {}\n };\n}\n\nfunction emptyFunctionThatReturnsNull() {\n return null;\n}\n\nmodule.exports = function(isValidElement, throwOnDirectAccess) {\n /* global Symbol */\n var ITERATOR_SYMBOL = typeof Symbol === 'function' && Symbol.iterator;\n var FAUX_ITERATOR_SYMBOL = '@@iterator'; // Before Symbol spec.\n\n /**\n * Returns the iterator method function contained on the iterable object.\n *\n * Be sure to invoke the function with the iterable as context:\n *\n * var iteratorFn = getIteratorFn(myIterable);\n * if (iteratorFn) {\n * var iterator = iteratorFn.call(myIterable);\n * ...\n * }\n *\n * @param {?object} maybeIterable\n * @return {?function}\n */\n function getIteratorFn(maybeIterable) {\n var iteratorFn = maybeIterable && (ITERATOR_SYMBOL && maybeIterable[ITERATOR_SYMBOL] || maybeIterable[FAUX_ITERATOR_SYMBOL]);\n if (typeof iteratorFn === 'function') {\n return iteratorFn;\n }\n }\n\n /**\n * Collection of methods that allow declaration and validation of props that are\n * supplied to React components. Example usage:\n *\n * var Props = require('ReactPropTypes');\n * var MyArticle = React.createClass({\n * propTypes: {\n * // An optional string prop named \"description\".\n * description: Props.string,\n *\n * // A required enum prop named \"category\".\n * category: Props.oneOf(['News','Photos']).isRequired,\n *\n * // A prop named \"dialog\" that requires an instance of Dialog.\n * dialog: Props.instanceOf(Dialog).isRequired\n * },\n * render: function() { ... }\n * });\n *\n * A more formal specification of how these methods are used:\n *\n * type := array|bool|func|object|number|string|oneOf([...])|instanceOf(...)\n * decl := ReactPropTypes.{type}(.isRequired)?\n *\n * Each and every declaration produces a function with the same signature. This\n * allows the creation of custom validation functions. For example:\n *\n * var MyLink = React.createClass({\n * propTypes: {\n * // An optional string or URI prop named \"href\".\n * href: function(props, propName, componentName) {\n * var propValue = props[propName];\n * if (propValue != null && typeof propValue !== 'string' &&\n * !(propValue instanceof URI)) {\n * return new Error(\n * 'Expected a string or an URI for ' + propName + ' in ' +\n * componentName\n * );\n * }\n * }\n * },\n * render: function() {...}\n * });\n *\n * @internal\n */\n\n var ANONYMOUS = '<<anonymous>>';\n\n // Important!\n // Keep this list in sync with production version in `./factoryWithThrowingShims.js`.\n var ReactPropTypes = {\n array: createPrimitiveTypeChecker('array'),\n bigint: createPrimitiveTypeChecker('bigint'),\n bool: createPrimitiveTypeChecker('boolean'),\n func: createPrimitiveTypeChecker('function'),\n number: createPrimitiveTypeChecker('number'),\n object: createPrimitiveTypeChecker('object'),\n string: createPrimitiveTypeChecker('string'),\n symbol: createPrimitiveTypeChecker('symbol'),\n\n any: createAnyTypeChecker(),\n arrayOf: createArrayOfTypeChecker,\n element: createElementTypeChecker(),\n elementType: createElementTypeTypeChecker(),\n instanceOf: createInstanceTypeChecker,\n node: createNodeChecker(),\n objectOf: createObjectOfTypeChecker,\n oneOf: createEnumTypeChecker,\n oneOfType: createUnionTypeChecker,\n shape: createShapeTypeChecker,\n exact: createStrictShapeTypeChecker,\n };\n\n /**\n * inlined Object.is polyfill to avoid requiring consumers ship their own\n * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is\n */\n /*eslint-disable no-self-compare*/\n function is(x, y) {\n // SameValue algorithm\n if (x === y) {\n // Steps 1-5, 7-10\n // Steps 6.b-6.e: +0 != -0\n return x !== 0 || 1 / x === 1 / y;\n } else {\n // Step 6.a: NaN == NaN\n return x !== x && y !== y;\n }\n }\n /*eslint-enable no-self-compare*/\n\n /**\n * We use an Error-like object for backward compatibility as people may call\n * PropTypes directly and inspect their output. However, we don't use real\n * Errors anymore. We don't inspect their stack anyway, and creating them\n * is prohibitively expensive if they are created too often, such as what\n * happens in oneOfType() for any type before the one that matched.\n */\n function PropTypeError(message, data) {\n this.message = message;\n this.data = data && typeof data === 'object' ? data: {};\n this.stack = '';\n }\n // Make `instanceof Error` still work for returned errors.\n PropTypeError.prototype = Error.prototype;\n\n function createChainableTypeChecker(validate) {\n if (process.env.NODE_ENV !== 'production') {\n var manualPropTypeCallCache = {};\n var manualPropTypeWarningCount = 0;\n }\n function checkType(isRequired, props, propName, componentName, location, propFullName, secret) {\n componentName = componentName || ANONYMOUS;\n propFullName = propFullName || propName;\n\n if (secret !== ReactPropTypesSecret) {\n if (throwOnDirectAccess) {\n // New behavior only for users of `prop-types` package\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use `PropTypes.checkPropTypes()` to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n } else if (process.env.NODE_ENV !== 'production' && typeof console !== 'undefined') {\n // Old behavior for people using React.PropTypes\n var cacheKey = componentName + ':' + propName;\n if (\n !manualPropTypeCallCache[cacheKey] &&\n // Avoid spamming the console because they are often not actionable except for lib authors\n manualPropTypeWarningCount < 3\n ) {\n printWarning(\n 'You are manually calling a React.PropTypes validation ' +\n 'function for the `' + propFullName + '` prop on `' + componentName + '`. This is deprecated ' +\n 'and will throw in the standalone `prop-types` package. ' +\n 'You may be seeing this warning due to a third-party PropTypes ' +\n 'library. See https://fb.me/react-warning-dont-call-proptypes ' + 'for details.'\n );\n manualPropTypeCallCache[cacheKey] = true;\n manualPropTypeWarningCount++;\n }\n }\n }\n if (props[propName] == null) {\n if (isRequired) {\n if (props[propName] === null) {\n return new PropTypeError('The ' + location + ' `' + propFullName + '` is marked as required ' + ('in `' + componentName + '`, but its value is `null`.'));\n }\n return new PropTypeError('The ' + location + ' `' + propFullName + '` is marked as required in ' + ('`' + componentName + '`, but its value is `undefined`.'));\n }\n return null;\n } else {\n return validate(props, propName, componentName, location, propFullName);\n }\n }\n\n var chainedCheckType = checkType.bind(null, false);\n chainedCheckType.isRequired = checkType.bind(null, true);\n\n return chainedCheckType;\n }\n\n function createPrimitiveTypeChecker(expectedType) {\n function validate(props, propName, componentName, location, propFullName, secret) {\n var propValue = props[propName];\n var propType = getPropType(propValue);\n if (propType !== expectedType) {\n // `propValue` being instance of, say, date/regexp, pass the 'object'\n // check, but we can offer a more precise error message here rather than\n // 'of type `object`'.\n var preciseType = getPreciseType(propValue);\n\n return new PropTypeError(\n 'Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + preciseType + '` supplied to `' + componentName + '`, expected ') + ('`' + expectedType + '`.'),\n {expectedType: expectedType}\n );\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createAnyTypeChecker() {\n return createChainableTypeChecker(emptyFunctionThatReturnsNull);\n }\n\n function createArrayOfTypeChecker(typeChecker) {\n function validate(props, propName, componentName, location, propFullName) {\n if (typeof typeChecker !== 'function') {\n return new PropTypeError('Property `' + propFullName + '` of component `' + componentName + '` has invalid PropType notation inside arrayOf.');\n }\n var propValue = props[propName];\n if (!Array.isArray(propValue)) {\n var propType = getPropType(propValue);\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected an array.'));\n }\n for (var i = 0; i < propValue.length; i++) {\n var error = typeChecker(propValue, i, componentName, location, propFullName + '[' + i + ']', ReactPropTypesSecret);\n if (error instanceof Error) {\n return error;\n }\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createElementTypeChecker() {\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n if (!isValidElement(propValue)) {\n var propType = getPropType(propValue);\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected a single ReactElement.'));\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createElementTypeTypeChecker() {\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n if (!ReactIs.isValidElementType(propValue)) {\n var propType = getPropType(propValue);\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected a single ReactElement type.'));\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createInstanceTypeChecker(expectedClass) {\n function validate(props, propName, componentName, location, propFullName) {\n if (!(props[propName] instanceof expectedClass)) {\n var expectedClassName = expectedClass.name || ANONYMOUS;\n var actualClassName = getClassName(props[propName]);\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + actualClassName + '` supplied to `' + componentName + '`, expected ') + ('instance of `' + expectedClassName + '`.'));\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createEnumTypeChecker(expectedValues) {\n if (!Array.isArray(expectedValues)) {\n if (process.env.NODE_ENV !== 'production') {\n if (arguments.length > 1) {\n printWarning(\n 'Invalid arguments supplied to oneOf, expected an array, got ' + arguments.length + ' arguments. ' +\n 'A common mistake is to write oneOf(x, y, z) instead of oneOf([x, y, z]).'\n );\n } else {\n printWarning('Invalid argument supplied to oneOf, expected an array.');\n }\n }\n return emptyFunctionThatReturnsNull;\n }\n\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n for (var i = 0; i < expectedValues.length; i++) {\n if (is(propValue, expectedValues[i])) {\n return null;\n }\n }\n\n var valuesString = JSON.stringify(expectedValues, function replacer(key, value) {\n var type = getPreciseType(value);\n if (type === 'symbol') {\n return String(value);\n }\n return value;\n });\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of value `' + String(propValue) + '` ' + ('supplied to `' + componentName + '`, expected one of ' + valuesString + '.'));\n }\n return createChainableTypeChecker(validate);\n }\n\n function createObjectOfTypeChecker(typeChecker) {\n function validate(props, propName, componentName, location, propFullName) {\n if (typeof typeChecker !== 'function') {\n return new PropTypeError('Property `' + propFullName + '` of component `' + componentName + '` has invalid PropType notation inside objectOf.');\n }\n var propValue = props[propName];\n var propType = getPropType(propValue);\n if (propType !== 'object') {\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected an object.'));\n }\n for (var key in propValue) {\n if (has(propValue, key)) {\n var error = typeChecker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret);\n if (error instanceof Error) {\n return error;\n }\n }\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createUnionTypeChecker(arrayOfTypeCheckers) {\n if (!Array.isArray(arrayOfTypeCheckers)) {\n process.env.NODE_ENV !== 'production' ? printWarning('Invalid argument supplied to oneOfType, expected an instance of array.') : void 0;\n return emptyFunctionThatReturnsNull;\n }\n\n for (var i = 0; i < arrayOfTypeCheckers.length; i++) {\n var checker = arrayOfTypeCheckers[i];\n if (typeof checker !== 'function') {\n printWarning(\n 'Invalid argument supplied to oneOfType. Expected an array of check functions, but ' +\n 'received ' + getPostfixForTypeWarning(checker) + ' at index ' + i + '.'\n );\n return emptyFunctionThatReturnsNull;\n }\n }\n\n function validate(props, propName, componentName, location, propFullName) {\n var expectedTypes = [];\n for (var i = 0; i < arrayOfTypeCheckers.length; i++) {\n var checker = arrayOfTypeCheckers[i];\n var checkerResult = checker(props, propName, componentName, location, propFullName, ReactPropTypesSecret);\n if (checkerResult == null) {\n return null;\n }\n if (checkerResult.data && has(checkerResult.data, 'expectedType')) {\n expectedTypes.push(checkerResult.data.expectedType);\n }\n }\n var expectedTypesMessage = (expectedTypes.length > 0) ? ', expected one of type [' + expectedTypes.join(', ') + ']': '';\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` supplied to ' + ('`' + componentName + '`' + expectedTypesMessage + '.'));\n }\n return createChainableTypeChecker(validate);\n }\n\n function createNodeChecker() {\n function validate(props, propName, componentName, location, propFullName) {\n if (!isNode(props[propName])) {\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` supplied to ' + ('`' + componentName + '`, expected a ReactNode.'));\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function invalidValidatorError(componentName, location, propFullName, key, type) {\n return new PropTypeError(\n (componentName || 'React class') + ': ' + location + ' type `' + propFullName + '.' + key + '` is invalid; ' +\n 'it must be a function, usually from the `prop-types` package, but received `' + type + '`.'\n );\n }\n\n function createShapeTypeChecker(shapeTypes) {\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n var propType = getPropType(propValue);\n if (propType !== 'object') {\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type `' + propType + '` ' + ('supplied to `' + componentName + '`, expected `object`.'));\n }\n for (var key in shapeTypes) {\n var checker = shapeTypes[key];\n if (typeof checker !== 'function') {\n return invalidValidatorError(componentName, location, propFullName, key, getPreciseType(checker));\n }\n var error = checker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret);\n if (error) {\n return error;\n }\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createStrictShapeTypeChecker(shapeTypes) {\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n var propType = getPropType(propValue);\n if (propType !== 'object') {\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type `' + propType + '` ' + ('supplied to `' + componentName + '`, expected `object`.'));\n }\n // We need to check all keys in case some are required but missing from props.\n var allKeys = assign({}, props[propName], shapeTypes);\n for (var key in allKeys) {\n var checker = shapeTypes[key];\n if (has(shapeTypes, key) && typeof checker !== 'function') {\n return invalidValidatorError(componentName, location, propFullName, key, getPreciseType(checker));\n }\n if (!checker) {\n return new PropTypeError(\n 'Invalid ' + location + ' `' + propFullName + '` key `' + key + '` supplied to `' + componentName + '`.' +\n '\\nBad object: ' + JSON.stringify(props[propName], null, ' ') +\n '\\nValid keys: ' + JSON.stringify(Object.keys(shapeTypes), null, ' ')\n );\n }\n var error = checker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret);\n if (error) {\n return error;\n }\n }\n return null;\n }\n\n return createChainableTypeChecker(validate);\n }\n\n function isNode(propValue) {\n switch (typeof propValue) {\n case 'number':\n case 'string':\n case 'undefined':\n return true;\n case 'boolean':\n return !propValue;\n case 'object':\n if (Array.isArray(propValue)) {\n return propValue.every(isNode);\n }\n if (propValue === null || isValidElement(propValue)) {\n return true;\n }\n\n var iteratorFn = getIteratorFn(propValue);\n if (iteratorFn) {\n var iterator = iteratorFn.call(propValue);\n var step;\n if (iteratorFn !== propValue.entries) {\n while (!(step = iterator.next()).done) {\n if (!isNode(step.value)) {\n return false;\n }\n }\n } else {\n // Iterator will provide entry [k,v] tuples rather than values.\n while (!(step = iterator.next()).done) {\n var entry = step.value;\n if (entry) {\n if (!isNode(entry[1])) {\n return false;\n }\n }\n }\n }\n } else {\n return false;\n }\n\n return true;\n default:\n return false;\n }\n }\n\n function isSymbol(propType, propValue) {\n // Native Symbol.\n if (propType === 'symbol') {\n return true;\n }\n\n // falsy value can't be a Symbol\n if (!propValue) {\n return false;\n }\n\n // 19.4.3.5 Symbol.prototype[@@toStringTag] === 'Symbol'\n if (propValue['@@toStringTag'] === 'Symbol') {\n return true;\n }\n\n // Fallback for non-spec compliant Symbols which are polyfilled.\n if (typeof Symbol === 'function' && propValue instanceof Symbol) {\n return true;\n }\n\n return false;\n }\n\n // Equivalent of `typeof` but with special handling for array and regexp.\n function getPropType(propValue) {\n var propType = typeof propValue;\n if (Array.isArray(propValue)) {\n return 'array';\n }\n if (propValue instanceof RegExp) {\n // Old webkits (at least until Android 4.0) return 'function' rather than\n // 'object' for typeof a RegExp. We'll normalize this here so that /bla/\n // passes PropTypes.object.\n return 'object';\n }\n if (isSymbol(propType, propValue)) {\n return 'symbol';\n }\n return propType;\n }\n\n // This handles more types than `getPropType`. Only used for error messages.\n // See `createPrimitiveTypeChecker`.\n function getPreciseType(propValue) {\n if (typeof propValue === 'undefined' || propValue === null) {\n return '' + propValue;\n }\n var propType = getPropType(propValue);\n if (propType === 'object') {\n if (propValue instanceof Date) {\n return 'date';\n } else if (propValue instanceof RegExp) {\n return 'regexp';\n }\n }\n return propType;\n }\n\n // Returns a string that is postfixed to a warning about an invalid type.\n // For example, \"undefined\" or \"of type array\"\n function getPostfixForTypeWarning(value) {\n var type = getPreciseType(value);\n switch (type) {\n case 'array':\n case 'object':\n return 'an ' + type;\n case 'boolean':\n case 'date':\n case 'regexp':\n return 'a ' + type;\n default:\n return type;\n }\n }\n\n // Returns class name of the object, if any.\n function getClassName(propValue) {\n if (!propValue.constructor || !propValue.constructor.name) {\n return ANONYMOUS;\n }\n return propValue.constructor.name;\n }\n\n ReactPropTypes.checkPropTypes = checkPropTypes;\n ReactPropTypes.resetWarningCache = checkPropTypes.resetWarningCache;\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n\nfunction emptyFunction() {}\nfunction emptyFunctionWithReset() {}\nemptyFunctionWithReset.resetWarningCache = emptyFunction;\n\nmodule.exports = function() {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret) {\n // It is still safe when called from React.\n return;\n }\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use PropTypes.checkPropTypes() to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n };\n shim.isRequired = shim;\n function getShim() {\n return shim;\n };\n // Important!\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n var ReactPropTypes = {\n array: shim,\n bigint: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\n\n any: shim,\n arrayOf: getShim,\n element: shim,\n elementType: shim,\n instanceOf: getShim,\n node: shim,\n objectOf: getShim,\n oneOf: getShim,\n oneOfType: getShim,\n shape: getShim,\n exact: getShim,\n\n checkPropTypes: emptyFunctionWithReset,\n resetWarningCache: emptyFunction\n };\n\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nif (process.env.NODE_ENV !== 'production') {\n var ReactIs = require('react-is');\n\n // By explicitly using `prop-types` you are opting into new development behavior.\n // http://fb.me/prop-types-in-prod\n var throwOnDirectAccess = true;\n module.exports = require('./factoryWithTypeCheckers')(ReactIs.isElement, throwOnDirectAccess);\n} else {\n // By explicitly using `prop-types` you are opting into new production behavior.\n // http://fb.me/prop-types-in-prod\n module.exports = require('./factoryWithThrowingShims')();\n}\n","/**\n * @license React\n * react-is.production.js\n *\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\"use strict\";\nvar REACT_ELEMENT_TYPE = Symbol.for(\"react.transitional.element\"),\n REACT_PORTAL_TYPE = Symbol.for(\"react.portal\"),\n REACT_FRAGMENT_TYPE = Symbol.for(\"react.fragment\"),\n REACT_STRICT_MODE_TYPE = Symbol.for(\"react.strict_mode\"),\n REACT_PROFILER_TYPE = Symbol.for(\"react.profiler\");\nSymbol.for(\"react.provider\");\nvar REACT_CONSUMER_TYPE = Symbol.for(\"react.consumer\"),\n REACT_CONTEXT_TYPE = Symbol.for(\"react.context\"),\n REACT_FORWARD_REF_TYPE = Symbol.for(\"react.forward_ref\"),\n REACT_SUSPENSE_TYPE = Symbol.for(\"react.suspense\"),\n REACT_SUSPENSE_LIST_TYPE = Symbol.for(\"react.suspense_list\"),\n REACT_MEMO_TYPE = Symbol.for(\"react.memo\"),\n REACT_LAZY_TYPE = Symbol.for(\"react.lazy\"),\n REACT_VIEW_TRANSITION_TYPE = Symbol.for(\"react.view_transition\"),\n REACT_CLIENT_REFERENCE = Symbol.for(\"react.client.reference\");\nfunction typeOf(object) {\n if (\"object\" === typeof object && null !== object) {\n var $$typeof = object.$$typeof;\n switch ($$typeof) {\n case REACT_ELEMENT_TYPE:\n switch (((object = object.type), object)) {\n case REACT_FRAGMENT_TYPE:\n case REACT_PROFILER_TYPE:\n case REACT_STRICT_MODE_TYPE:\n case REACT_SUSPENSE_TYPE:\n case REACT_SUSPENSE_LIST_TYPE:\n case REACT_VIEW_TRANSITION_TYPE:\n return object;\n default:\n switch (((object = object && object.$$typeof), object)) {\n case REACT_CONTEXT_TYPE:\n case REACT_FORWARD_REF_TYPE:\n case REACT_LAZY_TYPE:\n case REACT_MEMO_TYPE:\n return object;\n case REACT_CONSUMER_TYPE:\n return object;\n default:\n return $$typeof;\n }\n }\n case REACT_PORTAL_TYPE:\n return $$typeof;\n }\n }\n}\nexports.ContextConsumer = REACT_CONSUMER_TYPE;\nexports.ContextProvider = REACT_CONTEXT_TYPE;\nexports.Element = REACT_ELEMENT_TYPE;\nexports.ForwardRef = REACT_FORWARD_REF_TYPE;\nexports.Fragment = REACT_FRAGMENT_TYPE;\nexports.Lazy = REACT_LAZY_TYPE;\nexports.Memo = REACT_MEMO_TYPE;\nexports.Portal = REACT_PORTAL_TYPE;\nexports.Profiler = REACT_PROFILER_TYPE;\nexports.StrictMode = REACT_STRICT_MODE_TYPE;\nexports.Suspense = REACT_SUSPENSE_TYPE;\nexports.SuspenseList = REACT_SUSPENSE_LIST_TYPE;\nexports.isContextConsumer = function (object) {\n return typeOf(object) === REACT_CONSUMER_TYPE;\n};\nexports.isContextProvider = function (object) {\n return typeOf(object) === REACT_CONTEXT_TYPE;\n};\nexports.isElement = function (object) {\n return (\n \"object\" === typeof object &&\n null !== object &&\n object.$$typeof === REACT_ELEMENT_TYPE\n );\n};\nexports.isForwardRef = function (object) {\n return typeOf(object) === REACT_FORWARD_REF_TYPE;\n};\nexports.isFragment = function (object) {\n return typeOf(object) === REACT_FRAGMENT_TYPE;\n};\nexports.isLazy = function (object) {\n return typeOf(object) === REACT_LAZY_TYPE;\n};\nexports.isMemo = function (object) {\n return typeOf(object) === REACT_MEMO_TYPE;\n};\nexports.isPortal = function (object) {\n return typeOf(object) === REACT_PORTAL_TYPE;\n};\nexports.isProfiler = function (object) {\n return typeOf(object) === REACT_PROFILER_TYPE;\n};\nexports.isStrictMode = function (object) {\n return typeOf(object) === REACT_STRICT_MODE_TYPE;\n};\nexports.isSuspense = function (object) {\n return typeOf(object) === REACT_SUSPENSE_TYPE;\n};\nexports.isSuspenseList = function (object) {\n return typeOf(object) === REACT_SUSPENSE_LIST_TYPE;\n};\nexports.isValidElementType = function (type) {\n return \"string\" === typeof type ||\n \"function\" === typeof type ||\n type === REACT_FRAGMENT_TYPE ||\n type === REACT_PROFILER_TYPE ||\n type === REACT_STRICT_MODE_TYPE ||\n type === REACT_SUSPENSE_TYPE ||\n type === REACT_SUSPENSE_LIST_TYPE ||\n (\"object\" === typeof type &&\n null !== type &&\n (type.$$typeof === REACT_LAZY_TYPE ||\n type.$$typeof === REACT_MEMO_TYPE ||\n type.$$typeof === REACT_CONTEXT_TYPE ||\n type.$$typeof === REACT_CONSUMER_TYPE ||\n type.$$typeof === REACT_FORWARD_REF_TYPE ||\n type.$$typeof === REACT_CLIENT_REFERENCE ||\n void 0 !== type.getModuleId))\n ? !0\n : !1;\n};\nexports.typeOf = typeOf;\n","/**\n * @license React\n * react-is.development.js\n *\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\"use strict\";\n\"production\" !== process.env.NODE_ENV &&\n (function () {\n function typeOf(object) {\n if (\"object\" === typeof object && null !== object) {\n var $$typeof = object.$$typeof;\n switch ($$typeof) {\n case REACT_ELEMENT_TYPE:\n switch (((object = object.type), object)) {\n case REACT_FRAGMENT_TYPE:\n case REACT_PROFILER_TYPE:\n case REACT_STRICT_MODE_TYPE:\n case REACT_SUSPENSE_TYPE:\n case REACT_SUSPENSE_LIST_TYPE:\n case REACT_VIEW_TRANSITION_TYPE:\n return object;\n default:\n switch (((object = object && object.$$typeof), object)) {\n case REACT_CONTEXT_TYPE:\n case REACT_FORWARD_REF_TYPE:\n case REACT_LAZY_TYPE:\n case REACT_MEMO_TYPE:\n return object;\n case REACT_CONSUMER_TYPE:\n return object;\n default:\n return $$typeof;\n }\n }\n case REACT_PORTAL_TYPE:\n return $$typeof;\n }\n }\n }\n var REACT_ELEMENT_TYPE = Symbol.for(\"react.transitional.element\"),\n REACT_PORTAL_TYPE = Symbol.for(\"react.portal\"),\n REACT_FRAGMENT_TYPE = Symbol.for(\"react.fragment\"),\n REACT_STRICT_MODE_TYPE = Symbol.for(\"react.strict_mode\"),\n REACT_PROFILER_TYPE = Symbol.for(\"react.profiler\");\n Symbol.for(\"react.provider\");\n var REACT_CONSUMER_TYPE = Symbol.for(\"react.consumer\"),\n REACT_CONTEXT_TYPE = Symbol.for(\"react.context\"),\n REACT_FORWARD_REF_TYPE = Symbol.for(\"react.forward_ref\"),\n REACT_SUSPENSE_TYPE = Symbol.for(\"react.suspense\"),\n REACT_SUSPENSE_LIST_TYPE = Symbol.for(\"react.suspense_list\"),\n REACT_MEMO_TYPE = Symbol.for(\"react.memo\"),\n REACT_LAZY_TYPE = Symbol.for(\"react.lazy\"),\n REACT_VIEW_TRANSITION_TYPE = Symbol.for(\"react.view_transition\"),\n REACT_CLIENT_REFERENCE = Symbol.for(\"react.client.reference\");\n exports.ContextConsumer = REACT_CONSUMER_TYPE;\n exports.ContextProvider = REACT_CONTEXT_TYPE;\n exports.Element = REACT_ELEMENT_TYPE;\n exports.ForwardRef = REACT_FORWARD_REF_TYPE;\n exports.Fragment = REACT_FRAGMENT_TYPE;\n exports.Lazy = REACT_LAZY_TYPE;\n exports.Memo = REACT_MEMO_TYPE;\n exports.Portal = REACT_PORTAL_TYPE;\n exports.Profiler = REACT_PROFILER_TYPE;\n exports.StrictMode = REACT_STRICT_MODE_TYPE;\n exports.Suspense = REACT_SUSPENSE_TYPE;\n exports.SuspenseList = REACT_SUSPENSE_LIST_TYPE;\n exports.isContextConsumer = function (object) {\n return typeOf(object) === REACT_CONSUMER_TYPE;\n };\n exports.isContextProvider = function (object) {\n return typeOf(object) === REACT_CONTEXT_TYPE;\n };\n exports.isElement = function (object) {\n return (\n \"object\" === typeof object &&\n null !== object &&\n object.$$typeof === REACT_ELEMENT_TYPE\n );\n };\n exports.isForwardRef = function (object) {\n return typeOf(object) === REACT_FORWARD_REF_TYPE;\n };\n exports.isFragment = function (object) {\n return typeOf(object) === REACT_FRAGMENT_TYPE;\n };\n exports.isLazy = function (object) {\n return typeOf(object) === REACT_LAZY_TYPE;\n };\n exports.isMemo = function (object) {\n return typeOf(object) === REACT_MEMO_TYPE;\n };\n exports.isPortal = function (object) {\n return typeOf(object) === REACT_PORTAL_TYPE;\n };\n exports.isProfiler = function (object) {\n return typeOf(object) === REACT_PROFILER_TYPE;\n };\n exports.isStrictMode = function (object) {\n return typeOf(object) === REACT_STRICT_MODE_TYPE;\n };\n exports.isSuspense = function (object) {\n return typeOf(object) === REACT_SUSPENSE_TYPE;\n };\n exports.isSuspenseList = function (object) {\n return typeOf(object) === REACT_SUSPENSE_LIST_TYPE;\n };\n exports.isValidElementType = function (type) {\n return \"string\" === typeof type ||\n \"function\" === typeof type ||\n type === REACT_FRAGMENT_TYPE ||\n type === REACT_PROFILER_TYPE ||\n type === REACT_STRICT_MODE_TYPE ||\n type === REACT_SUSPENSE_TYPE ||\n type === REACT_SUSPENSE_LIST_TYPE ||\n (\"object\" === typeof type &&\n null !== type &&\n (type.$$typeof === REACT_LAZY_TYPE ||\n type.$$typeof === REACT_MEMO_TYPE ||\n type.$$typeof === REACT_CONTEXT_TYPE ||\n type.$$typeof === REACT_CONSUMER_TYPE ||\n type.$$typeof === REACT_FORWARD_REF_TYPE ||\n type.$$typeof === REACT_CLIENT_REFERENCE ||\n void 0 !== type.getModuleId))\n ? !0\n : !1;\n };\n exports.typeOf = typeOf;\n })();\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-is.production.js');\n} else {\n module.exports = require('./cjs/react-is.development.js');\n}\n","import * as React from 'react';\nimport { isValidElementType } from 'react-is';\n\n// https://github.com/sindresorhus/is-plain-obj/blob/main/index.js\nexport function isPlainObject(item) {\n if (typeof item !== 'object' || item === null) {\n return false;\n }\n const prototype = Object.getPrototypeOf(item);\n return (prototype === null || prototype === Object.prototype || Object.getPrototypeOf(prototype) === null) && !(Symbol.toStringTag in item) && !(Symbol.iterator in item);\n}\nfunction deepClone(source) {\n if (/*#__PURE__*/React.isValidElement(source) || isValidElementType(source) || !isPlainObject(source)) {\n return source;\n }\n const output = {};\n Object.keys(source).forEach(key => {\n output[key] = deepClone(source[key]);\n });\n return output;\n}\n\n/**\n * Merge objects deeply.\n * It will shallow copy React elements.\n *\n * If `options.clone` is set to `false` the source object will be merged directly into the target object.\n *\n * @example\n * ```ts\n * deepmerge({ a: { b: 1 }, d: 2 }, { a: { c: 2 }, d: 4 });\n * // => { a: { b: 1, c: 2 }, d: 4 }\n * ````\n *\n * @param target The target object.\n * @param source The source object.\n * @param options The merge options.\n * @param options.clone Set to `false` to merge the source object directly into the target object.\n * @returns The merged object.\n */\nexport default function deepmerge(target, source, options = {\n clone: true\n}) {\n const output = options.clone ? {\n ...target\n } : target;\n if (isPlainObject(target) && isPlainObject(source)) {\n Object.keys(source).forEach(key => {\n if (/*#__PURE__*/React.isValidElement(source[key]) || isValidElementType(source[key])) {\n output[key] = source[key];\n } else if (isPlainObject(source[key]) &&\n // Avoid prototype pollution\n Object.prototype.hasOwnProperty.call(target, key) && isPlainObject(target[key])) {\n // Since `output` is a clone of `target` and we have narrowed `target` in this block we can cast to the same type.\n output[key] = deepmerge(target[key], source[key], options);\n } else if (options.clone) {\n output[key] = isPlainObject(source[key]) ? deepClone(source[key]) : source[key];\n } else {\n output[key] = source[key];\n }\n });\n }\n return output;\n}","// Sorted ASC by size. That's important.\n// It can't be configured as it's used statically for propTypes.\nexport const breakpointKeys = ['xs', 'sm', 'md', 'lg', 'xl'];\nconst sortBreakpointsValues = values => {\n const breakpointsAsArray = Object.keys(values).map(key => ({\n key,\n val: values[key]\n })) || [];\n // Sort in ascending order\n breakpointsAsArray.sort((breakpoint1, breakpoint2) => breakpoint1.val - breakpoint2.val);\n return breakpointsAsArray.reduce((acc, obj) => {\n return {\n ...acc,\n [obj.key]: obj.val\n };\n }, {});\n};\n\n// Keep in mind that @media is inclusive by the CSS specification.\nexport default function createBreakpoints(breakpoints) {\n const {\n // The breakpoint **start** at this value.\n // For instance with the first breakpoint xs: [xs, sm).\n values = {\n xs: 0,\n // phone\n sm: 600,\n // tablet\n md: 900,\n // small laptop\n lg: 1200,\n // desktop\n xl: 1536 // large screen\n },\n unit = 'px',\n step = 5,\n ...other\n } = breakpoints;\n const sortedValues = sortBreakpointsValues(values);\n const keys = Object.keys(sortedValues);\n function up(key) {\n const value = typeof values[key] === 'number' ? values[key] : key;\n return `@media (min-width:${value}${unit})`;\n }\n function down(key) {\n const value = typeof values[key] === 'number' ? values[key] : key;\n return `@media (max-width:${value - step / 100}${unit})`;\n }\n function between(start, end) {\n const endIndex = keys.indexOf(end);\n return `@media (min-width:${typeof values[start] === 'number' ? values[start] : start}${unit}) and ` + `(max-width:${(endIndex !== -1 && typeof values[keys[endIndex]] === 'number' ? values[keys[endIndex]] : end) - step / 100}${unit})`;\n }\n function only(key) {\n if (keys.indexOf(key) + 1 < keys.length) {\n return between(key, keys[keys.indexOf(key) + 1]);\n }\n return up(key);\n }\n function not(key) {\n // handle first and last key separately, for better readability\n const keyIndex = keys.indexOf(key);\n if (keyIndex === 0) {\n return up(keys[1]);\n }\n if (keyIndex === keys.length - 1) {\n return down(keys[keyIndex]);\n }\n return between(key, keys[keys.indexOf(key) + 1]).replace('@media', '@media not all and');\n }\n return {\n keys,\n values: sortedValues,\n up,\n down,\n between,\n only,\n not,\n unit,\n ...other\n };\n}","const shape = {\n borderRadius: 4\n};\nexport default shape;","import PropTypes from 'prop-types';\nconst responsivePropType = process.env.NODE_ENV !== 'production' ? PropTypes.oneOfType([PropTypes.number, PropTypes.string, PropTypes.object, PropTypes.array]) : {};\nexport default responsivePropType;","import deepmerge from '@mui/utils/deepmerge';\nfunction merge(acc, item) {\n if (!item) {\n return acc;\n }\n return deepmerge(acc, item, {\n clone: false // No need to clone deep, it's way faster.\n });\n}\nexport default merge;","import PropTypes from 'prop-types';\nimport deepmerge from '@mui/utils/deepmerge';\nimport merge from \"../merge/index.js\";\nimport { isCqShorthand, getContainerQuery } from \"../cssContainerQueries/index.js\";\n\n// The breakpoint **start** at this value.\n// For instance with the first breakpoint xs: [xs, sm[.\nexport const values = {\n xs: 0,\n // phone\n sm: 600,\n // tablet\n md: 900,\n // small laptop\n lg: 1200,\n // desktop\n xl: 1536 // large screen\n};\nconst defaultBreakpoints = {\n // Sorted ASC by size. That's important.\n // It can't be configured as it's used statically for propTypes.\n keys: ['xs', 'sm', 'md', 'lg', 'xl'],\n up: key => `@media (min-width:${values[key]}px)`\n};\nconst defaultContainerQueries = {\n containerQueries: containerName => ({\n up: key => {\n let result = typeof key === 'number' ? key : values[key] || key;\n if (typeof result === 'number') {\n result = `${result}px`;\n }\n return containerName ? `@container ${containerName} (min-width:${result})` : `@container (min-width:${result})`;\n }\n })\n};\nexport function handleBreakpoints(props, propValue, styleFromPropValue) {\n const theme = props.theme || {};\n if (Array.isArray(propValue)) {\n const themeBreakpoints = theme.breakpoints || defaultBreakpoints;\n return propValue.reduce((acc, item, index) => {\n acc[themeBreakpoints.up(themeBreakpoints.keys[index])] = styleFromPropValue(propValue[index]);\n return acc;\n }, {});\n }\n if (typeof propValue === 'object') {\n const themeBreakpoints = theme.breakpoints || defaultBreakpoints;\n return Object.keys(propValue).reduce((acc, breakpoint) => {\n if (isCqShorthand(themeBreakpoints.keys, breakpoint)) {\n const containerKey = getContainerQuery(theme.containerQueries ? theme : defaultContainerQueries, breakpoint);\n if (containerKey) {\n acc[containerKey] = styleFromPropValue(propValue[breakpoint], breakpoint);\n }\n }\n // key is breakpoint\n else if (Object.keys(themeBreakpoints.values || values).includes(breakpoint)) {\n const mediaKey = themeBreakpoints.up(breakpoint);\n acc[mediaKey] = styleFromPropValue(propValue[breakpoint], breakpoint);\n } else {\n const cssKey = breakpoint;\n acc[cssKey] = propValue[cssKey];\n }\n return acc;\n }, {});\n }\n const output = styleFromPropValue(propValue);\n return output;\n}\nfunction breakpoints(styleFunction) {\n // false positive\n // eslint-disable-next-line react/function-component-definition\n const newStyleFunction = props => {\n const theme = props.theme || {};\n const base = styleFunction(props);\n const themeBreakpoints = theme.breakpoints || defaultBreakpoints;\n const extended = themeBreakpoints.keys.reduce((acc, key) => {\n if (props[key]) {\n acc = acc || {};\n acc[themeBreakpoints.up(key)] = styleFunction({\n theme,\n ...props[key]\n });\n }\n return acc;\n }, null);\n return merge(base, extended);\n };\n newStyleFunction.propTypes = process.env.NODE_ENV !== 'production' ? {\n ...styleFunction.propTypes,\n xs: PropTypes.object,\n sm: PropTypes.object,\n md: PropTypes.object,\n lg: PropTypes.object,\n xl: PropTypes.object\n } : {};\n newStyleFunction.filterProps = ['xs', 'sm', 'md', 'lg', 'xl', ...styleFunction.filterProps];\n return newStyleFunction;\n}\nexport function createEmptyBreakpointObject(breakpointsInput = {}) {\n const breakpointsInOrder = breakpointsInput.keys?.reduce((acc, key) => {\n const breakpointStyleKey = breakpointsInput.up(key);\n acc[breakpointStyleKey] = {};\n return acc;\n }, {});\n return breakpointsInOrder || {};\n}\nexport function removeUnusedBreakpoints(breakpointKeys, style) {\n return breakpointKeys.reduce((acc, key) => {\n const breakpointOutput = acc[key];\n const isBreakpointUnused = !breakpointOutput || Object.keys(breakpointOutput).length === 0;\n if (isBreakpointUnused) {\n delete acc[key];\n }\n return acc;\n }, style);\n}\nexport function mergeBreakpointsInOrder(breakpointsInput, ...styles) {\n const emptyBreakpoints = createEmptyBreakpointObject(breakpointsInput);\n const mergedOutput = [emptyBreakpoints, ...styles].reduce((prev, next) => deepmerge(prev, next), {});\n return removeUnusedBreakpoints(Object.keys(emptyBreakpoints), mergedOutput);\n}\n\n// compute base for responsive values; e.g.,\n// [1,2,3] => {xs: true, sm: true, md: true}\n// {xs: 1, sm: 2, md: 3} => {xs: true, sm: true, md: true}\nexport function computeBreakpointsBase(breakpointValues, themeBreakpoints) {\n // fixed value\n if (typeof breakpointValues !== 'object') {\n return {};\n }\n const base = {};\n const breakpointsKeys = Object.keys(themeBreakpoints);\n if (Array.isArray(breakpointValues)) {\n breakpointsKeys.forEach((breakpoint, i) => {\n if (i < breakpointValues.length) {\n base[breakpoint] = true;\n }\n });\n } else {\n breakpointsKeys.forEach(breakpoint => {\n if (breakpointValues[breakpoint] != null) {\n base[breakpoint] = true;\n }\n });\n }\n return base;\n}\nexport function resolveBreakpointValues({\n values: breakpointValues,\n breakpoints: themeBreakpoints,\n base: customBase\n}) {\n const base = customBase || computeBreakpointsBase(breakpointValues, themeBreakpoints);\n const keys = Object.keys(base);\n if (keys.length === 0) {\n return breakpointValues;\n }\n let previous;\n return keys.reduce((acc, breakpoint, i) => {\n if (Array.isArray(breakpointValues)) {\n acc[breakpoint] = breakpointValues[i] != null ? breakpointValues[i] : breakpointValues[previous];\n previous = i;\n } else if (typeof breakpointValues === 'object') {\n acc[breakpoint] = breakpointValues[breakpoint] != null ? breakpointValues[breakpoint] : breakpointValues[previous];\n previous = breakpoint;\n } else {\n acc[breakpoint] = breakpointValues;\n }\n return acc;\n }, {});\n}\nexport default breakpoints;","import _formatErrorMessage from \"@mui/utils/formatMuiErrorMessage\";\n/**\n * For using in `sx` prop to sort the breakpoint from low to high.\n * Note: this function does not work and will not support multiple units.\n * e.g. input: { '@container (min-width:300px)': '1rem', '@container (min-width:40rem)': '2rem' }\n * output: { '@container (min-width:40rem)': '2rem', '@container (min-width:300px)': '1rem' } // since 40 < 300 eventhough 40rem > 300px\n */\nexport function sortContainerQueries(theme, css) {\n if (!theme.containerQueries) {\n return css;\n }\n const sorted = Object.keys(css).filter(key => key.startsWith('@container')).sort((a, b) => {\n const regex = /min-width:\\s*([0-9.]+)/;\n return +(a.match(regex)?.[1] || 0) - +(b.match(regex)?.[1] || 0);\n });\n if (!sorted.length) {\n return css;\n }\n return sorted.reduce((acc, key) => {\n const value = css[key];\n delete acc[key];\n acc[key] = value;\n return acc;\n }, {\n ...css\n });\n}\nexport function isCqShorthand(breakpointKeys, value) {\n return value === '@' || value.startsWith('@') && (breakpointKeys.some(key => value.startsWith(`@${key}`)) || !!value.match(/^@\\d/));\n}\nexport function getContainerQuery(theme, shorthand) {\n const matches = shorthand.match(/^@([^/]+)?\\/?(.+)?$/);\n if (!matches) {\n if (process.env.NODE_ENV !== 'production') {\n throw new Error(process.env.NODE_ENV !== \"production\" ? `MUI: The provided shorthand ${`(${shorthand})`} is invalid. The format should be \\`@<breakpoint | number>\\` or \\`@<breakpoint | number>/<container>\\`.\\n` + 'For example, `@sm` or `@600` or `@40rem/sidebar`.' : _formatErrorMessage(18, `(${shorthand})`));\n }\n return null;\n }\n const [, containerQuery, containerName] = matches;\n const value = Number.isNaN(+containerQuery) ? containerQuery || 0 : +containerQuery;\n return theme.containerQueries(containerName).up(value);\n}\nexport default function cssContainerQueries(themeInput) {\n const toContainerQuery = (mediaQuery, name) => mediaQuery.replace('@media', name ? `@container ${name}` : '@container');\n function attachCq(node, name) {\n node.up = (...args) => toContainerQuery(themeInput.breakpoints.up(...args), name);\n node.down = (...args) => toContainerQuery(themeInput.breakpoints.down(...args), name);\n node.between = (...args) => toContainerQuery(themeInput.breakpoints.between(...args), name);\n node.only = (...args) => toContainerQuery(themeInput.breakpoints.only(...args), name);\n node.not = (...args) => {\n const result = toContainerQuery(themeInput.breakpoints.not(...args), name);\n if (result.includes('not all and')) {\n // `@container` does not work with `not all and`, so need to invert the logic\n return result.replace('not all and ', '').replace('min-width:', 'width<').replace('max-width:', 'width>').replace('and', 'or');\n }\n return result;\n };\n }\n const node = {};\n const containerQueries = name => {\n attachCq(node, name);\n return node;\n };\n attachCq(containerQueries);\n return {\n ...themeInput,\n containerQueries\n };\n}","import _formatErrorMessage from \"@mui/utils/formatMuiErrorMessage\";\n// It should to be noted that this function isn't equivalent to `text-transform: capitalize`.\n//\n// A strict capitalization should uppercase the first letter of each word in the sentence.\n// We only handle the first word.\nexport default function capitalize(string) {\n if (typeof string !== 'string') {\n throw new Error(process.env.NODE_ENV !== \"production\" ? 'MUI: `capitalize(string)` expects a string argument.' : _formatErrorMessage(7));\n }\n return string.charAt(0).toUpperCase() + string.slice(1);\n}","import capitalize from '@mui/utils/capitalize';\nimport responsivePropType from \"../responsivePropType/index.js\";\nimport { handleBreakpoints } from \"../breakpoints/index.js\";\nexport function getPath(obj, path, checkVars = true) {\n if (!path || typeof path !== 'string') {\n return null;\n }\n\n // Check if CSS variables are used\n if (obj && obj.vars && checkVars) {\n const val = `vars.${path}`.split('.').reduce((acc, item) => acc && acc[item] ? acc[item] : null, obj);\n if (val != null) {\n return val;\n }\n }\n return path.split('.').reduce((acc, item) => {\n if (acc && acc[item] != null) {\n return acc[item];\n }\n return null;\n }, obj);\n}\nexport function getStyleValue(themeMapping, transform, propValueFinal, userValue = propValueFinal) {\n let value;\n if (typeof themeMapping === 'function') {\n value = themeMapping(propValueFinal);\n } else if (Array.isArray(themeMapping)) {\n value = themeMapping[propValueFinal] || userValue;\n } else {\n value = getPath(themeMapping, propValueFinal) || userValue;\n }\n if (transform) {\n value = transform(value, userValue, themeMapping);\n }\n return value;\n}\nfunction style(options) {\n const {\n prop,\n cssProperty = options.prop,\n themeKey,\n transform\n } = options;\n\n // false positive\n // eslint-disable-next-line react/function-component-definition\n const fn = props => {\n if (props[prop] == null) {\n return null;\n }\n const propValue = props[prop];\n const theme = props.theme;\n const themeMapping = getPath(theme, themeKey) || {};\n const styleFromPropValue = propValueFinal => {\n let value = getStyleValue(themeMapping, transform, propValueFinal);\n if (propValueFinal === value && typeof propValueFinal === 'string') {\n // Haven't found value\n value = getStyleValue(themeMapping, transform, `${prop}${propValueFinal === 'default' ? '' : capitalize(propValueFinal)}`, propValueFinal);\n }\n if (cssProperty === false) {\n return value;\n }\n return {\n [cssProperty]: value\n };\n };\n return handleBreakpoints(props, propValue, styleFromPropValue);\n };\n fn.propTypes = process.env.NODE_ENV !== 'production' ? {\n [prop]: responsivePropType\n } : {};\n fn.filterProps = [prop];\n return fn;\n}\nexport default style;","import responsivePropType from \"../responsivePropType/index.js\";\nimport { handleBreakpoints } from \"../breakpoints/index.js\";\nimport { getPath } from \"../style/index.js\";\nimport merge from \"../merge/index.js\";\nimport memoize from \"../memoize/index.js\";\nconst properties = {\n m: 'margin',\n p: 'padding'\n};\nconst directions = {\n t: 'Top',\n r: 'Right',\n b: 'Bottom',\n l: 'Left',\n x: ['Left', 'Right'],\n y: ['Top', 'Bottom']\n};\nconst aliases = {\n marginX: 'mx',\n marginY: 'my',\n paddingX: 'px',\n paddingY: 'py'\n};\n\n// memoize() impact:\n// From 300,000 ops/sec\n// To 350,000 ops/sec\nconst getCssProperties = memoize(prop => {\n // It's not a shorthand notation.\n if (prop.length > 2) {\n if (aliases[prop]) {\n prop = aliases[prop];\n } else {\n return [prop];\n }\n }\n const [a, b] = prop.split('');\n const property = properties[a];\n const direction = directions[b] || '';\n return Array.isArray(direction) ? direction.map(dir => property + dir) : [property + direction];\n});\nexport const marginKeys = ['m', 'mt', 'mr', 'mb', 'ml', 'mx', 'my', 'margin', 'marginTop', 'marginRight', 'marginBottom', 'marginLeft', 'marginX', 'marginY', 'marginInline', 'marginInlineStart', 'marginInlineEnd', 'marginBlock', 'marginBlockStart', 'marginBlockEnd'];\nexport const paddingKeys = ['p', 'pt', 'pr', 'pb', 'pl', 'px', 'py', 'padding', 'paddingTop', 'paddingRight', 'paddingBottom', 'paddingLeft', 'paddingX', 'paddingY', 'paddingInline', 'paddingInlineStart', 'paddingInlineEnd', 'paddingBlock', 'paddingBlockStart', 'paddingBlockEnd'];\nconst spacingKeys = [...marginKeys, ...paddingKeys];\nexport function createUnaryUnit(theme, themeKey, defaultValue, propName) {\n const themeSpacing = getPath(theme, themeKey, true) ?? defaultValue;\n if (typeof themeSpacing === 'number' || typeof themeSpacing === 'string') {\n return val => {\n if (typeof val === 'string') {\n return val;\n }\n if (process.env.NODE_ENV !== 'production') {\n if (typeof val !== 'number') {\n console.error(`MUI: Expected ${propName} argument to be a number or a string, got ${val}.`);\n }\n }\n if (typeof themeSpacing === 'string') {\n if (themeSpacing.startsWith('var(') && val === 0) {\n return 0;\n }\n if (themeSpacing.startsWith('var(') && val === 1) {\n return themeSpacing;\n }\n return `calc(${val} * ${themeSpacing})`;\n }\n return themeSpacing * val;\n };\n }\n if (Array.isArray(themeSpacing)) {\n return val => {\n if (typeof val === 'string') {\n return val;\n }\n const abs = Math.abs(val);\n if (process.env.NODE_ENV !== 'production') {\n if (!Number.isInteger(abs)) {\n console.error([`MUI: The \\`theme.${themeKey}\\` array type cannot be combined with non integer values.` + `You should either use an integer value that can be used as index, or define the \\`theme.${themeKey}\\` as a number.`].join('\\n'));\n } else if (abs > themeSpacing.length - 1) {\n console.error([`MUI: The value provided (${abs}) overflows.`, `The supported values are: ${JSON.stringify(themeSpacing)}.`, `${abs} > ${themeSpacing.length - 1}, you need to add the missing values.`].join('\\n'));\n }\n }\n const transformed = themeSpacing[abs];\n if (val >= 0) {\n return transformed;\n }\n if (typeof transformed === 'number') {\n return -transformed;\n }\n if (typeof transformed === 'string' && transformed.startsWith('var(')) {\n return `calc(-1 * ${transformed})`;\n }\n return `-${transformed}`;\n };\n }\n if (typeof themeSpacing === 'function') {\n return themeSpacing;\n }\n if (process.env.NODE_ENV !== 'production') {\n console.error([`MUI: The \\`theme.${themeKey}\\` value (${themeSpacing}) is invalid.`, 'It should be a number, an array or a function.'].join('\\n'));\n }\n return () => undefined;\n}\nexport function createUnarySpacing(theme) {\n return createUnaryUnit(theme, 'spacing', 8, 'spacing');\n}\nexport function getValue(transformer, propValue) {\n if (typeof propValue === 'string' || propValue == null) {\n return propValue;\n }\n return transformer(propValue);\n}\nexport function getStyleFromPropValue(cssProperties, transformer) {\n return propValue => cssProperties.reduce((acc, cssProperty) => {\n acc[cssProperty] = getValue(transformer, propValue);\n return acc;\n }, {});\n}\nfunction resolveCssProperty(props, keys, prop, transformer) {\n // Using a hash computation over an array iteration could be faster, but with only 28 items,\n // it's doesn't worth the bundle size.\n if (!keys.includes(prop)) {\n return null;\n }\n const cssProperties = getCssProperties(prop);\n const styleFromPropValue = getStyleFromPropValue(cssProperties, transformer);\n const propValue = props[prop];\n return handleBreakpoints(props, propValue, styleFromPropValue);\n}\nfunction style(props, keys) {\n const transformer = createUnarySpacing(props.theme);\n return Object.keys(props).map(prop => resolveCssProperty(props, keys, prop, transformer)).reduce(merge, {});\n}\nexport function margin(props) {\n return style(props, marginKeys);\n}\nmargin.propTypes = process.env.NODE_ENV !== 'production' ? marginKeys.reduce((obj, key) => {\n obj[key] = responsivePropType;\n return obj;\n}, {}) : {};\nmargin.filterProps = marginKeys;\nexport function padding(props) {\n return style(props, paddingKeys);\n}\npadding.propTypes = process.env.NODE_ENV !== 'production' ? paddingKeys.reduce((obj, key) => {\n obj[key] = responsivePropType;\n return obj;\n}, {}) : {};\npadding.filterProps = paddingKeys;\nfunction spacing(props) {\n return style(props, spacingKeys);\n}\nspacing.propTypes = process.env.NODE_ENV !== 'production' ? spacingKeys.reduce((obj, key) => {\n obj[key] = responsivePropType;\n return obj;\n}, {}) : {};\nspacing.filterProps = spacingKeys;\nexport default spacing;","export default function memoize(fn) {\n const cache = {};\n return arg => {\n if (cache[arg] === undefined) {\n cache[arg] = fn(arg);\n }\n return cache[arg];\n };\n}","import merge from \"../merge/index.js\";\nfunction compose(...styles) {\n const handlers = styles.reduce((acc, style) => {\n style.filterProps.forEach(prop => {\n acc[prop] = style;\n });\n return acc;\n }, {});\n\n // false positive\n // eslint-disable-next-line react/function-component-definition\n const fn = props => {\n return Object.keys(props).reduce((acc, prop) => {\n if (handlers[prop]) {\n return merge(acc, handlers[prop](props));\n }\n return acc;\n }, {});\n };\n fn.propTypes = process.env.NODE_ENV !== 'production' ? styles.reduce((acc, style) => Object.assign(acc, style.propTypes), {}) : {};\n fn.filterProps = styles.reduce((acc, style) => acc.concat(style.filterProps), []);\n return fn;\n}\nexport default compose;","import responsivePropType from \"../responsivePropType/index.js\";\nimport style from \"../style/index.js\";\nimport compose from \"../compose/index.js\";\nimport { createUnaryUnit, getValue } from \"../spacing/index.js\";\nimport { handleBreakpoints } from \"../breakpoints/index.js\";\nexport function borderTransform(value) {\n if (typeof value !== 'number') {\n return value;\n }\n return `${value}px solid`;\n}\nfunction createBorderStyle(prop, transform) {\n return style({\n prop,\n themeKey: 'borders',\n transform\n });\n}\nexport const border = createBorderStyle('border', borderTransform);\nexport const borderTop = createBorderStyle('borderTop', borderTransform);\nexport const borderRight = createBorderStyle('borderRight', borderTransform);\nexport const borderBottom = createBorderStyle('borderBottom', borderTransform);\nexport const borderLeft = createBorderStyle('borderLeft', borderTransform);\nexport const borderColor = createBorderStyle('borderColor');\nexport const borderTopColor = createBorderStyle('borderTopColor');\nexport const borderRightColor = createBorderStyle('borderRightColor');\nexport const borderBottomColor = createBorderStyle('borderBottomColor');\nexport const borderLeftColor = createBorderStyle('borderLeftColor');\nexport const outline = createBorderStyle('outline', borderTransform);\nexport const outlineColor = createBorderStyle('outlineColor');\n\n// false positive\n// eslint-disable-next-line react/function-component-definition\nexport const borderRadius = props => {\n if (props.borderRadius !== undefined && props.borderRadius !== null) {\n const transformer = createUnaryUnit(props.theme, 'shape.borderRadius', 4, 'borderRadius');\n const styleFromPropValue = propValue => ({\n borderRadius: getValue(transformer, propValue)\n });\n return handleBreakpoints(props, props.borderRadius, styleFromPropValue);\n }\n return null;\n};\nborderRadius.propTypes = process.env.NODE_ENV !== 'production' ? {\n borderRadius: responsivePropType\n} : {};\nborderRadius.filterProps = ['borderRadius'];\nconst borders = compose(border, borderTop, borderRight, borderBottom, borderLeft, borderColor, borderTopColor, borderRightColor, borderBottomColor, borderLeftColor, borderRadius, outline, outlineColor);\nexport default borders;","import style from \"../style/index.js\";\nimport compose from \"../compose/index.js\";\nimport { createUnaryUnit, getValue } from \"../spacing/index.js\";\nimport { handleBreakpoints } from \"../breakpoints/index.js\";\nimport responsivePropType from \"../responsivePropType/index.js\";\n\n// false positive\n// eslint-disable-next-line react/function-component-definition\nexport const gap = props => {\n if (props.gap !== undefined && props.gap !== null) {\n const transformer = createUnaryUnit(props.theme, 'spacing', 8, 'gap');\n const styleFromPropValue = propValue => ({\n gap: getValue(transformer, propValue)\n });\n return handleBreakpoints(props, props.gap, styleFromPropValue);\n }\n return null;\n};\ngap.propTypes = process.env.NODE_ENV !== 'production' ? {\n gap: responsivePropType\n} : {};\ngap.filterProps = ['gap'];\n\n// false positive\n// eslint-disable-next-line react/function-component-definition\nexport const columnGap = props => {\n if (props.columnGap !== undefined && props.columnGap !== null) {\n const transformer = createUnaryUnit(props.theme, 'spacing', 8, 'columnGap');\n const styleFromPropValue = propValue => ({\n columnGap: getValue(transformer, propValue)\n });\n return handleBreakpoints(props, props.columnGap, styleFromPropValue);\n }\n return null;\n};\ncolumnGap.propTypes = process.env.NODE_ENV !== 'production' ? {\n columnGap: responsivePropType\n} : {};\ncolumnGap.filterProps = ['columnGap'];\n\n// false positive\n// eslint-disable-next-line react/function-component-definition\nexport const rowGap = props => {\n if (props.rowGap !== undefined && props.rowGap !== null) {\n const transformer = createUnaryUnit(props.theme, 'spacing', 8, 'rowGap');\n const styleFromPropValue = propValue => ({\n rowGap: getValue(transformer, propValue)\n });\n return handleBreakpoints(props, props.rowGap, styleFromPropValue);\n }\n return null;\n};\nrowGap.propTypes = process.env.NODE_ENV !== 'production' ? {\n rowGap: responsivePropType\n} : {};\nrowGap.filterProps = ['rowGap'];\nexport const gridColumn = style({\n prop: 'gridColumn'\n});\nexport const gridRow = style({\n prop: 'gridRow'\n});\nexport const gridAutoFlow = style({\n prop: 'gridAutoFlow'\n});\nexport const gridAutoColumns = style({\n prop: 'gridAutoColumns'\n});\nexport const gridAutoRows = style({\n prop: 'gridAutoRows'\n});\nexport const gridTemplateColumns = style({\n prop: 'gridTemplateColumns'\n});\nexport const gridTemplateRows = style({\n prop: 'gridTemplateRows'\n});\nexport const gridTemplateAreas = style({\n prop: 'gridTemplateAreas'\n});\nexport const gridArea = style({\n prop: 'gridArea'\n});\nconst grid = compose(gap, columnGap, rowGap, gridColumn, gridRow, gridAutoFlow, gridAutoColumns, gridAutoRows, gridTemplateColumns, gridTemplateRows, gridTemplateAreas, gridArea);\nexport default grid;","import style from \"../style/index.js\";\nimport compose from \"../compose/index.js\";\nexport function paletteTransform(value, userValue) {\n if (userValue === 'grey') {\n return userValue;\n }\n return value;\n}\nexport const color = style({\n prop: 'color',\n themeKey: 'palette',\n transform: paletteTransform\n});\nexport const bgcolor = style({\n prop: 'bgcolor',\n cssProperty: 'backgroundColor',\n themeKey: 'palette',\n transform: paletteTransform\n});\nexport const backgroundColor = style({\n prop: 'backgroundColor',\n themeKey: 'palette',\n transform: paletteTransform\n});\nconst palette = compose(color, bgcolor, backgroundColor);\nexport default palette;","import style from \"../style/index.js\";\nimport compose from \"../compose/index.js\";\nimport { handleBreakpoints, values as breakpointsValues } from \"../breakpoints/index.js\";\nexport function sizingTransform(value) {\n return value <= 1 && value !== 0 ? `${value * 100}%` : value;\n}\nexport const width = style({\n prop: 'width',\n transform: sizingTransform\n});\nexport const maxWidth = props => {\n if (props.maxWidth !== undefined && props.maxWidth !== null) {\n const styleFromPropValue = propValue => {\n const breakpoint = props.theme?.breakpoints?.values?.[propValue] || breakpointsValues[propValue];\n if (!breakpoint) {\n return {\n maxWidth: sizingTransform(propValue)\n };\n }\n if (props.theme?.breakpoints?.unit !== 'px') {\n return {\n maxWidth: `${breakpoint}${props.theme.breakpoints.unit}`\n };\n }\n return {\n maxWidth: breakpoint\n };\n };\n return handleBreakpoints(props, props.maxWidth, styleFromPropValue);\n }\n return null;\n};\nmaxWidth.filterProps = ['maxWidth'];\nexport const minWidth = style({\n prop: 'minWidth',\n transform: sizingTransform\n});\nexport const height = style({\n prop: 'height',\n transform: sizingTransform\n});\nexport const maxHeight = style({\n prop: 'maxHeight',\n transform: sizingTransform\n});\nexport const minHeight = style({\n prop: 'minHeight',\n transform: sizingTransform\n});\nexport const sizeWidth = style({\n prop: 'size',\n cssProperty: 'width',\n transform: sizingTransform\n});\nexport const sizeHeight = style({\n prop: 'size',\n cssProperty: 'height',\n transform: sizingTransform\n});\nexport const boxSizing = style({\n prop: 'boxSizing'\n});\nconst sizing = compose(width, maxWidth, minWidth, height, maxHeight, minHeight, boxSizing);\nexport default sizing;","import { padding, margin } from \"../spacing/index.js\";\nimport { borderRadius, borderTransform } from \"../borders/index.js\";\nimport { gap, rowGap, columnGap } from \"../cssGrid/index.js\";\nimport { paletteTransform } from \"../palette/index.js\";\nimport { maxWidth, sizingTransform } from \"../sizing/index.js\";\nconst defaultSxConfig = {\n // borders\n border: {\n themeKey: 'borders',\n transform: borderTransform\n },\n borderTop: {\n themeKey: 'borders',\n transform: borderTransform\n },\n borderRight: {\n themeKey: 'borders',\n transform: borderTransform\n },\n borderBottom: {\n themeKey: 'borders',\n transform: borderTransform\n },\n borderLeft: {\n themeKey: 'borders',\n transform: borderTransform\n },\n borderColor: {\n themeKey: 'palette'\n },\n borderTopColor: {\n themeKey: 'palette'\n },\n borderRightColor: {\n themeKey: 'palette'\n },\n borderBottomColor: {\n themeKey: 'palette'\n },\n borderLeftColor: {\n themeKey: 'palette'\n },\n outline: {\n themeKey: 'borders',\n transform: borderTransform\n },\n outlineColor: {\n themeKey: 'palette'\n },\n borderRadius: {\n themeKey: 'shape.borderRadius',\n style: borderRadius\n },\n // palette\n color: {\n themeKey: 'palette',\n transform: paletteTransform\n },\n bgcolor: {\n themeKey: 'palette',\n cssProperty: 'backgroundColor',\n transform: paletteTransform\n },\n backgroundColor: {\n themeKey: 'palette',\n transform: paletteTransform\n },\n // spacing\n p: {\n style: padding\n },\n pt: {\n style: padding\n },\n pr: {\n style: padding\n },\n pb: {\n style: padding\n },\n pl: {\n style: padding\n },\n px: {\n style: padding\n },\n py: {\n style: padding\n },\n padding: {\n style: padding\n },\n paddingTop: {\n style: padding\n },\n paddingRight: {\n style: padding\n },\n paddingBottom: {\n style: padding\n },\n paddingLeft: {\n style: padding\n },\n paddingX: {\n style: padding\n },\n paddingY: {\n style: padding\n },\n paddingInline: {\n style: padding\n },\n paddingInlineStart: {\n style: padding\n },\n paddingInlineEnd: {\n style: padding\n },\n paddingBlock: {\n style: padding\n },\n paddingBlockStart: {\n style: padding\n },\n paddingBlockEnd: {\n style: padding\n },\n m: {\n style: margin\n },\n mt: {\n style: margin\n },\n mr: {\n style: margin\n },\n mb: {\n style: margin\n },\n ml: {\n style: margin\n },\n mx: {\n style: margin\n },\n my: {\n style: margin\n },\n margin: {\n style: margin\n },\n marginTop: {\n style: margin\n },\n marginRight: {\n style: margin\n },\n marginBottom: {\n style: margin\n },\n marginLeft: {\n style: margin\n },\n marginX: {\n style: margin\n },\n marginY: {\n style: margin\n },\n marginInline: {\n style: margin\n },\n marginInlineStart: {\n style: margin\n },\n marginInlineEnd: {\n style: margin\n },\n marginBlock: {\n style: margin\n },\n marginBlockStart: {\n style: margin\n },\n marginBlockEnd: {\n style: margin\n },\n // display\n displayPrint: {\n cssProperty: false,\n transform: value => ({\n '@media print': {\n display: value\n }\n })\n },\n display: {},\n overflow: {},\n textOverflow: {},\n visibility: {},\n whiteSpace: {},\n // flexbox\n flexBasis: {},\n flexDirection: {},\n flexWrap: {},\n justifyContent: {},\n alignItems: {},\n alignContent: {},\n order: {},\n flex: {},\n flexGrow: {},\n flexShrink: {},\n alignSelf: {},\n justifyItems: {},\n justifySelf: {},\n // grid\n gap: {\n style: gap\n },\n rowGap: {\n style: rowGap\n },\n columnGap: {\n style: columnGap\n },\n gridColumn: {},\n gridRow: {},\n gridAutoFlow: {},\n gridAutoColumns: {},\n gridAutoRows: {},\n gridTemplateColumns: {},\n gridTemplateRows: {},\n gridTemplateAreas: {},\n gridArea: {},\n // positions\n position: {},\n zIndex: {\n themeKey: 'zIndex'\n },\n top: {},\n right: {},\n bottom: {},\n left: {},\n // shadows\n boxShadow: {\n themeKey: 'shadows'\n },\n // sizing\n width: {\n transform: sizingTransform\n },\n maxWidth: {\n style: maxWidth\n },\n minWidth: {\n transform: sizingTransform\n },\n height: {\n transform: sizingTransform\n },\n maxHeight: {\n transform: sizingTransform\n },\n minHeight: {\n transform: sizingTransform\n },\n boxSizing: {},\n // typography\n font: {\n themeKey: 'font'\n },\n fontFamily: {\n themeKey: 'typography'\n },\n fontSize: {\n themeKey: 'typography'\n },\n fontStyle: {\n themeKey: 'typography'\n },\n fontWeight: {\n themeKey: 'typography'\n },\n letterSpacing: {},\n textTransform: {},\n lineHeight: {},\n textAlign: {},\n typography: {\n cssProperty: false,\n themeKey: 'typography'\n }\n};\nexport default defaultSxConfig;","import capitalize from '@mui/utils/capitalize';\nimport merge from \"../merge/index.js\";\nimport { getPath, getStyleValue as getValue } from \"../style/index.js\";\nimport { handleBreakpoints, createEmptyBreakpointObject, removeUnusedBreakpoints } from \"../breakpoints/index.js\";\nimport { sortContainerQueries } from \"../cssContainerQueries/index.js\";\nimport defaultSxConfig from \"./defaultSxConfig.js\";\nfunction objectsHaveSameKeys(...objects) {\n const allKeys = objects.reduce((keys, object) => keys.concat(Object.keys(object)), []);\n const union = new Set(allKeys);\n return objects.every(object => union.size === Object.keys(object).length);\n}\nfunction callIfFn(maybeFn, arg) {\n return typeof maybeFn === 'function' ? maybeFn(arg) : maybeFn;\n}\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport function unstable_createStyleFunctionSx() {\n function getThemeValue(prop, val, theme, config) {\n const props = {\n [prop]: val,\n theme\n };\n const options = config[prop];\n if (!options) {\n return {\n [prop]: val\n };\n }\n const {\n cssProperty = prop,\n themeKey,\n transform,\n style\n } = options;\n if (val == null) {\n return null;\n }\n\n // TODO v6: remove, see https://github.com/mui/material-ui/pull/38123\n if (themeKey === 'typography' && val === 'inherit') {\n return {\n [prop]: val\n };\n }\n const themeMapping = getPath(theme, themeKey) || {};\n if (style) {\n return style(props);\n }\n const styleFromPropValue = propValueFinal => {\n let value = getValue(themeMapping, transform, propValueFinal);\n if (propValueFinal === value && typeof propValueFinal === 'string') {\n // Haven't found value\n value = getValue(themeMapping, transform, `${prop}${propValueFinal === 'default' ? '' : capitalize(propValueFinal)}`, propValueFinal);\n }\n if (cssProperty === false) {\n return value;\n }\n return {\n [cssProperty]: value\n };\n };\n return handleBreakpoints(props, val, styleFromPropValue);\n }\n function styleFunctionSx(props) {\n const {\n sx,\n theme = {}\n } = props || {};\n if (!sx) {\n return null; // Emotion & styled-components will neglect null\n }\n const config = theme.unstable_sxConfig ?? defaultSxConfig;\n\n /*\n * Receive `sxInput` as object or callback\n * and then recursively check keys & values to create media query object styles.\n * (the result will be used in `styled`)\n */\n function traverse(sxInput) {\n let sxObject = sxInput;\n if (typeof sxInput === 'function') {\n sxObject = sxInput(theme);\n } else if (typeof sxInput !== 'object') {\n // value\n return sxInput;\n }\n if (!sxObject) {\n return null;\n }\n const emptyBreakpoints = createEmptyBreakpointObject(theme.breakpoints);\n const breakpointsKeys = Object.keys(emptyBreakpoints);\n let css = emptyBreakpoints;\n Object.keys(sxObject).forEach(styleKey => {\n const value = callIfFn(sxObject[styleKey], theme);\n if (value !== null && value !== undefined) {\n if (typeof value === 'object') {\n if (config[styleKey]) {\n css = merge(css, getThemeValue(styleKey, value, theme, config));\n } else {\n const breakpointsValues = handleBreakpoints({\n theme\n }, value, x => ({\n [styleKey]: x\n }));\n if (objectsHaveSameKeys(breakpointsValues, value)) {\n css[styleKey] = styleFunctionSx({\n sx: value,\n theme\n });\n } else {\n css = merge(css, breakpointsValues);\n }\n }\n } else {\n css = merge(css, getThemeValue(styleKey, value, theme, config));\n }\n }\n });\n return sortContainerQueries(theme, removeUnusedBreakpoints(breakpointsKeys, css));\n }\n return Array.isArray(sx) ? sx.map(traverse) : traverse(sx);\n }\n return styleFunctionSx;\n}\nconst styleFunctionSx = unstable_createStyleFunctionSx();\nstyleFunctionSx.filterProps = ['sx'];\nexport default styleFunctionSx;","/**\n * A universal utility to style components with multiple color modes. Always use it from the theme object.\n * It works with:\n * - [Basic theme](https://mui.com/material-ui/customization/dark-mode/)\n * - [CSS theme variables](https://mui.com/material-ui/customization/css-theme-variables/overview/)\n * - Zero-runtime engine\n *\n * Tips: Use an array over object spread and place `theme.applyStyles()` last.\n *\n * With the styled function:\n * ✅ [{ background: '#e5e5e5' }, theme.applyStyles('dark', { background: '#1c1c1c' })]\n * 🚫 { background: '#e5e5e5', ...theme.applyStyles('dark', { background: '#1c1c1c' })}\n *\n * With the sx prop:\n * ✅ [{ background: '#e5e5e5' }, theme => theme.applyStyles('dark', { background: '#1c1c1c' })]\n * 🚫 { background: '#e5e5e5', ...theme => theme.applyStyles('dark', { background: '#1c1c1c' })}\n *\n * @example\n * 1. using with `styled`:\n * ```jsx\n * const Component = styled('div')(({ theme }) => [\n * { background: '#e5e5e5' },\n * theme.applyStyles('dark', {\n * background: '#1c1c1c',\n * color: '#fff',\n * }),\n * ]);\n * ```\n *\n * @example\n * 2. using with `sx` prop:\n * ```jsx\n * <Box sx={[\n * { background: '#e5e5e5' },\n * theme => theme.applyStyles('dark', {\n * background: '#1c1c1c',\n * color: '#fff',\n * }),\n * ]}\n * />\n * ```\n *\n * @example\n * 3. theming a component:\n * ```jsx\n * extendTheme({\n * components: {\n * MuiButton: {\n * styleOverrides: {\n * root: ({ theme }) => [\n * { background: '#e5e5e5' },\n * theme.applyStyles('dark', {\n * background: '#1c1c1c',\n * color: '#fff',\n * }),\n * ],\n * },\n * }\n * }\n * })\n *```\n */\nexport default function applyStyles(key, styles) {\n // @ts-expect-error this is 'any' type\n const theme = this;\n if (theme.vars) {\n if (!theme.colorSchemes?.[key] || typeof theme.getColorSchemeSelector !== 'function') {\n return {};\n }\n // If CssVarsProvider is used as a provider, returns '*:where({selector}) &'\n let selector = theme.getColorSchemeSelector(key);\n if (selector === '&') {\n return styles;\n }\n if (selector.includes('data-') || selector.includes('.')) {\n // '*' is required as a workaround for Emotion issue (https://github.com/emotion-js/emotion/issues/2836)\n selector = `*:where(${selector.replace(/\\s*&$/, '')}) &`;\n }\n return {\n [selector]: styles\n };\n }\n if (theme.palette.mode === key) {\n return styles;\n }\n return {};\n}","'use client';\n\nimport * as React from 'react';\nimport { ThemeContext } from '@mui/styled-engine';\nfunction isObjectEmpty(obj) {\n return Object.keys(obj).length === 0;\n}\nfunction useTheme(defaultTheme = null) {\n const contextTheme = React.useContext(ThemeContext);\n return !contextTheme || isObjectEmpty(contextTheme) ? defaultTheme : contextTheme;\n}\nexport default useTheme;","'use client';\n\nimport createTheme from \"../createTheme/index.js\";\nimport useThemeWithoutDefault from \"../useThemeWithoutDefault/index.js\";\nexport const systemDefaultTheme = createTheme();\nfunction useTheme(defaultTheme = systemDefaultTheme) {\n return useThemeWithoutDefault(defaultTheme);\n}\nexport default useTheme;","import deepmerge from '@mui/utils/deepmerge';\nimport createBreakpoints from \"../createBreakpoints/createBreakpoints.js\";\nimport cssContainerQueries from \"../cssContainerQueries/index.js\";\nimport shape from \"./shape.js\";\nimport createSpacing from \"./createSpacing.js\";\nimport styleFunctionSx from \"../styleFunctionSx/styleFunctionSx.js\";\nimport defaultSxConfig from \"../styleFunctionSx/defaultSxConfig.js\";\nimport applyStyles from \"./applyStyles.js\";\nfunction createTheme(options = {}, ...args) {\n const {\n breakpoints: breakpointsInput = {},\n palette: paletteInput = {},\n spacing: spacingInput,\n shape: shapeInput = {},\n ...other\n } = options;\n const breakpoints = createBreakpoints(breakpointsInput);\n const spacing = createSpacing(spacingInput);\n let muiTheme = deepmerge({\n breakpoints,\n direction: 'ltr',\n components: {},\n // Inject component definitions.\n palette: {\n mode: 'light',\n ...paletteInput\n },\n spacing,\n shape: {\n ...shape,\n ...shapeInput\n }\n }, other);\n muiTheme = cssContainerQueries(muiTheme);\n muiTheme.applyStyles = applyStyles;\n muiTheme = args.reduce((acc, argument) => deepmerge(acc, argument), muiTheme);\n muiTheme.unstable_sxConfig = {\n ...defaultSxConfig,\n ...other?.unstable_sxConfig\n };\n muiTheme.unstable_sx = function sx(props) {\n return styleFunctionSx({\n sx: props,\n theme: this\n });\n };\n return muiTheme;\n}\nexport default createTheme;","import { createUnarySpacing } from \"../spacing/index.js\";\n\n// The different signatures imply different meaning for their arguments that can't be expressed structurally.\n// We express the difference with variable names.\n\nexport default function createSpacing(spacingInput = 8,\n// Material Design layouts are visually balanced. Most measurements align to an 8dp grid, which aligns both spacing and the overall layout.\n// Smaller components, such as icons, can align to a 4dp grid.\n// https://m2.material.io/design/layout/understanding-layout.html\ntransform = createUnarySpacing({\n spacing: spacingInput\n})) {\n // Already transformed.\n if (spacingInput.mui) {\n return spacingInput;\n }\n const spacing = (...argsInput) => {\n if (process.env.NODE_ENV !== 'production') {\n if (!(argsInput.length <= 4)) {\n console.error(`MUI: Too many arguments provided, expected between 0 and 4, got ${argsInput.length}`);\n }\n }\n const args = argsInput.length === 0 ? [1] : argsInput;\n return args.map(argument => {\n const output = transform(argument);\n return typeof output === 'number' ? `${output}px` : output;\n }).join(' ');\n };\n spacing.mui = true;\n return spacing;\n}","import { isPlainObject } from '@mui/utils/deepmerge';\nimport defaultSxConfig from \"./defaultSxConfig.js\";\nconst splitProps = props => {\n const result = {\n systemProps: {},\n otherProps: {}\n };\n const config = props?.theme?.unstable_sxConfig ?? defaultSxConfig;\n Object.keys(props).forEach(prop => {\n if (config[prop]) {\n result.systemProps[prop] = props[prop];\n } else {\n result.otherProps[prop] = props[prop];\n }\n });\n return result;\n};\nexport default function extendSxProp(props) {\n const {\n sx: inSx,\n ...other\n } = props;\n const {\n systemProps,\n otherProps\n } = splitProps(other);\n let finalSx;\n if (Array.isArray(inSx)) {\n finalSx = [systemProps, ...inSx];\n } else if (typeof inSx === 'function') {\n finalSx = (...args) => {\n const result = inSx(...args);\n if (!isPlainObject(result)) {\n return systemProps;\n }\n return {\n ...systemProps,\n ...result\n };\n };\n } else {\n finalSx = {\n ...systemProps,\n ...inSx\n };\n }\n return {\n ...otherProps,\n sx: finalSx\n };\n}","const defaultGenerator = componentName => componentName;\nconst createClassNameGenerator = () => {\n let generate = defaultGenerator;\n return {\n configure(generator) {\n generate = generator;\n },\n generate(componentName) {\n return generate(componentName);\n },\n reset() {\n generate = defaultGenerator;\n }\n };\n};\nconst ClassNameGenerator = createClassNameGenerator();\nexport default ClassNameGenerator;","import ClassNameGenerator from \"../ClassNameGenerator/index.js\";\nexport const globalStateClasses = {\n active: 'active',\n checked: 'checked',\n completed: 'completed',\n disabled: 'disabled',\n error: 'error',\n expanded: 'expanded',\n focused: 'focused',\n focusVisible: 'focusVisible',\n open: 'open',\n readOnly: 'readOnly',\n required: 'required',\n selected: 'selected'\n};\nexport default function generateUtilityClass(componentName, slot, globalStatePrefix = 'Mui') {\n const globalStateClass = globalStateClasses[slot];\n return globalStateClass ? `${globalStatePrefix}-${globalStateClass}` : `${ClassNameGenerator.generate(componentName)}-${slot}`;\n}\nexport function isGlobalState(slot) {\n return globalStateClasses[slot] !== undefined;\n}","import generateUtilityClasses from '@mui/utils/generateUtilityClasses';\nconst boxClasses = generateUtilityClasses('MuiBox', ['root']);\nexport default boxClasses;","'use client';\n\nimport PropTypes from 'prop-types';\nimport ClassNameGenerator from '@mui/utils/ClassNameGenerator';\nimport createBox from \"../createBox/index.js\";\nimport boxClasses from \"./boxClasses.js\";\nconst Box = createBox({\n defaultClassName: boxClasses.root,\n generateClassName: ClassNameGenerator.generate\n});\nprocess.env.NODE_ENV !== \"production\" ? Box.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the d.ts file and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * @ignore\n */\n children: PropTypes.node,\n /**\n * The component used for the root node.\n * Either a string to use a HTML element or a component.\n */\n component: PropTypes.elementType,\n /**\n * The system prop that allows defining system overrides as well as additional CSS styles.\n */\n sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object])\n} : void 0;\nexport default Box;","'use client';\n\nimport * as React from 'react';\nimport clsx from 'clsx';\nimport styled from '@mui/styled-engine';\nimport styleFunctionSx, { extendSxProp } from \"../styleFunctionSx/index.js\";\nimport useTheme from \"../useTheme/index.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport default function createBox(options = {}) {\n const {\n themeId,\n defaultTheme,\n defaultClassName = 'MuiBox-root',\n generateClassName\n } = options;\n const BoxRoot = styled('div', {\n shouldForwardProp: prop => prop !== 'theme' && prop !== 'sx' && prop !== 'as'\n })(styleFunctionSx);\n const Box = /*#__PURE__*/React.forwardRef(function Box(inProps, ref) {\n const theme = useTheme(defaultTheme);\n const {\n className,\n component = 'div',\n ...other\n } = extendSxProp(inProps);\n return /*#__PURE__*/_jsx(BoxRoot, {\n as: component,\n ref: ref,\n className: clsx(className, generateClassName ? generateClassName(defaultClassName) : defaultClassName),\n theme: themeId ? theme[themeId] || theme : theme,\n ...other\n });\n });\n return Box;\n}","/**\n * @mui/styled-engine v7.1.0\n *\n * @license MIT\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use client';\n\n/* eslint-disable no-underscore-dangle */\nimport emStyled from '@emotion/styled';\nimport { serializeStyles as emSerializeStyles } from '@emotion/serialize';\nexport default function styled(tag, options) {\n const stylesFactory = emStyled(tag, options);\n if (process.env.NODE_ENV !== 'production') {\n return (...styles) => {\n const component = typeof tag === 'string' ? `\"${tag}\"` : 'component';\n if (styles.length === 0) {\n console.error([`MUI: Seems like you called \\`styled(${component})()\\` without a \\`style\\` argument.`, 'You must provide a `styles` argument: `styled(\"div\")(styleYouForgotToPass)`.'].join('\\n'));\n } else if (styles.some(style => style === undefined)) {\n console.error(`MUI: the styled(${component})(...args) API requires all its args to be defined.`);\n }\n return stylesFactory(...styles);\n };\n }\n return stylesFactory;\n}\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport function internal_mutateStyles(tag, processor) {\n // Emotion attaches all the styles as `__emotion_styles`.\n // Ref: https://github.com/emotion-js/emotion/blob/16d971d0da229596d6bcc39d282ba9753c9ee7cf/packages/styled/src/base.js#L186\n if (Array.isArray(tag.__emotion_styles)) {\n tag.__emotion_styles = processor(tag.__emotion_styles);\n }\n}\n\n// Emotion only accepts an array, but we want to avoid allocations\nconst wrapper = [];\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport function internal_serializeStyles(styles) {\n wrapper[0] = styles;\n return emSerializeStyles(wrapper);\n}\nexport { ThemeContext, keyframes, css } from '@emotion/react';\nexport { default as StyledEngineProvider } from \"./StyledEngineProvider/index.js\";\nexport { default as GlobalStyles } from \"./GlobalStyles/index.js\";","import generateUtilityClass from \"../generateUtilityClass/index.js\";\nexport default function generateUtilityClasses(componentName, slots, globalStatePrefix = 'Mui') {\n const result = {};\n slots.forEach(slot => {\n result[slot] = generateUtilityClass(componentName, slot, globalStatePrefix);\n });\n return result;\n}","import { TextField, TextFieldProps } from \"@mui/material\";\r\n\r\nconst TemplateTextField: React.FC<Omit<TextFieldProps, \"outlined\">> = (\r\n props\r\n) => {\r\n return <TextField {...props} slotProps={{ inputLabel: { shrink: true } }} />;\r\n};\r\n\r\nexport default TemplateTextField;\r\n","import { Grid2 } from \"@mui/material\";\r\nimport TemplateTextField from \"./FormFields/TemplateTextField\";\r\nimport Datefield from \"./FormFields/Datefield\";\r\nimport DatetimeField from \"./FormFields/DatetimeField\";\r\nimport ComboBox from \"./FormFields/ComboBox\";\r\nimport CheckBox from \"./FormFields/CheckBox\";\r\nimport { DATE_FORMAT, DATE_TIME_FORMAT } from \"../../../../util/constants\";\r\nimport { isNumeric } from \"../../../../util/AppUtils\";\r\nimport { FormElementFieldProps } from \"../DataEntryTypes\";\r\n\r\nconst FormElementField: React.FC<FormElementFieldProps> = (\r\n element: FormElementFieldProps\r\n) => {\r\n if (element?.fieldInfo) {\r\n const props = element.fieldInfo;\r\n const formManager = element?.formManager || null;\r\n const formActions = element?.formActions || null;\r\n const formValues = element?.formValues || null;\r\n const fieldName: any = element?.fieldInfo?.fieldName || null;\r\n const fieldType = element?.fieldInfo?.fieldType || null;\r\n if (!(props && formManager && formValues && fieldName && fieldType)) {\r\n return <></>;\r\n }\r\n return (props?.hidden === undefined || !props?.hidden) &&\r\n !element.hiddenFields.includes(fieldName) ? (\r\n <Grid2\r\n size={\r\n props?.formProps?.fieldSize || {\r\n lg: 12,\r\n md: 12,\r\n sm: 12,\r\n }\r\n }\r\n sx={{\r\n padding: 1,\r\n width: \"100%\",\r\n }}\r\n >\r\n {fieldType === \"text\" || fieldType === \"number\" ? (\r\n <TemplateTextField\r\n fullWidth\r\n type={fieldType}\r\n disabled={\r\n props?.disabled || element.disabledFields.includes(fieldName)\r\n ? true\r\n : false\r\n }\r\n hidden={props?.hidden || false}\r\n label={props?.fieldLabel}\r\n value={formValues[fieldName]}\r\n onChange={(event) => {\r\n let newValue = null;\r\n if (event.target.value != \"\") {\r\n if (fieldType === \"number\" && isNumeric(event.target.value)) {\r\n newValue = Number(event.target.value);\r\n } else {\r\n newValue = event.target.value;\r\n }\r\n }\r\n formManager.setValue(fieldName, newValue);\r\n if (props?.formProps?.onValueChangeCallBack) {\r\n props?.formProps?.onValueChangeCallBack(\r\n newValue,\r\n formManager,\r\n formActions\r\n );\r\n }\r\n }}\r\n sx={props?.formProps?.style}\r\n error={formManager.formState.errors[fieldName] != undefined}\r\n helperText={formManager?.formState?.errors[\r\n fieldName\r\n ]?.message?.toString()}\r\n />\r\n ) : props?.fieldType === \"date\" ? (\r\n <Datefield\r\n format={props?.dateFormat || DATE_FORMAT}\r\n sx={props?.formProps?.style || { width: \"100%\" }}\r\n disabled={\r\n props?.disabled || element.disabledFields.includes(fieldName)\r\n ? true\r\n : false\r\n }\r\n label={props?.fieldLabel}\r\n onChangeCallBack={(v: any) => {\r\n formManager.setValue(fieldName, v);\r\n if (props?.formProps?.onValueChangeCallBack) {\r\n props?.formProps?.onValueChangeCallBack(\r\n v,\r\n formManager,\r\n formActions\r\n );\r\n }\r\n }}\r\n value={formValues[fieldName]}\r\n error={formManager.formState.errors[fieldName] != undefined}\r\n errorMessage={formManager?.formState?.errors[\r\n fieldName\r\n ]?.message?.toString()}\r\n />\r\n ) : props?.fieldType === \"datetime\" ? (\r\n <DatetimeField\r\n format={props?.dateFormat || DATE_TIME_FORMAT}\r\n sx={props?.formProps?.style || { width: \"100%\" }}\r\n disabled={\r\n props?.disabled || element.disabledFields.includes(fieldName)\r\n ? true\r\n : false\r\n }\r\n label={props?.fieldLabel}\r\n onChangeCallBack={(v: any) => {\r\n formManager.setValue(fieldName, v);\r\n if (props?.formProps?.onValueChangeCallBack) {\r\n props?.formProps?.onValueChangeCallBack(\r\n v,\r\n formManager,\r\n formActions\r\n );\r\n }\r\n }}\r\n value={formValues[fieldName]}\r\n error={formManager.formState.errors[fieldName] != undefined}\r\n errorMessage={formManager?.formState?.errors[\r\n fieldName\r\n ]?.message?.toString()}\r\n />\r\n ) : props?.fieldType === \"checkbox\" ? (\r\n <CheckBox\r\n label={props?.fieldLabel}\r\n onChangeCallBack={(v: any) => {\r\n formManager.setValue(fieldName, v);\r\n if (props?.formProps?.onValueChangeCallBack) {\r\n props?.formProps?.onValueChangeCallBack(\r\n v,\r\n formManager,\r\n formActions\r\n );\r\n }\r\n }}\r\n value={formValues[fieldName]}\r\n checkedValue={props?.checkedValue || \"true\"}\r\n unCheckedValue={props?.unCheckedValue || \"false\"}\r\n disabled={\r\n props?.disabled || element.disabledFields.includes(fieldName)\r\n ? true\r\n : false\r\n }\r\n sx={props?.formProps?.style}\r\n />\r\n ) : props?.fieldType === \"combobox\" ? (\r\n <ComboBox\r\n sx={props?.formProps?.style || { width: \"100%\" }}\r\n label={props?.fieldLabel}\r\n disabled={\r\n props?.disabled || element.disabledFields.includes(fieldName)\r\n ? true\r\n : false\r\n }\r\n onChangeCallBack={(v: any, selectedRecord: any) => {\r\n let newValue = null;\r\n if (v) {\r\n newValue = v + \"\";\r\n }\r\n formManager.setValue(fieldName, newValue);\r\n if (props?.formProps?.onValueChangeCallBack) {\r\n props?.formProps?.onValueChangeCallBack(\r\n newValue,\r\n formManager,\r\n formActions,\r\n selectedRecord\r\n );\r\n }\r\n }}\r\n options={props?.options || []}\r\n displayField={props?.optionDisplayField || \"\"}\r\n valueField={props?.optionValueField || \"\"}\r\n value={formValues[fieldName]}\r\n errorMessage={formManager?.formState?.errors[\r\n fieldName\r\n ]?.message?.toString()}\r\n />\r\n ) : (\r\n <>Unknown field type</>\r\n )}\r\n </Grid2>\r\n ) : (\r\n <></>\r\n );\r\n } else {\r\n return <></>;\r\n }\r\n};\r\n\r\nexport default FormElementField;\r\n","import { Button } from \"@mui/material\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport { RecordAction } from \"../DataEntryTypes\";\r\nimport useSession from \"../../../../hooks/UseSession\";\r\nimport { useConfirmationWindow } from \"../../../../hooks/UseConfirmationWindow\";\r\n\r\nconst FormAction: React.FC<RecordAction> = (action: RecordAction) => {\r\n const session = useSession();\r\n const { ConfirmationWindow, setOpen: setConfirmationWindowState } =\r\n useConfirmationWindow({\r\n body: action?.confirmationMessage || \"\",\r\n title: \"Confirmation\",\r\n onConfirmationCallBk: () => {\r\n action?.actionFn(action?.record);\r\n },\r\n });\r\n if (\r\n action?.authority === undefined ||\r\n action?.authority === null ||\r\n session.isUserAuthorized(action.authority)\r\n ) {\r\n return (\r\n <>\r\n <ConfirmationWindow />\r\n <Button\r\n variant={action?.formActionProps?.actionButtonVariant}\r\n color={action?.formActionProps?.actionButtonColor}\r\n onClick={() => {\r\n if (action?.actionFn) {\r\n if (action?.preActionValidation) {\r\n if (!action.preActionValidation(action.record)) {\r\n return;\r\n }\r\n }\r\n if (action?.isConfirmationRequired === true) {\r\n setConfirmationWindowState(true);\r\n } else {\r\n action?.actionFn(action.record);\r\n }\r\n }\r\n }}\r\n >\r\n {action?.icon ? (\r\n <FontAwesomeIcon\r\n icon={action.icon}\r\n style={{ marginRight: 5, marginLeft: 5 }}\r\n />\r\n ) : (\r\n <></>\r\n )}\r\n <div>{action?.label}</div>\r\n </Button>\r\n </>\r\n );\r\n } else {\r\n return <></>;\r\n }\r\n};\r\n\r\nexport default FormAction;\r\n","import { Grid2 } from \"@mui/material\";\r\nimport FormElementField from \"./FormElementField\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport FormAction from \"./FormAction\";\r\nimport {\r\n FormElementGroupProps,\r\n FormElementProps,\r\n RecordAction,\r\n} from \"../DataEntryTypes\";\r\n\r\nconst FormElementGroup: React.FC<FormElementGroupProps> = (\r\n props: FormElementGroupProps\r\n) => {\r\n return (\r\n <>\r\n <Grid2 container sx={props?.style} alignItems=\"flex-start\">\r\n {props?.label ? (\r\n <Grid2\r\n size={12}\r\n sx={{ padding: 1, fontWeight: \"bold\", display: \"flex\" }}\r\n >\r\n {props?.icon ? (\r\n <>\r\n <FontAwesomeIcon\r\n icon={props.icon}\r\n style={{ marginRight: 5, marginLeft: 5 }}\r\n />\r\n <div>{props.label}</div>\r\n </>\r\n ) : (\r\n <>{props.label}</>\r\n )}\r\n </Grid2>\r\n ) : (\r\n <></>\r\n )}\r\n {props?.elements\r\n ? props.elements.map((element: FormElementProps) => {\r\n if (element.type === \"group\") {\r\n return (\r\n <FormElementGroup\r\n {...element.props}\r\n formManager={props.formManager}\r\n formValues={props.formValues}\r\n formActions={props.formActions}\r\n hiddenFields={props.hiddenFields}\r\n disabledFields={props.disabledFields}\r\n />\r\n );\r\n } else if (element.type === \"field\" && element.mode === \"props\") {\r\n return (\r\n <FormElementField\r\n fieldInfo={element.props}\r\n formManager={props.formManager}\r\n formValues={props.formValues}\r\n formActions={props.formActions}\r\n hiddenFields={props.hiddenFields}\r\n disabledFields={props.disabledFields}\r\n />\r\n );\r\n } else if (element.type === \"field\" && element.mode === \"node\") {\r\n return (\r\n <Grid2\r\n size={\r\n element?.props?.formProps?.fieldSize || {\r\n lg: 3,\r\n md: 6,\r\n sm: 12,\r\n }\r\n }\r\n sx={{ padding: 1, width: \"100%\" }}\r\n >\r\n <element.node\r\n formManager={props.formManager}\r\n formValues={props.formValues}\r\n formActions={props.formActions}\r\n />\r\n </Grid2>\r\n );\r\n }\r\n })\r\n : null}\r\n\r\n {props?.actions ? (\r\n <Grid2 size={{ sm: 12 }} sx={{ padding: 1 }}>\r\n {props.actions.map((action: RecordAction) => {\r\n return <FormAction {...action} record={props.formValues} />;\r\n })}\r\n </Grid2>\r\n ) : (\r\n <></>\r\n )}\r\n </Grid2>\r\n </>\r\n );\r\n};\r\n\r\nexport default FormElementGroup;\r\n","import { Box } from \"@mui/system\";\r\nimport React, { useEffect, useState } from \"react\";\r\nimport * as z from \"zod\";\r\nimport { useForm } from \"react-hook-form\";\r\nimport { zodResolver } from \"@hookform/resolvers/zod\";\r\nimport { useParams } from \"react-router-dom\";\r\nimport { Button, Grid2 } from \"@mui/material\";\r\nimport { toast } from \"react-toastify\";\r\nimport FormElementGroup from \"./FormElementGroup\";\r\nimport FormElementField from \"./FormElementField\";\r\nimport FormAction from \"./FormAction\";\r\nimport { constructValidationSchema, getAllFields } from \"../DataEntryUtil\";\r\nimport {\r\n FormElementProps,\r\n RecordAction,\r\n TemplateFormProps,\r\n} from \"../DataEntryTypes\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\n\r\nconst TemplateForm: React.FC<TemplateFormProps> = (\r\n props: TemplateFormProps\r\n) => {\r\n const fields = getAllFields(props.elements);\r\n const [hiddenFields, setHiddenFields] = useState<string[]>([]);\r\n const [disabledFields, setDisabledFields] = useState<string[]>([]);\r\n const formSchema = z.object(constructValidationSchema(fields));\r\n type FormData = z.infer<typeof formSchema>;\r\n const formManager = useForm<FormData>({\r\n resolver: zodResolver(formSchema),\r\n });\r\n const formValues = formManager.watch();\r\n const pathParameters = useParams();\r\n const formRouteRecordIdParamName: any = props?.formRouteRecordIdParamName;\r\n\r\n const loadRecord = async () => {\r\n let idToLoad = null;\r\n if (props?.recordIdToEdit) {\r\n idToLoad = props.recordIdToEdit;\r\n } else if (\r\n formRouteRecordIdParamName &&\r\n pathParameters[formRouteRecordIdParamName]\r\n ) {\r\n idToLoad = pathParameters[formRouteRecordIdParamName];\r\n }\r\n if (idToLoad) {\r\n const retrievedRecord: any = await props.apiActions.loadRecordById(\r\n idToLoad\r\n );\r\n if (retrievedRecord) {\r\n formManager.reset({ ...retrievedRecord });\r\n }\r\n }\r\n };\r\n\r\n const saveRecord = async (record: any) => {\r\n if (props?.preSaveValidation && !props.preSaveValidation(record)) {\r\n return;\r\n }\r\n if (record) {\r\n const savedRecord: any = await props.apiActions.saveRecord(record);\r\n if (savedRecord) {\r\n formManager.reset({ ...savedRecord });\r\n if (props?.formSavedSuccessfullyCallBk) {\r\n props.formSavedSuccessfullyCallBk(savedRecord);\r\n }\r\n if (props?.formCloseCallBk) {\r\n props.formCloseCallBk();\r\n }\r\n }\r\n }\r\n };\r\n\r\n const formActions = {\r\n setFieldValue: (fieldName: string, fieldValue: any) => {\r\n formManager.setValue(fieldName, fieldValue);\r\n },\r\n hideField: (fieldName: string) => {\r\n setHiddenFields((oldValues) => {\r\n const newValues = [...oldValues, fieldName];\r\n return newValues;\r\n });\r\n },\r\n showField: (fieldName: string) => {\r\n setHiddenFields((oldValues) => {\r\n const newValues = oldValues.filter((x) => x !== fieldName);\r\n return newValues;\r\n });\r\n },\r\n disableField: (fieldName: string) => {\r\n setDisabledFields((oldValues) => {\r\n const newValues = [...oldValues, fieldName];\r\n return newValues;\r\n });\r\n },\r\n enableField: (fieldName: string) => {\r\n setDisabledFields((oldValues) => {\r\n const newValues = oldValues.filter((x) => x !== fieldName);\r\n return newValues;\r\n });\r\n },\r\n };\r\n\r\n useEffect(() => {\r\n loadRecord();\r\n }, [props?.recordIdToEdit]);\r\n\r\n return (\r\n <>\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n flex: 1,\r\n width: \"100%\",\r\n height: \"fit-content\",\r\n flexDirection: \"column\",\r\n alignItems: \"center\",\r\n overflow: \"auto\",\r\n }}\r\n >\r\n <Grid2 sx={{ width: \"100%\" }} container>\r\n {props.elements.map((formElement: FormElementProps) => {\r\n if (formElement.type === \"group\") {\r\n return (\r\n <FormElementGroup\r\n {...formElement.props}\r\n formManager={formManager}\r\n formValues={formValues}\r\n formActions={formActions}\r\n hiddenFields={hiddenFields}\r\n disabledFields={disabledFields}\r\n />\r\n );\r\n } else if (\r\n formElement.type === \"field\" &&\r\n formElement.mode === \"props\"\r\n ) {\r\n return (\r\n <FormElementField\r\n fieldInfo={formElement.props}\r\n formManager={formManager}\r\n formValues={formValues}\r\n formActions={formActions}\r\n hiddenFields={hiddenFields}\r\n disabledFields={disabledFields}\r\n />\r\n );\r\n } else if (\r\n formElement.type === \"field\" &&\r\n formElement.mode === \"node\"\r\n ) {\r\n return (\r\n <Grid2\r\n size={\r\n formElement?.props?.formProps?.fieldSize || {\r\n lg: 3,\r\n md: 6,\r\n xs: 12,\r\n }\r\n }\r\n sx={{ padding: 1, width: \"100%\" }}\r\n >\r\n <formElement.node\r\n formManager={formManager}\r\n formValues={formValues}\r\n />\r\n </Grid2>\r\n );\r\n }\r\n })}\r\n </Grid2>\r\n </Box>\r\n\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n width: \"100%\",\r\n alignItems: \"center\",\r\n justifyContent: \"flex-start\",\r\n }}\r\n >\r\n {props?.actions ? (\r\n props.actions.map((action: RecordAction) => {\r\n if (action?.formActionProps?.enabled === true) {\r\n return <FormAction {...action} record={formValues} />;\r\n } else {\r\n return <></>;\r\n }\r\n })\r\n ) : (\r\n <></>\r\n )}\r\n <div style={{ flex: 1 }}></div>\r\n <Button\r\n variant={\r\n props?.saveButtonSpecs?.actionButtonVariant\r\n ? props.saveButtonSpecs.actionButtonVariant\r\n : \"contained\"\r\n }\r\n sx={{ m: 1 }}\r\n startIcon={\r\n props?.saveButtonSpecs?.icon ? (\r\n <FontAwesomeIcon icon={props.saveButtonSpecs.icon} />\r\n ) : null\r\n }\r\n color={\r\n props?.saveButtonSpecs?.actionButtonColor\r\n ? props.saveButtonSpecs.actionButtonColor\r\n : \"primary\"\r\n }\r\n onClick={formManager.handleSubmit(\r\n (values) => {\r\n console.log(\"form values\", values);\r\n saveRecord(values);\r\n },\r\n (errors) => {\r\n toast.error(\r\n \"Form Data is not valid, make sure you have all field with valid data\"\r\n );\r\n console.log(\"form validation error\", errors);\r\n }\r\n )}\r\n >\r\n {props?.saveButtonSpecs?.label || \"save\"}\r\n </Button>\r\n <Button\r\n variant={\r\n props?.cancelButtonSpecs?.actionButtonVariant\r\n ? props.cancelButtonSpecs.actionButtonVariant\r\n : \"contained\"\r\n }\r\n startIcon={\r\n props?.cancelButtonSpecs?.icon ? (\r\n <FontAwesomeIcon icon={props.cancelButtonSpecs.icon} />\r\n ) : null\r\n }\r\n color={\r\n props?.cancelButtonSpecs?.actionButtonColor\r\n ? props.cancelButtonSpecs.actionButtonColor\r\n : \"error\"\r\n }\r\n sx={{ m: 1 }}\r\n onClick={() => {\r\n if (props?.formCloseCallBk) {\r\n props.formCloseCallBk();\r\n }\r\n formManager.reset({});\r\n }}\r\n >\r\n {props?.cancelButtonSpecs?.label || \"cancel\"}\r\n </Button>\r\n </Box>\r\n </>\r\n );\r\n};\r\n\r\nexport default TemplateForm;\r\n","import { useEffect, useState } from \"react\";\r\nimport {\r\n AppBar,\r\n Box,\r\n IconButton,\r\n Modal,\r\n Paper,\r\n Toolbar,\r\n Typography,\r\n} from \"@mui/material\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\n\r\nexport interface TemplateWindowProp {\r\n height?: any;\r\n width?: any;\r\n minWidth?: any;\r\n minHeight?: any;\r\n windowIcon?: any;\r\n windowTitle?: string;\r\n onCloseCallBack?: any;\r\n}\r\n\r\ninterface WindowProps {\r\n children?: React.ReactNode;\r\n}\r\n\r\nexport const useWindow = (props: TemplateWindowProp) => {\r\n const [windowState, setWindowState] = useState(false);\r\n\r\n const Window: React.FC<WindowProps> = (windowProps: WindowProps) => {\r\n return (\r\n <Modal\r\n open={windowState}\r\n sx={{ zIndex: (theme) => theme.zIndex.drawer }}\r\n onClose={() => {\r\n if (!windowState && props?.onCloseCallBack) {\r\n props.onCloseCallBack();\r\n }\r\n }}\r\n >\r\n <Box\r\n sx={{\r\n position: \"absolute\",\r\n top: \"50%\",\r\n left: \"50%\",\r\n maxHeight: \"90%\",\r\n transform: \"translate(-50%, -50%)\",\r\n height: props?.height || \"80%\",\r\n width: props?.width || \"90%\",\r\n minWidth: props.minWidth || 400,\r\n minHeight: props.minHeight || 200,\r\n overflow: \"hidden\",\r\n bgcolor: \"modalBackground.main\",\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n alignItems: \"center\",\r\n justifyContent: \"flex-start\",\r\n }}\r\n >\r\n <AppBar position=\"static\">\r\n <Toolbar variant=\"dense\">\r\n <FontAwesomeIcon\r\n icon={props?.windowIcon || \"window-maximize\"}\r\n style={{ marginRight: 5 }}\r\n />\r\n <Typography variant=\"h6\" color=\"inherit\" component=\"div\">\r\n {props?.windowTitle || \"window\"}\r\n </Typography>\r\n <div style={{ flexGrow: 1 }}></div>\r\n <IconButton\r\n onClick={() => {\r\n setWindowState(false);\r\n if (\r\n props.onCloseCallBack != undefined &&\r\n props.onCloseCallBack != null\r\n ) {\r\n props.onCloseCallBack();\r\n }\r\n }}\r\n color=\"secondary\"\r\n >\r\n <FontAwesomeIcon icon=\"xmark-square\" />\r\n </IconButton>\r\n </Toolbar>\r\n </AppBar>\r\n <Paper\r\n sx={{\r\n // flexGrow: 1,\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n alignItems: \"center\",\r\n width: \"100%\",\r\n height: \"100%\",\r\n padding: 1,\r\n // justifyContent: \"center\",\r\n overflow: \"hidden\",\r\n }}\r\n >\r\n {windowProps?.children}\r\n </Paper>\r\n </Box>\r\n </Modal>\r\n );\r\n };\r\n return { windowState, setWindowState, Window };\r\n};\r\n","import {\r\n DataGridPremium,\r\n GridActionsCellItem,\r\n GridActionsCellItemProps,\r\n GridColumnOrderChangeParams,\r\n GridColumnResizeParams,\r\n GridColumnVisibilityModel,\r\n GridEventListener,\r\n GridExpandMoreIcon,\r\n GridPinnedColumnFields,\r\n GridRowGroupingModel,\r\n GridRowModes,\r\n GridRowModesModel,\r\n GridRowParams,\r\n GridRowSelectionModel,\r\n} from \"@mui/x-data-grid-premium\";\r\nimport { TemplateGridColDef, TemplateGridProps } from \"../DataEntryTypes\";\r\nimport TemplateGridTopBar from \"./TemplateGridTopBar\";\r\nimport { useNavigate } from \"react-router-dom\";\r\nimport React, { useEffect, useState } from \"react\";\r\nimport { z } from \"zod\";\r\nimport {\r\n constructGridColumnsFromFields,\r\n constructValidationSchema,\r\n getAllFields,\r\n} from \"../DataEntryUtil\";\r\nimport { toast } from \"react-toastify\";\r\nimport {\r\n Accordion,\r\n AccordionDetails,\r\n AccordionSummary,\r\n Box,\r\n Divider,\r\n IconButton,\r\n Tooltip,\r\n Typography,\r\n} from \"@mui/material\";\r\nimport { capitalizeFirstLetter, isNumber } from \"../../../../util/AppUtils\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport TemplateGridRecordAction from \"./TemplateGridRecordAction\";\r\nimport TemplateForm from \"../TemplateDataForm/TemplateForm\";\r\nimport { useSelector } from \"react-redux\";\r\nimport { RootState } from \"../../../../redux/store\";\r\nimport { useTranslation } from \"react-i18next\";\r\nimport useSession from \"../../../../hooks/UseSession\";\r\nimport { useConfirmationWindow } from \"../../../../hooks/UseConfirmationWindow\";\r\nimport { useWindow } from \"../../../../hooks/UseWindow\";\r\nlet currentNewRecordIndex = -1;\r\n\r\ninterface GridState {\r\n columnVisibilityModel?: GridColumnVisibilityModel;\r\n columnOrder?: string[];\r\n columnWidths?: { [key: string]: number };\r\n columnGroupingModel?: GridRowGroupingModel;\r\n pinnedColumns?: GridPinnedColumnFields;\r\n}\r\n\r\nconst loadGridState = (gridStateKey: string): GridState => {\r\n try {\r\n const saved = localStorage.getItem(gridStateKey);\r\n return saved ? JSON.parse(saved) : {};\r\n } catch (e) {\r\n console.error(\"Failed to load grid state\", e);\r\n return {};\r\n }\r\n};\r\n\r\nconst saveGridState = (gridStateKey: string, statePart: GridState) => {\r\n const current = loadGridState(gridStateKey);\r\n localStorage.setItem(\r\n gridStateKey,\r\n JSON.stringify({ ...current, ...statePart })\r\n );\r\n};\r\n\r\nconst PIN_FIXED_COLUMNS = [\"__check__\", \"actions\"];\r\n\r\nconst TemplateGrid: React.FC<TemplateGridProps> = (props) => {\r\n const { t } = useTranslation();\r\n const fields = getAllFields(props.formElements);\r\n const hiddenFields = [];\r\n const savedState = React.useMemo<GridState>(\r\n () => (props?.gridStateKey ? loadGridState(props.gridStateKey) : {}),\r\n []\r\n );\r\n for (const field of fields) {\r\n if (field?.gridProps?.hidden === true) {\r\n hiddenFields.push(field.fieldName);\r\n }\r\n }\r\n let initialVisibilityState: GridColumnVisibilityModel = {};\r\n if (savedState?.columnVisibilityModel) {\r\n initialVisibilityState = savedState.columnVisibilityModel;\r\n const existingFields = Object.keys(initialVisibilityState);\r\n for (const field of hiddenFields) {\r\n if (!existingFields.includes(field)) {\r\n initialVisibilityState[field] = false;\r\n }\r\n }\r\n } else {\r\n for (const field of hiddenFields) {\r\n initialVisibilityState[field] = false;\r\n }\r\n }\r\n\r\n const themeDirection = useSelector(\r\n (state: RootState) => state.AppLayout.appDirection\r\n );\r\n\r\n const clearGridState = () => {\r\n if (props?.gridStateKey) {\r\n localStorage.removeItem(props.gridStateKey);\r\n }\r\n setColumnVisibilityModel({});\r\n setColumnOrder([]);\r\n setColumnWidths({});\r\n setGridRowGroupingModel([]);\r\n setPinnedColumns({\r\n left: [...(themeDirection === \"ltr\" ? PIN_FIXED_COLUMNS : [])],\r\n right: [...(themeDirection === \"rtl\" ? PIN_FIXED_COLUMNS : [])],\r\n });\r\n };\r\n const [columnVisibilityModel, setColumnVisibilityModel] =\r\n React.useState<GridColumnVisibilityModel>(initialVisibilityState);\r\n const [columnOrder, setColumnOrder] = React.useState<string[]>(\r\n savedState.columnOrder || []\r\n );\r\n const [columnWidths, setColumnWidths] = React.useState<{\r\n [key: string]: number;\r\n }>(savedState.columnWidths || {});\r\n const [gridRowGroupingModel, setGridRowGroupingModel] =\r\n useState<GridRowGroupingModel>(savedState.columnGroupingModel || []);\r\n let newLeft = savedState?.pinnedColumns?.left || [];\r\n newLeft = newLeft.filter(\r\n (record: any) => !PIN_FIXED_COLUMNS.includes(record)\r\n );\r\n let newRight = savedState?.pinnedColumns?.right || [] || [];\r\n newRight = newRight.filter(\r\n (record: any) => !PIN_FIXED_COLUMNS.includes(record)\r\n );\r\n\r\n const [pinnedColumns, setPinnedColumns] = useState<GridPinnedColumnFields>({\r\n left: [...(themeDirection === \"ltr\" ? PIN_FIXED_COLUMNS : []), ...newLeft],\r\n right: [\r\n ...(themeDirection === \"rtl\" ? PIN_FIXED_COLUMNS : []),\r\n ...newRight,\r\n ],\r\n });\r\n\r\n const session = useSession();\r\n const navigate = useNavigate();\r\n const [recordToDelete, setRecordToDelete] = useState<any>(null);\r\n const [recordToEdit, setRecordToEdit] = useState<any>(null);\r\n const [rowModesModel, setRowModesModel] = useState<GridRowModesModel>({});\r\n\r\n const [rowSelectionModel, setRowSelectionModel] =\r\n useState<GridRowSelectionModel>({ ids: new Set(), type: \"include\" });\r\n let keyColumnName: string = \"id\";\r\n if (props?.keyColumnName) {\r\n keyColumnName = props?.keyColumnName;\r\n }\r\n const setData = props.setData;\r\n const validationSchema = z.object(constructValidationSchema(fields));\r\n const generatedColumns = constructGridColumnsFromFields(\r\n fields,\r\n props?.editMode?.editMode === \"row\" || false,\r\n t\r\n );\r\n let isEditAllowed = true;\r\n if (props?.editAction?.authority) {\r\n isEditAllowed = session.isUserAuthorized(props.editAction.authority);\r\n }\r\n let isDeleteAllowed = true;\r\n if (props?.deleteAction?.authority) {\r\n isDeleteAllowed = session.isUserAuthorized(props.deleteAction.authority);\r\n }\r\n\r\n const handleRowModesModelChange = (newModel: GridRowModesModel) => {\r\n setRowModesModel(newModel);\r\n };\r\n\r\n const handlePinnedColumnsChange = (newModel: GridPinnedColumnFields) => {\r\n let newLeft = newModel?.left || [];\r\n newLeft = newLeft.filter(\r\n (record: any) => !PIN_FIXED_COLUMNS.includes(record)\r\n );\r\n let newRight = newModel?.right || [];\r\n newRight = newRight.filter(\r\n (record: any) => !PIN_FIXED_COLUMNS.includes(record)\r\n );\r\n const newPinedColumns: GridPinnedColumnFields = {\r\n left: [\r\n ...(themeDirection === \"ltr\" ? PIN_FIXED_COLUMNS : []),\r\n ...newLeft,\r\n ],\r\n right: [\r\n ...(themeDirection === \"rtl\" ? PIN_FIXED_COLUMNS : []),\r\n ...newRight,\r\n ],\r\n };\r\n setPinnedColumns(newPinedColumns);\r\n if (props?.gridStateKey) {\r\n saveGridState(props.gridStateKey, { pinnedColumns: newPinedColumns });\r\n }\r\n };\r\n\r\n const handleDeleteRecord = async () => {\r\n let result = true;\r\n if (!(recordToDelete && recordToDelete?.isNew === true)) {\r\n result = await props.apiActions.deleteRecordById(\r\n recordToDelete[keyColumnName]\r\n );\r\n }\r\n if (result) {\r\n if (props?.deleteAction?.postActionCallBack) {\r\n await props.deleteAction.postActionCallBack(recordToDelete);\r\n }\r\n\r\n setData((oldData: any) => {\r\n const newData = oldData.filter(\r\n (record: any) =>\r\n record[keyColumnName] != recordToDelete[keyColumnName]\r\n );\r\n return newData;\r\n });\r\n }\r\n };\r\n\r\n const { ConfirmationWindow, setOpen: setConfirmationWindowOpened } =\r\n useConfirmationWindow({\r\n title: \"Confirmation\",\r\n body: \"Are you sure you want to delete this record ?\",\r\n onConfirmationCallBk: handleDeleteRecord,\r\n });\r\n\r\n let formModalHeight = undefined;\r\n let formModalWidth = undefined;\r\n let formModalMinHeight = undefined;\r\n let formModalMinWidth = undefined;\r\n let formModalIcon = undefined;\r\n let formModalTitle = undefined;\r\n\r\n if (props?.editMode?.editMode === \"modal\") {\r\n formModalHeight = props?.editMode?.specs?.modalHeight || \"fit-content\";\r\n formModalWidth = props?.editMode?.specs?.modalWidth || \"300\";\r\n formModalMinHeight = props?.editMode?.specs?.modalMinHeight;\r\n formModalMinWidth = props?.editMode?.specs?.modalMinWidth;\r\n formModalIcon = props?.editMode?.specs?.modalIcon || \"window\";\r\n formModalTitle = props?.editMode?.specs?.modalTitle || \"Record Form\";\r\n }\r\n\r\n const { Window: FormWindow, setWindowState: setFormWindowState } = useWindow({\r\n height: formModalHeight,\r\n minHeight: formModalMinHeight,\r\n minWidth: formModalMinWidth,\r\n onCloseCallBack: () => {\r\n props.apiActions.reloadData(props?.gridLoadParametersValues);\r\n },\r\n width: formModalWidth,\r\n windowIcon: formModalIcon,\r\n windowTitle: formModalTitle,\r\n });\r\n\r\n const handleCreateNewRecord = () => {\r\n if (props?.editMode?.editMode === \"form\") {\r\n navigate(props.editMode.specs.formRoute);\r\n } else if (props?.editMode?.editMode === \"modal\") {\r\n setFormWindowState(true);\r\n } else if (props?.editMode?.editMode === \"row\") {\r\n currentNewRecordIndex = currentNewRecordIndex - 1;\r\n const newRecord: any = {};\r\n newRecord[keyColumnName] = currentNewRecordIndex;\r\n newRecord.isNew = true;\r\n for (const gridColumn of generatedColumns) {\r\n if (\r\n gridColumn?.type != \"actions\" &&\r\n gridColumn?.field != keyColumnName\r\n ) {\r\n if (gridColumn?.field) {\r\n newRecord[gridColumn.field] = null;\r\n }\r\n }\r\n }\r\n setData((oldRows: any) => [newRecord, ...oldRows]);\r\n setRowModesModel((oldModel: any) => ({\r\n ...oldModel,\r\n [currentNewRecordIndex]: { mode: GridRowModes.Edit },\r\n }));\r\n }\r\n };\r\n\r\n const handleEditRecord = async (record: any) => {\r\n if (record) {\r\n setRecordToEdit(record);\r\n if (props.editMode.editMode === \"form\") {\r\n navigate(props.editMode.specs.formRoute + \"/\" + record[keyColumnName]);\r\n } else if (props.editMode.editMode === \"modal\") {\r\n setFormWindowState(true);\r\n } else if (props?.editMode?.editMode === \"row\") {\r\n const id = record[keyColumnName];\r\n setRowModesModel({\r\n ...rowModesModel,\r\n [id]: { mode: GridRowModes.Edit },\r\n });\r\n }\r\n }\r\n };\r\n\r\n const validateRecord = (record: any) => {\r\n try {\r\n validationSchema.parse(record);\r\n } catch (err) {\r\n console.log(\"validateRecord err\", err);\r\n let errorMessage: any = null;\r\n if (err instanceof z.ZodError) {\r\n errorMessage = err.errors\r\n .map(\r\n (error) => \"Error in field (\" + error.path + \") : \" + error.message\r\n )\r\n .join(\",\");\r\n } else {\r\n errorMessage = \"invalid record data\";\r\n }\r\n return errorMessage;\r\n }\r\n };\r\n\r\n const handleSaveRowClick = (record: any) => {\r\n const id = record[keyColumnName];\r\n setRowModesModel({\r\n ...rowModesModel,\r\n [id]: { mode: GridRowModes.View },\r\n });\r\n };\r\n\r\n const processRowUpdate = async (record: any) => {\r\n if (props.editMode.editMode === \"row\") {\r\n let savedRecord: any = null;\r\n const errorMessage = validateRecord(record);\r\n if (errorMessage) {\r\n const errors = errorMessage.split(\",\");\r\n toast.error(\r\n <div style={{}}>\r\n {errors.map((error: any) => (\r\n <>\r\n <div>{error}</div>\r\n <Divider />\r\n </>\r\n ))}\r\n </div>\r\n );\r\n throw new Error(errorMessage);\r\n }\r\n if (props?.editAction?.preActionValidation) {\r\n if (!props.editAction.preActionValidation(record)) {\r\n throw new Error(\"error on the configured presave validation\");\r\n }\r\n }\r\n const requestObject: any = { ...record };\r\n if (\r\n record[keyColumnName] &&\r\n isNumber(record[keyColumnName]) &&\r\n Number(record[keyColumnName]) < 0\r\n ) {\r\n requestObject[keyColumnName] = null;\r\n }\r\n savedRecord = await props.apiActions.saveRecord(requestObject);\r\n if (savedRecord == null) {\r\n throw new Error(\r\n \"Failed to process your request, contact your administrator\"\r\n );\r\n }\r\n if (props?.editAction?.postActionCallBack) {\r\n await props.editAction.postActionCallBack(record);\r\n }\r\n if (record?.isNew === true) {\r\n setData((oldData: any) => {\r\n const newData = oldData.filter(\r\n (x: any) => x[keyColumnName] !== record[keyColumnName]\r\n );\r\n return [savedRecord, ...newData];\r\n });\r\n }\r\n if (\r\n props?.editMode?.reloadAfterSave === true &&\r\n props?.apiActions?.reloadData\r\n ) {\r\n props?.apiActions?.reloadData(props?.gridLoadParametersValues);\r\n }\r\n return savedRecord;\r\n }\r\n };\r\n\r\n const handleCancelRowEditClick = (record: any) => {\r\n const id = record[keyColumnName];\r\n if (id && isNumber(id) && id < 0) {\r\n setRowModesModel({\r\n ...rowModesModel,\r\n [id]: { mode: GridRowModes.View, ignoreModifications: true },\r\n });\r\n setData((oldData: any) => {\r\n const newData = oldData.filter(\r\n (record: any) => record[keyColumnName] != id\r\n );\r\n return newData;\r\n });\r\n } else {\r\n setRowModesModel({\r\n ...rowModesModel,\r\n [id]: { mode: GridRowModes.View, ignoreModifications: true },\r\n });\r\n }\r\n };\r\n\r\n const getActionColumnActions = (params: GridRowParams<any>) => {\r\n const record: any = params.row;\r\n const actions: Array<React.ReactElement<GridActionsCellItemProps>> = [];\r\n if (props?.editMode?.editMode != \"none\") {\r\n if (\r\n props?.disableDefaultAction === undefined ||\r\n !props.disableDefaultAction\r\n ) {\r\n const isInEditMode: boolean =\r\n rowModesModel[record[keyColumnName]]?.mode === GridRowModes.Edit;\r\n if (props.editMode.editMode === \"row\" && isInEditMode) {\r\n if (isEditAllowed) {\r\n actions.push(\r\n <GridActionsCellItem\r\n icon={<FontAwesomeIcon icon=\"save\" />}\r\n label={t(\"SAVE_BTN_LABEL\")}\r\n onClick={() => {\r\n handleSaveRowClick(record);\r\n }}\r\n />\r\n );\r\n actions.push(\r\n <GridActionsCellItem\r\n icon={<FontAwesomeIcon icon=\"cancel\" />}\r\n label={t(\"CANCEL_BTN_LABEL\")}\r\n onClick={() => {\r\n handleCancelRowEditClick(record);\r\n }}\r\n color=\"inherit\"\r\n />\r\n );\r\n }\r\n } else {\r\n if (props?.editAction && props?.editAction?.isEnabled === true) {\r\n let isEditActionVisibleForRecord = true;\r\n if (props?.editAction?.isActionVisibleForRecord) {\r\n isEditActionVisibleForRecord =\r\n props?.editAction?.isActionVisibleForRecord(record);\r\n }\r\n let isActionEditDisabledForRecord = false;\r\n if (props?.editAction?.isActionDisabledForRecord) {\r\n isActionEditDisabledForRecord =\r\n props?.editAction?.isActionDisabledForRecord(record);\r\n }\r\n if (isEditAllowed && isEditActionVisibleForRecord) {\r\n actions.push(\r\n <GridActionsCellItem\r\n disabled={isActionEditDisabledForRecord}\r\n icon={\r\n <Tooltip title={t(\"EDIT_BTN_LABEL\")}>\r\n <FontAwesomeIcon\r\n icon={\"edit\"}\r\n style={{\r\n color: isActionEditDisabledForRecord\r\n ? \"gray\"\r\n : undefined,\r\n }}\r\n />\r\n </Tooltip>\r\n }\r\n showInMenu={\r\n props?.editAction?.gridActionProps?.showInMenu || false\r\n }\r\n label={t(\"EDIT_BTN_LABEL\")}\r\n className=\"textPrimary\"\r\n color=\"inherit\"\r\n onClick={() => {\r\n if (isEditAllowed && !isActionEditDisabledForRecord) {\r\n handleEditRecord(record);\r\n }\r\n }}\r\n />\r\n );\r\n }\r\n }\r\n if (props?.deleteAction && props?.deleteAction?.isEnabled === true) {\r\n let isDeleteActionVisibleForRecord = true;\r\n if (props?.deleteAction?.isActionVisibleForRecord) {\r\n isDeleteActionVisibleForRecord =\r\n props?.deleteAction?.isActionVisibleForRecord(record);\r\n }\r\n let isDeleteActionDisabledForRecord = false;\r\n if (props?.deleteAction?.isActionDisabledForRecord) {\r\n isDeleteActionDisabledForRecord =\r\n props?.deleteAction?.isActionDisabledForRecord(record);\r\n }\r\n if (isDeleteAllowed && isDeleteActionVisibleForRecord) {\r\n actions.push(\r\n <GridActionsCellItem\r\n disabled={isDeleteActionDisabledForRecord}\r\n icon={\r\n <Tooltip title={t(\"DELETE_BTN_LABEL\")}>\r\n <FontAwesomeIcon\r\n icon={\"trash\"}\r\n style={{\r\n color: isDeleteActionDisabledForRecord\r\n ? \"gray\"\r\n : undefined,\r\n }}\r\n />\r\n </Tooltip>\r\n }\r\n showInMenu={\r\n props?.deleteAction?.gridActionProps?.showInMenu || false\r\n }\r\n label={t(\"DELETE_BTN_LABEL\")}\r\n className=\"textPrimary\"\r\n color=\"inherit\"\r\n onClick={() => {\r\n if (isDeleteAllowed && !isDeleteActionDisabledForRecord) {\r\n if (props?.deleteAction?.preActionValidation) {\r\n if (!props.deleteAction.preActionValidation(record)) {\r\n return;\r\n }\r\n }\r\n setRecordToDelete(record);\r\n setConfirmationWindowOpened(true);\r\n }\r\n }}\r\n />\r\n );\r\n }\r\n }\r\n }\r\n }\r\n }\r\n if (props?.rowActions) {\r\n for (const rowAction of props.rowActions) {\r\n if (\r\n !(\r\n rowAction?.gridActionProps?.multiRecord &&\r\n rowAction?.gridActionProps?.multiRecord === true\r\n )\r\n ) {\r\n actions.push(\r\n <TemplateGridRecordAction\r\n {...rowAction}\r\n record={record}\r\n reloadData={async () => {\r\n props.apiActions.reloadData(props?.gridLoadParametersValues);\r\n }}\r\n />\r\n );\r\n }\r\n }\r\n }\r\n\r\n return actions;\r\n };\r\n\r\n const actionColumn: TemplateGridColDef = {\r\n type: \"actions\",\r\n field: \"actions\",\r\n headerName: \"\",\r\n headerAlign: \"center\",\r\n width:\r\n (props?.rowActions ? props.rowActions.length * 30 : 0) +\r\n (props?.editAction && props?.editAction?.isEnabled ? 30 : 0) +\r\n (props?.deleteAction && props?.deleteAction?.isEnabled ? 30 : 0),\r\n getActions: getActionColumnActions,\r\n };\r\n\r\n let structuredColumns: Array<TemplateGridColDef> = [];\r\n if (\r\n props?.disableDefaultAction === undefined ||\r\n !props.disableDefaultAction ||\r\n (props?.rowActions && props?.rowActions.length > 0)\r\n ) {\r\n structuredColumns.push(actionColumn);\r\n }\r\n\r\n structuredColumns = [...structuredColumns, ...generatedColumns];\r\n const handleRowSelection = (gridSelectionModel: GridRowSelectionModel) => {\r\n setRowSelectionModel(gridSelectionModel);\r\n };\r\n useEffect(() => {\r\n if (props?.autoLoad === undefined || props.autoLoad === true) {\r\n props.apiActions.reloadData(props?.gridLoadParametersValues);\r\n }\r\n }, []);\r\n\r\n const handleColumnVisibilityChange = (model: GridColumnVisibilityModel) => {\r\n setColumnVisibilityModel(model);\r\n if (props?.gridStateKey) {\r\n saveGridState(props.gridStateKey, { columnVisibilityModel: model });\r\n }\r\n };\r\n\r\n const handleColumnOrderChange: GridEventListener<\"columnOrderChange\"> = (\r\n params: GridColumnOrderChangeParams\r\n ) => {\r\n const { column, targetIndex } = params;\r\n setColumnOrder((prevOrder) => {\r\n const currentOrder = prevOrder.length\r\n ? [...prevOrder]\r\n : structuredColumns.map((col) => col.field);\r\n const fromIndex = currentOrder.indexOf(column.field);\r\n if (fromIndex === -1) return currentOrder;\r\n\r\n currentOrder.splice(fromIndex, 1); // remove\r\n currentOrder.splice(targetIndex, 0, column.field); // insert at new index\r\n\r\n if (props?.gridStateKey) {\r\n saveGridState(props.gridStateKey, { columnOrder: currentOrder });\r\n }\r\n\r\n return currentOrder;\r\n });\r\n };\r\n\r\n const handleRowGroupChange = (model: GridRowGroupingModel) => {\r\n setGridRowGroupingModel(model);\r\n if (props?.gridStateKey) {\r\n saveGridState(props.gridStateKey, { columnGroupingModel: model });\r\n }\r\n };\r\n\r\n const handleColumnWidthChange: GridEventListener<\"columnWidthChange\"> = (\r\n params: GridColumnResizeParams\r\n ) => {\r\n const updatedWidths = {\r\n ...columnWidths,\r\n [params.colDef.field]: params.width,\r\n };\r\n setColumnWidths(updatedWidths);\r\n if (props?.gridStateKey) {\r\n saveGridState(props.gridStateKey, { columnWidths: updatedWidths });\r\n }\r\n };\r\n\r\n const adjustedColumns: Array<TemplateGridColDef> = React.useMemo(() => {\r\n const baseCols = structuredColumns.map((col) => ({\r\n ...col,\r\n width: columnWidths[col.field] || col.width,\r\n }));\r\n\r\n // Reorder based on saved columnOrder\r\n if (columnOrder.length) {\r\n const fieldToCol = new Map(baseCols.map((col) => [col.field, col]));\r\n return columnOrder.map((field) => fieldToCol.get(field)!).filter(Boolean);\r\n }\r\n\r\n return baseCols;\r\n }, [columnOrder, columnWidths, structuredColumns]);\r\n return (\r\n <>\r\n <ConfirmationWindow />\r\n {props?.editMode?.editMode === \"modal\" ? (\r\n <FormWindow>\r\n {props?.editMode?.specs?.formComponent ? (\r\n <props.editMode.specs.formComponent\r\n recordIdToEdit={\r\n recordToEdit ? recordToEdit[keyColumnName] : undefined\r\n }\r\n formCloseCallBk={() => {\r\n setFormWindowState(false);\r\n props.apiActions.reloadData(props?.gridLoadParametersValues);\r\n }}\r\n />\r\n ) : (\r\n <TemplateForm\r\n recordIdToEdit={\r\n recordToEdit ? recordToEdit[keyColumnName] : undefined\r\n }\r\n formCloseCallBk={() => {\r\n setFormWindowState(false);\r\n props.apiActions.reloadData(props?.gridLoadParametersValues);\r\n }}\r\n elements={props.formElements}\r\n apiActions={props.apiActions}\r\n editAuthorityKey={props?.editAction?.authority}\r\n formSavedSuccessfullyCallBk={\r\n props?.editAction?.postActionCallBack\r\n }\r\n preSaveValidation={props?.editAction?.preActionValidation}\r\n actions={props?.rowActions}\r\n />\r\n )}\r\n </FormWindow>\r\n ) : (\r\n <></>\r\n )}\r\n {props?.hideInfoBar === undefined && !props?.hideInfoBar ? (\r\n <Box sx={{ display: \"flex\" }}>\r\n {props?.hideBackButton === undefined && !props?.hideBackButton ? (\r\n <IconButton\r\n onClick={() => {\r\n navigate(\"-1\", { replace: true });\r\n }}\r\n >\r\n <FontAwesomeIcon icon=\"arrow-left\" />\r\n </IconButton>\r\n ) : (\r\n <></>\r\n )}\r\n <Box\r\n sx={{\r\n flex: 1,\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n }}\r\n >\r\n {props?.girdIcon ? (\r\n <FontAwesomeIcon\r\n icon={props.girdIcon}\r\n style={{ marginRight: 5, marginLeft: 5 }}\r\n />\r\n ) : (\r\n <></>\r\n )}\r\n <Typography variant=\"h5\">\r\n {props?.gridTitle\r\n ? capitalizeFirstLetter(t(props?.gridTitle))\r\n : \"\"}\r\n </Typography>\r\n </Box>\r\n </Box>\r\n ) : (\r\n <></>\r\n )}\r\n\r\n {props?.gridLoadParameters &&\r\n props?.gridLoadParametersValues &&\r\n props?.setGridLoadParametersValues ? (\r\n <Accordion defaultExpanded>\r\n <AccordionSummary expandIcon={<GridExpandMoreIcon />}>\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n }}\r\n >\r\n <FontAwesomeIcon\r\n style={{ marginLeft: 5, marginRight: 5 }}\r\n icon=\"search\"\r\n />\r\n <Typography component=\"span\">Filters</Typography>\r\n </Box>\r\n </AccordionSummary>\r\n <AccordionDetails>\r\n <Box>\r\n <TemplateForm\r\n saveButtonSpecs={{\r\n label: t(\"SEARCH_BTN_LABEL\"),\r\n icon: \"search\",\r\n actionButtonVariant: \"outlined\",\r\n actionButtonColor: \"success\",\r\n }}\r\n cancelButtonSpecs={{\r\n label: t(\"RESET_BTN_LABEL\"),\r\n icon: \"eraser\",\r\n actionButtonVariant: \"outlined\",\r\n actionButtonColor: \"error\",\r\n }}\r\n apiActions={{\r\n deleteRecordById: async () => {\r\n return true;\r\n },\r\n saveRecord: async (params) => {\r\n if (params != undefined) {\r\n props.setGridLoadParametersValues(params);\r\n } else {\r\n props.setGridLoadParametersValues({});\r\n }\r\n props.apiActions.reloadData(params);\r\n },\r\n reloadData: async () => {},\r\n loadRecordById: async () => {},\r\n }}\r\n elements={props.gridLoadParameters}\r\n />\r\n </Box>\r\n </AccordionDetails>\r\n </Accordion>\r\n ) : (\r\n <></>\r\n )}\r\n\r\n <DataGridPremium\r\n {...props?.muiProps}\r\n slots={{ toolbar: TemplateGridTopBar }}\r\n slotProps={{\r\n toolbar: {\r\n templateProps: {\r\n ...props,\r\n rowSelectionModel: rowSelectionModel,\r\n data: props?.data,\r\n },\r\n handleCreateNewRecord,\r\n clearGridState,\r\n } as any,\r\n }}\r\n getRowId={(record: any) => {\r\n return record[keyColumnName];\r\n }}\r\n showToolbar={true}\r\n rows={props?.data}\r\n columns={adjustedColumns}\r\n checkboxSelection\r\n editMode=\"row\"\r\n rowModesModel={\r\n props.editMode.editMode == \"row\" ? rowModesModel : undefined\r\n }\r\n onRowModesModelChange={\r\n props.editMode.editMode == \"row\"\r\n ? handleRowModesModelChange\r\n : undefined\r\n }\r\n rowGroupingColumnMode=\"multiple\"\r\n processRowUpdate={processRowUpdate}\r\n rowSelectionModel={rowSelectionModel}\r\n onRowSelectionModelChange={handleRowSelection}\r\n columnVisibilityModel={columnVisibilityModel}\r\n onColumnVisibilityModelChange={handleColumnVisibilityChange}\r\n onColumnOrderChange={handleColumnOrderChange}\r\n onColumnWidthChange={handleColumnWidthChange}\r\n rowGroupingModel={gridRowGroupingModel}\r\n onRowGroupingModelChange={(model: GridRowGroupingModel) => {\r\n handleRowGroupChange(model);\r\n }}\r\n pinnedColumns={pinnedColumns}\r\n onPinnedColumnsChange={handlePinnedColumnsChange}\r\n />\r\n </>\r\n );\r\n};\r\n\r\nexport default TemplateGrid;\r\n","import { createSlice, PayloadAction } from \"@reduxjs/toolkit\";\r\n\r\nexport interface CommonStoresInterface {\r\n stores: { [key: string]: StoreMetaData };\r\n storeKeys: Array<String>;\r\n isAutoLoadLoaded: boolean;\r\n}\r\n\r\ninterface setStoreDataProps {\r\n storeKey: string;\r\n data: Array<any>;\r\n}\r\n\r\nexport interface StoreMetaData {\r\n url: string;\r\n data: Array<any>;\r\n autoLoad: boolean;\r\n authority?: string;\r\n}\r\n\r\nexport const commonStoresInitialState: CommonStoresInterface = {\r\n stores: {},\r\n storeKeys: [],\r\n isAutoLoadLoaded: false,\r\n};\r\n\r\nconst commonStoreSlice = createSlice({\r\n name: \"loadingMask\",\r\n initialState: commonStoresInitialState,\r\n reducers: {\r\n setStoresMetaData: (state, action) => {\r\n state.stores = action.payload;\r\n state.storeKeys = Object.keys(action.payload);\r\n },\r\n setStoreData: (state, action: PayloadAction<setStoreDataProps>) => {\r\n state.stores[action.payload.storeKey].data = action.payload.data;\r\n },\r\n setAutoLoadLoaded: () => {\r\n state.isAutoLoadLoaded = true;\r\n },\r\n },\r\n});\r\n\r\nexport const { setStoreData, setStoresMetaData, setAutoLoadLoaded } =\r\n commonStoreSlice.actions;\r\nexport default commonStoreSlice.reducer;\r\n","import { useDispatch, useSelector } from \"react-redux\";\r\nimport useSession from \"./UseSession\";\r\nimport useAxios from \"./useAxios\";\r\nimport { setStoreData } from \"../redux/features/common/CommonStoreSlice\";\r\n\r\nexport type ApiActionsProps = {\r\n findAll?: string;\r\n commonStoreKey?: string;\r\n setData?: any;\r\n findById?: string;\r\n findByIdParamName?: string;\r\n save?: string;\r\n deleteById?: string;\r\n deleteByIdParamName?: string;\r\n};\r\n\r\nexport type ApiActions = {\r\n reloadData: (params?: any) => Promise<void>;\r\n saveRecord: (record: any) => Promise<any | null>;\r\n loadRecordById: (recordId: any) => Promise<any>;\r\n deleteRecordById: (recordId: any) => Promise<boolean>;\r\n};\r\n\r\nconst useApiActions: (apiActionsProps: ApiActionsProps) => ApiActions = (\r\n apiActionsProps: ApiActionsProps\r\n) => {\r\n const CommonStores = useSelector((state: any) => state.commonStores.stores);\r\n const dispatch = useDispatch();\r\n const session = useSession();\r\n const { handleGetRequest, handlePostRequest, handleDeleteRequest } =\r\n useAxios();\r\n const reloadData = async (params?: any) => {\r\n if (apiActionsProps?.commonStoreKey) {\r\n const storeKeys = Object.keys(CommonStores);\r\n for (const storeKey of storeKeys) {\r\n if (storeKey === apiActionsProps.commonStoreKey) {\r\n if (\r\n (CommonStores[storeKey]?.authority === undefined ||\r\n CommonStores[storeKey]?.authority === null ||\r\n session.isUserAuthorized(CommonStores[storeKey]?.authority)) &&\r\n CommonStores[storeKey]?.url != \"\"\r\n ) {\r\n await handleGetRequest({\r\n endPointURI: CommonStores[storeKey].url,\r\n showMask: false,\r\n successCallBkFn: (response: any) => {\r\n dispatch(setStoreData({ storeKey, data: response.data }));\r\n apiActionsProps.setData(response.data);\r\n },\r\n failureCallBkFn: () => {\r\n dispatch(setStoreData({ storeKey, data: [] }));\r\n apiActionsProps.setData([]);\r\n },\r\n });\r\n break;\r\n }\r\n }\r\n }\r\n } else if (apiActionsProps?.findAll) {\r\n await handleGetRequest({\r\n endPointURI: apiActionsProps.findAll,\r\n showMask: true,\r\n parameters: params || {},\r\n successCallBkFn: (response: any) => {\r\n apiActionsProps.setData(response.data);\r\n },\r\n });\r\n }\r\n };\r\n const saveRecord = async (record: any) => {\r\n let savedRecord = null;\r\n if (apiActionsProps?.save) {\r\n await handlePostRequest({\r\n endPointURI: apiActionsProps.save,\r\n data: record,\r\n showMask: true,\r\n successCallBkFn: (response: any) => {\r\n savedRecord = response.data;\r\n },\r\n });\r\n }\r\n return savedRecord;\r\n };\r\n const loadRecordById = async (recordId: any) => {\r\n let record: any = null;\r\n if (apiActionsProps?.findById) {\r\n const parameters: any = {};\r\n const keyParameterName = apiActionsProps?.findByIdParamName || \"id\";\r\n parameters[keyParameterName] = recordId;\r\n await handleGetRequest({\r\n endPointURI: apiActionsProps.findById,\r\n showMask: true,\r\n parameters,\r\n successCallBkFn: (response: any) => {\r\n record = response.data;\r\n },\r\n });\r\n }\r\n return record;\r\n };\r\n const deleteRecordById = async (recordId: any) => {\r\n let result = true;\r\n if (apiActionsProps?.deleteById) {\r\n const parameters: any = {};\r\n const keyParameterName = apiActionsProps?.deleteByIdParamName || \"id\";\r\n parameters[keyParameterName] = recordId;\r\n await handleDeleteRequest({\r\n endPointURI: apiActionsProps.deleteById,\r\n showMask: true,\r\n parameters,\r\n successCallBkFn: () => {\r\n result = true;\r\n },\r\n failureCallBkFn: () => {\r\n result = false;\r\n },\r\n });\r\n }\r\n return result;\r\n };\r\n return { reloadData, loadRecordById, saveRecord, deleteRecordById };\r\n};\r\n\r\nexport default useApiActions;\r\n","import * as React from \"react\";\r\nimport List from \"@mui/material/List\";\r\nimport Card from \"@mui/material/Card\";\r\nimport CardHeader from \"@mui/material/CardHeader\";\r\nimport ListItem from \"@mui/material/ListItem\";\r\nimport ListItemText from \"@mui/material/ListItemText\";\r\nimport ListItemIcon from \"@mui/material/ListItemIcon\";\r\nimport Checkbox from \"@mui/material/Checkbox\";\r\nimport Button from \"@mui/material/Button\";\r\nimport Divider from \"@mui/material/Divider\";\r\nimport { Box, Grid2, ListItemButton } from \"@mui/material\";\r\nimport TemplateTextField from \"./DataEntryTemplates/TemplateDataForm/FormFields/TemplateTextField\";\r\n\r\nfunction not(a, b) {\r\n return a.filter((value) => b.indexOf(value) === -1);\r\n}\r\n\r\nfunction intersection(a, b) {\r\n return a.filter((value) => b.indexOf(value) !== -1);\r\n}\r\n\r\nfunction union(a, b) {\r\n return [...a, ...not(b, a)];\r\n}\r\n\r\nexport type TransferListProps = {\r\n valueField: string;\r\n displayField: string;\r\n options: Array<any>;\r\n selectedOptions: Array<any>;\r\n setSelection: any;\r\n};\r\n\r\nconst TransferList: React.FC<TransferListProps> = ({\r\n valueField = \"id\",\r\n displayField = \"name\",\r\n options = [],\r\n selectedOptions = [],\r\n setSelection,\r\n}) => {\r\n const [checked, setChecked] = React.useState([]);\r\n const [left, setLeft] = React.useState(options);\r\n const [right, setRight] = React.useState(selectedOptions);\r\n\r\n const [leftFilterValue, setLeftFilterValue] = React.useState<string>(\"\");\r\n const [rightFilterValue, setRightFilterValue] = React.useState<string>(\"\");\r\n\r\n const leftChecked = intersection(checked, left);\r\n const rightChecked = intersection(checked, right);\r\n\r\n const handleToggle = (value) => () => {\r\n const currentIndex = checked.indexOf(value);\r\n const newChecked = [...checked];\r\n\r\n if (currentIndex === -1) {\r\n newChecked.push(value);\r\n } else {\r\n newChecked.splice(currentIndex, 1);\r\n }\r\n\r\n setChecked(newChecked);\r\n };\r\n\r\n const numberOfChecked = (items) => intersection(checked, items).length;\r\n\r\n const handleToggleAll = (items) => () => {\r\n if (numberOfChecked(items) === items.length) {\r\n setChecked(not(checked, items));\r\n } else {\r\n setChecked(union(checked, items));\r\n }\r\n };\r\n\r\n const handleCheckedRight = () => {\r\n setRight((oldState) => {\r\n let newState = right.concat(leftChecked);\r\n setSelection(newState);\r\n return newState;\r\n });\r\n setLeft(not(left, leftChecked));\r\n setChecked(not(checked, leftChecked));\r\n };\r\n\r\n const handleCheckedLeft = () => {\r\n setLeft(left.concat(rightChecked));\r\n setRight((oldState) => {\r\n let newState = not(right, rightChecked);\r\n setSelection(newState);\r\n return newState;\r\n });\r\n setChecked(not(checked, rightChecked));\r\n };\r\n\r\n const customList = (\r\n title: string,\r\n unfilteredItems: Array<any>,\r\n side: \"left\" | \"right\"\r\n ) => {\r\n const items = unfilteredItems.filter((option: any) => {\r\n if (option[displayField]) {\r\n const value: string = option[displayField];\r\n if (\r\n side === \"left\" &&\r\n value\r\n .toLocaleLowerCase()\r\n .includes(leftFilterValue.toLocaleLowerCase())\r\n ) {\r\n return true;\r\n } else if (\r\n side === \"right\" &&\r\n value\r\n .toLocaleLowerCase()\r\n .includes(rightFilterValue.toLocaleLowerCase())\r\n ) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n });\r\n return (\r\n <Card sx={{ height: \"100%\" }}>\r\n <CardHeader\r\n sx={{ px: 2, py: 1 }}\r\n avatar={\r\n <Checkbox\r\n onClick={handleToggleAll(items)}\r\n checked={\r\n numberOfChecked(items) === items.length && items.length !== 0\r\n }\r\n indeterminate={\r\n numberOfChecked(items) !== items.length &&\r\n numberOfChecked(items) !== 0\r\n }\r\n disabled={items.length === 0}\r\n inputProps={{\r\n \"aria-label\": \"all items selected\",\r\n }}\r\n />\r\n }\r\n title={title}\r\n subheader={`${numberOfChecked(unfilteredItems)} / ${\r\n unfilteredItems.length\r\n } Selected`}\r\n />\r\n <Box sx={{ width: \"100%\", padding: 1 }}>\r\n <TemplateTextField\r\n fullWidth\r\n label=\"search\"\r\n value={side === \"left\" ? leftFilterValue : rightFilterValue}\r\n onChange={(event) => {\r\n if (side === \"left\") {\r\n setLeftFilterValue(event.target.value);\r\n } else {\r\n setRightFilterValue(event.target.value);\r\n }\r\n }}\r\n />\r\n </Box>\r\n <Divider />\r\n <List\r\n sx={{\r\n width: \"100%\",\r\n height: \"100%\",\r\n bgcolor: \"secondary\",\r\n overflow: \"auto\",\r\n }}\r\n dense\r\n component=\"div\"\r\n role=\"list\"\r\n >\r\n {items.map((value) => {\r\n const labelId = `transfer-list-all-item-${value[valueField]}-label`;\r\n\r\n return (\r\n <ListItemButton\r\n key={value[valueField]}\r\n role=\"listitem\"\r\n onClick={handleToggle(value)}\r\n sx={{ cursor: \"pointer\" }} \r\n >\r\n <ListItemIcon>\r\n <Checkbox\r\n checked={checked.indexOf(value) !== -1}\r\n tabIndex={-1}\r\n disableRipple\r\n />\r\n </ListItemIcon>\r\n <ListItemText\r\n id={value[valueField]}\r\n primary={value[displayField]}\r\n />\r\n </ListItemButton>\r\n );\r\n })}\r\n </List>\r\n </Card>\r\n );\r\n };\r\n return (\r\n <Grid2\r\n container\r\n spacing={2}\r\n sx={{\r\n flexGrow: 1,\r\n overflow: \"auto\",\r\n margin: 1,\r\n display: \"flex\",\r\n width: \"100%\",\r\n }}\r\n justifyContent=\"center\"\r\n alignItems=\"center\"\r\n >\r\n <Grid2 sx={{ height: \"100%\", flex: 1 }}>\r\n {customList(\"Available Items\", left, \"left\")}\r\n </Grid2>\r\n <Grid2>\r\n <Grid2 container direction=\"column\" alignItems=\"center\">\r\n <Button\r\n sx={{ my: 0.5 }}\r\n variant=\"outlined\"\r\n size=\"small\"\r\n onClick={handleCheckedRight}\r\n disabled={leftChecked.length === 0}\r\n aria-label=\"move selected right\"\r\n >\r\n &gt;\r\n </Button>\r\n <Button\r\n sx={{ my: 0.5 }}\r\n variant=\"outlined\"\r\n size=\"small\"\r\n onClick={handleCheckedLeft}\r\n disabled={rightChecked.length === 0}\r\n aria-label=\"move selected left\"\r\n >\r\n &lt;\r\n </Button>\r\n </Grid2>\r\n </Grid2>\r\n <Grid2 sx={{ height: \"100%\", flex: 1 }}>\r\n {customList(\"Currently Selected\", right, \"right\")}\r\n </Grid2>\r\n </Grid2>\r\n );\r\n};\r\n\r\nexport default TransferList;\r\n","import { PieChart } from \"@mui/x-charts/PieChart\";\r\nimport { WidgetProps } from \"../TemplateDashboard\";\r\n\r\nconst TemplatePieChart: React.FC<WidgetProps> = (props) => {\r\n // construct data object\r\n const chartData = props.data.map((record: any, index: any) => {\r\n return {\r\n id: index,\r\n value: record[props.valueField],\r\n label: record[props.labelField] + \"\",\r\n };\r\n });\r\n console.log(\"chartData\", chartData);\r\n return (\r\n <PieChart\r\n series={[\r\n {\r\n data: chartData,\r\n },\r\n ]}\r\n />\r\n );\r\n};\r\n\r\nexport default TemplatePieChart;\r\n","import { BarChart } from \"@mui/x-charts\";\r\nimport { WidgetProps } from \"../TemplateDashboard\";\r\n\r\nconst TemplateBarChart: React.FC<WidgetProps> = (props) => {\r\n return (\r\n <BarChart\r\n dataset={props.data}\r\n xAxis={[{ dataKey: props.valueField, scaleType: \"band\" }]}\r\n series={props.labelField?.split(\",\").map((labelField) => {\r\n return { dataKey: labelField, label: labelField };\r\n })}\r\n />\r\n );\r\n};\r\n\r\nexport default TemplateBarChart;\r\n","import { LineChart } from \"@mui/x-charts\";\r\nimport { WidgetProps } from \"../TemplateDashboard\";\r\n\r\nconst TemplateLineChart: React.FC<WidgetProps> = (props) => {\r\n return (\r\n <LineChart\r\n dataset={props.data}\r\n xAxis={[{ dataKey: props.valueField, scaleType: \"band\" }]}\r\n series={props.labelField?.split(\",\").map((labelField) => {\r\n return { dataKey: labelField, label: labelField };\r\n })}\r\n />\r\n );\r\n};\r\n\r\nexport default TemplateLineChart;\r\n","import { Gauge } from \"@mui/x-charts\";\r\nimport { SingleRecordWidgetProps } from \"../TemplateDashboard\";\r\nimport { Typography } from \"@mui/material\";\r\n\r\nconst TemplateGauge: React.FC<SingleRecordWidgetProps> = (props: any) => {\r\n return (\r\n <>\r\n <Typography sx={{ fontSize: 16, fontWeight: \"bold\" }}>\r\n {props.widgetTitle} - {props.record[props.labelField]}\r\n </Typography>\r\n <Gauge width={200} height={200} value={props.record[props.valueField]} />\r\n </>\r\n );\r\n};\r\n\r\nexport default TemplateGauge;\r\n","import { Box, Paper, Typography } from \"@mui/material\";\r\nimport { SingleRecordWidgetProps } from \"../TemplateDashboard\";\r\n\r\nconst TemplateDataCard: React.FC<SingleRecordWidgetProps> = (props: any) => {\r\n return (\r\n <Paper\r\n sx={{\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n height: 150,\r\n padding: 1,\r\n flexGrow: 1,\r\n justifyContent: \"center\",\r\n alignItems: \"center\",\r\n }}\r\n >\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n width: \"100%\",\r\n justifyContent: \"space-evenly\",\r\n alignItems: \"center\",\r\n }}\r\n >\r\n <Typography sx={{ fontSize: 16, fontWeight: \"bold\" }}>\r\n {props.widgetTitle}\r\n </Typography>\r\n </Box>\r\n <Box\r\n sx={{\r\n flex: 1,\r\n display: \"flex\",\r\n width: \"100%\",\r\n justifyContent: \"space-evenly\",\r\n alignItems: \"center\",\r\n }}\r\n >\r\n {/* <div>left</div> */}\r\n <div>{`${props.record[props.labelField]} : ${\r\n props.record[props.valueField]\r\n }`}</div>\r\n {/* <div>right</div> */}\r\n </Box>\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n width: \"100%\",\r\n justifyContent: \"space-evenly\",\r\n alignItems: \"center\",\r\n }}\r\n >\r\n {/* <div>left</div>\r\n <div>center</div>\r\n <div>right</div> */}\r\n </Box>\r\n </Paper>\r\n );\r\n};\r\n\r\nexport default TemplateDataCard;\r\n","import * as React from \"react\";\r\nimport LinearProgress, {\r\n LinearProgressProps,\r\n} from \"@mui/material/LinearProgress\";\r\nimport Typography from \"@mui/material/Typography\";\r\nimport Box from \"@mui/material/Box\";\r\nimport { SingleRecordWidgetProps } from \"../TemplateDashboard\";\r\n\r\nfunction LinearProgressWithLabel(\r\n props: LinearProgressProps & { value: number }\r\n) {\r\n return (\r\n <Box sx={{ display: \"flex\", alignItems: \"center\" }}>\r\n <Box sx={{ width: \"100%\", mr: 1 }}>\r\n <LinearProgress variant=\"determinate\" {...props} />\r\n </Box>\r\n <Box sx={{ minWidth: 35 }}>\r\n <Typography\r\n variant=\"body2\"\r\n sx={{ color: \"text.secondary\" }}\r\n >{`${Math.round(props.value)}%`}</Typography>\r\n </Box>\r\n </Box>\r\n );\r\n}\r\n\r\nconst TemplateLineProgress: React.FC<SingleRecordWidgetProps> = (\r\n props: any\r\n) => {\r\n return (\r\n <Box sx={{ width: \"100%\" }}>\r\n <Typography sx={{ fontSize: 16, fontWeight: \"bold\" }}>\r\n {props.widgetTitle} - {props.record[props.labelField]}\r\n </Typography>\r\n <LinearProgressWithLabel value={props.record[props.valueField]} />\r\n </Box>\r\n );\r\n};\r\n\r\nexport default TemplateLineProgress;\r\n","import Grid from \"@mui/material/Grid2\";\r\nimport TemplatePieChart from \"./charts/TemplatePieChart\";\r\nimport TemplateBarChart from \"./charts/TemplateBarChart\";\r\nimport TemplateLineChart from \"./charts/TemplateLineChart\";\r\nimport TemplateGauge from \"./charts/TemplateGauge\";\r\nimport TemplateDataCard from \"./charts/TemplateDataCard\";\r\nimport TemplateLineProgress from \"./charts/TemplateLineProgress\";\r\nimport { Typography } from \"@mui/material\";\r\n\r\ninterface WidgetContainerProps {\r\n children: React.ReactNode;\r\n widgetType: \"Line\" | \"Bar\" | \"Pie\" | \"Card\" | \"Gauge\" | \"Progress\";\r\n}\r\n\r\nexport interface WidgetProps {\r\n widgetTitle?: string;\r\n widgetType: \"Line\" | \"Bar\" | \"Pie\" | \"Card\" | \"Gauge\" | \"Progress\";\r\n data: any;\r\n valueField: string; //x-axis field in case of line/bar chart\r\n labelField: string; //y-axis field in case of line/bar chart, it can also be a comma separated string for multiple series\r\n}\r\n\r\nexport interface SingleRecordWidgetProps {\r\n widgetTitle?: string;\r\n record: object;\r\n valueField: string;\r\n labelField: string;\r\n}\r\n\r\nexport interface DashboardProps {\r\n dashboardTitle: string;\r\n dashboardWidgets: Array<WidgetProps>;\r\n}\r\n\r\nconst WidgetContainer: React.FC<WidgetContainerProps> = ({\r\n children,\r\n widgetType,\r\n}) => {\r\n return (\r\n <Grid\r\n size={{ xs: 12, sm: 6, md: 4 }}\r\n sx={{\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n padding: 1,\r\n display: \"flex\",\r\n flexDirection: widgetType != \"Card\" ? \"column\" : undefined,\r\n height: 300,\r\n }}\r\n >\r\n {children}\r\n </Grid>\r\n );\r\n};\r\n\r\nconst TemplateDashboard: React.FC<DashboardProps> = (props) => {\r\n return (\r\n <>\r\n <Typography sx={{ fontSize: 20, fontWeight: \"bold\" }}>\r\n {props.dashboardTitle}\r\n </Typography>\r\n <Grid\r\n container\r\n sx={{\r\n flexGrow: 1,\r\n width: \"100%\",\r\n overflowY: \"auto\",\r\n padding: 2,\r\n }}\r\n >\r\n {props.dashboardWidgets.map((widgetProps: any, index: any) => {\r\n if (\r\n widgetProps.widgetType === \"Card\" ||\r\n widgetProps.widgetType === \"Gauge\" ||\r\n widgetProps.widgetType === \"Progress\"\r\n ) {\r\n return (\r\n <>\r\n {widgetProps.data.map((record: any, index: any) => {\r\n const singleRecordWidgetProps: SingleRecordWidgetProps = {\r\n widgetTitle: widgetProps.widgetTitle,\r\n record,\r\n labelField: widgetProps.labelField,\r\n valueField: widgetProps.valueField,\r\n };\r\n return (\r\n <WidgetContainer\r\n key={index}\r\n widgetType={widgetProps.widgetType}\r\n >\r\n {widgetProps.widgetType === \"Card\" ? (\r\n <TemplateDataCard {...singleRecordWidgetProps} />\r\n ) : null}\r\n {widgetProps.widgetType === \"Gauge\" ? (\r\n <TemplateGauge {...singleRecordWidgetProps} />\r\n ) : null}\r\n {widgetProps.widgetType === \"Progress\" ? (\r\n <TemplateLineProgress {...singleRecordWidgetProps} />\r\n ) : null}\r\n </WidgetContainer>\r\n );\r\n })}\r\n </>\r\n );\r\n } else {\r\n return (\r\n <WidgetContainer key={index} widgetType={widgetProps.widgetType}>\r\n {widgetProps.widgetType === \"Pie\" ? (\r\n <TemplatePieChart {...widgetProps} />\r\n ) : null}\r\n {widgetProps.widgetType === \"Line\" ? (\r\n <TemplateLineChart {...widgetProps} />\r\n ) : null}\r\n {widgetProps.widgetType === \"Bar\" ? (\r\n <TemplateBarChart {...widgetProps} />\r\n ) : null}\r\n </WidgetContainer>\r\n );\r\n }\r\n })}\r\n </Grid>\r\n </>\r\n );\r\n};\r\n\r\nexport default TemplateDashboard;\r\n","import { useState } from \"react\";\r\nimport { Box, Button } from \"@mui/material\";\r\nimport { toast } from \"react-toastify\";\r\nimport { useAxios } from \"../../hooks\";\r\nimport { TransferList } from \"../templates\";\r\n\r\ntype RoleAuthoritiesFormProps = {\r\n roleId: number;\r\n availableAuthorities: Array<any>;\r\n currentRoleAuthorities: Array<any>;\r\n closeModalFn: () => void;\r\n};\r\n\r\nconst RoleAuthoritiesForm: React.FC<RoleAuthoritiesFormProps> = (props) => {\r\n const [selectedOptions, setSelectedOptions] = useState([\r\n ...props.currentRoleAuthorities,\r\n ]);\r\n const { handlePostRequest } = useAxios();\r\n const saveRoleAuthorities = async () => {\r\n await handlePostRequest({\r\n endPointURI: \"api/v1/admin/role/authorities\",\r\n showMask: true,\r\n parameters: { roleId: props.roleId },\r\n data: selectedOptions,\r\n successCallBkFn: () => {\r\n toast.success(\"Your request has been proccesed successfully\");\r\n if (props.closeModalFn) {\r\n props.closeModalFn();\r\n }\r\n },\r\n });\r\n };\r\n return (\r\n <>\r\n <TransferList\r\n displayField=\"authorityName\"\r\n options={props.availableAuthorities}\r\n valueField=\"id\"\r\n selectedOptions={selectedOptions}\r\n setSelection={setSelectedOptions}\r\n />\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"flex-end\",\r\n width: \"100%\",\r\n }}\r\n >\r\n <Button\r\n variant=\"contained\"\r\n onClick={saveRoleAuthorities}\r\n sx={{ marginRight: 1, marginLeft: 1 }}\r\n >\r\n Save\r\n </Button>\r\n <Button variant=\"contained\" color=\"error\" onClick={props.closeModalFn}>\r\n Cancel\r\n </Button>\r\n </Box>\r\n </>\r\n );\r\n};\r\n\r\nexport default RoleAuthoritiesForm;\r\n","import Home from \"../components/common/Home\";\r\nimport { ADMINISTRATION_ROUTES } from \"./administration\";\r\nimport { SystemRoute } from \"./types\";\r\n\r\nexport const SYSTEM_ROUTES: Array<SystemRoute> = [\r\n {\r\n path: \"/\",\r\n component: Home,\r\n },\r\n ...ADMINISTRATION_ROUTES,\r\n];\r\n","import { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport { Box } from \"@mui/material\";\r\nimport { useSelector } from \"react-redux\";\r\n\r\nconst Home: React.FC = () => {\r\n const counter = useSelector((state) => state.counter.value);\r\n return (\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n flex: 1,\r\n fontSize: 24,\r\n fontWeight: \"bold\",\r\n }}\r\n >\r\n <img src=\"logo.png\" style={{ margin: 5 }} />\r\n <div>Welcome to Ezzsteel Flat Product Management System</div>\r\n <div style={{ fontSize: 16 }}>\r\n Use side menu [\r\n <FontAwesomeIcon\r\n icon=\"bars\"\r\n style={{ marginLeft: 10, marginRight: 10 }}\r\n />\r\n ] to navigate to your authorized system modules\r\n </div>\r\n <div>counter [{counter}]</div>\r\n </Box>\r\n );\r\n};\r\n\r\nexport default Home;\r\n","import { SystemRoute } from \"../types\";\r\nimport { adminRoutes } from \"./adminRoutes\";\r\n\r\nexport const ADMINISTRATION_ROUTES: Array<SystemRoute> = [...adminRoutes];\r\n","import { SystemRoute } from \"../types\";\r\n\r\nimport AuthorityGrid from \"../../components/admin/AuthorityGrid\";\r\nimport BluePrintGrid from \"../../components/admin/BluePrintGrid\";\r\nimport BluePrintPageGrid from \"../../components/admin/BluePrintPageGrid\";\r\nimport BluePrintPointGrid from \"../../components/admin/BluePrintPointGrid\";\r\nimport DashboardGrid from \"../../components/admin/DashboardGrid\";\r\nimport DashboardWidgetGrid from \"../../components/admin/DashboardWidgetGrid\";\r\nimport DataQueryGrid from \"../../components/admin/DataQueryGrid\";\r\nimport DataQueryParameterGrid from \"../../components/admin/DataQueryParameterGrid\";\r\nimport DatasourceConnectionGrid from \"../../components/admin/DatasourceConnectionGrid\";\r\nimport EmployeeGrid from \"../../components/admin/EmployeeGrid\";\r\nimport EntityParameterGrid from \"../../components/admin/EntityParameterGrid\";\r\nimport ExcelUploaderDetailGrid from \"../../components/admin/ExcelUploaderDetailGrid\";\r\nimport ExcelUploaderHeaderGrid from \"../../components/admin/ExcelUploaderHeaderGrid\";\r\nimport LookupGrid from \"../../components/admin/LookupGrid\";\r\nimport MailAttachmentGrid from \"../../components/admin/MailAttachmentGrid\";\r\nimport MailBodyGrid from \"../../components/admin/MailBodyGrid\";\r\nimport MailNotificationQueueGrid from \"../../components/admin/MailNotificationQueueGrid\";\r\nimport MailRecipientGrid from \"../../components/admin/MailRecipientGrid\";\r\nimport MailTemplateGrid from \"../../components/admin/MailTemplateGrid\";\r\nimport NewTableGrid from \"../../components/admin/NewTableGrid\";\r\nimport NotificationGrid from \"../../components/admin/NotificationGrid\";\r\nimport NotificationQueueGrid from \"../../components/admin/NotificationQueueGrid\";\r\nimport OrganizationGrid from \"../../components/admin/OrganizationGrid\";\r\nimport OrganizationApplicationGrid from \"../../components/admin/OrganizationApplicationGrid\";\r\nimport OrganizationRankGrid from \"../../components/admin/OrganizationRankGrid\";\r\nimport OrganizationUnitGrid from \"../../components/admin/OrganizationUnitGrid\";\r\nimport OrganizationUserGrid from \"../../components/admin/OrganizationUserGrid\";\r\nimport OrganizationUserRoleGrid from \"../../components/admin/OrganizationUserRoleGrid\";\r\nimport ReportGrid from \"../../components/admin/ReportGrid\";\r\nimport ReportParameterGrid from \"../../components/admin/ReportParameterGrid\";\r\nimport RoleGrid from \"../../components/admin/RoleGrid\";\r\nimport RoleAuthorityGrid from \"../../components/admin/RoleAuthorityGrid\";\r\nimport UserAccountGrid from \"../../components/admin/UserAccountGrid\";\r\nimport UserRequestGrid from \"../../components/admin/UserRequestGrid\";\r\nimport WidgetGrid from \"../../components/admin/WidgetGrid\";\r\nimport WorkflowDocumentGrid from \"../../components/admin/WorkflowDocumentGrid\";\r\nimport WorkflowDocumentActionGrid from \"../../components/admin/WorkflowDocumentActionGrid\";\r\nimport WorkflowDocumentActionHistoryGrid from \"../../components/admin/WorkflowDocumentActionHistoryGrid\";\r\nimport WorkflowDocumentActionMailGrid from \"../../components/admin/WorkflowDocumentActionMailGrid\";\r\nimport WorkflowDocumentMailLogGrid from \"../../components/admin/WorkflowDocumentMailLogGrid\";\r\nimport WorkflowDocumentStatusGrid from \"../../components/admin/WorkflowDocumentStatusGrid\";\r\nimport AttachmentGrid from \"../../components/admin/AttachmentGrid\";\r\nexport const adminRoutes: Array<SystemRoute> = [\r\n {\r\n path: \"admin/attachments\",\r\n component: AttachmentGrid,\r\n authority: \"ATTACHMENT_VIEW\",\r\n },\r\n {\r\n path: \"admin/authorities\",\r\n component: AuthorityGrid,\r\n authority: \"AUTHORITY_VIEW\",\r\n },\r\n {\r\n path: \"admin/blueprints\",\r\n component: BluePrintGrid,\r\n authority: \"BLUE_PRINT_VIEW\",\r\n },\r\n {\r\n path: \"admin/blueprintpages\",\r\n component: BluePrintPageGrid,\r\n authority: \"BLUE_PRINT_PAGE_VIEW\",\r\n },\r\n {\r\n path: \"admin/blueprintpoints\",\r\n component: BluePrintPointGrid,\r\n authority: \"BLUE_PRINT_POINT_VIEW\",\r\n },\r\n {\r\n path: \"admin/dashboards\",\r\n component: DashboardGrid,\r\n authority: \"DASHBOARD_VIEW\",\r\n },\r\n {\r\n path: \"admin/dashboardwidgets\",\r\n component: DashboardWidgetGrid,\r\n authority: \"DASHBOARD_WIDGET_VIEW\",\r\n },\r\n {\r\n path: \"admin/dataqueries\",\r\n component: DataQueryGrid,\r\n authority: \"DATA_QUERY_VIEW\",\r\n },\r\n {\r\n path: \"admin/dataqueryparameters\",\r\n component: DataQueryParameterGrid,\r\n authority: \"DATA_QUERY_PARAMETER_VIEW\",\r\n },\r\n {\r\n path: \"admin/datasourceconnections\",\r\n component: DatasourceConnectionGrid,\r\n authority: \"DATASOURCE_CONNECTION_VIEW\",\r\n },\r\n {\r\n path: \"admin/employees\",\r\n component: EmployeeGrid,\r\n authority: \"EMPLOYEE_VIEW\",\r\n },\r\n {\r\n path: \"admin/entityparameters\",\r\n component: EntityParameterGrid,\r\n authority: \"ENTITY_PARAMETER_VIEW\",\r\n },\r\n {\r\n path: \"admin/exceluploaderdetails\",\r\n component: ExcelUploaderDetailGrid,\r\n authority: \"EXCEL_UPLOADER_DETAIL_VIEW\",\r\n },\r\n {\r\n path: \"admin/exceluploaderheaders\",\r\n component: ExcelUploaderHeaderGrid,\r\n authority: \"EXCEL_UPLOADER_HEADER_VIEW\",\r\n },\r\n {\r\n path: \"admin/lookups\",\r\n component: LookupGrid,\r\n authority: \"LOOKUP_VIEW\",\r\n },\r\n {\r\n path: \"admin/mailattachments\",\r\n component: MailAttachmentGrid,\r\n authority: \"MAIL_ATTACHMENT_VIEW\",\r\n },\r\n {\r\n path: \"admin/mailbodies\",\r\n component: MailBodyGrid,\r\n authority: \"MAIL_BODY_VIEW\",\r\n },\r\n {\r\n path: \"admin/mailnotificationqueues\",\r\n component: MailNotificationQueueGrid,\r\n authority: \"MAIL_NOTIFICATION_QUEUE_VIEW\",\r\n },\r\n {\r\n path: \"admin/mailrecipients\",\r\n component: MailRecipientGrid,\r\n authority: \"MAIL_RECIPIENT_VIEW\",\r\n },\r\n {\r\n path: \"admin/mailtemplates\",\r\n component: MailTemplateGrid,\r\n authority: \"MAIL_TEMPLATE_VIEW\",\r\n },\r\n {\r\n path: \"admin/newtables\",\r\n component: NewTableGrid,\r\n authority: \"NEW_TABLE_VIEW\",\r\n },\r\n {\r\n path: \"admin/notifications\",\r\n component: NotificationGrid,\r\n authority: \"NOTIFICATION_VIEW\",\r\n },\r\n {\r\n path: \"admin/notificationqueues\",\r\n component: NotificationQueueGrid,\r\n authority: \"NOTIFICATION_QUEUE_VIEW\",\r\n },\r\n {\r\n path: \"admin/organizations\",\r\n component: OrganizationGrid,\r\n authority: \"ORGANIZATION_VIEW\",\r\n },\r\n {\r\n path: \"admin/organizationapplications\",\r\n component: OrganizationApplicationGrid,\r\n authority: \"ORGANIZATION_APPLICATION_VIEW\",\r\n },\r\n {\r\n path: \"admin/organizationranks\",\r\n component: OrganizationRankGrid,\r\n authority: \"ORGANIZATION_RANK_VIEW\",\r\n },\r\n {\r\n path: \"admin/organizationunits\",\r\n component: OrganizationUnitGrid,\r\n authority: \"ORGANIZATION_UNIT_VIEW\",\r\n },\r\n {\r\n path: \"admin/organizationusers\",\r\n component: OrganizationUserGrid,\r\n authority: \"ORGANIZATION_USER_VIEW\",\r\n },\r\n {\r\n path: \"admin/organizationuserroles\",\r\n component: OrganizationUserRoleGrid,\r\n authority: \"ORGANIZATION_USER_ROLE_VIEW\",\r\n },\r\n {\r\n path: \"admin/reports\",\r\n component: ReportGrid,\r\n authority: \"REPORT_VIEW\",\r\n },\r\n {\r\n path: \"admin/reportparameters\",\r\n component: ReportParameterGrid,\r\n authority: \"REPORT_PARAMETER_VIEW\",\r\n },\r\n {\r\n path: \"admin/roles\",\r\n component: RoleGrid,\r\n authority: \"ROLE_VIEW\",\r\n },\r\n {\r\n path: \"admin/roleauthorities\",\r\n component: RoleAuthorityGrid,\r\n authority: \"ROLE_AUTHORITY_VIEW\",\r\n },\r\n {\r\n path: \"admin/useraccounts\",\r\n component: UserAccountGrid,\r\n authority: \"USER_ACCOUNT_VIEW\",\r\n },\r\n {\r\n path: \"admin/userrequests\",\r\n component: UserRequestGrid,\r\n authority: \"USER_REQUEST_VIEW\",\r\n },\r\n {\r\n path: \"admin/widgets\",\r\n component: WidgetGrid,\r\n authority: \"WIDGET_VIEW\",\r\n },\r\n {\r\n path: \"admin/workflowdocuments\",\r\n component: WorkflowDocumentGrid,\r\n authority: \"WORKFLOW_DOCUMENT_VIEW\",\r\n },\r\n {\r\n path: \"admin/workflowdocumentactions\",\r\n component: WorkflowDocumentActionGrid,\r\n authority: \"WORKFLOW_DOCUMENT_ACTION_VIEW\",\r\n },\r\n {\r\n path: \"admin/workflowdocumentactionhistories\",\r\n component: WorkflowDocumentActionHistoryGrid,\r\n authority: \"WORKFLOW_DOCUMENT_ACTION_HISTORY_VIEW\",\r\n },\r\n {\r\n path: \"admin/workflowdocumentactionmails\",\r\n component: WorkflowDocumentActionMailGrid,\r\n authority: \"WORKFLOW_DOCUMENT_ACTION_MAIL_VIEW\",\r\n },\r\n {\r\n path: \"admin/workflowdocumentmaillogs\",\r\n component: WorkflowDocumentMailLogGrid,\r\n authority: \"WORKFLOW_DOCUMENT_MAIL_LOG_VIEW\",\r\n },\r\n {\r\n path: \"admin/workflowdocumentstatuses\",\r\n component: WorkflowDocumentStatusGrid,\r\n authority: \"WORKFLOW_DOCUMENT_STATUS_VIEW\",\r\n },\r\n];\r\n\r\n// import { adminRoutes } from \"./adminRoutes\";\r\n// [...adminRoutes]\r\n","import { useState } from \"react\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\n\r\n\r\nconst AttachmentGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/attachment/all\",\r\n deleteById: \"api/v1/admin/attachment\",\r\n save: \"api/v1/admin/attachment\",\r\n findById: \"api/v1/admin/attachment\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ATTACHMENT_ATTACHMENT_NUMBER\",\r\n fieldName: \"attachmentNumber\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ATTACHMENT_ATTACHMENT_SIZE\",\r\n fieldName: \"attachmentSize\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ATTACHMENT_ATTACHMENT_TYPE\",\r\n fieldName: \"attachmentType\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ATTACHMENT_CATEGORY\",\r\n fieldName: \"category\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ATTACHMENT_DOC_TYPE\",\r\n fieldName: \"docType\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ATTACHMENT_FILE_NAME\",\r\n fieldName: \"fileName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ATTACHMENT_REF_KEY\",\r\n fieldName: \"refKey\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ATTACHMENT_REMARK\",\r\n fieldName: \"remark\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"ATTACHMENT_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"ATTACHMENT_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"ATTACHMENT_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default AttachmentGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst AuthorityGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n commonStoreKey: \"SystemAuthorities\",\r\n deleteById: \"api/v1/admin/authority\",\r\n save: \"api/v1/admin/authority\",\r\n findById: \"api/v1/admin/authority\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"AUTHORITY_AUTHORITY_CODE\",\r\n fieldName: \"authorityCode\",\r\n required: true,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"AUTHORITY_AUTHORITY_DESCRIPTION\",\r\n fieldName: \"authorityDescription\",\r\n required: true,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"AUTHORITY_AUTHORITY_NAME\",\r\n fieldName: \"authorityName\",\r\n required: true,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"AUTHORITY_IS_ACTIVE\",\r\n fieldName: \"isActive\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"AUTHORITY_ORGANIZATION_APPLICATION_ID\",\r\n fieldName: \"organizationApplicationId\",\r\n required: false,\r\n fieldType: \"text\",\r\n gridProps: {\r\n hidden: true,\r\n },\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\", reloadAfterSave: true }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"AUTHORITY_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"AUTHORITY_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"AUTHORITY_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default AuthorityGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst BluePrintGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/blueprint/all\",\r\n deleteById: \"api/v1/admin/blueprint\",\r\n save: \"api/v1/admin/blueprint\",\r\n findById: \"api/v1/admin/blueprint\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_BLUE_PRINT_CODE\",\r\n fieldName: \"bluePrintCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_QUERY_ID\",\r\n fieldName: \"queryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"BLUE_PRINT_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"BLUE_PRINT_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"BLUE_PRINT_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default BluePrintGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst BluePrintPageGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/blueprintpage/all\",\r\n deleteById: \"api/v1/admin/blueprintpage\",\r\n save: \"api/v1/admin/blueprintpage\",\r\n findById: \"api/v1/admin/blueprintpage\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_PAGE_BLUE_PRINT_ID\",\r\n fieldName: \"bluePrintId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_PAGE_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_PAGE_PAGE_NAME\",\r\n fieldName: \"pageName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_PAGE_PAGE_ORDER\",\r\n fieldName: \"pageOrder\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_PAGE_QUERY_ID\",\r\n fieldName: \"queryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"BLUE_PRINT_PAGE_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"BLUE_PRINT_PAGE_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"BLUE_PRINT_PAGE_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default BluePrintPageGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst BluePrintPointGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/blueprintpoint/all\",\r\n deleteById: \"api/v1/admin/blueprintpoint\",\r\n save: \"api/v1/admin/blueprintpoint\",\r\n findById: \"api/v1/admin/blueprintpoint\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_POINT_BLUE_PRINT_PAGE_ID\",\r\n fieldName: \"bluePrintPageId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_POINT_FONT_SIZE\",\r\n fieldName: \"fontSize\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_POINT_POINT_CODE\",\r\n fieldName: \"pointCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_POINT_X\",\r\n fieldName: \"x\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_POINT_Y\",\r\n fieldName: \"y\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"BLUE_PRINT_POINT_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"BLUE_PRINT_POINT_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"BLUE_PRINT_POINT_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default BluePrintPointGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst DashboardGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/dashboard/all\",\r\n deleteById: \"api/v1/admin/dashboard\",\r\n save: \"api/v1/admin/dashboard\",\r\n findById: \"api/v1/admin/dashboard\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DASHBOARD_DASHBOARD_CODE\",\r\n fieldName: \"dashboardCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DASHBOARD_DASHBOARD_NAME\",\r\n fieldName: \"dashboardName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DASHBOARD_DASHBOARD_TITLE\",\r\n fieldName: \"dashboardTitle\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DASHBOARD_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DASHBOARD_LOAD_WIDGETS_INDIVIDUALLY\",\r\n fieldName: \"loadWidgetsIndividually\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DASHBOARD_NUMBER_OF_COLUMNS\",\r\n fieldName: \"numberOfColumns\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"DASHBOARD_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"DASHBOARD_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"DASHBOARD_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default DashboardGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst DashboardWidgetGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/dashboardwidget/all\",\r\n deleteById: \"api/v1/admin/dashboardwidget\",\r\n save: \"api/v1/admin/dashboardwidget\",\r\n findById: \"api/v1/admin/dashboardwidget\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DASHBOARD_WIDGET_DASHBOARD_ID\",\r\n fieldName: \"dashboardId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DASHBOARD_WIDGET_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DASHBOARD_WIDGET_WIDGET_ID\",\r\n fieldName: \"widgetId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DASHBOARD_WIDGET_WIDGET_ORDER\",\r\n fieldName: \"widgetOrder\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"DASHBOARD_WIDGET_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"DASHBOARD_WIDGET_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"DASHBOARD_WIDGET_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default DashboardWidgetGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst DataQueryGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n commonStoreKey: \"SystemDataQueries\",\r\n deleteById: \"api/v1/admin/dataquery\",\r\n save: \"api/v1/admin/dataquery\",\r\n findById: \"api/v1/admin/dataquery\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATA_QUERY_DATASOURCE_CON_ID\",\r\n fieldName: \"datasourceConId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATA_QUERY_QUERY_NAME\",\r\n fieldName: \"queryName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATA_QUERY_QUERY_STR\",\r\n fieldName: \"queryStr\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATA_QUERY_USE_SYS_CON\",\r\n fieldName: \"useSysCon\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\", reloadAfterSave: true }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"DATA_QUERY_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"DATA_QUERY_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"DATA_QUERY_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default DataQueryGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst DataQueryParameterGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/dataqueryparameter/all\",\r\n deleteById: \"api/v1/admin/dataqueryparameter\",\r\n save: \"api/v1/admin/dataqueryparameter\",\r\n findById: \"api/v1/admin/dataqueryparameter\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATA_QUERY_PARAMETER_DATA_QUERY_ID\",\r\n fieldName: \"dataQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATA_QUERY_PARAMETER_DEFAULT_VALUE\",\r\n fieldName: \"defaultValue\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATA_QUERY_PARAMETER_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATA_QUERY_PARAMETER_ENTITY_PARAMETER_ID\",\r\n fieldName: \"entityParameterId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATA_QUERY_PARAMETER_HIDDEN\",\r\n fieldName: \"hidden\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATA_QUERY_PARAMETER_MANDATORY\",\r\n fieldName: \"mandatory\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"DATA_QUERY_PARAMETER_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"DATA_QUERY_PARAMETER_EDIT\" }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"DATA_QUERY_PARAMETER_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default DataQueryParameterGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst DatasourceConnectionGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n commonStoreKey: \"SystemDataSources\",\r\n deleteById: \"api/v1/admin/datasourceconnection\",\r\n save: \"api/v1/admin/datasourceconnection\",\r\n findById: \"api/v1/admin/datasourceconnection\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATASOURCE_CONNECTION_CONNECTION_NAME\",\r\n fieldName: \"connectionName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATASOURCE_CONNECTION_DATASOURCE_PASSWORD\",\r\n fieldName: \"datasourcePassword\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATASOURCE_CONNECTION_DATASOURCE_TYPE\",\r\n fieldName: \"datasourceType\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATASOURCE_CONNECTION_DATASOURCE_URL\",\r\n fieldName: \"datasourceUrl\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATASOURCE_CONNECTION_DATASOURCE_USERNAME\",\r\n fieldName: \"datasourceUsername\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATASOURCE_CONNECTION_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\", reloadAfterSave: true }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"DATASOURCE_CONNECTION_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"DATASOURCE_CONNECTION_EDIT\" }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"DATASOURCE_CONNECTION_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default DatasourceConnectionGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst EmployeeGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/employee/all\",\r\n deleteById: \"api/v1/admin/employee\",\r\n save: \"api/v1/admin/employee\",\r\n findById: \"api/v1/admin/employee\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EMPLOYEE_EMAIL\",\r\n fieldName: \"email\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EMPLOYEE_EMPLOYEE_NAME\",\r\n fieldName: \"employeeName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EMPLOYEE_EMPLOYEE_NUMBER\",\r\n fieldName: \"employeeNumber\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EMPLOYEE_MOBILE_NUMBER\",\r\n fieldName: \"mobileNumber\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EMPLOYEE_ORGANIZATION_RANK_ID\",\r\n fieldName: \"organizationRankId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EMPLOYEE_ORGANIZATION_UNIT_ID\",\r\n fieldName: \"organizationUnitId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EMPLOYEE_USER_ACCOUNT_ID\",\r\n fieldName: \"userAccountId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"EMPLOYEE_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"EMPLOYEE_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"EMPLOYEE_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default EmployeeGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst EntityParameterGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n commonStoreKey: \"SystemEntityParameters\",\r\n deleteById: \"api/v1/admin/entityparameter\",\r\n save: \"api/v1/admin/entityparameter\",\r\n findById: \"api/v1/admin/entityparameter\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ENTITY_PARAMETER_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ENTITY_PARAMETER_PARAMETER_CODE\",\r\n fieldName: \"parameterCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ENTITY_PARAMETER_PARAMETER_DATA_QUERY_ID\",\r\n fieldName: \"parameterDataQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ENTITY_PARAMETER_PARAMETER_DATASET\",\r\n fieldName: \"parameterDataset\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ENTITY_PARAMETER_PARAMETER_DISPLAY_FIELD\",\r\n fieldName: \"parameterDisplayField\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ENTITY_PARAMETER_PARAMETER_LABEL\",\r\n fieldName: \"parameterLabel\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ENTITY_PARAMETER_PARAMETER_TYPE\",\r\n fieldName: \"parameterType\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ENTITY_PARAMETER_PARAMETER_VALUE_FIELD\",\r\n fieldName: \"parameterValueField\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ENTITY_PARAMETER_PARAMETER_VALUE_FORMAT\",\r\n fieldName: \"parameterValueFormat\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\", reloadAfterSave: true }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"ENTITY_PARAMETER_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"ENTITY_PARAMETER_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"ENTITY_PARAMETER_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default EntityParameterGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst ExcelUploaderDetailGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/exceluploaderdetail/all\",\r\n deleteById: \"api/v1/admin/exceluploaderdetail\",\r\n save: \"api/v1/admin/exceluploaderdetail\",\r\n findById: \"api/v1/admin/exceluploaderdetail\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EXCEL_UPLOADER_DETAIL_COLUMN_INDEX\",\r\n fieldName: \"columnIndex\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EXCEL_UPLOADER_DETAIL_EXCEL_UPLOADER_HEADER_ID\",\r\n fieldName: \"excelUploaderHeaderId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EXCEL_UPLOADER_DETAIL_LOOKUP_QUERY_ID\",\r\n fieldName: \"lookupQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EXCEL_UPLOADER_DETAIL_TABLE_FIELD\",\r\n fieldName: \"tableField\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"EXCEL_UPLOADER_DETAIL_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"EXCEL_UPLOADER_DETAIL_EDIT\" }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"EXCEL_UPLOADER_DETAIL_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default ExcelUploaderDetailGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst ExcelUploaderHeaderGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/exceluploaderheader/all\",\r\n deleteById: \"api/v1/admin/exceluploaderheader\",\r\n save: \"api/v1/admin/exceluploaderheader\",\r\n findById: \"api/v1/admin/exceluploaderheader\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EXCEL_UPLOADER_HEADER_UPLOADER_CONNECTION_ID\",\r\n fieldName: \"uploaderConnectionId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EXCEL_UPLOADER_HEADER_UPLOADER_DATABASE_NAME\",\r\n fieldName: \"uploaderDatabaseName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EXCEL_UPLOADER_HEADER_UPLOADER_NAME\",\r\n fieldName: \"uploaderName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EXCEL_UPLOADER_HEADER_UPLOADER_TABLE_NAME\",\r\n fieldName: \"uploaderTableName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"EXCEL_UPLOADER_HEADER_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"EXCEL_UPLOADER_HEADER_EDIT\" }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"EXCEL_UPLOADER_HEADER_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default ExcelUploaderHeaderGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst LookupGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/lookup/all\",\r\n deleteById: \"api/v1/admin/lookup\",\r\n save: \"api/v1/admin/lookup\",\r\n findById: \"api/v1/admin/lookup\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"LOOKUP_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"LOOKUP_LOOKUP_AR_DISPLAY\",\r\n fieldName: \"lookupArDisplay\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"LOOKUP_LOOKUP_EN_DISPLAY\",\r\n fieldName: \"lookupEnDisplay\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"LOOKUP_LOOKUP_TYPE\",\r\n fieldName: \"lookupType\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"LOOKUP_LOOKUP_VALUE\",\r\n fieldName: \"lookupValue\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"LOOKUP_ORG_CODE\",\r\n fieldName: \"orgCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"LOOKUP_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"LOOKUP_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"LOOKUP_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default LookupGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst MailAttachmentGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/mailattachment/all\",\r\n deleteById: \"api/v1/admin/mailattachment\",\r\n save: \"api/v1/admin/mailattachment\",\r\n findById: \"api/v1/admin/mailattachment\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_ATTACHMENT_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_ATTACHMENT_MAIL_TEMPLATE_ID\",\r\n fieldName: \"mailTemplateId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_ATTACHMENT_REPORT_ID\",\r\n fieldName: \"reportId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"MAIL_ATTACHMENT_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"MAIL_ATTACHMENT_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"MAIL_ATTACHMENT_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default MailAttachmentGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst MailBodyGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/mailbody/all\",\r\n deleteById: \"api/v1/admin/mailbody\",\r\n save: \"api/v1/admin/mailbody\",\r\n findById: \"api/v1/admin/mailbody\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_BODY_BODY_CONTENT\",\r\n fieldName: \"bodyContent\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_BODY_BODY_CONTENT_DATA_QUERY_ID\",\r\n fieldName: \"bodyContentDataQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_BODY_BODY_ORDER\",\r\n fieldName: \"bodyOrder\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_BODY_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_BODY_IS_MAIN\",\r\n fieldName: \"isMain\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_BODY_MAIL_TEMPLATE_ID\",\r\n fieldName: \"mailTemplateId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_BODY_PRINT_FOR_EACH_RECORD\",\r\n fieldName: \"printForEachRecord\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"MAIL_BODY_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"MAIL_BODY_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"MAIL_BODY_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default MailBodyGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst MailNotificationQueueGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/mailnotificationqueue/all\",\r\n deleteById: \"api/v1/admin/mailnotificationqueue\",\r\n save: \"api/v1/admin/mailnotificationqueue\",\r\n findById: \"api/v1/admin/mailnotificationqueue\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_NOTIFICATION_QUEUE_CUSTOM_MAIL_ATTACHED_REPORT_ID\",\r\n fieldName: \"customMailAttachedReportId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_NOTIFICATION_QUEUE_CUSTOM_MAIL_BODY\",\r\n fieldName: \"customMailBody\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_NOTIFICATION_QUEUE_CUSTOM_MAIL_SUBJECT\",\r\n fieldName: \"customMailSubject\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_NOTIFICATION_QUEUE_CUSTOM_RECIPIENTS\",\r\n fieldName: \"customRecipients\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_NOTIFICATION_QUEUE_IS_NOTIFIED\",\r\n fieldName: \"isNotified\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_NOTIFICATION_QUEUE_MAIL_PARAMETERS\",\r\n fieldName: \"mailParameters\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_NOTIFICATION_QUEUE_MAIL_TEMPLATE_ID\",\r\n fieldName: \"mailTemplateId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_NOTIFICATION_QUEUE_NOTIFICATION_MESSAGE\",\r\n fieldName: \"notificationMessage\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_NOTIFICATION_QUEUE_NOTIFICATION_TIME\",\r\n fieldName: \"notificationTime\",\r\n required: false,\r\n fieldType: \"datetime\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"MAIL_NOTIFICATION_QUEUE_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{\r\n isEnabled: true,\r\n authority: \"MAIL_NOTIFICATION_QUEUE_EDIT\",\r\n }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"MAIL_NOTIFICATION_QUEUE_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default MailNotificationQueueGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst MailRecipientGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/mailrecipient/all\",\r\n deleteById: \"api/v1/admin/mailrecipient\",\r\n save: \"api/v1/admin/mailrecipient\",\r\n findById: \"api/v1/admin/mailrecipient\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_RECIPIENT_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_RECIPIENT_MAIL_TEMPLATE_ID\",\r\n fieldName: \"mailTemplateId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_RECIPIENT_RECIPIENT_MAIL\",\r\n fieldName: \"recipientMail\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_RECIPIENT_RECIPIENT_TYPE\",\r\n fieldName: \"recipientType\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"MAIL_RECIPIENT_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"MAIL_RECIPIENT_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"MAIL_RECIPIENT_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default MailRecipientGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst MailTemplateGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/mailtemplate/all\",\r\n deleteById: \"api/v1/admin/mailtemplate\",\r\n save: \"api/v1/admin/mailtemplate\",\r\n findById: \"api/v1/admin/mailtemplate\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_TEMPLATE_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_TEMPLATE_MAIL_CC_DATA_QUERY_ID\",\r\n fieldName: \"mailCcDataQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_TEMPLATE_MAIL_SUBJECT\",\r\n fieldName: \"mailSubject\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_TEMPLATE_MAIL_TEMPLATE_CODE\",\r\n fieldName: \"mailTemplateCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_TEMPLATE_MAIL_TEMPLATE_NAME\",\r\n fieldName: \"mailTemplateName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_TEMPLATE_MAIL_TO_DATA_QUERY_ID\",\r\n fieldName: \"mailToDataQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_TEMPLATE_PERIOD_TYPE\",\r\n fieldName: \"periodType\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_TEMPLATE_PERIOD_VALUE\",\r\n fieldName: \"periodValue\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_TEMPLATE_PERIODICAL\",\r\n fieldName: \"periodical\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_TEMPLATE_START_SENDING_AT\",\r\n fieldName: \"startSendingAt\",\r\n required: false,\r\n fieldType: \"datetime\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_TEMPLATE_SUBJECT_DATA_QUERY_ID\",\r\n fieldName: \"subjectDataQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"MAIL_TEMPLATE_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"MAIL_TEMPLATE_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"MAIL_TEMPLATE_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default MailTemplateGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst NewTableGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/newtable/all\",\r\n deleteById: \"api/v1/admin/newtable\",\r\n save: \"api/v1/admin/newtable\",\r\n findById: \"api/v1/admin/newtable\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NEW_TABLE_TEST_DATE\",\r\n fieldName: \"testDate\",\r\n required: false,\r\n fieldType: \"date\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NEW_TABLE_TEST_LONG\",\r\n fieldName: \"testLong\",\r\n required: false,\r\n fieldType: \"number\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NEW_TABLE_TEST_DECIMAL\",\r\n fieldName: \"testDecimal\",\r\n required: false,\r\n fieldType: \"number\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"NEW_TABLE_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"NEW_TABLE_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"NEW_TABLE_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default NewTableGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst NotificationGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/notification/all\",\r\n deleteById: \"api/v1/admin/notification\",\r\n save: \"api/v1/admin/notification\",\r\n findById: \"api/v1/admin/notification\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_NOTIFICATION_ACTION_KEY\",\r\n fieldName: \"notificationActionKey\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_NOTIFICATION_ACTION_PAYLOAD\",\r\n fieldName: \"notificationActionPayload\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_NOTIFICATION_CODE\",\r\n fieldName: \"notificationCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_NOTIFICATION_ICON\",\r\n fieldName: \"notificationIcon\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_NOTIFICATION_QUERY_ID\",\r\n fieldName: \"notificationQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_NOTIFICATION_TEXT\",\r\n fieldName: \"notificationText\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_USERS_TO_NOTIFY_QUERY_ID\",\r\n fieldName: \"usersToNotifyQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"NOTIFICATION_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"NOTIFICATION_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"NOTIFICATION_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default NotificationGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst NotificationQueueGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/notificationqueue/all\",\r\n deleteById: \"api/v1/admin/notificationqueue\",\r\n save: \"api/v1/admin/notificationqueue\",\r\n findById: \"api/v1/admin/notificationqueue\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_QUEUE_CUSTOM_NOTIFICATION_ACTION_KEY\",\r\n fieldName: \"customNotificationActionKey\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_QUEUE_CUSTOM_NOTIFICATION_ACTION_PAYLOAD\",\r\n fieldName: \"customNotificationActionPayload\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_QUEUE_CUSTOM_NOTIFICATION_ICON\",\r\n fieldName: \"customNotificationIcon\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_QUEUE_CUSTOM_NOTIFICATION_TEXT\",\r\n fieldName: \"customNotificationText\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_QUEUE_IS_NOTIFIED\",\r\n fieldName: \"isNotified\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_QUEUE_NOTIFICATION_CODE\",\r\n fieldName: \"notificationCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_QUEUE_NOTIFICATION_PARAMS\",\r\n fieldName: \"notificationParams\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_QUEUE_NOTIFIED_TIME\",\r\n fieldName: \"notifiedTime\",\r\n required: false,\r\n fieldType: \"datetime\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_QUEUE_USERNAME\",\r\n fieldName: \"username\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"NOTIFICATION_QUEUE_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"NOTIFICATION_QUEUE_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"NOTIFICATION_QUEUE_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default NotificationQueueGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst OrganizationGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/organization/all\",\r\n deleteById: \"api/v1/admin/organization\",\r\n save: \"api/v1/admin/organization\",\r\n findById: \"api/v1/admin/organization\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_ORGANIZATION_CODE\",\r\n fieldName: \"organizationCode\",\r\n required: true,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_IS_ACTIVE\",\r\n fieldName: \"isActive\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_ORGANIZATION_NAME\",\r\n fieldName: \"organizationName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"organizationCode\"}\r\n gridTitle=\"ORGANIZATION_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"ORGANIZATION_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"ORGANIZATION_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default OrganizationGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst OrganizationApplicationGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/organizationapplication/all\",\r\n deleteById: \"api/v1/admin/organizationapplication\",\r\n save: \"api/v1/admin/organizationapplication\",\r\n findById: \"api/v1/admin/organizationapplication\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_APPLICATION_APPLICATION_CODE\",\r\n fieldName: \"applicationCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_APPLICATION_APPLICATION_DESCRIPTION\",\r\n fieldName: \"applicationDescription\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_APPLICATION_APPLICATION_NAME\",\r\n fieldName: \"applicationName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_APPLICATION_IS_ACTIVE\",\r\n fieldName: \"isActive\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"ORGANIZATION_APPLICATION_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{\r\n isEnabled: true,\r\n authority: \"ORGANIZATION_APPLICATION_EDIT\",\r\n }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"ORGANIZATION_APPLICATION_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default OrganizationApplicationGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst OrganizationRankGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/organizationrank/all\",\r\n deleteById: \"api/v1/admin/organizationrank\",\r\n save: \"api/v1/admin/organizationrank\",\r\n findById: \"api/v1/admin/organizationrank\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_RANK_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_RANK_ORGANIZATION_CODE\",\r\n fieldName: \"organizationCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_RANK_RANK_CODE\",\r\n fieldName: \"rankCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_RANK_RANK_NAME\",\r\n fieldName: \"rankName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_RANK_RANK_ORDER\",\r\n fieldName: \"rankOrder\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"ORGANIZATION_RANK_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"ORGANIZATION_RANK_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"ORGANIZATION_RANK_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default OrganizationRankGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst OrganizationUnitGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/organizationunit/all\",\r\n deleteById: \"api/v1/admin/organizationunit\",\r\n save: \"api/v1/admin/organizationunit\",\r\n findById: \"api/v1/admin/organizationunit\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_UNIT_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_UNIT_ORGANIZATION_CODE\",\r\n fieldName: \"organizationCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_UNIT_ORGANIZATION_UNIT_AR_NAME\",\r\n fieldName: \"organizationUnitArName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_UNIT_ORGANIZATION_UNIT_EN_NAME\",\r\n fieldName: \"organizationUnitEnName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_UNIT_ORGANIZATION_UNIT_PARENT_ID\",\r\n fieldName: \"organizationUnitParentId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"ORGANIZATION_UNIT_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"ORGANIZATION_UNIT_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"ORGANIZATION_UNIT_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default OrganizationUnitGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst OrganizationUserGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/organizationuser/all\",\r\n deleteById: \"api/v1/admin/organizationuser\",\r\n save: \"api/v1/admin/organizationuser\",\r\n findById: \"api/v1/admin/organizationuser\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_USER_IS_ACTIVE\",\r\n fieldName: \"isActive\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_USER_IS_DEFAULT\",\r\n fieldName: \"isDefault\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_USER_ORGANIZATION_CODE\",\r\n fieldName: \"organizationCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_USER_USERNAME\",\r\n fieldName: \"username\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"ORGANIZATION_USER_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"ORGANIZATION_USER_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"ORGANIZATION_USER_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default OrganizationUserGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst OrganizationUserRoleGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/organizationuserrole/all\",\r\n deleteById: \"api/v1/admin/organizationuserrole\",\r\n save: \"api/v1/admin/organizationuserrole\",\r\n findById: \"api/v1/admin/organizationuserrole\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_USER_ROLE_END_DATE\",\r\n fieldName: \"endDate\",\r\n required: false,\r\n fieldType: \"datetime\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_USER_ROLE_IS_ACTIVE\",\r\n fieldName: \"isActive\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_USER_ROLE_ORGANIZATION_CODE\",\r\n fieldName: \"organizationCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_USER_ROLE_ROLE_ID\",\r\n fieldName: \"roleId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_USER_ROLE_START_DATE\",\r\n fieldName: \"startDate\",\r\n required: false,\r\n fieldType: \"datetime\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_USER_ROLE_USERNAME\",\r\n fieldName: \"username\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"ORGANIZATION_USER_ROLE_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"ORGANIZATION_USER_ROLE_EDIT\" }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"ORGANIZATION_USER_ROLE_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default OrganizationUserRoleGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst ReportGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/report/all\",\r\n deleteById: \"api/v1/admin/report\",\r\n save: \"api/v1/admin/report\",\r\n findById: \"api/v1/admin/report\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_DATASOURCE_CON_ID\",\r\n fieldName: \"datasourceConId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_REPORT_BLUE_PRINT_ID\",\r\n fieldName: \"reportBluePrintId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_REPORT_CATEGORY\",\r\n fieldName: \"reportCategory\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_REPORT_CODE\",\r\n fieldName: \"reportCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_REPORT_EXCEL_DATA_QUERY_ID\",\r\n fieldName: \"reportExcelDataQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_REPORT_EXPORT_NAME\",\r\n fieldName: \"reportExportName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_REPORT_JASPER_NAME\",\r\n fieldName: \"reportJasperName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_REPORT_JASPER_PATH\",\r\n fieldName: \"reportJasperPath\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_REPORT_MENU_CODE\",\r\n fieldName: \"reportMenuCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_REPORT_NAME\",\r\n fieldName: \"reportName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_REPORT_TYPE\",\r\n fieldName: \"reportType\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_USE_SYS_DATASOURCE\",\r\n fieldName: \"useSysDatasource\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"REPORT_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"REPORT_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"REPORT_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default ReportGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst ReportParameterGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/reportparameter/all\",\r\n deleteById: \"api/v1/admin/reportparameter\",\r\n save: \"api/v1/admin/reportparameter\",\r\n findById: \"api/v1/admin/reportparameter\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_PARAMETER_DEFAULT_VALUE\",\r\n fieldName: \"defaultValue\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_PARAMETER_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_PARAMETER_ENTITY_PARAMETER_ID\",\r\n fieldName: \"entityParameterId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_PARAMETER_HIDDEN\",\r\n fieldName: \"hidden\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_PARAMETER_MANDATORY\",\r\n fieldName: \"mandatory\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_PARAMETER_REPORT_ID\",\r\n fieldName: \"reportId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"REPORT_PARAMETER_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"REPORT_PARAMETER_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"REPORT_PARAMETER_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default ReportParameterGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\nimport { useAxios, useWindow } from \"../../hooks\";\r\nimport RoleAuthoritiesForm from \"./RoleAuthoritiesForm\";\r\n\r\nconst RoleGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n commonStoreKey: \"SystemRoles\",\r\n deleteById: \"api/v1/admin/role\",\r\n save: \"api/v1/admin/role\",\r\n findById: \"api/v1/admin/role\",\r\n setData: setData,\r\n });\r\n const [selectedRole, setSelectedRole] = useState<any>(null);\r\n const { handleGetRequest } = useAxios();\r\n const [selectedRoleAuthorities, setSelectedRoleAuthorities] = useState<any>(\r\n []\r\n );\r\n const [\r\n selectedRoleAvailableAuthorities,\r\n setSelectedRoleAvailableAuthorities,\r\n ] = useState<any>([]);\r\n const {\r\n Window: RoleAuthoritiesWindow,\r\n setWindowState: setRoleAuthorirtiesWindowOpen,\r\n } = useWindow({\r\n width: \"50%\",\r\n windowIcon: \"key\",\r\n windowTitle: \"Role Authorities\",\r\n });\r\n const loadRoleAuthorities = async (data: any) => {\r\n await handleGetRequest({\r\n endPointURI: \"api/v1/admin/role/authorities\",\r\n showMask: true,\r\n parameters: {\r\n roleId: data.id,\r\n },\r\n successCallBkFn: (response: any) => {\r\n setRoleAuthorirtiesWindowOpen(true);\r\n setSelectedRoleAuthorities(response.data.selectedAuthorities);\r\n setSelectedRoleAvailableAuthorities(response.data.availableAuthorities);\r\n },\r\n });\r\n };\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ROLE_ROLE_NAME\",\r\n fieldName: \"roleName\",\r\n required: true,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ROLE_DESCRIPTION\",\r\n fieldName: \"description\",\r\n required: true,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ROLE_IS_ACTIVE\",\r\n fieldName: \"isActive\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ROLE_ORGANIZATION_APPLICATION_ID\",\r\n fieldName: \"organizationApplicationId\",\r\n required: false,\r\n fieldType: \"text\",\r\n gridProps: {\r\n hidden: true,\r\n },\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <>\r\n <RoleAuthoritiesWindow>\r\n <RoleAuthoritiesForm\r\n roleId={selectedRole?.id}\r\n availableAuthorities={selectedRoleAvailableAuthorities}\r\n currentRoleAuthorities={selectedRoleAuthorities}\r\n closeModalFn={() => {\r\n setRoleAuthorirtiesWindowOpen(false);\r\n }}\r\n />\r\n </RoleAuthoritiesWindow>\r\n <TemplateGrid\r\n rowActions={[\r\n {\r\n icon: \"key\",\r\n label: \"authorities\",\r\n actionFn: async (data) => {\r\n setSelectedRole(data);\r\n loadRoleAuthorities(data);\r\n },\r\n },\r\n ]}\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\", reloadAfterSave: true }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"ROLE_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"ROLE_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"ROLE_DELETE\" }}\r\n />\r\n </>\r\n );\r\n};\r\n\r\nexport default RoleGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst RoleAuthorityGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/roleauthority/all\",\r\n deleteById: \"api/v1/admin/roleauthority\",\r\n save: \"api/v1/admin/roleauthority\",\r\n findById: \"api/v1/admin/roleauthority\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ROLE_AUTHORITY_AUTHORITY_ID\",\r\n fieldName: \"authorityId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ROLE_AUTHORITY_IS_ACTIVE\",\r\n fieldName: \"isActive\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ROLE_AUTHORITY_ROLE_ID\",\r\n fieldName: \"roleId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"ROLE_AUTHORITY_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"ROLE_AUTHORITY_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"ROLE_AUTHORITY_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default RoleAuthorityGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst UserAccountGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/useraccount/all\",\r\n deleteById: \"api/v1/admin/useraccount\",\r\n save: \"api/v1/admin/useraccount\",\r\n findById: \"api/v1/admin/useraccount\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_ACCOUNT_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_ACCOUNT_PASSWORD\",\r\n fieldName: \"password\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_ACCOUNT_USERNAME\",\r\n fieldName: \"username\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"USER_ACCOUNT_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"USER_ACCOUNT_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"USER_ACCOUNT_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default UserAccountGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst UserRequestGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/userrequest/all\",\r\n deleteById: \"api/v1/admin/userrequest\",\r\n save: \"api/v1/admin/userrequest\",\r\n findById: \"api/v1/admin/userrequest\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_REQUEST_IS_NOTIFIED\",\r\n fieldName: \"isNotified\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_REQUEST_MAILS_TO_NOTIFY\",\r\n fieldName: \"mailsToNotify\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_REQUEST_NOTIFICATION_MESSAGE\",\r\n fieldName: \"notificationMessage\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_REQUEST_NOTIFICATION_TIME\",\r\n fieldName: \"notificationTime\",\r\n required: false,\r\n fieldType: \"datetime\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_REQUEST_NOTIFICATION_TYPE\",\r\n fieldName: \"notificationType\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_REQUEST_NOTIFY_USER\",\r\n fieldName: \"notifyUser\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_REQUEST_REPORT_CODE\",\r\n fieldName: \"reportCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_REQUEST_REPORT_PARAMETERS\",\r\n fieldName: \"reportParameters\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_REQUEST_REQUEST_TYPE\",\r\n fieldName: \"requestType\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_REQUEST_STATUS\",\r\n fieldName: \"status\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_REQUEST_STATUS_MESSAGE\",\r\n fieldName: \"statusMessage\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"USER_REQUEST_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"USER_REQUEST_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"USER_REQUEST_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default UserRequestGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst WidgetGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/widget/all\",\r\n deleteById: \"api/v1/admin/widget\",\r\n save: \"api/v1/admin/widget\",\r\n findById: \"api/v1/admin/widget\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_DATA_QUERY_ID\",\r\n fieldName: \"dataQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_HEIGHT\",\r\n fieldName: \"height\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_HORIZONTAL_AXIS_FIELD\",\r\n fieldName: \"horizontalAxisField\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_HORIZONTAL_AXIS_LABEL\",\r\n fieldName: \"horizontalAxisLabel\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_ICON\",\r\n fieldName: \"icon\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_SERIES_KEYS\",\r\n fieldName: \"seriesKeys\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_TITLE\",\r\n fieldName: \"title\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_VERTICAL_AXIS_FIELD\",\r\n fieldName: \"verticalAxisField\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_VERTICAL_AXIS_LABEL\",\r\n fieldName: \"verticalAxisLabel\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_WIDGET_DESCRIPTION\",\r\n fieldName: \"widgetDescription\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_WIDGET_NAME\",\r\n fieldName: \"widgetName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_WIDGET_TYPE\",\r\n fieldName: \"widgetType\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_WIDTH\",\r\n fieldName: \"width\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"WIDGET_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"WIDGET_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"WIDGET_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default WidgetGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst WorkflowDocumentGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/workflowdocument/all\",\r\n deleteById: \"api/v1/admin/workflowdocument\",\r\n save: \"api/v1/admin/workflowdocument\",\r\n findById: \"api/v1/admin/workflowdocument\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_APP_NOTIFICATION_ICON\",\r\n fieldName: \"appNotificationIcon\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_APP_NOTIFICATION_STYLE\",\r\n fieldName: \"appNotificationStyle\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_APP_VIEW_ROUTE\",\r\n fieldName: \"appViewRoute\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_DOCUMENT_CODE\",\r\n fieldName: \"documentCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_DOCUMENT_CON_ID\",\r\n fieldName: \"documentConId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_DOCUMENT_DATABASE_NAME\",\r\n fieldName: \"documentDatabaseName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_DOCUMENT_DATABASE_TABLE\",\r\n fieldName: \"documentDatabaseTable\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_DOCUMENT_ID_FIELD\",\r\n fieldName: \"documentIdField\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_DOCUMENT_NAME\",\r\n fieldName: \"documentName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_DOCUMENT_NUMBER_FIELD\",\r\n fieldName: \"documentNumberField\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_DOCUMENT_REPORT_ID\",\r\n fieldName: \"documentReportId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_DOCUMENT_STATUS_FIELD\",\r\n fieldName: \"documentStatusField\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_MAIL_APPROVAL_ALLOWED\",\r\n fieldName: \"mailApprovalAllowed\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ORG_CODE\",\r\n fieldName: \"orgCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_USE_SYSTEM_CON\",\r\n fieldName: \"useSystemCon\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"WORKFLOW_DOCUMENT_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"WORKFLOW_DOCUMENT_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"WORKFLOW_DOCUMENT_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default WorkflowDocumentGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst WorkflowDocumentActionGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/workflowdocumentaction/all\",\r\n deleteById: \"api/v1/admin/workflowdocumentaction\",\r\n save: \"api/v1/admin/workflowdocumentaction\",\r\n findById: \"api/v1/admin/workflowdocumentaction\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_DOCUMENT_ACTION_CODE\",\r\n fieldName: \"documentActionCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_DOCUMENT_ACTION_NAME\",\r\n fieldName: \"documentActionName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_NEXT_DOCUMENT_STATUS_ID\",\r\n fieldName: \"nextDocumentStatusId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_POST_ACTION_ENDPOINT\",\r\n fieldName: \"postActionEndpoint\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_PRE_ACTION_ENDPOINT\",\r\n fieldName: \"preActionEndpoint\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_REQUIRE_COMMENT\",\r\n fieldName: \"requireComment\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_WORKFLOW_DOCUMENT_ID\",\r\n fieldName: \"workflowDocumentId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"WORKFLOW_DOCUMENT_ACTION_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{\r\n isEnabled: true,\r\n authority: \"WORKFLOW_DOCUMENT_ACTION_EDIT\",\r\n }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"WORKFLOW_DOCUMENT_ACTION_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default WorkflowDocumentActionGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst WorkflowDocumentActionHistoryGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/workflowdocumentactionhistory/all\",\r\n deleteById: \"api/v1/admin/workflowdocumentactionhistory\",\r\n save: \"api/v1/admin/workflowdocumentactionhistory\",\r\n findById: \"api/v1/admin/workflowdocumentactionhistory\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_HISTORY_ACTION_BY\",\r\n fieldName: \"actionBy\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_HISTORY_ACTION_COMMENT\",\r\n fieldName: \"actionComment\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_HISTORY_ACTION_METHOD\",\r\n fieldName: \"actionMethod\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_HISTORY_ACTION_TIME\",\r\n fieldName: \"actionTime\",\r\n required: false,\r\n fieldType: \"datetime\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_HISTORY_DOCUMENT_ACTION_ID\",\r\n fieldName: \"documentActionId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_HISTORY_DOCUMENT_REF_ID\",\r\n fieldName: \"documentRefId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_HISTORY_WORKFLOW_DOCUMENT_ID\",\r\n fieldName: \"workflowDocumentId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"WORKFLOW_DOCUMENT_ACTION_HISTORY_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{\r\n isEnabled: true,\r\n authority: \"WORKFLOW_DOCUMENT_ACTION_HISTORY_EDIT\",\r\n }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"WORKFLOW_DOCUMENT_ACTION_HISTORY_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default WorkflowDocumentActionHistoryGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst WorkflowDocumentActionMailGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/workflowdocumentactionmail/all\",\r\n deleteById: \"api/v1/admin/workflowdocumentactionmail\",\r\n save: \"api/v1/admin/workflowdocumentactionmail\",\r\n findById: \"api/v1/admin/workflowdocumentactionmail\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_MAIL_DOCUMENT_ACTION_ID\",\r\n fieldName: \"documentActionId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_MAIL_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_MAIL_MAIL_TEMPLATE_ID\",\r\n fieldName: \"mailTemplateId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"WORKFLOW_DOCUMENT_ACTION_MAIL_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{\r\n isEnabled: true,\r\n authority: \"WORKFLOW_DOCUMENT_ACTION_MAIL_EDIT\",\r\n }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"WORKFLOW_DOCUMENT_ACTION_MAIL_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default WorkflowDocumentActionMailGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst WorkflowDocumentMailLogGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/workflowdocumentmaillog/all\",\r\n deleteById: \"api/v1/admin/workflowdocumentmaillog\",\r\n save: \"api/v1/admin/workflowdocumentmaillog\",\r\n findById: \"api/v1/admin/workflowdocumentmaillog\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_MAIL_LOG_GRAPH_API_MSG_ID\",\r\n fieldName: \"graphApiMsgId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_MAIL_LOG_IS_PROCESSED\",\r\n fieldName: \"isProcessed\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_MAIL_LOG_MAIL_ACTION_CODE\",\r\n fieldName: \"mailActionCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_MAIL_LOG_MAIL_BODY_CONTENT\",\r\n fieldName: \"mailBodyContent\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_MAIL_LOG_MAIL_FROM\",\r\n fieldName: \"mailFrom\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_MAIL_LOG_MAIL_SUBJECT\",\r\n fieldName: \"mailSubject\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_MAIL_LOG_PROCESS_MESSAGE\",\r\n fieldName: \"processMessage\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_MAIL_LOG_PROCESS_TIME\",\r\n fieldName: \"processTime\",\r\n required: false,\r\n fieldType: \"datetime\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_MAIL_LOG_REF_DOC_ID\",\r\n fieldName: \"refDocId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_MAIL_LOG_WORKFLOW_DOCUMENT_ID\",\r\n fieldName: \"workflowDocumentId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"WORKFLOW_DOCUMENT_MAIL_LOG_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{\r\n isEnabled: true,\r\n authority: \"WORKFLOW_DOCUMENT_MAIL_LOG_EDIT\",\r\n }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"WORKFLOW_DOCUMENT_MAIL_LOG_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default WorkflowDocumentMailLogGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst WorkflowDocumentStatusGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/workflowdocumentstatus/all\",\r\n deleteById: \"api/v1/admin/workflowdocumentstatus\",\r\n save: \"api/v1/admin/workflowdocumentstatus\",\r\n findById: \"api/v1/admin/workflowdocumentstatus\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_STATUS_DOCUMENT_STATUS_CODE\",\r\n fieldName: \"documentStatusCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_STATUS_DOCUMENT_STATUS_NAME\",\r\n fieldName: \"documentStatusName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_STATUS_DOCUMENT_STATUS_ORDER\",\r\n fieldName: \"documentStatusOrder\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_STATUS_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_STATUS_IS_ZERO_STATE\",\r\n fieldName: \"isZeroState\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_STATUS_NEXT_ACTION_TAKERS_QUERY_ID\",\r\n fieldName: \"nextActionTakersQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_STATUS_NEXT_ACTIONS_QUERY_ID\",\r\n fieldName: \"nextActionsQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_STATUS_WORKFLOW_DOCUMENT_ID\",\r\n fieldName: \"workflowDocumentId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"WORKFLOW_DOCUMENT_STATUS_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{\r\n isEnabled: true,\r\n authority: \"WORKFLOW_DOCUMENT_STATUS_EDIT\",\r\n }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"WORKFLOW_DOCUMENT_STATUS_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default WorkflowDocumentStatusGrid;\r\n","import { Box } from \"@mui/material\";\r\nimport { useSelector } from \"react-redux\";\r\nimport { CacheProvider } from \"@emotion/react\";\r\nimport { Route, Routes } from \"react-router-dom\";\r\nimport { RootState } from \"../redux/store\";\r\nimport { cacheLtr, cacheRtl } from \"../components/common/LayoutHandlers\";\r\nimport { SYSTEM_ROUTES } from \"../routes\";\r\nimport { SystemRoute } from \"../routes/types\";\r\n\r\nconst MainContent: React.FC = () => {\r\n const AppLayoutState = useSelector((state: RootState) => state.AppLayout);\r\n const AppInfo = useSelector((state: RootState) => state.AppInfo.value);\r\n const businessRoutes = useSelector(\r\n (state: RootState) => state.AppInfo.value.businessRoutes\r\n );\r\n return (\r\n <CacheProvider\r\n value={AppLayoutState.appDirection === \"ltr\" ? cacheLtr : cacheRtl}\r\n >\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n // alignItems: \"center\",\r\n justifyContent: \"flex-start\",\r\n flex: 1,\r\n overflow: \"hidden\",\r\n padding: 3,\r\n }}\r\n >\r\n <Routes>\r\n {AppInfo.enableAdministrationModule\r\n ? SYSTEM_ROUTES.map((route: SystemRoute, index) => {\r\n return (\r\n <Route\r\n key={\"adm\" + index}\r\n path={route.path}\r\n Component={route.component}\r\n />\r\n );\r\n })\r\n : null}\r\n {businessRoutes.map((route: SystemRoute, index) => {\r\n return (\r\n <Route\r\n key={\"bs\" + index}\r\n path={route.path}\r\n Component={route.component}\r\n />\r\n );\r\n })}\r\n </Routes>\r\n </Box>\r\n </CacheProvider>\r\n );\r\n};\r\n\r\nexport default MainContent;\r\n","import { styled } from \"@mui/material/styles\";\r\nimport { grey } from \"@mui/material/colors\";\r\nimport SwipeableDrawer from \"@mui/material/SwipeableDrawer\";\r\nimport { useDispatch, useSelector } from \"react-redux\";\r\nimport { Box, Typography } from \"@mui/material\";\r\nimport { RootState } from \"../redux/store\";\r\nimport { AppLayoutActions } from \"../redux/features/common/AppLayoutSlice\";\r\nimport NavigationTree from \"./NavigationTree\";\r\n\r\nconst drawerBleeding = 56;\r\n\r\ninterface Props {\r\n /**\r\n * Injected by the documentation to work in an iframe.\r\n * You won't need it on your project.\r\n */\r\n window?: () => Window;\r\n}\r\n\r\nconst Puller = styled(\"div\")(({ theme }) => ({\r\n width: 30,\r\n height: 6,\r\n margin: 10,\r\n backgroundColor: grey[300],\r\n borderRadius: 3,\r\n // position: \"absolute\",\r\n top: 8,\r\n // left: \"calc(50% - 15px)\",\r\n ...theme.applyStyles(\"dark\", {\r\n backgroundColor: grey[900],\r\n }),\r\n}));\r\n\r\nexport default function MobileDrawer(props: Props) {\r\n const { window } = props;\r\n const AppLayout = useSelector((state: RootState) => state.AppLayout);\r\n const AppInfo = useSelector((state: RootState) => state.AppInfo.value);\r\n const dispatch = useDispatch();\r\n const toggleDrawer = (newState: boolean) => {\r\n dispatch(AppLayoutActions.setSideBarState(newState));\r\n };\r\n // This is used only for the example\r\n const container =\r\n window !== undefined ? () => window().document.body : undefined;\r\n\r\n return (\r\n <SwipeableDrawer\r\n container={container}\r\n anchor=\"bottom\"\r\n open={AppLayout.sideBarOpened}\r\n onClose={() => {\r\n toggleDrawer(false);\r\n }}\r\n onOpen={() => {\r\n toggleDrawer(true);\r\n }}\r\n swipeAreaWidth={drawerBleeding}\r\n disableSwipeToOpen={false}\r\n ModalProps={{\r\n keepMounted: true,\r\n }}\r\n >\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n alignItems: \"center\",\r\n height: \"100%\",\r\n overflow: \"hidden\",\r\n }}\r\n >\r\n <Puller />\r\n <Box\r\n sx={{\r\n flexGrow: 1,\r\n display: \"flex\",\r\n justifyContent: \"center\",\r\n width: \"99%\",\r\n overflowY: \"auto\",\r\n }}\r\n >\r\n <NavigationTree />\r\n </Box>\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"space-around\",\r\n marginTop: 1,\r\n width: \"100%\",\r\n }}\r\n >\r\n <Typography sx={{ fontSize: 12 }} color=\"textDisabled\">\r\n {AppInfo.appName}\r\n </Typography>\r\n <Typography sx={{ fontSize: 12 }} color=\"textDisabled\">\r\n V.{AppInfo.appVersion}\r\n </Typography>\r\n </Box>\r\n </Box>\r\n </SwipeableDrawer>\r\n );\r\n}\r\n","import { useSelector } from \"react-redux\";\r\nimport { RootState } from \"../../redux/store\";\r\nimport { Backdrop, CircularProgress } from \"@mui/material\";\r\n\r\nconst LoadingMask: React.FC = () => {\r\n const loadingMask = useSelector(\r\n (state: RootState) => state.loadingMask.value\r\n );\r\n return (\r\n <Backdrop\r\n sx={{ color: \"#fff\", zIndex: (theme) => theme.zIndex.drawer + 1 }}\r\n open={loadingMask.isOpened}\r\n >\r\n <CircularProgress color=\"inherit\" />\r\n </Backdrop>\r\n );\r\n};\r\n\r\nexport default LoadingMask;\r\n","import {\r\n Box,\r\n Button,\r\n CircularProgress,\r\n createTheme,\r\n Paper,\r\n TextField,\r\n Typography,\r\n} from \"@mui/material\";\r\nimport { useDispatch, useSelector } from \"react-redux\";\r\nimport { ThemeProvider } from \"@emotion/react\";\r\nimport { useEffect, useState } from \"react\";\r\nimport axios from \"axios\";\r\nimport { toast } from \"react-toastify\";\r\nimport { RootState } from \"../../redux/store\";\r\nimport { UserSessionActions } from \"../../redux/features/common/UserSessionSlice\";\r\nimport { DARK_THEME_INITIAL_MAIN_COLOR, DARK_THEME_INITIAL_SECANDARY_COLOR } from \"../../util\";\r\n\r\nconst Login: React.FC = () => {\r\n const appInfo = useSelector((state: RootState) => state.AppInfo.value);\r\n const [username, setUsername] = useState(\"\");\r\n const [password, setPassword] = useState(\"\");\r\n const [isLoginInProcess, setIsLoginInProcess] = useState(false);\r\n const UserSessionState = useSelector(\r\n (state: RootState) => state.UserSession.value\r\n );\r\n const dispatch = useDispatch();\r\n const handleLogin = async () => {\r\n if (username == null || username == \"\") {\r\n toast.error(\"username is required to proceed\");\r\n return;\r\n }\r\n if (password == null || password == \"\") {\r\n toast.error(\"password is required to proceed\");\r\n return;\r\n }\r\n setIsLoginInProcess(true);\r\n let response: any = null;\r\n try {\r\n response = await axios.post(\r\n `${appInfo.apiBaseUrl}/api/auth/login`,\r\n {\r\n username,\r\n password,\r\n },\r\n {\r\n withCredentials: true,\r\n }\r\n );\r\n if (response.data != null && response.data !== \"\") {\r\n setIsLoginInProcess(false);\r\n const UserSession = {\r\n isAuthenticated: true,\r\n authorities: response.data.authorities,\r\n userProfile: response.data,\r\n };\r\n dispatch(UserSessionActions.setAuthenticated(UserSession));\r\n }\r\n } catch (e: any) {\r\n setIsLoginInProcess(false);\r\n toast.error(\r\n e?.response?.data ||\r\n \"failed to authenticate, contact your administrator\"\r\n );\r\n }\r\n };\r\n const userSession = useSelector(\r\n (state: RootState) => state.UserSession.value\r\n );\r\n const loginTheme = createTheme({\r\n components: {\r\n MuiCssBaseline: {\r\n styleOverrides: `\r\n /* Custom Scrollbar */\r\n * {\r\n scrollbar-width: thin;\r\n scrollbar-color: ${\r\n appInfo.appTheme?.dark?.primaryColor ||\r\n DARK_THEME_INITIAL_MAIN_COLOR\r\n } #121212;\r\n }\r\n \r\n /* Webkit Browsers */\r\n *::-webkit-scrollbar {\r\n width: 12px;\r\n height: 10px;\r\n } \r\n `,\r\n },\r\n },\r\n palette: {\r\n mode: \"dark\",\r\n primary: {\r\n main:\r\n appInfo.appTheme?.dark?.primaryColor || DARK_THEME_INITIAL_MAIN_COLOR,\r\n },\r\n secondary: {\r\n main:\r\n appInfo.appTheme?.dark?.secondaryColor ||\r\n DARK_THEME_INITIAL_SECANDARY_COLOR,\r\n },\r\n },\r\n });\r\n const checkUserSession = async () => {\r\n if (appInfo?.apiBaseUrl) {\r\n if (userSession.isAuthenticated == null) {\r\n try {\r\n let response = await axios.get(\r\n `${appInfo.apiBaseUrl}/api/auth/userInfo`,\r\n {\r\n withCredentials: true,\r\n }\r\n );\r\n if (response != null && response.data != null) {\r\n const UserSession = {\r\n isAuthenticated: true,\r\n authorities: response.data.authorities,\r\n userProfile: response.data,\r\n };\r\n dispatch(UserSessionActions.setAuthenticated(UserSession));\r\n } else {\r\n dispatch(UserSessionActions.setUnAuthenticated());\r\n }\r\n } catch (error) {\r\n dispatch(UserSessionActions.setUnAuthenticated());\r\n }\r\n }\r\n }\r\n };\r\n useEffect(() => {\r\n checkUserSession();\r\n }, [appInfo]);\r\n return (\r\n <ThemeProvider theme={loginTheme}>\r\n <Paper\r\n sx={{\r\n display: \"flex\",\r\n height: \"100vh\",\r\n width: \"100%\",\r\n borderRadius: 0,\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n }}\r\n >\r\n {UserSessionState.isAuthenticated == false ? (\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n }}\r\n >\r\n <img src={appInfo?.appLogo} width={150} height={150} />\r\n <Typography sx={{ m: 1 }} variant=\"h4\" color=\"textSecondary\">\r\n {appInfo?.appName}\r\n </Typography>\r\n <Typography\r\n sx={{\r\n paddingRight: 1,\r\n width: \"100%\",\r\n textAlign: \"right\",\r\n fontSize: 10,\r\n }}\r\n variant=\"caption\"\r\n color=\"textSecondary\"\r\n >\r\n V.{appInfo.appVersion}\r\n </Typography>\r\n <TextField\r\n label=\"username\"\r\n sx={{ width: 300, m: 1 }}\r\n value={username}\r\n onChange={(event) => {\r\n setUsername(event.target.value);\r\n }}\r\n onKeyDown={(event) => {\r\n if (event.key === \"Enter\") {\r\n handleLogin();\r\n }\r\n }}\r\n />\r\n <TextField\r\n label=\"password\"\r\n sx={{ width: 300, m: 1 }}\r\n value={password}\r\n type=\"password\"\r\n onChange={(event) => {\r\n setPassword(event.target.value);\r\n }}\r\n onKeyDown={(event) => {\r\n if (event.key === \"Enter\") {\r\n handleLogin();\r\n }\r\n }}\r\n />\r\n <Button\r\n loading={isLoginInProcess}\r\n onClick={handleLogin}\r\n variant=\"contained\"\r\n color=\"primary\"\r\n sx={{ m: 1 }}\r\n >\r\n login\r\n </Button>\r\n </Box>\r\n ) : (\r\n <>\r\n <CircularProgress sx={{ marginRight: 1 }} />\r\n <div>You will be redirected shortly ... please wait</div>\r\n </>\r\n )}\r\n </Paper>\r\n </ThemeProvider>\r\n );\r\n};\r\n\r\nexport default Login;\r\n","import { styled, useTheme } from \"@mui/material/styles\";\r\nimport CssBaseline from \"@mui/material/CssBaseline\";\r\nimport { useDispatch, useSelector } from \"react-redux\";\r\nimport TopBar from \"./TopBar\";\r\nimport { DrawerHeader } from \"./DrawerHeader\";\r\nimport SideBar from \"./SideBar\";\r\nimport MainContent from \"./MainContent\";\r\nimport { BrowserRouter } from \"react-router-dom\";\r\nimport MobileDrawer from \"./MobileDrawer\";\r\nimport { ToastContainer } from \"react-toastify\";\r\nimport { useEffect, useState } from \"react\";\r\nimport useLoadingMask from \"../hooks/useLoadingMask\";\r\nimport { useIsMobile } from \"../hooks/UseMobile\";\r\nimport useSession from \"../hooks/UseSession\";\r\nimport useAxios from \"../hooks/useAxios\";\r\nimport { DRAWER_WIDTH } from \"../redux/features/common/AppLayoutSlice\";\r\nimport { UserSessionProps } from \"../redux/features/common/UserSessionSlice\";\r\nimport LoadingMask from \"../components/common/LoadingMask\";\r\nimport Login from \"../components/common/Login\";\r\nimport { setStoreData } from \"../redux/features/common/CommonStoreSlice\";\r\n\r\nconst Main = styled(\"main\", {\r\n shouldForwardProp: (prop) => prop !== \"open\",\r\n})<{\r\n open?: boolean;\r\n}>(({ theme: any, open }) => {\r\n const AppLayout = useSelector((state: any) => state.AppLayout);\r\n const dispatch = useDispatch();\r\n const { show, hide } = useLoadingMask();\r\n const commonStores = useSelector((state: any) => state.commonStores);\r\n const [isAutoLoadLoaded, setAutoLoadLoaded] = useState<boolean>(false);\r\n const theme = useTheme();\r\n const isMobile = useIsMobile();\r\n const { isUserAuthorized } = useSession();\r\n\r\n // loadCommonStores\r\n const { handleGetRequest } = useAxios();\r\n const loadCommonStores = async () => {\r\n debugger;\r\n if (!isAutoLoadLoaded) { \r\n setAutoLoadLoaded(true);\r\n show(\"Loading ... please wait\");\r\n const stores = commonStores.stores;\r\n const storeKeys = commonStores.storeKeys;\r\n for (let storeKey of storeKeys) {\r\n if (\r\n (stores[storeKey]?.authority === undefined ||\r\n stores[storeKey]?.authority === null ||\r\n isUserAuthorized(stores[storeKey]?.authority)) &&\r\n stores[storeKey]?.url != \"\" &&\r\n stores[storeKey].autoLoad === true\r\n ) {\r\n await handleGetRequest({\r\n endPointURI: stores[storeKey].url,\r\n showMask: false,\r\n successCallBkFn: (response) => {\r\n dispatch(setStoreData({ storeKey, data: response.data }));\r\n },\r\n failureCallBkFn: () => {\r\n dispatch(setStoreData({ storeKey, data: [] }));\r\n },\r\n });\r\n }\r\n }\r\n hide();\r\n }\r\n };\r\n\r\n useEffect(() => {\r\n if (commonStores.storeKeys) {\r\n loadCommonStores();\r\n }\r\n }, [commonStores.storeKeys]);\r\n\r\n return {\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n overflow: \"hidden\",\r\n flexGrow: 1,\r\n width: !isMobile && open ? `calc(100% - ${DRAWER_WIDTH}px)` : \"100%\",\r\n direction: AppLayout.appDirection,\r\n justifyContent: \"flex-start\",\r\n transition:\r\n open === true\r\n ? theme.transitions.create([\"margin\", \"width\"], {\r\n easing: theme.transitions.easing.easeOut,\r\n duration: theme.transitions.duration.enteringScreen,\r\n })\r\n : theme.transitions.create([\"margin\", \"width\"], {\r\n easing: theme.transitions.easing.sharp,\r\n duration: theme.transitions.duration.leavingScreen,\r\n }),\r\n marginLeft:\r\n !isMobile && AppLayout.appDirection === \"ltr\" && open === true\r\n ? DRAWER_WIDTH + \"px\"\r\n : 0,\r\n marginRight:\r\n !isMobile && AppLayout.appDirection === \"rtl\" && open === true\r\n ? DRAWER_WIDTH + \"px\"\r\n : 0,\r\n };\r\n});\r\n\r\nexport default function Layout() {\r\n const AppLayoutState = useSelector((state: any) => state.AppLayout);\r\n const isMobile = useIsMobile();\r\n const UserSession: UserSessionProps = useSelector(\r\n (state: any) => state.UserSession\r\n );\r\n return (\r\n <BrowserRouter>\r\n <ToastContainer draggable={true} position=\"bottom-center\" />\r\n <LoadingMask />\r\n {UserSession.value.isAuthenticated === true ? (\r\n <Main open={AppLayoutState.sideBarOpened}>\r\n <CssBaseline />\r\n <TopBar />\r\n {!isMobile ? <SideBar /> : null}\r\n {isMobile ? <MobileDrawer /> : null}\r\n <DrawerHeader />\r\n <MainContent />\r\n </Main>\r\n ) : (\r\n <Login />\r\n )}\r\n </BrowserRouter>\r\n );\r\n}\r\n","import { createSlice, Reducer } from \"@reduxjs/toolkit\";\r\nimport { SystemRoute } from \"../../../routes/types\";\r\nimport { ExtendedTreeItemProps } from \"../../../navigationItems\";\r\nimport { StoreMetaData } from \"./CommonStoreSlice\";\r\n\r\nexport type AppInfo = {\r\n documentTitle: string | null;\r\n apiBaseUrl: string | null;\r\n appName: string | null;\r\n appVersion: string | null;\r\n appLogo: any | null;\r\n businessRoutes: Array<SystemRoute>;\r\n businessNavigationItems: Array<ExtendedTreeItemProps>;\r\n businessReduxReducers: { [key: string]: Reducer<any> };\r\n businessCommonStoresMetaData: { [key: string]: StoreMetaData };\r\n muiPremiumKey: string;\r\n enableAdministrationModule: boolean;\r\n appTheme?: {\r\n light: { primaryColor: string; secondaryColor: string };\r\n dark: { primaryColor: string; secondaryColor: string };\r\n };\r\n};\r\n\r\nexport type AppInfoProp = {\r\n value: AppInfo;\r\n};\r\n\r\nconst initialState: AppInfoProp = {\r\n value: {\r\n documentTitle: null,\r\n apiBaseUrl: null,\r\n appName: null,\r\n appVersion: null,\r\n appLogo: null,\r\n muiPremiumKey: null,\r\n enableAdministrationModule: false,\r\n businessRoutes: [],\r\n businessNavigationItems: [],\r\n businessReduxReducers: {},\r\n businessCommonStoresMetaData: {},\r\n appTheme: {\r\n light: { primaryColor: \"#37505C\", secondaryColor: \"#ff6d00\" },\r\n dark: { primaryColor: \"#ea690e\", secondaryColor: \"#74776B\" },\r\n },\r\n },\r\n};\r\n\r\nconst AppInfoSlice = createSlice({\r\n name: \"AppInfo\",\r\n initialState: initialState,\r\n reducers: {\r\n setAppInfo: (state, action) => {\r\n state.value = action.payload;\r\n },\r\n },\r\n});\r\n\r\nexport const AppInfoActions = AppInfoSlice.actions;\r\nexport default AppInfoSlice.reducer;\r\n","import { CommonStoresInterface } from \"../common/CommonStoreSlice\";\r\n\r\nexport const ADMINISTRATION_STORES: CommonStoresInterface = {\r\n SystemDataSourceType: {\r\n autoLoad: false,\r\n data: [{ value: \"Mysql\" }, { value: \"Oracle\" }, { value: \"DB2\" }],\r\n url: \"\",\r\n },\r\n SystemParameterTypes: {\r\n autoLoad: false,\r\n url: \"\",\r\n data: [\r\n { value: \"datetime\" },\r\n { value: \"date\" },\r\n { value: \"text\" },\r\n { value: \"number\" },\r\n { value: \"droplist\" },\r\n ],\r\n },\r\n SystemReportTypes: {\r\n autoLoad: false,\r\n url: \"\",\r\n data: [{ value: \"Excel\" }, { value: \"Jasper\" }, { value: \"Blueprint\" }],\r\n },\r\n SystemWidgetTypes: {\r\n autoLoad: false,\r\n url: \"\",\r\n data: [\r\n { name: \"LineChart\" },\r\n { name: \"ColumnChart\" },\r\n { name: \"PieChart\" },\r\n { name: \"Card\" },\r\n { name: \"CircularProgress\" },\r\n { name: \"LinearProgress\" },\r\n ],\r\n },\r\n SystemMailRecipientTypes: {\r\n autoLoad: false,\r\n url: \"\",\r\n data: [{ name: \"To\" }, { name: \"CC\" }],\r\n },\r\n SystemDataSources: {\r\n autoLoad: true,\r\n data: [],\r\n authority: \"DEVELOPMENT_ADMIN\",\r\n url: \"api/v1/admin/datasourceconnection/all\",\r\n },\r\n SystemDataQueries: {\r\n autoLoad: true,\r\n data: [],\r\n authority: \"DEVELOPMENT_ADMIN\",\r\n url: \"api/v1/admin/dataquery/all\",\r\n },\r\n SystemEntityParameters: {\r\n autoLoad: true,\r\n data: [],\r\n authority: \"DEVELOPMENT_ADMIN\",\r\n url: \"api/v1/admin/entityparameter/all\",\r\n },\r\n SystemAuthorities: {\r\n autoLoad: true,\r\n data: [],\r\n authority: \"DEVELOPMENT_ADMIN\",\r\n url: \"api/v1/admin/authority/all\",\r\n },\r\n SystemRoles: {\r\n autoLoad: true,\r\n data: [],\r\n authority: \"DEVELOPMENT_ADMIN\",\r\n url: \"api/v1/admin/role/all\",\r\n },\r\n};\r\n","import { useDispatch, useSelector } from \"react-redux\";\r\nimport { createTheme, ThemeOptions } from \"@mui/material\";\r\nimport { ThemeProvider } from \"@emotion/react\";\r\nimport React, { useEffect } from \"react\";\r\nimport Layout from \"../layout/Layout\";\r\nimport { AppInfo, AppInfoActions } from \"../redux/features/common/AppInfoSlice\";\r\nimport { LicenseInfo } from \"@mui/x-license\";\r\nimport {\r\n DARK_THEME_INITIAL_MAIN_COLOR,\r\n DARK_THEME_INITIAL_SECANDARY_COLOR,\r\n LIGHT_THEME_INITIAL_MAIN_COLOR,\r\n LIGHT_THEME_INITIAL_SECANDARY_COLOR,\r\n} from \"../util\";\r\nimport { setStoresMetaData } from \"../redux/features/common/CommonStoreSlice\";\r\nimport { ADMINISTRATION_STORES } from \"../redux/features/administration/AdministrationStoresMetaData\";\r\n\r\nconst App: React.FC<AppInfo> = (props: AppInfo) => {\r\n const dispatch = useDispatch();\r\n LicenseInfo.setLicenseKey(props.muiPremiumKey);\r\n const LightThemeOptions: ThemeOptions = {\r\n components: {\r\n MuiCssBaseline: {\r\n styleOverrides: `\r\n /* Custom Scrollbar */\r\n * {\r\n scrollbar-width: thin;\r\n scrollbar-color: ${\r\n props.appTheme?.light?.primaryColor ||\r\n LIGHT_THEME_INITIAL_MAIN_COLOR\r\n } #ffffff;\r\n }\r\n \r\n /* Webkit Browsers */\r\n *::-webkit-scrollbar {\r\n width: 12px;\r\n height: 10px;\r\n } \r\n `,\r\n },\r\n },\r\n palette: {\r\n mode: \"light\",\r\n primary: {\r\n main:\r\n props.appTheme?.light?.primaryColor || LIGHT_THEME_INITIAL_MAIN_COLOR,\r\n },\r\n secondary: {\r\n main:\r\n props.appTheme?.light?.secondaryColor ||\r\n LIGHT_THEME_INITIAL_SECANDARY_COLOR,\r\n },\r\n background: {\r\n default: \"#f5f5f5\",\r\n paper: \"#f5f5f5\",\r\n },\r\n },\r\n };\r\n const DarkThemeOptions: ThemeOptions = {\r\n components: {\r\n MuiCssBaseline: {\r\n styleOverrides: `\r\n /* Custom Scrollbar */\r\n * {\r\n scrollbar-width: thin;\r\n scrollbar-color: ${\r\n props.appTheme?.dark?.primaryColor || DARK_THEME_INITIAL_MAIN_COLOR\r\n } #121212;\r\n }\r\n \r\n /* Webkit Browsers */\r\n *::-webkit-scrollbar {\r\n width: 12px;\r\n height: 10px;\r\n } \r\n `,\r\n },\r\n },\r\n palette: {\r\n mode: \"dark\",\r\n primary: {\r\n main:\r\n props.appTheme?.dark?.primaryColor || DARK_THEME_INITIAL_MAIN_COLOR,\r\n },\r\n secondary: {\r\n main:\r\n props.appTheme?.dark?.secondaryColor ||\r\n DARK_THEME_INITIAL_SECANDARY_COLOR,\r\n },\r\n },\r\n };\r\n\r\n let commonStores = {};\r\n if (props.enableAdministrationModule) {\r\n commonStores = { ...ADMINISTRATION_STORES };\r\n }\r\n if (props.businessCommonStoresMetaData) {\r\n commonStores = {\r\n ...commonStores,\r\n ...props.businessCommonStoresMetaData,\r\n };\r\n } \r\n dispatch(setStoresMetaData(commonStores));\r\n const AppLayoutState = useSelector((state: any) => state.AppLayout);\r\n let themeOptions = { ...LightThemeOptions };\r\n if (AppLayoutState.themeMode === \"dark\") {\r\n themeOptions = { ...DarkThemeOptions };\r\n }\r\n const theme = createTheme({\r\n direction: AppLayoutState.appDirection,\r\n ...themeOptions,\r\n });\r\n useEffect(() => {\r\n document.title = props.documentTitle;\r\n dispatch(AppInfoActions.setAppInfo(props));\r\n }, []);\r\n return (\r\n <ThemeProvider theme={theme}>\r\n <Layout />\r\n </ThemeProvider>\r\n );\r\n};\r\n\r\nexport default App;\r\n","import { Provider } from \"react-redux\";\r\nimport { library } from \"@fortawesome/fontawesome-svg-core\";\r\nimport { fab } from \"@fortawesome/free-brands-svg-icons\";\r\nimport { far } from \"@fortawesome/free-regular-svg-icons\";\r\nimport { fas } from \"@fortawesome/free-solid-svg-icons\";\r\nimport \"../styles/index.css\";\r\nimport \"react-toastify/dist/ReactToastify.css\";\r\nimport App from \"./App\";\r\nimport { AppInfo } from \"../redux/features/common/AppInfoSlice\";\r\nimport AppLayoutReducer from \"../redux/features/common/AppLayoutSlice\";\r\nimport UserSessionReducer from \"../redux/features/common/UserSessionSlice\";\r\nimport LoadingMaskReducer from \"../redux/features/common/LoadingMaskSlice\";\r\nimport CommonStoreReducer from \"../redux/features/common/CommonStoreSlice\";\r\nimport AppInfoReducer from \"../redux/features/common/AppInfoSlice\";\r\nimport { configureStore } from \"@reduxjs/toolkit\";\r\n\r\nlibrary.add(fab);\r\nlibrary.add(far);\r\nlibrary.add(fas);\r\n\r\nexport const BaseApp: React.FC<AppInfo> = (props) => {\r\n const systemReducers = {\r\n AppLayout: AppLayoutReducer,\r\n UserSession: UserSessionReducer,\r\n loadingMask: LoadingMaskReducer,\r\n commonStores: CommonStoreReducer,\r\n AppInfo: AppInfoReducer,\r\n ...props.businessReduxReducers,\r\n };\r\n const store = configureStore({\r\n reducer: systemReducers,\r\n });\r\n // let csInitialState: CommonStoresInterface = {};\r\n // if (props.enableAdministrationModule) {\r\n // for (let adminStoreKey of Object.keys(ADMINISTRATION_STORES)) {\r\n // csInitialState[adminStoreKey] = ADMINISTRATION_STORES[adminStoreKey];\r\n // addCommonStore(adminStoreKey, ADMINISTRATION_STORES[adminStoreKey]);\r\n // }\r\n // }\r\n // if (props?.businessCommonStoresMetaData) {\r\n // for (let businessStoreKey of Object.keys(\r\n // props.businessCommonStoresMetaData\r\n // )) {\r\n // csInitialState[businessStoreKey] =\r\n // props.businessCommonStoresMetaData[businessStoreKey];\r\n // addCommonStore(\r\n // businessStoreKey,\r\n // props.businessCommonStoresMetaData[businessStoreKey]\r\n // );\r\n // }\r\n // }\r\n\r\n return (\r\n <Provider store={store}>\r\n <App {...props} />\r\n </Provider>\r\n );\r\n};\r\n"],"names":["css","ref","insertAt","document","head","getElementsByTagName","style","createElement","type","firstChild","insertBefore","appendChild","styleSheet","cssText","createTextNode","useIsMobile","breakpoint","isMobile","setIsMobile","useState","window","innerWidth","useEffect","handleResize","addEventListener","removeEventListener","DRAWER_WIDTH","AppLayoutSlice","createSlice","name","sideBarOpened","themeMode","localStorage","getItem","appDirection","reducers","toggleSideBarState","state","setSideBarState","action","payload","setThemeMode","setAppDirection","AppLayoutActions","actions","AppLayoutReducer","reducer","loadingMaskSlice","value","isOpened","message","showLoadingMask","hideLoadingMask","LoadingMaskReducer","useLoadingMask","dispatch","useDispatch","show","hide","useAxios","mask","apiBaseUrl","useSelector","AppInfo","axiosInstance","axios","create","baseURL","timeout","withCredentials","defaults","interceptors","response","use","error","status","toast","autoClose","data","handleGetRequest","async","props","endPointURI","parameters","undefined","showMask","loadingMessage","get","params","successCallBkFn","failureCallBkFn","handlePostRequest","post","handleDeleteRequest","delete","HandleDownloadHTTPPostPDF","responseType","UserSessionSlice","isAuthenticated","authorities","userProfile","setAuthenticated","setUnAuthenticated","UserSessionActions","UserSessionReducer","resources","en","translation","common","ar","i18n","initReactI18next","init","lng","fallbackLng","AppBar","styled","MuiAppBar","shouldForwardProp","prop","theme","AppLayout","transition","transitions","easing","sharp","duration","leavingScreen","variants","open","width","marginLeft","marginRight","easeOut","enteringScreen","TopBar","UserSession","_jsx","position","children","_jsxs","Toolbar","IconButton","color","onClick","edge","sx","mr","ml","display","FontAwesomeIcon","icon","Avatar","src","appLogo","Typography","variant","noWrap","component","flex","appName","setItem","prefix","iconName","nextLanguage","language","changeLanguage","username","console","log","rotation","DrawerHeader","alignItems","mixins","toolbar","justifyContent","r","e","t","f","n","Array","isArray","o","length","clsx","arguments","useSession","isUserAuthorized","authorityCode","grantedAuthority","authority","findNavigationItemById","id","nodes","node","found","NavigationItems","label","actionPayload","path","DotIcon","Box","height","borderRadius","bgcolor","verticalAlign","zIndex","mx","StyledTreeItemRoot","TreeItem2Root","palette","grey","treeItemClasses","groupTransition","spacing","applyStyles","CustomTreeItemContent","TreeItem2Content","flexDirection","marginBottom","marginTop","padding","paddingRight","primary","dark","main","content","left","top","backgroundColor","alpha","contrastText","AnimatedCollapse","animated","Collapse","TransitionComponent","useSpring","to","opacity","in","transform","StyledTreeItemLabelText","fontWeight","CustomLabel","expandable","other","useTranslation","appLayoutState","TreeItem2Label","fontSize","isExpandable","reactChildren","some","Boolean","CustomTreeItem","React","forwardRef","itemId","disabled","getRootProps","getContentProps","getIconContainerProps","getCheckboxProps","getLabelProps","getGroupTransitionProps","getDragAndDropOverlayProps","publicAPI","useTreeItem2","rootRef","item","TreeItem2Provider","className","expanded","selected","focused","TreeItem2IconContainer","TreeItem2Icon","TreeItem2Checkbox","TreeItem2DragAndDropOverlay","NavigationTree","navigate","useNavigate","filterData","filter","map","mergedNavigationItems","enableAdministrationModule","push","businessNavigationItems","authoriedNavigationItems","RichTreeView","items","onItemClick","event","navigationItem","flexGrow","maxWidth","direction","maxHeight","overflowY","overflowX","slots","SideBar","useTheme","Drawer","flexShrink","boxSizing","anchor","textAlign","appVersion","Divider","cacheRtl","createCache","key","stylisPlugins","prefixer","rtlPlugin","cacheLtr","useConfirmationWindow","setOpen","ConfirmationWindow","Dialog","DialogTitle","title","DialogContent","DialogContentText","body","DialogActions","Button","onConfirmationCallBk","autoFocus","TemplateGridMultiRecordAction","rowAction","session","confirmationMessage","actionFn","recordsToProcessActionOn","recordIdsToProcessActionOn","reloadData","isActionAllowed","_Fragment","preActionValidation","record","isConfirmationRequired","formActionProps","actionButtonVariant","size","actionButtonColor","DATE_FORMAT","DATE_TIME_FORMAT","LIGHT_THEME_INITIAL_MAIN_COLOR","LIGHT_THEME_INITIAL_SECANDARY_COLOR","DARK_THEME_INITIAL_MAIN_COLOR","DARK_THEME_INITIAL_SECANDARY_COLOR","Datefield","LocalizationProvider","dateAdapter","AdapterMoment","DatePicker","moment","format","onChange","momentValue","v","isValid","onChangeCallBack","slotProps","textField","InputLabelProps","shrink","required","errorMessage","helperText","DatetimeField","DateTimePicker","ComboBox","AppLayoutState","Autocomplete","option","options","valueField","getValue","newValue","clearOnBlur","handleHomeEndKeys","getOptionLabel","displayField","renderOption","props1","popper","Popper","renderInput","TextField","CheckBox","FormControlLabel","control","Checkbox","checked","checkedValue","target","unCheckedValue","generateDateTimeColumn","colDef","renderEditCell","api","setEditCellValue","field","valueParser","row","column","valueFormatter","generateComboColumn","valueGetter","renderCell","find","selectedRecord","generateCheckBoxColumn","getElementFields","element","fields","mode","elements","childElement","getAllFields","constructValidationSchema","validationSchemaObj","fieldName","fieldType","z","number","required_error","invalid_type_error","optional","nullable","string","min","StyledQuickFilter","QuickFilter","StyledToolbarButton","ToolbarButton","ownerState","gridArea","pointerEvents","StyledTextField","TemplateGridTopBar","isCreationAuthorized","templateProps","editAction","gridSelection","rowSelectionModel","keyColumnName","sRecords","sRecordIds","ids","selectedId","x","selectedRecords","selectedRecordIds","getGridSelection","Set","editMode","handleCreateNewRecord","rowActions","gridActionProps","multiRecord","apiActions","gridLoadParametersValues","tBar","Tooltip","ColumnsPanelTrigger","render","GridViewColumnIcon","FilterPanelTrigger","Badge","badgeContent","filterCount","GridFilterListIcon","gridStateKey","clearGridState","orientation","flexItem","ExportExcel","MenuItem","QuickFilterTrigger","triggerProps","enterDelay","QuickFilterControl","controlProps","inputRef","placeholder","input","startAdornment","InputAdornment","endAdornment","QuickFilterClear","hasDigitsOnly","str","test","isNumber","isNaN","isNumeric","trim","Number","capitalizeFirstLetter","charAt","toUpperCase","slice","TemplateGridRecordAction","iconStyle","getActionIconStyleForRecord","isActionVisibleForRecord","isActionDisabledForRecord","GridActionsCellItem","showInMenu","formatMuiErrorMessage","code","args","url","URL","forEach","arg","searchParams","append","process","env","NODE_ENV","reactIsModule","exports","b","Symbol","for","c","d","g","h","k","l","m","p","q","w","y","a","u","$$typeof","A","reactIs_production_min","AsyncMode","ConcurrentMode","ContextConsumer","Element","ForwardRef","Fragment","Lazy","Portal","Profiler","StrictMode","Suspense","isAsyncMode","isConcurrentMode","isContextConsumer","isContextProvider","isElement","isForwardRef","isFragment","isLazy","isMemo","isProfiler","isStrictMode","isSuspense","isValidElementType","typeOf","require$$0","hasSymbol","REACT_ELEMENT_TYPE","REACT_PORTAL_TYPE","REACT_FRAGMENT_TYPE","REACT_STRICT_MODE_TYPE","REACT_PROFILER_TYPE","REACT_PROVIDER_TYPE","REACT_CONTEXT_TYPE","REACT_ASYNC_MODE_TYPE","REACT_CONCURRENT_MODE_TYPE","REACT_FORWARD_REF_TYPE","REACT_SUSPENSE_TYPE","REACT_SUSPENSE_LIST_TYPE","REACT_MEMO_TYPE","REACT_LAZY_TYPE","REACT_BLOCK_TYPE","REACT_FUNDAMENTAL_TYPE","REACT_RESPONDER_TYPE","REACT_SCOPE_TYPE","object","$$typeofType","ContextProvider","Memo","hasWarnedAboutDeprecatedIsAsyncMode","reactIs_development","isPortal","getOwnPropertySymbols","Object","hasOwnProperty","prototype","propIsEnumerable","propertyIsEnumerable","objectAssign","assign","test1","String","getOwnPropertyNames","test2","i","fromCharCode","join","test3","split","letter","keys","err","shouldUseNative","source","from","symbols","val","TypeError","toObject","s","call","ReactPropTypesSecret_1","has","Function","bind","printWarning","ReactPropTypesSecret","loggedTypeFailures","require$$1","text","Error","checkPropTypes","typeSpecs","values","location","componentName","getStack","typeSpecName","ex","stack","resetWarningCache","checkPropTypes_1","ReactIs","require$$2","require$$3","require$$4","emptyFunctionThatReturnsNull","factoryWithTypeCheckers","isValidElement","throwOnDirectAccess","ITERATOR_SYMBOL","iterator","ANONYMOUS","ReactPropTypes","array","createPrimitiveTypeChecker","bigint","bool","func","symbol","any","createChainableTypeChecker","arrayOf","typeChecker","propName","propFullName","PropTypeError","propValue","getPropType","elementType","instanceOf","expectedClass","expectedClassName","constructor","isNode","objectOf","propType","oneOf","expectedValues","is","valuesString","JSON","stringify","getPreciseType","oneOfType","arrayOfTypeCheckers","checker","getPostfixForTypeWarning","expectedTypes","checkerResult","expectedType","shape","shapeTypes","invalidValidatorError","exact","allKeys","this","validate","manualPropTypeCallCache","manualPropTypeWarningCount","checkType","isRequired","secret","cacheKey","chainedCheckType","every","iteratorFn","maybeIterable","getIteratorFn","step","entries","next","done","entry","RegExp","isSymbol","Date","PropTypes","emptyFunction","emptyFunctionWithReset","factoryWithThrowingShims","shim","getShim","propTypesModule","REACT_CONSUMER_TYPE","REACT_VIEW_TRANSITION_TYPE","REACT_CLIENT_REFERENCE","reactIs_production","SuspenseList","isSuspenseList","getModuleId","isPlainObject","getPrototypeOf","toStringTag","deepClone","output","deepmerge","clone","createBreakpoints","breakpoints","xs","sm","md","lg","xl","unit","sortedValues","breakpointsAsArray","sort","breakpoint1","breakpoint2","reduce","acc","obj","sortBreakpointsValues","up","down","between","start","end","endIndex","indexOf","only","not","keyIndex","replace","responsivePropType","merge","defaultBreakpoints","defaultContainerQueries","containerQueries","containerName","result","handleBreakpoints","styleFromPropValue","themeBreakpoints","index","breakpointKeys","startsWith","match","containerKey","shorthand","matches","_formatErrorMessage","containerQuery","getContainerQuery","includes","cssKey","capitalize","getPath","checkVars","vars","getStyleValue","themeMapping","propValueFinal","userValue","cssProperty","themeKey","fn","propTypes","filterProps","properties","directions","aliases","marginX","marginY","paddingX","paddingY","getCssProperties","cache","memoize","property","dir","marginKeys","paddingKeys","spacingKeys","createUnaryUnit","defaultValue","themeSpacing","abs","Math","isInteger","transformed","createUnarySpacing","transformer","resolveCssProperty","cssProperties","getStyleFromPropValue","margin","compose","styles","handlers","concat","borderTransform","createBorderStyle","border","borderTop","borderRight","borderBottom","borderLeft","borderColor","borderTopColor","borderRightColor","borderBottomColor","borderLeftColor","outline","outlineColor","gap","columnGap","rowGap","paletteTransform","sizingTransform","breakpointsValues","minWidth","minHeight","defaultSxConfig","pt","pr","pb","pl","px","py","paddingTop","paddingBottom","paddingLeft","paddingInline","paddingInlineStart","paddingInlineEnd","paddingBlock","paddingBlockStart","paddingBlockEnd","mt","mb","my","marginInline","marginInlineStart","marginInlineEnd","marginBlock","marginBlockStart","marginBlockEnd","displayPrint","overflow","textOverflow","visibility","whiteSpace","flexBasis","flexWrap","alignContent","order","alignSelf","justifyItems","justifySelf","gridColumn","gridRow","gridAutoFlow","gridAutoColumns","gridAutoRows","gridTemplateColumns","gridTemplateRows","gridTemplateAreas","right","bottom","boxShadow","font","fontFamily","fontStyle","letterSpacing","textTransform","lineHeight","typography","styleFunctionSx","getThemeValue","config","unstable_sxConfig","traverse","sxInput","sxObject","emptyBreakpoints","breakpointsInput","breakpointsInOrder","createEmptyBreakpointObject","breakpointsKeys","styleKey","maybeFn","objects","union","objectsHaveSameKeys","sorted","regex","sortContainerQueries","breakpointOutput","removeUnusedBreakpoints","unstable_createStyleFunctionSx","colorSchemes","getColorSchemeSelector","selector","defaultTheme","contextTheme","useContext","ThemeContext","systemDefaultTheme","paletteInput","spacingInput","shapeInput","mui","argsInput","argument","createSpacing","muiTheme","components","themeInput","toContainerQuery","mediaQuery","attachCq","cssContainerQueries","unstable_sx","createTheme","extendSxProp","inSx","systemProps","otherProps","splitProps","finalSx","defaultGenerator","ClassNameGenerator","generate","configure","generator","reset","createClassNameGenerator","globalStateClasses","active","completed","focusVisible","readOnly","themeId","defaultClassName","generateClassName","BoxRoot","tag","stylesFactory","emStyled","inProps","useThemeWithoutDefault","as","createBox","globalStatePrefix","slot","globalStateClass","generateUtilityClass","generateUtilityClasses","root","TemplateTextField","inputLabel","FormElementField","fieldInfo","formManager","formActions","formValues","hidden","hiddenFields","Grid2","formProps","fieldSize","fullWidth","disabledFields","fieldLabel","setValue","onValueChangeCallBack","formState","errors","toString","dateFormat","optionDisplayField","optionValueField","FormAction","setConfirmationWindowState","FormElementGroup","container","TemplateForm","setHiddenFields","setDisabledFields","formSchema","useForm","resolver","zodResolver","watch","pathParameters","useParams","formRouteRecordIdParamName","setFieldValue","fieldValue","hideField","oldValues","showField","disableField","enableField","idToLoad","recordIdToEdit","retrievedRecord","loadRecordById","loadRecord","formElement","enabled","saveButtonSpecs","startIcon","handleSubmit","preSaveValidation","savedRecord","saveRecord","formSavedSuccessfullyCallBk","formCloseCallBk","cancelButtonSpecs","useWindow","windowState","setWindowState","Window","windowProps","Modal","drawer","onClose","onCloseCallBack","windowIcon","windowTitle","Paper","currentNewRecordIndex","loadGridState","saved","parse","saveGridState","statePart","current","PIN_FIXED_COLUMNS","TemplateGrid","formElements","savedState","useMemo","gridProps","initialVisibilityState","columnVisibilityModel","existingFields","themeDirection","setColumnVisibilityModel","columnOrder","setColumnOrder","columnWidths","setColumnWidths","gridRowGroupingModel","setGridRowGroupingModel","columnGroupingModel","newLeft","pinnedColumns","newRight","setPinnedColumns","recordToDelete","setRecordToDelete","recordToEdit","setRecordToEdit","rowModesModel","setRowModesModel","setRowSelectionModel","setData","validationSchema","generatedColumns","isDefaultEditable","columns","tableField","muiProps","editable","headerName","headerAlign","align","searchable","constructGridColumnsFromFields","isEditAllowed","isDeleteAllowed","deleteAction","setConfirmationWindowOpened","isNew","deleteRecordById","postActionCallBack","oldData","formModalHeight","formModalWidth","formModalMinHeight","formModalMinWidth","formModalIcon","formModalTitle","specs","modalHeight","modalWidth","modalMinHeight","modalMinWidth","modalIcon","modalTitle","FormWindow","setFormWindowState","actionColumn","isEnabled","getActions","disableDefaultAction","isInEditMode","GridRowModes","Edit","View","handleSaveRowClick","ignoreModifications","newData","handleCancelRowEditClick","isEditActionVisibleForRecord","isActionEditDisabledForRecord","formRoute","handleEditRecord","isDeleteActionVisibleForRecord","isDeleteActionDisabledForRecord","structuredColumns","autoLoad","adjustedColumns","baseCols","col","fieldToCol","Map","formComponent","editAuthorityKey","hideInfoBar","hideBackButton","girdIcon","gridTitle","gridLoadParameters","setGridLoadParametersValues","Accordion","defaultExpanded","AccordionSummary","expandIcon","GridExpandMoreIcon","AccordionDetails","DataGridPremium","newRecord","oldRows","oldModel","removeItem","getRowId","showToolbar","rows","checkboxSelection","onRowModesModelChange","newModel","rowGroupingColumnMode","processRowUpdate","ZodError","validateRecord","requestObject","reloadAfterSave","onRowSelectionModelChange","gridSelectionModel","onColumnVisibilityModelChange","model","onColumnOrderChange","targetIndex","prevOrder","currentOrder","fromIndex","splice","onColumnWidthChange","updatedWidths","rowGroupingModel","onRowGroupingModelChange","handleRowGroupChange","onPinnedColumnsChange","newPinedColumns","commonStoreSlice","initialState","stores","storeKeys","isAutoLoadLoaded","setStoresMetaData","setStoreData","storeKey","setAutoLoadLoaded","CommonStoreReducer","useApiActions","apiActionsProps","CommonStores","commonStores","commonStoreKey","findAll","recordId","findById","findByIdParamName","save","deleteById","deleteByIdParamName","intersection","TransferList","selectedOptions","setSelection","setChecked","setLeft","setRight","leftFilterValue","setLeftFilterValue","rightFilterValue","setRightFilterValue","leftChecked","rightChecked","handleToggle","currentIndex","newChecked","numberOfChecked","handleToggleAll","customList","unfilteredItems","side","toLocaleLowerCase","Card","CardHeader","avatar","indeterminate","inputProps","subheader","List","dense","role","ListItemButton","cursor","ListItemIcon","tabIndex","disableRipple","ListItemText","oldState","newState","TemplatePieChart","chartData","labelField","PieChart","series","TemplateBarChart","BarChart","dataset","xAxis","dataKey","scaleType","TemplateLineChart","LineChart","TemplateGauge","widgetTitle","Gauge","TemplateDataCard","LinearProgressWithLabel","LinearProgress","round","TemplateLineProgress","WidgetContainer","widgetType","Grid","TemplateDashboard","dashboardTitle","dashboardWidgets","widgetProps","singleRecordWidgetProps","RoleAuthoritiesForm","setSelectedOptions","currentRoleAuthorities","availableAuthorities","roleId","success","closeModalFn","SYSTEM_ROUTES","counter","selectedRole","setSelectedRole","selectedRoleAuthorities","setSelectedRoleAuthorities","selectedRoleAvailableAuthorities","setSelectedRoleAvailableAuthorities","RoleAuthoritiesWindow","setRoleAuthorirtiesWindowOpen","selectedAuthorities","loadRoleAuthorities","MainContent","businessRoutes","CacheProvider","Routes","route","Route","Component","Puller","MobileDrawer","toggleDrawer","SwipeableDrawer","onOpen","swipeAreaWidth","disableSwipeToOpen","ModalProps","keepMounted","LoadingMask","loadingMask","Backdrop","CircularProgress","Login","appInfo","setUsername","password","setPassword","isLoginInProcess","setIsLoginInProcess","UserSessionState","handleLogin","userSession","loginTheme","MuiCssBaseline","styleOverrides","appTheme","primaryColor","secondary","secondaryColor","checkUserSession","ThemeProvider","onKeyDown","loading","Main","loadCommonStores","Layout","BrowserRouter","ToastContainer","draggable","CssBaseline","AppInfoSlice","documentTitle","muiPremiumKey","businessReduxReducers","businessCommonStoresMetaData","light","setAppInfo","AppInfoActions","AppInfoReducer","ADMINISTRATION_STORES","SystemDataSourceType","SystemParameterTypes","SystemReportTypes","SystemWidgetTypes","SystemMailRecipientTypes","SystemDataSources","SystemDataQueries","SystemEntityParameters","SystemAuthorities","SystemRoles","App","LicenseInfo","setLicenseKey","LightThemeOptions","background","default","paper","DarkThemeOptions","themeOptions","library","add","fab","far","fas","BaseApp","systemReducers","store","configureStore","Provider"],"mappings":"0lIAAA,SAAqBA,EAAKC,QACX,IAARA,IAAiBA,EAAM,CAAE,GAC9B,IAAIC,EAAWD,EAAIC,SAEnB,GAAgC,oBAAbC,SAAnB,CAEA,IAAIC,EAAOD,SAASC,MAAQD,SAASE,qBAAqB,QAAQ,GAC9DC,EAAQH,SAASI,cAAc,SACnCD,EAAME,KAAO,WAEI,QAAbN,GACEE,EAAKK,WACPL,EAAKM,aAAaJ,EAAOF,EAAKK,YAKhCL,EAAKO,YAAYL,GAGfA,EAAMM,WACRN,EAAMM,WAAWC,QAAUb,EAE3BM,EAAMK,YAAYR,SAASW,eAAed,GAnBU,CAqBxD,wTCvBae,GAAc,CAACC,EAAa,OACvC,MAAOC,EAAUC,GAAeC,EAASC,OAAOC,WAAaL,GAQ7D,OANAM,GAAU,KACR,MAAMC,EAAe,IAAML,EAAYE,OAAOC,WAAaL,GAE3D,OADAI,OAAOI,iBAAiB,SAAUD,GAC3B,IAAMH,OAAOK,oBAAoB,SAAUF,KACjD,CAACP,IAEGC,GCTIS,GAAe,IActBC,GAAiBC,GAAY,CACjCC,KAAM,yBAP6B,CACnCC,eAAe,EACfC,UAAWC,aAAaC,QAAQ,cAAgB,QAChDC,aAAkD,MAApCF,aAAaC,QAAQ,YAAsB,MAAQ,OAMjEE,SAAU,CACRC,mBAAqBC,IACnBA,EAAMP,eAAiBO,EAAMP,eAE/BQ,gBAAiB,CAACD,EAAOE,KACvBF,EAAMP,cAAgBS,EAAOC,SAE/BC,aAAc,CAACJ,EAAOE,KACpBF,EAAMN,UAAYQ,EAAOC,SAE3BE,gBAAiB,CAACL,EAAOE,KACvBF,EAAMH,aAAeK,EAAOC,YAKrBG,GAAmBhB,GAAeiB,QAC/C,IAAeC,GAAAlB,GAAemB,QC9B9B,MAIMC,GAAmBnB,GAAY,CACnCC,KAAM,2BALoC,CAC1CmB,MAAO,CAAEC,UAAU,EAAOC,QAAS,OAMnCf,SAAU,CACRgB,gBAAiB,CACfd,EACAE,KAEAF,EAAMW,MAAMC,UAAW,EACvBZ,EAAMW,MAAME,QAAUX,EAAOC,SAE/BY,gBAAkBf,IAChBA,EAAMW,MAAMC,UAAW,EACvBZ,EAAMW,MAAME,QAAU,UAKfC,gBAAEA,GAAeC,gBAAEA,IAAoBL,GAAiBH,QACrE,IAAeS,GAAAN,GAAiBD,QCzB1B,MAAAQ,GAAiB,KACrB,MAAMC,EAAWC,IAOjB,MAAO,CAAEC,KANKP,IACZK,EAASJ,GAAgBD,KAKZQ,KAHF,KACXH,EAASH,SCMPO,GAAW,KACf,MAAMC,EAAON,KACPO,EAAaC,GAChBzB,GAAqBA,EAAM0B,QAAQf,MAAMa,aAEtCG,EAAgBC,GAAMC,OAAO,CACjCC,QAASN,EACTO,QAAS,IACTC,iBAAiB,IAGnBL,EAAcM,SAASD,iBAAkB,EACzCL,EAAcO,aAAaC,SAASC,KACjCD,GACQA,IAERE,IAEGA,IACIA,EAAMF,WACJE,EAAMF,SAASG,QACa,MAA1BD,EAAMF,SAASG,SAKvBC,GAAMF,MAAM,uDAAwD,CAClEG,WAAW,IAGbH,IACIA,EAAMF,WACJE,EAAMF,SAASG,QACa,MAA1BD,EAAMF,SAASG,SAKvBC,GAAMF,MAAM,iDAEZA,IACIA,EAAMF,WACJE,EAAMF,SAASG,QACa,MAA1BD,EAAMF,SAASG,SAKvBC,GAAMF,MAAMA,EAAMF,SAASM,MAE3BF,GAAMF,MACJ,6DAGG,WAgMX,MAAO,CACLK,iBA9LuBC,MACvBC,EAAoB,CAAEC,YAAa,GAAIC,WAAY,CAAA,WAG9BC,IAAnBH,EAAMI,UACY,MAAlBJ,EAAMI,WACa,IAAnBJ,EAAMI,UAENzB,EAAKH,KAAKwB,EAAMK,gBAElB,MAAMd,QAAsBR,EAAcuB,IAAIN,EAAMC,YAAa,CAC/DM,OAAQ,IAAKP,EAAME,YACnBd,iBAAiB,IAUnB,YANqBe,IAAnBH,EAAMI,UACY,MAAlBJ,EAAMI,WACa,IAAnBJ,EAAMI,UAENzB,EAAKF,OAEU,UAAbc,QAE0BY,IAA1BH,EAAMQ,iBACmB,MAAzBR,EAAMQ,iBAENR,EAAMQ,gBAAgBjB,GAEjBA,SAGqBY,IAA1BH,EAAMS,iBACmB,MAAzBT,EAAMS,iBAENT,EAAMS,gBAAgBlB,GAEjB,UA0JTmB,kBApFwBX,MACxBC,EAAoB,CAAEC,YAAa,GAAIC,WAAY,CAAE,EAAEL,KAAM,CAAA,WAGxCM,IAAnBH,EAAMI,UACY,MAAlBJ,EAAMI,WACa,IAAnBJ,EAAMI,UAENzB,EAAKH,KAAKwB,EAAMK,gBAElB,IAAId,QAAsBR,EAAc4B,KACtCX,EAAMC,YACND,EAAMH,KACN,CACEU,OAAQP,EAAME,aAUlB,YANqBC,IAAnBH,EAAMI,UACY,MAAlBJ,EAAMI,WACa,IAAnBJ,EAAMI,UAENzB,EAAKF,OAEU,UAAbc,QAE0BY,IAA1BH,EAAMQ,iBACmB,MAAzBR,EAAMQ,iBAENR,EAAMQ,gBAAgBjB,GAEjBA,SAGqBY,IAA1BH,EAAMS,iBACmB,MAAzBT,EAAMS,iBAENT,EAAMS,gBAAgBlB,GAEjB,UA8CTqB,oBA3C0Bb,MAC1BC,EAAoB,CAAEC,YAAa,GAAIC,WAAY,CAAA,WAG9BC,IAAnBH,EAAMI,UACY,MAAlBJ,EAAMI,WACa,IAAnBJ,EAAMI,UAENzB,EAAKH,KAAKwB,EAAMK,gBAElB,IAAId,QAAsBR,EAAc8B,OAAOb,EAAMC,YAAa,CAChEM,OAAQ,IACHP,EAAME,cAUb,YANqBC,IAAnBH,EAAMI,UACY,MAAlBJ,EAAMI,WACa,IAAnBJ,EAAMI,UAENzB,EAAKF,OAEU,UAAbc,QAE0BY,IAA1BH,EAAMQ,iBACmB,MAAzBR,EAAMQ,iBAENR,EAAMQ,gBAAgBjB,GAEjBA,SAGqBY,IAA1BH,EAAMS,iBACmB,MAAzBT,EAAMS,iBAENT,EAAMS,gBAAgBlB,GAEjB,UAOTuB,0BAxJgCf,MAChCC,EAAoB,CAAEC,YAAa,GAAIC,WAAY,CAAE,EAAEL,KAAM,CAAA,WAGxCM,IAAnBH,EAAMI,UACY,MAAlBJ,EAAMI,WACa,IAAnBJ,EAAMI,UAENzB,EAAKH,KAAKwB,EAAMK,gBAElB,MAAMd,QAAsBR,EAAc4B,KACxCX,EAAMC,YACND,EAAMH,KACN,CACEkB,aAAc,SAUlB,YANqBZ,IAAnBH,EAAMI,UACY,MAAlBJ,EAAMI,WACa,IAAnBJ,EAAMI,UAENzB,EAAKF,OAEU,UAAbc,QAE0BY,IAA1BH,EAAMQ,iBACmB,MAAzBR,EAAMQ,iBAENR,EAAMQ,gBAAgBjB,GAEjBA,SAGqBY,IAA1BH,EAAMS,iBACmB,MAAzBT,EAAMS,iBAENT,EAAMS,gBAAgBlB,GAEjB,YC9GPyB,GAAmBrE,GAAY,CACnCC,KAAM,2BAT+B,CACrCmB,MAAO,CACLkD,gBAAiB,KACjBC,YAAa,GACbC,YAAa,OAOfjE,SAAU,CACRkE,iBAAkB,CAAChE,EAAOE,KACxBF,EAAMW,MAAQT,EAAOC,SAEvB8D,mBAAqBjE,IACnBA,EAAMW,MAAQ,CACZkD,iBAAiB,EACjBC,YAAa,GACbC,YAAa,UAMRG,GAAqBN,GAAiBrD,QACnD,IAAe4D,GAAAP,GAAiBnD,itEC3DzB,MCCD2D,GAAY,CAChBC,GAAI,CAAEC,YDFqB,IACxBC,w1gBCEHC,GAAI,CAAEF,YCFoB,IACvBC,gugBCDLE,GAAKrC,IAAIsC,IAAkBC,KAAK,CAC9BP,UAAWA,GACXQ,IAAKjF,aAAaC,QAAQ,aAAe,KACzCiF,YAAa,OAGR,MCUDC,GAASC,EAAOC,GAAW,CAC/BC,kBAAoBC,GAAkB,SAATA,GADhBH,EAEC,EAAGI,YACjB,MAAMC,EAAY3D,GAAazB,GAAqBA,EAAMoF,YACpDxG,EAAWF,KACjB,MAAO,CACL2G,WAAYF,EAAMG,YAAYzD,OAAO,CAAC,SAAU,SAAU,CACxD0D,OAAQJ,EAAMG,YAAYC,OAAOC,MACjCC,SAAUN,EAAMG,YAAYG,SAASC,gBAEvCC,SAAU,CACR,CACE/C,MAAO,EAAGgD,UAAWA,EACrB3H,MAAO,CACL4H,MAAQjH,OAA8CmE,EAAnC,qBACnB+C,WACGlH,GAAuC,QAA3BwG,EAAUvF,kBAEnBkD,EADA,QAENgD,YACGnH,GAAuC,QAA3BwG,EAAUvF,kBAEnBkD,EADA,QAENsC,WAAYF,EAAMG,YAAYzD,OAAO,CAAC,SAAU,SAAU,CACxD0D,OAAQJ,EAAMG,YAAYC,OAAOS,QACjCP,SAAUN,EAAMG,YAAYG,SAASQ,wBAQ3CC,GAAmB,KACvB,MAAMxE,EAAUD,GAAazB,GAAqBA,EAAM0B,QAAQf,QAC1DyE,EAAY3D,GAAazB,GAAqBA,EAAMoF,YACpDe,EAAc1E,GAAazB,GAAqBA,EAAMmG,eACtDzD,iBAAEA,GAAqBpB,KACvB1C,EAAWF,KACXwC,EAAWC,IAYjB,OACEiF,EAACtB,GAAM,CAACuB,SAAS,QAAQT,KAAMR,EAAU3F,cAAa6G,SACpDC,EAACC,GAAO,CAAAF,SAAA,CACNF,EAACK,GACCC,MAAM,UAAS,aACJ,cACXC,QATc,KACpBzF,EAASZ,GAAiBP,uBASpB6G,KAAK,QACLC,GAAI,CACF,CACEC,GAA+B,QAA3B1B,EAAUvF,aAAyB,OAAIkD,EAC3CgE,GAA+B,QAA3B3B,EAAUvF,aAAyB,OAAIkD,GAE7CqC,EAAU3F,eAAiB,CAAEuH,QAAS,SACvCV,SAEDF,EAACa,GAAgB,CAAAC,KAAK,WAExBd,EAACe,EAAM,CAACC,IAAK1F,EAAQ2F,QAASR,GAAI,CAAEd,YAAa,EAAGD,WAAY,KAChEM,EAACkB,EAAU,CAACC,QAAQ,KAAKC,UAAOC,UAAU,MAAMZ,GAAI,CAAEa,KAAM,GAAGpB,SAC5D1H,EAAW,GAAK8C,EAAQiG,UAE3BvB,EAACK,EACC,CAAAC,MAAM,UACNC,QAAS,KACPzF,EACEZ,GAAiBF,aACS,UAAxBgF,EAAU1F,UAAwB,OAAS,UAG/CC,aAAaiI,QACX,YACwB,UAAxBxC,EAAU1F,UAAwB,OAAS,UAE9C4G,SAEwB,UAAxBlB,EAAU1F,UACT0G,EAACa,GAAgB,CAAAC,KAAK,SAEtBd,EAACa,GAAe,CAACC,KAAM,CAAEW,OAAQ,MAAOC,SAAU,WAGtD1B,EAACK,EAAU,CACTC,MAAM,UACNC,QAAS,KACP,IAAIoB,EAAiC,OAAlBtD,GAAKuD,SAAoB,KAAO,KD1GjC,IAACpD,IC2GJmD,ED1GzBtD,GAAKwD,eAAerD,GACpBjF,aAAaiI,QAAQ,WAAYhD,GC0GvB1D,EACEZ,GAAiBD,gBACE,OAAjB0H,EAAwB,MAAQ,kBAKtC3B,EAACa,GAAgB,CAAAC,KAAK,eAExBd,EAACe,EAAM,CAAA,GACPf,EAAK,MAAA,CAAAnI,MAAO,CAAE6H,WAAY,EAAGC,YAAa,GAAGO,SAC1C1H,EAAW,GAAKuH,EAAYxF,OAAOoD,aAAamE,WAEnD9B,EAACK,EAAW,CAAAC,MAAM,UAAUC,QAvEbhE,UACnB,UACQD,EAAiB,CAAEG,YAAa,oBACtC,MAAOR,GACP8F,QAAQC,IAAI,eAAgB/F,GAE9BnB,EAASgD,GAAmBD,uBAkEtBqC,SAAAF,EAACa,GACC,CAAAoB,SAAqC,QAA3BjD,EAAUvF,aAAyB,SAAMkD,EACnDmE,KAAK,qCCnIJoB,GAAevD,EAAO,MAAPA,EAAc,EAAGI,YAAa,CACxD6B,QAAS,OACTuB,WAAY,YAGTpD,EAAMqD,OAAOC,QAChBC,eAAgB,eCRlB,SAASC,GAAEC,GAAG,IAAIC,EAAEC,EAAEC,EAAE,GAAG,GAAG,iBAAiBH,GAAG,iBAAiBA,EAAEG,GAAGH,OAAO,GAAG,iBAAiBA,EAAE,GAAGI,MAAMC,QAAQL,GAAG,CAAC,IAAIM,EAAEN,EAAEO,OAAO,IAAIN,EAAE,EAAEA,EAAEK,EAAEL,IAAID,EAAEC,KAAKC,EAAEH,GAAEC,EAAEC,OAAOE,IAAIA,GAAG,KAAKA,GAAGD,EAAE,MAAM,IAAIA,KAAKF,EAAEA,EAAEE,KAAKC,IAAIA,GAAG,KAAKA,GAAGD,GAAG,OAAOC,CAAC,CAAQ,SAASK,KAAO,IAAI,IAAIR,EAAEC,EAAEC,EAAE,EAAEC,EAAE,GAAGG,EAAEG,UAAUF,OAAOL,EAAEI,EAAEJ,KAAKF,EAAES,UAAUP,MAAMD,EAAEF,GAAEC,MAAMG,IAAIA,GAAG,KAAKA,GAAGF,GAAG,OAAOE,CAAC,CCIzW,MAAAO,GAAa,KACjB,MAAMnD,EAAc1E,GAAazB,GAAqBA,EAAMmG,cAiB5D,MAAO,CAAEA,cAAaoD,iBAhBIC,IACxB,GAAIrD,GAAaxF,OAAOmD,YAItB,IAAK,IAAI2F,KAAoBtD,EAAYxF,MAAMmD,YAC7C,GACkC,sBAAhC2F,GAAkBC,WAClBD,GAAkBC,YAAcF,EAEhC,OAAO,EAIb,OAAO,KCHEG,GAAyB,CACpCC,EACAC,KAEA,IAAK,MAAMC,KAAQD,EAAO,CACxB,GAAIC,EAAKF,KAAOA,EAAI,OAAOE,EAC3B,GAAIA,EAAKxD,SAAU,CACjB,MAAMyD,EAAQJ,GAAuBC,EAAIE,EAAKxD,UAC9C,GAAIyD,EAAO,OAAOA,KAMXC,GAA6D,IC3BI,CCA5E,CACEJ,GAAI,QACJK,MAAO,wBACPP,UAAW,oBACXxC,KAAM,OACNZ,SAAU,CACR,CACEsD,GAAI,yBACJK,MAAO,oBACP/C,KAAM,OACNZ,SAAU,CACR,CACEsD,GAAI,sCACJK,MAAO,sBACP/C,KAAM,QACNhH,OAAQ,aACRgK,cAAe,CAAEC,KAAM,wBAEzB,CACEP,GAAI,iDACJK,MAAO,kCACP/C,KAAM,kBACNhH,OAAQ,aACRgK,cAAe,CAAEC,KAAM,qCAI7B,CACEP,GAAI,iBACJK,MAAO,0BACP/C,KAAM,SACNZ,SAAU,CACR,CACEsD,GAAI,2BACJK,MAAO,mBACP/C,KAAM,MACNhH,OAAQ,aACRgK,cAAe,CAAEC,KAAM,sBAEzB,CACEP,GAAI,aACJK,MAAO,cACP/C,KAAM,MACNhH,OAAQ,aACRgK,cAAe,CAAEC,KAAM,gBAEzB,CACEP,GAAI,0BACJK,MAAO,kBACP/C,KAAM,OACNhH,OAAQ,aACRgK,cAAe,CAAEC,KAAM,sBAI7B,CACEP,GAAI,iBACJK,MAAO,oBACP/C,KAAM,OACNZ,SAAU,CACR,CACEsD,GAAI,sCACJK,MAAO,+BACP/C,KAAM,OACNhH,OAAQ,aACRgK,cAAe,CAAEC,KAAM,gCAEzB,CACEP,GAAI,iCACJK,MAAO,0BACP/C,KAAM,IACNhH,OAAQ,aACRgK,cAAe,CAAEC,KAAM,2BAEzB,CACEP,GAAI,2BACJK,MAAO,oBACP/C,KAAM,YACNhH,OAAQ,aACRgK,cAAe,CAAEC,KAAM,sBAEzB,CACEP,GAAI,qCACJK,MAAO,+BACP/C,KAAM,aACNhH,OAAQ,aACRgK,cAAe,CAAEC,KAAM,+BAEzB,CACEP,GAAI,wBACJK,MAAO,gBACP/C,KAAM,OACNhH,OAAQ,aACRgK,cAAe,CAAEC,KAAM,kBAEzB,CACEP,GAAI,kCACJK,MAAO,2BACP/C,KAAM,gBACNhH,OAAQ,aACRgK,cAAe,CAAEC,KAAM,4BAEzB,CACEP,GAAI,2BACJK,MAAO,oBACP/C,KAAM,cACNhH,OAAQ,aACRgK,cAAe,CAAEC,KAAM,qBAEzB,CACEP,GAAI,wBACJK,MAAO,gBACP/C,KAAM,YACNhH,OAAQ,aACRgK,cAAe,CAAEC,KAAM,kBAEzB,CACEP,GAAI,2BACJK,MAAO,mBACP/C,KAAM,uBACNhH,OAAQ,aACRgK,cAAe,CAAEC,KAAM,qBAEzB,CACEP,GAAI,8BACJK,MAAO,uBACP/C,KAAM,WACNhH,OAAQ,aACRgK,cAAe,CAAEC,KAAM,wBAEzB,CACEP,GAAI,8BACJK,MAAO,sBACP/C,KAAM,OACNhH,OAAQ,aACRgK,cAAe,CAAEC,KAAM,0BAI7B,CACEP,GAAI,iBACJK,MAAO,oBACP/C,KAAM,KACNZ,SAAU,CACR,CACEsD,GAAI,gCACJK,MAAO,oCACP/C,KAAM,iBACNhH,OAAQ,aACRgK,cAAe,CAAEC,KAAM,mCAEzB,CACEP,GAAI,8BACJK,MAAO,iCACP/C,KAAM,qBACNhH,OAAQ,aACRgK,cAAe,CAAEC,KAAM,iCAEzB,CACEP,GAAI,0BACJK,MAAO,4BACP/C,KAAM,OACNhH,OAAQ,aACRgK,cAAe,CAAEC,KAAM,+BAK7B,CACEP,GAAI,eACJK,MAAO,gBACP/C,KAAM,aACNhH,OAAQ,aACRgK,cAAe,CAAEC,KAAM,sBC9I/B,SAASC,KACP,OACEhE,EAACiE,GAAG,CACFxD,GAAI,CACFhB,MAAO,EACPyE,OAAQ,EACRC,aAAc,MACdC,QAAS,eACTxD,QAAS,eACTyD,cAAe,SACfC,OAAQ,EACRC,GAAI,IAIZ,CAQA,MAAMC,GAAqB7F,EAAO8F,GAAP9F,EAAsB,EAAGI,YAAa,CAC/DuB,MAAOvB,EAAM2F,QAAQC,KAAK,KAC1B1E,SAAU,WACV,CAAC,MAAM2E,GAAgBC,mBAAoB,CACzCnF,WAAYX,EAAM+F,QAAQ,SAEzB/F,EAAMgG,YAAY,QAAS,CAC5BzE,MAAOvB,EAAM2F,QAAQC,KAAK,WAIxBK,GAAwBrG,EAAOsG,GAAPtG,EAAyB,EAAGI,YAAa,CACrEmG,cAAe,cACff,aAAcpF,EAAM+F,QAAQ,IAC5BK,aAAcpG,EAAM+F,QAAQ,IAC5BM,UAAWrG,EAAM+F,QAAQ,IACzBO,QAAStG,EAAM+F,QAAQ,IACvBQ,aAAcvG,EAAM+F,QAAQ,GAC5B,kBAAqB,CACnB,2EACE,CACExE,MAAOvB,EAAM2F,QAAQa,QAAQC,QAC1BzG,EAAMgG,YAAY,QAAS,CAC5BzE,MAAOvB,EAAM2F,QAAQa,QAAQE,QAGnC,YAAa,CACXC,QAAS,KACT9E,QAAS,QACTX,SAAU,WACV0F,KAAM,OACNC,IAAK,OACL1B,OAAQ,oBACRzE,MAAO,QACPoG,gBAAiB9G,EAAM2F,QAAQC,KAAK,QACjC5F,EAAMgG,YAAY,QAAS,CAC5Bc,gBAAiB9G,EAAM2F,QAAQC,KAAK,SAI1C,UAAW,CACTkB,gBAAiBC,EAAM/G,EAAM2F,QAAQa,QAAQE,KAAM,IACnDnF,MAAO,WACJvB,EAAMgG,YAAY,QAAS,CAC5BzE,MAAOvB,EAAM2F,QAAQa,QAAQE,QAGjC,4DAA+D,CAC7DI,gBAAiB9G,EAAM2F,QAAQa,QAAQC,KACvClF,MAAOvB,EAAM2F,QAAQa,QAAQQ,gBAC1BhH,EAAMgG,YAAY,QAAS,CAC5Bc,gBAAiB9G,EAAM2F,QAAQa,QAAQE,YAKvCO,GAAmBC,GAASC,IAElC,SAASC,GAAoB3J,GAC3B,MAAM3E,EAAQuO,GAAU,CACtBC,GAAI,CACFC,QAAS9J,EAAM+J,GAAK,EAAI,EACxBC,UAAW,iBAAiBhK,EAAM+J,GAAK,EAAI,aAI/C,OAAOvG,EAACgG,GAAiB,CAAAnO,MAAOA,KAAW2E,GAC7C,CAEA,MAAMiK,GAA0B9H,EAAOuC,GAAPvC,CAAmB,CACjD2B,MAAO,UACPoG,WAAY,MASd,SAASC,IAAY7F,KACnBA,EAAI8F,WACJA,EAAU1G,SACVA,KACG2G,IAEH,MAAMpE,EAAEA,GAAMqE,KACRC,EAAiB1L,GAAazB,GAAqBA,EAAMoF,YAC/D,OACEmB,EAAC6G,OACKH,EACJpG,GAAI,CACFG,QAAS,OACTuB,WAAY,SACZkD,QAAS,GACVnF,SAAA,CAEDF,EAACa,GACC,CAAAhJ,MAAO,CACL8H,YAA6C,QAAhCoH,EAAetN,aAAyB,OAAIkD,EACzD+C,WAA4C,QAAhCqH,EAAetN,aAAyB,OAAIkD,EACxDsK,SAAU,UAEZnG,KAAMA,IAERd,EAACyG,GAAwB,CAAAtF,QAAQ,QAAQV,GAAI,CAAEwG,SAAU,IAAI/G,SAC1DuC,EAAEvC,KAEJ0G,GAAc5G,EAACgE,GAAU,MAGhC,CAEA,MAAMkD,GAAgBC,GAChBvE,MAAMC,QAAQsE,GACTA,EAAcpE,OAAS,GAAKoE,EAAcC,KAAKF,IAEjDG,QAAQF,GAOXG,GAAiBC,EAAMC,YAAW,SACtChL,EACAhF,GAEA,MAAMgM,GAAEA,EAAEiE,OAAEA,EAAM5D,MAAEA,EAAK6D,SAAEA,EAAQxH,SAAEA,KAAa2G,GAAUrK,GACtDmL,aACJA,EAAYC,gBACZA,EAAeC,sBACfA,EAAqBC,iBACrBA,EAAgBC,cAChBA,EAAaC,wBACbA,EAAuBC,2BACvBA,EAA0B/L,OAC1BA,EAAMgM,UACNA,GACEC,GAAa,CAAE3E,KAAIiE,SAAQvH,WAAU2D,QAAO6D,WAAUU,QAAS5Q,IAC7D6Q,EAAOH,EAAU1O,QAAQiO,GACzBb,EAAaM,GAAahH,GAChC,OACEF,EAACsI,GAAiB,CAACb,OAAQA,WACzBtH,EAACqE,OAAuBmD,EAAad,GAAM3G,SAAA,CACzCC,EAAC6E,GAAqB,IAChB4C,EAAgB,CAClBW,UAAWvF,GAAK,UAAW,CACzB,eAAgB9G,EAAOsM,SACvB,eAAgBtM,EAAOuM,SACvB,cAAevM,EAAOwM,QACtB,eAAgBxM,EAAOwL,aAEzBxH,SAAA,CAEFF,EAAC2I,GAA2B,IAAAd,IAAuB3H,SACjDF,EAAC4I,GAAc,CAAA1M,OAAQA,MAEzB8D,EAAC6I,GAAiB,IAAKf,MACvB9H,EAAC2G,GACK,IAAAoB,EAAc,CAChBjH,KAAMuH,GAAMvH,MAAQ,OACpB8F,WAAYA,GAAc1K,EAAOsM,aAGrCxI,EAAC8I,OAAgCb,SAElC/H,GAAYF,EAACmG,GAAwB,IAAA6B,UAI9C,IAEc,SAAUe,KACtB,MAAMC,EAAWC,KACXlC,EAAiB1L,GAAazB,GAAqBA,EAAMoF,YACzD1D,EAAUD,GAAazB,GAAqBA,EAAM0B,QAAQf,QAC/CQ,IACjB,MAAMvC,EAAWF,MACX6K,iBAAEA,GAAqBD,KACvBgG,EAAc7M,GACXA,EACJ8M,QACEd,QACoB1L,IAAnB0L,EAAK/E,WACa,MAAlB+E,EAAK/E,WACLH,EAAiBkF,EAAK/E,aAEzB8F,KAAKf,IACAA,EAAKnI,WACPmI,EAAKnI,SAAWgJ,EAAWb,EAAKnI,WAE3BmI,KAIPgB,EAAwB,GAC1B/N,EAAQgO,4BACVD,EAAsBE,QAAQ3F,IAEhCyF,EAAsBE,QAAQjO,EAAQkO,yBACtC,MAAMC,EAA2BP,EAAWG,GAE5C,OACErJ,EAAC0J,GAAY,CACXC,MAAOF,EACPG,YAAa,CAACC,EAAOpC,KACnB,MAAMqC,EAAiBvG,GACrBkE,EACA4B,GAG2B,eAA3BS,GAAgBhQ,QACiB,MAAjCgQ,GAAgBhG,oBACanH,IAA5BmN,EAAe5J,UACc,OAA5B4J,EAAe5J,UACmB,GAAlC4J,EAAe5J,SAAS6C,QAE1BiG,EAASc,GAAgBhG,eAAeC,MAAQ,KAIpDtD,GAAI,CACFyD,OAAQ,cACR6F,SAAU,EACVC,SAAU/Q,GACVgR,UAAWlD,EAAetN,aAC1ByQ,UAAW1R,EAAW,SAAMmE,EAC5BwN,UAAW,OACXC,UAAW,QAEbC,MAAO,CAAEhC,KAAMf,KAGrB,CCtRA,MAAMgD,GAAoB,KACxB,MAAMhP,EAAUD,GAAazB,GAAqBA,EAAM0B,QAAQf,QAC1DwE,EAAQwL,IACRvL,EAAY3D,GAAazB,GAAqBA,EAAMoF,YACpDlE,EAAWC,IAIjB,OACEoF,EAACqK,GAAM,CACL/J,GAAI,CACFhB,MAAOxG,GACPwR,WAAY,EACZ,qBAAsB,CACpBhL,MAAOxG,GACPyR,UAAW,eAGfvJ,QAAQ,aACRwJ,OAAmC,QAA3B3L,EAAUvF,aAAyB,OAAS,QACpD+F,KAAMR,EAAU3F,cAEhB6G,SAAA,CAAAC,EAAC+B,GACC,CAAAhC,SAAA,CAAAC,EAAC8D,EAAI,CAAAxD,GAAI,CAAEhB,MAAO,QAAQS,SAAA,CACxBF,EAACkB,EAAU,CACTZ,MAAM,UACNG,GAAI,CACFhB,MAAO,OACPmL,UAAW,SACX3D,SAAU,GACVP,WAAY,QACbxG,SAAA,mBAIHC,EAAC8D,EAAG,CACFxD,GAAI,CACFG,QAAS,OACTuB,WAAY,SACZG,eAAgB,eAChB8C,UAAW,GACZlF,SAAA,CAEDF,EAACkB,EAAU,CAACT,GAAI,CAAEwG,SAAU,IAAM3G,MAAM,eAAcJ,SACnD5E,EAAQiG,UAEXpB,EAACe,EAAW,CAAAT,GAAI,CAAEwG,SAAU,IAAM3G,MAAM,eACnCJ,SAAA,CAAA,KAAA5E,EAAQuP,oBAIjB7K,EAACK,GAAU,CAACE,QA9CI,KACpBzF,EAASZ,GAAiBP,uBA8CnBuG,SAAoB,QAApBnB,EAAMkL,UACLjK,EAACa,GAAgB,CAAAC,KAAK,eAEtBd,EAACa,GAAgB,CAAAC,KAAK,qBAI5Bd,EAAC8K,OACD9K,EAAC+I,GAAiB,CAAA,OCtEXgC,GAAWC,GAAY,CAClCC,IAAK,SACLC,cAAe,CAACC,GAAUC,MAGfC,GAAWL,GAAY,CAClCC,IAAK,QCOMK,GAAyB9O,IACpC,MAAOgD,EAAM+L,GAAW7S,GAAkB,IACpC+J,EAAEA,GAAMqE,KAiCd,MAAO,CAAE0E,mBAhC4B,IAEjCrL,EAACsL,EAAM,CAACjM,KAAMA,YACZQ,EAAC0L,YAAalP,EAAMmP,QACpB3L,EAAC4L,EAAa,CAAA1L,SACZF,EAAC6L,EAAiB,CAAA3L,SAAE1D,EAAMsP,SAE5B3L,EAAC4L,EAAa,CAAA7L,SAAA,CACZF,EAACgM,EAAM,CACL7K,QAAQ,YACRb,MAAM,UACNC,QAAS,KACPgL,GAAQ,IACTrL,SAEAuC,EAAE,cAELzC,EAACgM,EAAM,CACL7K,QAAQ,YACRb,MAAM,QACNC,QAAS,KACP/D,EAAMyP,uBACNV,GAAQ,IAEVW,WAAS,EAAAhM,SAERuC,EAAE,qBAMgBjD,OAAM+L,YC5C/BY,GACJC,IAEA,MAAM3J,EAAEA,GAAMqE,KACRuF,EAAUnJ,MACVsI,mBAAEA,EAAkBD,QAAEA,GAAYD,GAAsB,CAC5DQ,KAAMrJ,EAAE2J,GAAWE,qBAAuB,uBAC1CX,MAAOlJ,EAAE,gBACTwJ,qBAAsB1P,gBACd6P,GAAWG,SACfH,EAAUI,yBACVJ,EAAUK,6BAERL,GAAWM,YACbN,EAAUM,gBAIhB,IAAIC,GAAkB,EAKtB,GAJIP,EAAU9I,YACZqJ,EAAkBN,EAAQlJ,iBAAiBiJ,EAAU9I,YAGnDqJ,EACF,OACExM,EAAAyM,EAAA,CAAA1M,SAAA,CACEF,EAACwL,EAAqB,CAAA,GACtBrL,EAAC6L,EACC,CAAAzL,QAAShE,UACP,GACE6P,GAAWI,0BACXJ,GAAWI,yBAAyBzJ,OAAS,EAC7C,CACA,GAAIqJ,GAAWS,oBACb,IAAK,MAAMC,KAAUV,EAAUI,yBAC7B,IAAKJ,EAAUS,oBAAoBC,GACjC,QAIoC,IAAtCV,GAAWW,uBACbxB,GAAQ,UAEFa,EAAUG,SACdH,EAAUI,yBACVJ,EAAUK,4BAERL,GAAWM,YACbN,EAAUM,mBAIdvQ,GAAMF,MAAMwG,EAAE,0CAGlBtB,QACEiL,GAAWvI,MACP,WACAuI,GAAWY,iBAAiBC,oBAC5Bb,EAAUY,gBAAgBC,oBAC1B,OAENC,KAAK,QACL5M,MAAO8L,GAAWY,iBAAiBG,mBAAqB,UAASjN,SAAA,CAEhEkM,GAAWtL,KACVd,EAACa,GACC,CAAAhJ,MAAO,CAAE8H,YAAa,EAAGD,WAAY,GACrCoB,KAAMsL,EAAUtL,OAGlBd,EAAK4M,EAAA,CAAA,GAENR,GAAWvI,MAAQpB,EAAE2J,EAAUvI,OAAS7D,EAAA4M,EAAA,WCjFtCQ,GAAc,aACdC,GAAmB,sBACnBC,GAAiC,UACjCC,GAAsC,UACtCC,GAAgC,UAChCC,GAAqC,UCa5CC,GAAuClR,IAC3C,MAAMiG,EAAEA,GAAMqE,KACd,OACE9G,EAAC2N,GAAoB,CAACC,YAAaC,GAAa3N,SAC9CF,EAAC8N,GACC,CAAAvT,MACiB,MAAfiC,EAAMjC,YAAiCoC,IAAhBH,EAAMjC,OAAuC,KAAhBiC,EAAMjC,MACtDwT,GAAOvR,EAAMjC,MAAOiC,GAAOwR,QAAUZ,IACrC,KAEN3M,GAAIjE,EAAMiE,GACVoD,MAAOpB,EAAEjG,EAAMqH,OACfmK,OAAQxR,GAAOwR,QAAUZ,GACzB1F,SAAUlL,EAAMkL,SAChBuG,SAAWC,IACT,IAAIC,EAAI,KACW,MAAfD,GAAuBA,EAAYE,YACrCD,EAAID,EAAYF,OAAOxR,GAAOwR,QAAUZ,UAGbzQ,IAA3BH,EAAM6R,kBACoB,MAA1B7R,EAAM6R,kBAEN7R,EAAM6R,iBAAiBF,IAG3BG,UAAW,CACTC,UAAW,CACTC,gBAAiB,CAAEC,QAAQ,GAC3BtN,QAAS,WACTuN,SAAUlS,EAAMkS,SAChBzS,WACyBU,IAAvBH,EAAMmS,cAAoD,MAAtBnS,EAAMmS,aAC5CC,gBACyBjS,IAAvBH,EAAMmS,cAAoD,MAAtBnS,EAAMmS,aACxC3O,EAAA4M,EAAA,CAAA1M,SAAGuC,EAAEjG,EAAMmS,gBAEX3O,eCrCV6O,GAA+CrS,IACnD,MAAMiG,EAAEA,GAAMqE,KACd,OACE9G,EAAC2N,GAAoB,CAACC,YAAaC,GAAa3N,SAC9CF,EAAC8O,GACC,CAAAvU,MACiB,MAAfiC,EAAMjC,YAAiCoC,IAAhBH,EAAMjC,OAAuC,KAAhBiC,EAAMjC,MACtDwT,GAAOvR,EAAMjC,MAAOiC,GAAOwR,QAAUX,IACrC,KAENxJ,MAAOpB,EAAEjG,EAAMqH,OACfpD,GAAIjE,EAAMiE,GACVuN,OAAQxR,GAAOwR,QAAUX,GACzB3F,SAAUlL,EAAMkL,SAChBuG,SAAWC,IACT,IAAIC,EAAI,KACW,MAAfD,GAAuBA,EAAYE,YACrCD,EAAID,EAAYF,OAAOxR,GAAOwR,QAAUX,UAGb1Q,IAA3BH,EAAM6R,kBACoB,MAA1B7R,EAAM6R,kBAEN7R,EAAM6R,iBAAiBF,IAG3BG,UAAW,CACTC,UAAW,CACTpN,QAAS,WACTuN,SAAUlS,EAAMkS,SAChBzS,WACyBU,IAAvBH,EAAMmS,cAAoD,MAAtBnS,EAAMmS,aAC5CC,gBACyBjS,IAAvBH,EAAMmS,cAAoD,MAAtBnS,EAAMmS,aACxC3O,EAAA4M,EAAA,CAAA1M,SAAGuC,EAAEjG,EAAMmS,gBAEX3O,eCpCV+O,GAAqCvS,IACzC,MAAMwS,EAAiB3T,GAAazB,GAAqBA,EAAMoF,aACzDyD,EAAEA,GAAMqE,KASd,OACE9G,EAACiP,EACC,CAAAxO,GAAIjE,EAAMiE,GACVlG,MAXa,CAAC4T,IAChB,IAAK,IAAIe,KAAU1S,EAAM2S,QACvB,GAAID,EAAO1S,EAAM4S,aAAejB,EAC9B,OAAOe,EAGX,OAAO,MAKEG,CAAS7S,EAAMjC,OACtB4U,QAAS3S,EAAM2S,QACfzH,SAAUlL,EAAMkL,SAChBuG,SAAU,CAACpE,EAAOyF,KAChB,QAC6B3S,IAA3BH,EAAM6R,kBACoB,MAA1B7R,EAAM6R,iBAEN,GAAgB,MAAZiB,EAAkB,CACpB,IAAInB,EAAImB,EAAS9S,EAAM4S,YACvB5S,EAAM6R,iBAAiBF,EAAGmB,QAE1B9S,EAAM6R,iBAAiB,KAAM,OAInCkB,aAAW,EACXC,mBAAiB,EACjBC,eAAiBP,GACE,MAAVA,EAAiBzM,EAAEyM,EAAO1S,EAAMkT,eAAiB,GAE1DC,aAAc,CAACC,EAAQV,IAEnBlP,EAAQ,KAAA,IAAA4P,EACL1P,SAAU,MAAVgP,EAAiBzM,EAAEyM,EAAO1S,EAAMkT,eAAiB,KAIxDrF,MAAO,CACLwF,OAASrT,GACPwD,EAAC8P,EACK,IAAAtT,EACJ3E,MAAO,IAAK2E,EAAM3E,MAAOoS,UAAW+E,EAAevV,iBAIzDsW,YAAchT,GAEViD,EAACgQ,EAAS,IACJjT,EACJ2R,SAAUlS,EAAMkS,WAAY,EAC5BvN,QAAQ,WACRqN,gBAAiB,CAAEC,QAAQ,GAC3B5K,MAAOpB,EAAEjG,EAAMqH,OACf5H,MACwB,MAAtBO,EAAMmS,mBAA+ChS,IAAvBH,EAAMmS,aAItCC,WACwB,MAAtBpS,EAAMmS,mBAA+ChS,IAAvBH,EAAMmS,aAChClM,EAAEjG,EAAMmS,cACR,QCtEZsB,GAAqCzT,IACzC,MAAMiG,EAAEA,GAAMqE,KACd,OACE9G,EAACkQ,EACC,CAAAzP,GAAIjE,EAAMiE,GACViH,SAAUlL,EAAMkL,WAAY,EAC5BgH,SAAUlS,EAAMkS,WAAY,EAC5ByB,QACEnQ,EAACoQ,EACC,CAAAC,QACE7T,GAAO8T,cAAgB9T,EAAMjC,OACb,SAAhBiC,EAAMjC,OACS,KAAfiC,EAAMjC,MAIR0T,SAAWzL,SAEoB7F,IAA3BH,EAAM6R,kBACoB,MAA1B7R,EAAM6R,mBAEF7L,EAAE+N,OAAOF,aAEc1T,IAAvBH,EAAM8T,cACgB,MAAtB9T,EAAM8T,aAEN9T,EAAM6R,iBAAiB7R,EAAM8T,cAE7B9T,EAAM6R,iBAAiB,aAIE1R,IAAzBH,EAAMgU,gBACkB,MAAxBhU,EAAMgU,eAENhU,EAAM6R,iBAAiB7R,EAAMgU,gBAE7BhU,EAAM6R,iBAAiB,aAOnCxK,MAAOpB,EAAEjG,EAAMqH,UCfR4M,GAA+BC,IACP,IAC9BA,EACH3Y,KAAM,SACN4Y,eAAiB5T,GAEbiD,EAAC6O,GACC,CAAApO,GAAI,CAAEhB,MAAO,QACboE,MAAM,GACNtJ,MAAOwC,EAAOxC,MACd8T,iBAAmBF,IACjBpR,EAAO6T,IAAIC,iBAAiB,CAC1BrN,GAAIzG,EAAOyG,GACXsN,MAAO/T,EAAO+T,MACdvW,MAAO4T,OAMjB4C,YAAa,CAACxW,EAAYyW,EAAUC,KAClC,IAAI9C,EAAI,KAIR,OAHc,OAAV5T,IACF4T,EAAIJ,GAAOxT,GAAOyT,OAAOX,KAEpBc,GAET+C,eAAgB,CAAC3W,EAAYyW,EAAUC,IAC9BD,EAAIC,EAAOH,SAWXK,GAEcT,IACU,IAC9BA,EACH3Y,KAAM,SACNqZ,YAAc7W,GACRA,EACKA,EAAQ,GAEVA,EAET8W,WAAa3U,IACX,IAAIoQ,EAAS,KACb,IACEA,EAASpQ,EAAWgU,OAAOvB,QAAQmC,MAChCjJ,GAAcA,EAAK3L,EAAWgU,OAAOtB,aAAe1S,EAAWnC,QAElE,MAAOiI,GAAG,CACZ,OACExC,EAAA,MAAA,CAAAE,SACa,MAAV4M,EACGA,EAAOpQ,EAAWgU,OAAOhB,cACzBhT,EAAWnC,SAKrBoW,eAAiB5T,GAEbiD,EAAC+O,GACK,IAAAhS,EACJ0D,GAAI,CAAEhB,MAAO,QACb0P,QAASuB,EAAOvB,QAChBC,WAAYsB,EAAOtB,WACnBM,aAAcgB,EAAOhB,aACrBrB,iBAAkB,CAACF,EAAQoD,KACf,OAANpD,GACFpR,EAAO6T,IAAIC,iBAAiB,CAC1BrN,GAAIzG,EAAOyG,GACXsN,MAAO/T,EAAO+T,MACdvW,MAAO,OAGXwC,EAAO6T,IAAIC,iBAAiB,CAC1BrN,GAAIzG,EAAOyG,GACXsN,MAAO/T,EAAO+T,MACdvW,MAAO4T,EAAI,UAeZqD,GAEcd,IAClB,IACFA,EACH3Y,KAAM,SACNqZ,YAAc7W,GACC,MAATA,GAA0BoC,MAATpC,EACZ,KAEAA,EAAQ,GAGnB8W,WAAa3U,IACX,MAAMnC,EAAQmC,GAAYnC,MAC1B,OACEA,IAAUmW,EAAOJ,cACP,SAAV/V,GACU,IAAVA,IACU,IAAVA,EAEOyF,EAACa,GAAe,CAACC,KAAK,QAAQR,MAAM,UAEpCN,EAACa,GAAe,CAACC,KAAK,QAAQR,MAAM,SAG/CqQ,eAAiB5T,GAEbiD,EAACiQ,GACK,IAAAlT,EACJuT,aAAcI,GAAQJ,cAAgB,OACtCE,eAAgBE,GAAQF,gBAAkB,QAC1CnC,iBAAmBF,IACjBpR,EAAO6T,IAAIC,iBAAiB,CAC1BrN,GAAIzG,EAAOyG,GACXsN,MAAO/T,EAAO+T,MACdvW,MAAO4T,EAAI,UCrKZsD,GAEmBC,IAC9B,MAAMC,EAAkC,GACxC,GAAqB,UAAjBD,EAAQ3Z,MAAqC,UAAjB2Z,EAAQE,MAAoBF,GAASlV,MACnEmV,EAAOpI,KAAKmI,EAAQlV,YACf,GACY,UAAjBkV,EAAQ3Z,MACR2Z,GAASlV,OACTkV,GAASlV,OAAOqV,SAEhB,IAAK,MAAMC,KAAgBJ,EAAQlV,MAAMqV,SACvCF,EAAOpI,QAAQkI,GAAiBK,IAGpC,OAAOH,GAGII,GAEmBF,IAC9B,MAAMF,EAAkC,GACxC,IAAK,MAAMD,KAAWG,EACpBF,EAAOpI,QAAQkI,GAAiBC,IAElC,OAAOC,GAkGIK,GAA6BL,IACxC,MAAMM,EAA2B,CAAE,EACnC,IAAK,MAAMnB,KAASa,EAClB,GAAIb,GAAOoB,UAAW,CACpB,MAAMA,EAAYpB,EAAMoB,UACA,WAApBpB,EAAMqB,UAENF,EAAoBC,IADE,IAApBpB,GAAOpC,SACwB0D,GAAEC,OAAO,CACxCC,eAAgB,yBAChBC,mBAAoB,gCAGWH,GAAEC,SAASG,WAAWC,WAIvDR,EAAoBC,IADE,IAApBpB,GAAOpC,SACwB0D,GAC9BM,OAAO,CAAEjY,QAAS,2BAClBkY,IAAI,EAAG,0BAEuBP,GAAEM,SAASF,WAAWC,WAK/D,OAAOR,GC/HHW,GAAoBjU,EAAOkU,GAAPlU,CAAoB,CAC5CiC,QAAS,OACTuB,WAAY,WAGR2Q,GAAsBnU,EAAOoU,GAAPpU,EAC1B,EAAGI,QAAOiU,iBAAkB,CAC1BC,SAAU,QACVxT,MAAO,cACPyE,OAAQ,cACRI,OAAQ,EACRgC,QAAS0M,EAAWxK,SAAW,EAAI,EACnC0K,cAAeF,EAAWxK,SAAW,OAAS,OAC9CvJ,WAAYF,EAAMG,YAAYzD,OAAO,CAAC,gBAIpC0X,GAAkBxU,EAAOqR,EAAPrR,EAErB,EAAGI,QAAOiU,iBAAkB,CAC7BC,SAAU,QACV7I,UAAW,OACX3K,MAAOuT,EAAWxK,SAAW,IAAM,uBACnClC,QAAS0M,EAAWxK,SAAW,EAAI,EACnCvJ,WAAYF,EAAMG,YAAYzD,OAAO,CAAC,QAAS,gBAG3C2X,GACJ5W,IAEA,MAAMiG,EAAEA,GAAMqE,KACRuF,EAAUnJ,KACVmQ,GAAuB7W,GAAO8W,eAAeC,YAAYjQ,WAC3D+I,EAAQlJ,iBAAiB3G,EAAM8W,cAAcC,WAAWjQ,WAGtDkQ,EDuGa,EACnBC,EACApX,EACAqX,KAEA,MAAMC,EAAW,GACXC,EAAa,GACnB,GAC6B,YAA3BH,EAAkB1b,MACa,IAA/B0b,EAAkBI,IAAI3G,KAEtB,IAAK,MAAMJ,KAAUzQ,EACnBsX,EAASpK,KAAKuD,GACd8G,EAAWrK,KAAKuD,EAAO4G,SAGzB,GAAID,GAAmBI,IACrB,IAAK,MAAMC,KAAcL,EAAkBI,IAAK,CAC9C,MAAM/G,EAASzQ,EAAKiV,MAAMyC,GAAMA,EAAEL,KAAmBI,IACrDH,EAASpK,KAAKuD,GACd8G,EAAWrK,KAAKuK,GAItB,MAAO,CAAEE,gBAAiBL,EAAUM,kBAAmBL,IC/HjCM,CACpB1X,GAAO8W,eAAeG,mBAAqB,CACzCI,IAAK,IAAIM,IACTpc,KAAM,WAERyE,GAAO8W,eAAejX,MAAQ,GAC9BG,GAAO8W,eAAeI,eAAiB,MAEzC,OACEvT,EAACC,GAAO,CAAAF,SAAA,CAENmT,GAC4C,QAA5C7W,GAAO8W,eAAec,UAAUA,SAC9BjU,EAAC6L,EAAO,CAAAzL,QAAS/D,GAAO6X,sBAAqBnU,SAAA,CAC3CF,EAACa,IACCC,KAAK,MACLjJ,MAAO,CAAE8H,YAAa,EAAGD,WAAY,KAEtC+C,EAAE,oBAGLzC,QAEDxD,GAAO8W,eAAegB,WACrB9X,EAAM8W,cAAcgB,WAAWlL,KAAKgD,IACU,IAA5CA,GAAWmI,iBAAiBC,YAC1BxU,EAACmM,GACK,IAAAC,EACJM,WAAYnQ,UACVC,EAAM8W,cAAcmB,WAAW/H,WAC7BlQ,GAAO8W,eAAeoB,2BAG1BjI,2BAA4B+G,EAAcS,kBAC1CzH,yBAA0BgH,EAAcQ,kBAG1ChU,EAAK4M,EAAA,MAIT5M,EAAK4M,EAAA,CAAA,GAEP5M,EAACiE,EAAI,CAAAxD,GAAI,CAAEa,KAAM,EAAGiD,GAAI,IAAKrE,SAAG1D,GAAO8W,eAAeqB,OAEtD3U,EAAC4U,EAAQ,CAAAjJ,MAAM,UAASzL,SACtBF,EAAC6U,GAAmB,CAACC,OAAQ9U,EAAC+S,GAAa,CAAA,YACzC/S,EAAC+U,IAAmB9N,SAAS,cAIjCjH,EAAC4U,EAAQ,CAAAjJ,MAAM,UAASzL,SACtBF,EAACgV,GAAkB,CACjBF,OAAQ,CAACtY,EAAO5C,IACdoG,EAAC+S,GAAa,IAAKvW,EAAO8D,MAAM,UAASJ,SACvCF,EAACiV,EAAK,CACJC,aAActb,EAAMub,YACpB7U,MAAM,UACNa,QAAQ,MAAKjB,SAEbF,EAACoV,GAAkB,CAACnO,SAAS,kBAOtCzK,GAAO8W,eAAe+B,aACrBrV,EAAC4U,EAAO,CAACjJ,MAAOlJ,EAAE,oBAChBvC,SAAAF,EAACK,EAAW,CAAAE,QAAS/D,GAAO8Y,eAC1BpV,SAAAF,EAACa,GAAgB,CAAAC,KAAK,eAI1Bd,EAAA4M,EAAA,CAAA,GAGF5M,EAAC8K,EACC,CAAAyK,YAAY,WACZpU,QAAQ,SACRqU,YACA/U,GAAI,CAAE8D,GAAI,MAGZvE,EAAC4U,EAAQ,CAAAjJ,MAAOlJ,EAAE,+BAChBzC,EAACyV,IAAYX,OAAQ9U,EAAC0V,EAAQ,CAAA,GAC5BxV,SAAAF,EAACa,GAAgB,CAAAC,KAAK,aAAaR,MAAM,cAI7CH,EAACyS,GACC,CAAA1S,SAAA,CAAAF,EAAC2V,GACC,CAAAb,OAAQ,CAACc,EAAchc,IACrBoG,EAAC4U,GAAQjJ,MAAOlJ,EAAE,oBAAqBoT,WAAY,EAAC3V,SAClDF,EAAC8S,OACK8C,EACJ5C,WAAY,CAAExK,SAAU5O,EAAM4O,UAC9BlI,MAAM,UAAS,gBACA1G,EAAM4O,SAErBtI,SAAAF,EAACa,GAAgB,CAAAC,KAAK,iBAK9Bd,EAAC8V,GACC,CAAAhB,OAAQ,EAAGtd,SAAQue,GAAgBnc,IACjCoG,EAACmT,GAAe,IACV4C,EACJ/C,WAAY,CAAExK,SAAU5O,EAAM4O,UAC9BwN,SAAUxe,EAAG,aACF,SACXye,YAAa,GAAGxT,EAAE,yBAClByK,KAAK,QACLoB,UAAW,CACT4H,MAAO,CACLC,eACEnW,EAACoW,EAAc,CAACnW,SAAS,QACvBC,SAAAF,EAACa,GAAgB,CAAAC,KAAK,aAG1BuV,aAAczc,EAAMW,MAClByF,EAACoW,EAAc,CAACnW,SAAS,eACvBD,EAACsW,IACC9V,KAAK,MACL0M,KAAK,qBACM,eAAchN,SAGzBF,EAACa,GAAe,CAACC,KAAK,cAGxB,QACDiV,EAAazH,WAAW4H,UAE1BH,EAAazH,kBAO1BtO,EAACK,EACC,CAAAE,QAAS,KACP/D,EAAM8W,cAAcmB,WAAW/H,WAC7BlQ,GAAO8W,eAAeoB,2BAEzBxU,SAEDF,EAACa,GAAgB,CAAAC,KAAK,kBC7NxB,SAAUyV,GAAcC,GAC5B,MAAO,QAAQC,KAAKD,EACtB,CAEM,SAAUE,GAASnc,GACvB,MAAwB,iBAAVA,IAAuBoc,MAAMpc,EAC7C,CAEM,SAAUqc,GAAUrc,GACxB,MACmB,iBAAVA,GAAuC,KAAjBA,EAAMsc,SAAkBF,MAAMG,OAAOvc,GAEtE,CAEM,SAAUwc,GAAsBP,GACpC,OAAKA,EACEA,EAAIQ,OAAO,GAAGC,cAAgBT,EAAIU,MAAM,GAD9B,EAEnB,CCTA,MAAMC,GACJ/K,IAEA,MAAM3J,EAAEA,GAAMqE,KACRuF,EAAUnJ,MACVsI,mBAAEA,EAAkBD,QAAEA,GAAYD,GAAsB,CAC5DQ,KAAMrJ,EAAE2J,GAAWE,qBAAuB,uBAC1CX,MAAOlJ,EAAE,gBACTwJ,qBAAsB1P,gBACd6P,GAAWG,SAASH,EAAUU,SAChCV,GAAWM,YACbN,EAAUM,gBAIhB,IAAIC,GAAkB,EAClBP,EAAU9I,YACZqJ,EAAkBN,EAAQlJ,iBAAiBiJ,EAAU9I,YAEvD,IAAI8T,EAAiB,CAAE,EACnBhL,GAAWiL,8BACbD,EAAYhL,EAAUiL,4BAA4BjL,EAAUU,SAE9D,IAAIwK,GAA2B,EAC3BlL,GAAWkL,2BACbA,EAA2BlL,GAAWkL,yBACpClL,EAAUU,SAGd,IAAIyK,GAA4B,EAMhC,GALInL,GAAWmL,4BACbA,EAA4BnL,EAAUmL,0BACpCnL,EAAUU,SAGVH,GAAmB2K,EACrB,OACEnX,eACEH,EAACwL,MACDxL,EAACwX,GACC,CAAA9P,SAAU6P,EACVzW,KACEd,EAAC4U,EAAQ,CAAAjJ,MAAOS,GAAWvI,MAAQpB,EAAE2J,EAAUvI,OAAS,YACtD7D,EAACa,IACCC,KAAMsL,EAAUtL,KAChBjJ,MAAO,IACFuf,EACH9W,MAAOiX,EACH,OACoB5a,MAApBya,GAAW9W,MACX8W,EAAU9W,WACV3D,OAKZ8a,WAAYrL,GAAWmI,iBAAiBkD,aAAc,EACtD5T,MAAO,GACP0E,UAAU,cACVjI,MAAM,UACNC,QAAShE,UACP,IAAKgb,EAA2B,CAC9B,GAAInL,GAAWS,sBACRT,EAAUS,oBAAoBT,EAAUU,QAC3C,QAGsC,IAAtCV,GAAWW,uBACbxB,GAAQ,UAEFa,EAAUG,SAASH,EAAUU,QAC/BV,GAAWM,YACbN,EAAUM,sBCtEb,SAASgL,GAAsBC,KAASC,GACrD,MAAMC,EAAM,IAAIC,IAAI,0CAA0CH,KAE9D,OADAC,EAAKG,SAAQC,GAAOH,EAAII,aAAaC,OAAO,SAAUF,KAC/C,uBAAuBL,YAAeE,yBAC/C;;;;;;;;kCCZ6B,eAAzBM,QAAQC,IAAIC,SACdC,GAAAC,wCCMW,IAAIC,EAAE,mBAAoBC,QAAQA,OAAOC,IAAIC,EAAEH,EAAEC,OAAOC,IAAI,iBAAiB,MAAME,EAAEJ,EAAEC,OAAOC,IAAI,gBAAgB,MAAMlW,EAAEgW,EAAEC,OAAOC,IAAI,kBAAkB,MAAMhW,EAAE8V,EAAEC,OAAOC,IAAI,qBAAqB,MAAMG,EAAEL,EAAEC,OAAOC,IAAI,kBAAkB,MAAMI,EAAEN,EAAEC,OAAOC,IAAI,kBAAkB,MAAMK,EAAEP,EAAEC,OAAOC,IAAI,iBAAiB,MAAMM,EAAER,EAAEC,OAAOC,IAAI,oBAAoB,MAAMO,EAAET,EAAEC,OAAOC,IAAI,yBAAyB,MAAM/V,EAAE6V,EAAEC,OAAOC,IAAI,qBAAqB,MAAMQ,EAAEV,EAAEC,OAAOC,IAAI,kBAAkB,MAAMS,EAAEX,EACpfC,OAAOC,IAAI,uBAAuB,MAAMnW,EAAEiW,EAAEC,OAAOC,IAAI,cAAc,MAAMjW,EAAE+V,EAAEC,OAAOC,IAAI,cAAc,MAAMvK,EAAEqK,EAAEC,OAAOC,IAAI,eAAe,MAAMU,EAAEZ,EAAEC,OAAOC,IAAI,qBAAqB,MAAM3E,EAAEyE,EAAEC,OAAOC,IAAI,mBAAmB,MAAMW,EAAEb,EAAEC,OAAOC,IAAI,eAAe,MAClQ,SAAStG,EAAEkH,GAAG,GAAG,iBAAkBA,GAAG,OAAOA,EAAE,CAAC,IAAIC,EAAED,EAAEE,SAAS,OAAOD,GAAG,KAAKZ,EAAE,OAAOW,EAAEA,EAAEvhB,MAAQ,KAAKihB,EAAE,KAAKC,EAAE,KAAKzW,EAAE,KAAKqW,EAAE,KAAKnW,EAAE,KAAKwW,EAAE,OAAOI,EAAE,QAAQ,OAAOA,EAAEA,GAAGA,EAAEE,UAAY,KAAKT,EAAE,KAAKpW,EAAE,KAAKF,EAAE,KAAKF,EAAE,KAAKuW,EAAE,OAAOQ,EAAE,QAAQ,OAAOC,GAAG,KAAKX,EAAE,OAAOW,EAAE,CAAC,CAAC,SAASE,EAAEH,GAAG,OAAOlH,EAAEkH,KAAKL,CAAC,QAACS,GAAiBC,UAACX,EAAEU,GAAAE,eAAuBX,EAAES,GAAuBG,gBAACd,EAAEW,mBAAwBZ,EAAEY,GAAAI,QAAgBnB,EAAEe,GAAkBK,WAACpX,EAAE+W,GAAAM,SAAiBxX,EAAEkX,GAAYO,KAACxX,EAAEiX,QAAanX,EAAEmX,GAAAQ,OAAetB,EAChfc,GAAAS,SAAiBtB,EAAEa,GAAAU,WAAmB1X,EAAEgX,GAAAW,SAAiBnB,EAAEQ,GAAAY,YAAoB,SAAShB,GAAG,OAAOG,EAAEH,IAAIlH,EAAEkH,KAAKN,CAAC,EAAEU,GAAwBa,iBAACd,EAAEC,GAAyBc,kBAAC,SAASlB,GAAG,OAAOlH,EAAEkH,KAAKP,CAAC,EAAEW,GAAyBe,kBAAC,SAASnB,GAAG,OAAOlH,EAAEkH,KAAKR,CAAC,EAAEY,GAAiBgB,UAAC,SAASpB,GAAG,MAAM,iBAAkBA,GAAG,OAAOA,GAAGA,EAAEE,WAAWb,CAAC,EAAEe,GAAoBiB,aAAC,SAASrB,GAAG,OAAOlH,EAAEkH,KAAK3W,CAAC,EAAE+W,GAAkBkB,WAAC,SAAStB,GAAG,OAAOlH,EAAEkH,KAAK9W,CAAC,EAAEkX,GAAcmB,OAAC,SAASvB,GAAG,OAAOlH,EAAEkH,KAAK7W,CAAC,EAC1diX,GAAAoB,OAAe,SAASxB,GAAG,OAAOlH,EAAEkH,KAAK/W,CAAC,EAAEmX,YAAiB,SAASJ,GAAG,OAAOlH,EAAEkH,KAAKV,CAAC,EAAEc,GAAkBqB,WAAC,SAASzB,GAAG,OAAOlH,EAAEkH,KAAKT,CAAC,EAAEa,GAAAsB,aAAqB,SAAS1B,GAAG,OAAOlH,EAAEkH,KAAK5W,CAAC,EAAEgX,GAAkBuB,WAAC,SAAS3B,GAAG,OAAOlH,EAAEkH,KAAKJ,CAAC,EAChNQ,GAAAwB,mBAAC,SAAS5B,GAAG,MAAM,iBAAkBA,GAAG,mBAAoBA,GAAGA,IAAI9W,GAAG8W,IAAIL,GAAGK,IAAIT,GAAGS,IAAI5W,GAAG4W,IAAIJ,GAAGI,IAAIH,GAAG,iBAAkBG,GAAG,OAAOA,IAAIA,EAAEE,WAAW/W,GAAG6W,EAAEE,WAAWjX,GAAG+W,EAAEE,WAAWV,GAAGQ,EAAEE,WAAWT,GAAGO,EAAEE,WAAW7W,GAAG2W,EAAEE,WAAWJ,GAAGE,EAAEE,WAAWzF,GAAGuF,EAAEE,WAAWH,GAAGC,EAAEE,WAAWrL,EAAE,EAAEuL,GAAcyB,OAAC/I,KDXhTgJ,GAEjB9C,GAAAC,mBEQ2B,eAAzBJ,QAAQC,IAAIC,UACd,WAKF,IAAIgD,EAA8B,mBAAX5C,QAAyBA,OAAOC,IACnD4C,EAAqBD,EAAY5C,OAAOC,IAAI,iBAAmB,MAC/D6C,EAAoBF,EAAY5C,OAAOC,IAAI,gBAAkB,MAC7D8C,EAAsBH,EAAY5C,OAAOC,IAAI,kBAAoB,MACjE+C,EAAyBJ,EAAY5C,OAAOC,IAAI,qBAAuB,MACvEgD,EAAsBL,EAAY5C,OAAOC,IAAI,kBAAoB,MACjEiD,EAAsBN,EAAY5C,OAAOC,IAAI,kBAAoB,MACjEkD,EAAqBP,EAAY5C,OAAOC,IAAI,iBAAmB,MAG/DmD,EAAwBR,EAAY5C,OAAOC,IAAI,oBAAsB,MACrEoD,EAA6BT,EAAY5C,OAAOC,IAAI,yBAA2B,MAC/EqD,EAAyBV,EAAY5C,OAAOC,IAAI,qBAAuB,MACvEsD,EAAsBX,EAAY5C,OAAOC,IAAI,kBAAoB,MACjEuD,EAA2BZ,EAAY5C,OAAOC,IAAI,uBAAyB,MAC3EwD,EAAkBb,EAAY5C,OAAOC,IAAI,cAAgB,MACzDyD,EAAkBd,EAAY5C,OAAOC,IAAI,cAAgB,MACzD0D,EAAmBf,EAAY5C,OAAOC,IAAI,eAAiB,MAC3D2D,EAAyBhB,EAAY5C,OAAOC,IAAI,qBAAuB,MACvE4D,EAAuBjB,EAAY5C,OAAOC,IAAI,mBAAqB,MACnE6D,EAAmBlB,EAAY5C,OAAOC,IAAI,eAAiB,MAO/D,SAASyC,EAAOqB,GACd,GAAsB,iBAAXA,GAAkC,OAAXA,EAAiB,CACjD,IAAIhD,EAAWgD,EAAOhD,SAEtB,OAAQA,GACN,KAAK8B,EACH,IAAIvjB,EAAOykB,EAAOzkB,KAElB,OAAQA,GACN,KAAK8jB,EACL,KAAKC,EACL,KAAKN,EACL,KAAKE,EACL,KAAKD,EACL,KAAKO,EACH,OAAOjkB,EAET,QACE,IAAI0kB,EAAe1kB,GAAQA,EAAKyhB,SAEhC,OAAQiD,GACN,KAAKb,EACL,KAAKG,EACL,KAAKI,EACL,KAAKD,EACL,KAAKP,EACH,OAAOc,EAET,QACE,OAAOjD,GAKjB,KAAK+B,EACH,OAAO/B,EAEf,CAGC,CAED,IAAIG,EAAYkC,EACZjC,EAAiBkC,EACjBjC,EAAkB+B,EAClBc,EAAkBf,EAClB7B,EAAUwB,EACVvB,EAAagC,EACb/B,EAAWwB,EACXvB,EAAOkC,EACPQ,EAAOT,EACPhC,EAASqB,EACTpB,EAAWuB,EACXtB,EAAaqB,EACbpB,EAAW2B,EACXY,GAAsC,EAa1C,SAASrC,EAAiBiC,GACxB,OAAOrB,EAAOqB,KAAYV,CAC5B,CAmCAe,GAAAlD,UAAoBA,EACpBkD,GAAAjD,eAAyBA,EACzBiD,GAAAhD,gBAA0BA,EAC1BgD,GAAAH,gBAA0BA,EAC1BG,GAAA/C,QAAkBA,EAClB+C,GAAA9C,WAAqBA,EACrB8C,GAAA7C,SAAmBA,EACnB6C,GAAA5C,KAAeA,EACf4C,GAAAF,KAAeA,EACfE,GAAA3C,OAAiBA,EACjB2C,GAAA1C,SAAmBA,EACnB0C,GAAAzC,WAAqBA,EACrByC,GAAAxC,SAAmBA,EACnBwC,GAAAvC,YA7DA,SAAqBkC,GASnB,OAPOI,IACHA,GAAsC,EAEtC7a,QAAc,KAAE,kLAIbwY,EAAiBiC,IAAWrB,EAAOqB,KAAYX,CACxD,EAoDAgB,GAAAtC,iBAA2BA,EAC3BsC,GAAArC,kBAjDA,SAA2BgC,GACzB,OAAOrB,EAAOqB,KAAYZ,CAC5B,EAgDAiB,GAAApC,kBA/CA,SAA2B+B,GACzB,OAAOrB,EAAOqB,KAAYb,CAC5B,EA8CAkB,GAAAnC,UA7CA,SAAmB8B,GACjB,MAAyB,iBAAXA,GAAkC,OAAXA,GAAmBA,EAAOhD,WAAa8B,CAC9E,EA4CAuB,GAAAlC,aA3CA,SAAsB6B,GACpB,OAAOrB,EAAOqB,KAAYT,CAC5B,EA0CAc,GAAAjC,WAzCA,SAAoB4B,GAClB,OAAOrB,EAAOqB,KAAYhB,CAC5B,EAwCAqB,GAAAhC,OAvCA,SAAgB2B,GACd,OAAOrB,EAAOqB,KAAYL,CAC5B,EAsCAU,GAAA/B,OArCA,SAAgB0B,GACd,OAAOrB,EAAOqB,KAAYN,CAC5B,EAoCAW,GAAAC,SAnCA,SAAkBN,GAChB,OAAOrB,EAAOqB,KAAYjB,CAC5B,EAkCAsB,GAAA9B,WAjCA,SAAoByB,GAClB,OAAOrB,EAAOqB,KAAYd,CAC5B,EAgCAmB,GAAA7B,aA/BA,SAAsBwB,GACpB,OAAOrB,EAAOqB,KAAYf,CAC5B,EA8BAoB,GAAA5B,WA7BA,SAAoBuB,GAClB,OAAOrB,EAAOqB,KAAYR,CAC5B,EA4BAa,GAAA3B,mBAxIA,SAA4BnjB,GAC1B,MAAuB,iBAATA,GAAqC,mBAATA,GAC1CA,IAASyjB,GAAuBzjB,IAAS+jB,GAA8B/jB,IAAS2jB,GAAuB3jB,IAAS0jB,GAA0B1jB,IAASikB,GAAuBjkB,IAASkkB,GAA4C,iBAATlkB,GAA8B,OAATA,IAAkBA,EAAKyhB,WAAa2C,GAAmBpkB,EAAKyhB,WAAa0C,GAAmBnkB,EAAKyhB,WAAamC,GAAuB5jB,EAAKyhB,WAAaoC,GAAsB7jB,EAAKyhB,WAAauC,GAA0BhkB,EAAKyhB,WAAa6C,GAA0BtkB,EAAKyhB,WAAa8C,GAAwBvkB,EAAKyhB,WAAa+C,GAAoBxkB,EAAKyhB,WAAa4C,EACplB,EAsIAS,GAAA1B,OAAiBA,CACd,CArKD;;;;;qCCNF,IAAI4B,EAAwBC,OAAOD,sBAC/BE,EAAiBD,OAAOE,UAAUD,eAClCE,EAAmBH,OAAOE,UAAUE,4BAsDxCC,GA5CA,WACC,IACC,IAAKL,OAAOM,OACX,OAAO,EAMR,IAAIC,EAAQ,IAAIC,OAAO,OAEvB,GADAD,EAAM,GAAK,KACkC,MAAzCP,OAAOS,oBAAoBF,GAAO,GACrC,OAAO,EAKR,IADA,IAAIG,EAAQ,CAAE,EACLC,EAAI,EAAGA,EAAI,GAAIA,IACvBD,EAAM,IAAMF,OAAOI,aAAaD,IAAMA,EAKvC,GAAwB,eAHXX,OAAOS,oBAAoBC,GAAOtU,KAAI,SAAUzG,GAC5D,OAAO+a,EAAM/a,EAChB,IACakb,KAAK,IACf,OAAO,EAIR,IAAIC,EAAQ,CAAE,EAId,MAHA,uBAAuBC,MAAM,IAAIhG,SAAQ,SAAUiG,GAClDF,EAAME,GAAUA,CACnB,IAEI,yBADEhB,OAAOiB,KAAKjB,OAAOM,OAAO,CAAE,EAAEQ,IAAQD,KAAK,GAM/C,CAAC,MAAOK,GAER,OAAO,CACT,CACA,CAEiBC,GAAoBnB,OAAOM,OAAS,SAAU/M,EAAQ6N,GAKtE,IAJA,IAAIC,EAEAC,EADAjY,EAtDL,SAAkBkY,GACjB,GAAIA,QACH,MAAM,IAAIC,UAAU,yDAGrB,OAAOxB,OAAOuB,EACf,CAgDUE,CAASlO,GAGTmO,EAAI,EAAGA,EAAIzb,UAAUF,OAAQ2b,IAAK,CAG1C,IAAK,IAAIzT,KAFToT,EAAOrB,OAAO/Z,UAAUyb,IAGnBzB,EAAe0B,KAAKN,EAAMpT,KAC7B5E,EAAG4E,GAAOoT,EAAKpT,IAIjB,GAAI8R,EAAuB,CAC1BuB,EAAUvB,EAAsBsB,GAChC,IAAK,IAAIV,EAAI,EAAGA,EAAIW,EAAQvb,OAAQ4a,IAC/BR,EAAiBwB,KAAKN,EAAMC,EAAQX,MACvCtX,EAAGiY,EAAQX,IAAMU,EAAKC,EAAQX,IAGnC,CACA,CAEC,OAAOtX,CACP,+CC9EDuY,GAF2B,gFCT3BC,GAAiBC,SAASH,KAAKI,KAAK/B,OAAOE,UAAUD,oDCSrD,IAAI+B,EAAe,WAAa,EAEhC,GAA6B,eAAzB7G,QAAQC,IAAIC,SAA2B,CACzC,IAAI4G,EAA4D7D,KAC5D8D,EAAqB,CAAE,EACvBL,EAA0BM,KAE9BH,EAAe,SAASI,GACtB,IAAI3kB,EAAU,YAAc2kB,EACL,oBAAZrd,SACTA,QAAQ9F,MAAMxB,GAEhB,IAIE,MAAM,IAAI4kB,MAAM5kB,EACjB,CAAC,MAAOsZ,GAAG,CACb,CACH,CAaA,SAASuL,EAAeC,EAAWC,EAAQC,EAAUC,EAAeC,GAClE,GAA6B,eAAzBxH,QAAQC,IAAIC,SACd,IAAK,IAAIuH,KAAgBL,EACvB,GAAIV,EAAIU,EAAWK,GAAe,CAChC,IAAI3jB,EAIJ,IAGE,GAAuC,mBAA5BsjB,EAAUK,GAA8B,CACjD,IAAI1B,EAAMmB,OACPK,GAAiB,eAAiB,KAAOD,EAAW,UAAYG,EAAjE,oGACwFL,EAAUK,GADlG,mGAKF,MADA1B,EAAI9kB,KAAO,sBACL8kB,CAClB,CACUjiB,EAAQsjB,EAAUK,GAAcJ,EAAQI,EAAcF,EAAeD,EAAU,KAAMR,EACtF,CAAC,MAAOY,GACP5jB,EAAQ4jB,CAClB,CAWQ,IAVI5jB,GAAWA,aAAiBojB,OAC9BL,GACGU,GAAiB,eAAiB,2BACnCD,EAAW,KAAOG,EADlB,kGAEqE3jB,EAFrE,kKAQAA,aAAiBojB,SAAWpjB,EAAMxB,WAAWykB,GAAqB,CAGpEA,EAAmBjjB,EAAMxB,UAAW,EAEpC,IAAIqlB,EAAQH,EAAWA,IAAa,GAEpCX,EACE,UAAYS,EAAW,UAAYxjB,EAAMxB,SAAoB,MAATqlB,EAAgBA,EAAQ,IAExF,CACA,CAGA,QAOAR,EAAeS,kBAAoB,WACJ,eAAzB5H,QAAQC,IAAIC,WACd6G,EAAqB,CAAE,EAE3B,EAEAc,GAAiBV,qCC7FjB,IAAIW,EAAU7E,KACVkC,EAAS6B,KAETF,EAA4DiB,KAC5DrB,EAA0BsB,KAC1Bb,EAA4Cc,KAE5CpB,EAAe,WAAa,EAiBhC,SAASqB,IACP,OAAO,IACT,OAjB6B,eAAzBlI,QAAQC,IAAIC,WACd2G,EAAe,SAASI,GACtB,IAAI3kB,EAAU,YAAc2kB,EACL,oBAAZrd,SACTA,QAAQ9F,MAAMxB,GAEhB,IAIE,MAAM,IAAI4kB,MAAM5kB,EACjB,CAAC,MAAOsZ,GAAG,CACb,GAOHuM,GAAiB,SAASC,EAAgBC,GAExC,IAAIC,EAAoC,mBAAXhI,QAAyBA,OAAOiI,SAuE7D,IAAIC,EAAY,gBAIZC,EAAiB,CACnBC,MAAOC,EAA2B,SAClCC,OAAQD,EAA2B,UACnCE,KAAMF,EAA2B,WACjCG,KAAMH,EAA2B,YACjCzO,OAAQyO,EAA2B,UACnCtE,OAAQsE,EAA2B,UACnCpO,OAAQoO,EAA2B,UACnCI,OAAQJ,EAA2B,UAEnCK,IA6HOC,EAA2Bf,GA5HlCgB,QA+HF,SAAkCC,GAkBhC,OAAOF,GAjBP,SAAkB5kB,EAAO+kB,EAAU7B,EAAeD,EAAU+B,GAC1D,GAA2B,mBAAhBF,EACT,OAAO,IAAIG,EAAc,aAAeD,EAAe,mBAAqB9B,EAAgB,mDAE9F,IAAIgC,EAAYllB,EAAM+kB,GACtB,IAAK3e,MAAMC,QAAQ6e,GAEjB,OAAO,IAAID,EAAc,WAAahC,EAAW,KAAO+B,EAA/B,cADVG,EAAYD,GAC6E,kBAAoBhC,EAAgB,yBAE9I,IAAK,IAAI/B,EAAI,EAAGA,EAAI+D,EAAU3e,OAAQ4a,IAAK,CACzC,IAAI1hB,EAAQqlB,EAAYI,EAAW/D,EAAG+B,EAAeD,EAAU+B,EAAe,IAAM7D,EAAI,IAAKsB,GAC7F,GAAIhjB,aAAiBojB,MACnB,OAAOpjB,CAEjB,CACM,OAAO,IACb,GAEA,EAjJIyV,QA4JO0P,GARP,SAAkB5kB,EAAO+kB,EAAU7B,EAAeD,EAAU+B,GAC1D,IAAIE,EAAYllB,EAAM+kB,GACtB,OAAKhB,EAAemB,GAIb,KAFE,IAAID,EAAc,WAAahC,EAAW,KAAO+B,EAA/B,cADVG,EAAYD,GAC6E,kBAAoBhC,EAAgB,qCAGpJ,IA1JIkC,YAuKOR,GARP,SAAkB5kB,EAAO+kB,EAAU7B,EAAeD,EAAU+B,GAC1D,IAAIE,EAAYllB,EAAM+kB,GACtB,OAAKtB,EAAQ/E,mBAAmBwG,GAIzB,KAFE,IAAID,EAAc,WAAahC,EAAW,KAAO+B,EAA/B,cADVG,EAAYD,GAC6E,kBAAoBhC,EAAgB,0CAGpJ,IArKImC,WAyKF,SAAmCC,GASjC,OAAOV,GARP,SAAkB5kB,EAAO+kB,EAAU7B,EAAeD,EAAU+B,GAC1D,KAAMhlB,EAAM+kB,aAAqBO,GAAgB,CAC/C,IAAIC,EAAoBD,EAAc1oB,MAAQunB,EAE9C,OAAO,IAAIc,EAAc,WAAahC,EAAW,KAAO+B,EAA/B,iBAuSTE,EAxSmBllB,EAAM+kB,IAyS9BS,aAAgBN,EAAUM,YAAY5oB,KAG9CsoB,EAAUM,YAAY5oB,KAFpBunB,GAzS0G,mBAAoBjB,EAA1G,4BAA+JqC,EAAoB,KACpN,CAsSE,IAAsBL,EArSlB,OAAO,IACb,GAEA,EAlLIhe,KAwRO0d,GANP,SAAkB5kB,EAAO+kB,EAAU7B,EAAeD,EAAU+B,GAC1D,OAAKS,EAAOzlB,EAAM+kB,IAGX,KAFE,IAAIE,EAAc,WAAahC,EAAW,KAAO+B,EAA/B,kBAAwE9B,EAAgB,2BAGzH,IAtRIwC,SAsNF,SAAmCZ,GAoBjC,OAAOF,GAnBP,SAAkB5kB,EAAO+kB,EAAU7B,EAAeD,EAAU+B,GAC1D,GAA2B,mBAAhBF,EACT,OAAO,IAAIG,EAAc,aAAeD,EAAe,mBAAqB9B,EAAgB,oDAE9F,IAAIgC,EAAYllB,EAAM+kB,GAClBY,EAAWR,EAAYD,GAC3B,GAAiB,WAAbS,EACF,OAAO,IAAIV,EAAc,WAAahC,EAAW,KAAO+B,EAA/B,cAAoEW,EAAW,kBAAoBzC,EAAgB,0BAE9I,IAAK,IAAIzU,KAAOyW,EACd,GAAI7C,EAAI6C,EAAWzW,GAAM,CACvB,IAAIhP,EAAQqlB,EAAYI,EAAWzW,EAAKyU,EAAeD,EAAU+B,EAAe,IAAMvW,EAAKgU,GAC3F,GAAIhjB,aAAiBojB,MACnB,OAAOpjB,CAEnB,CAEM,OAAO,IACb,GAEA,EA1OImmB,MAkLF,SAA+BC,GAC7B,IAAKzf,MAAMC,QAAQwf,GAWjB,MAV6B,eAAzBlK,QAAQC,IAAIC,UAEZ2G,EADE/b,UAAUF,OAAS,EAEnB,+DAAiEE,UAAUF,OAA3E,uFAIW,0DAGVsd,EAoBT,OAAOe,GAjBP,SAAkB5kB,EAAO+kB,EAAU7B,EAAeD,EAAU+B,GAE1D,IADA,IAAIE,EAAYllB,EAAM+kB,GACb5D,EAAI,EAAGA,EAAI0E,EAAetf,OAAQ4a,IACzC,GAAI2E,EAAGZ,EAAWW,EAAe1E,IAC/B,OAAO,KAIX,IAAI4E,EAAeC,KAAKC,UAAUJ,GAAgB,SAAkBpX,EAAK1Q,GAEvE,MAAa,WADFmoB,EAAenoB,GAEjBijB,OAAOjjB,GAETA,CACf,IACM,OAAO,IAAIknB,EAAc,WAAahC,EAAW,KAAO+B,EAAe,eAAiBhE,OAAOkE,GAAtE,kBAA6GhC,EAAgB,sBAAwB6C,EAAe,IACnM,GAEA,EAlNII,UA2OF,SAAgCC,GAC9B,IAAKhgB,MAAMC,QAAQ+f,GAEjB,MADyB,eAAzBzK,QAAQC,IAAIC,UAA4B2G,EAAa,0EAC9CqB,EAGT,IAAK,IAAI1C,EAAI,EAAGA,EAAIiF,EAAoB7f,OAAQ4a,IAAK,CACnD,IAAIkF,EAAUD,EAAoBjF,GAClC,GAAuB,mBAAZkF,EAKT,OAJA7D,EACE,8FACc8D,EAAyBD,GAAW,aAAelF,EAAI,KAEhE0C,CAEf,CAiBI,OAAOe,GAfP,SAAkB5kB,EAAO+kB,EAAU7B,EAAeD,EAAU+B,GAE1D,IADA,IAAIuB,EAAgB,GACXpF,EAAI,EAAGA,EAAIiF,EAAoB7f,OAAQ4a,IAAK,CACnD,IACIqF,GAAgBH,EADND,EAAoBjF,IACNnhB,EAAO+kB,EAAU7B,EAAeD,EAAU+B,EAAcvC,GACpF,GAAqB,MAAjB+D,EACF,OAAO,KAELA,EAAc3mB,MAAQwiB,EAAImE,EAAc3mB,KAAM,iBAChD0mB,EAAcxZ,KAAKyZ,EAAc3mB,KAAK4mB,aAEhD,CAEM,OAAO,IAAIxB,EAAc,WAAahC,EAAW,KAAO+B,EAA/B,kBAAwE9B,EAAgB,KADrFqD,EAAchgB,OAAS,EAAK,2BAA6BggB,EAAclF,KAAK,MAAQ,IAAK,IACyB,IACpJ,GAEA,EA3QIqF,MA8RF,SAAgCC,GAmB9B,OAAO/B,GAlBP,SAAkB5kB,EAAO+kB,EAAU7B,EAAeD,EAAU+B,GAC1D,IAAIE,EAAYllB,EAAM+kB,GAClBY,EAAWR,EAAYD,GAC3B,GAAiB,WAAbS,EACF,OAAO,IAAIV,EAAc,WAAahC,EAAW,KAAO+B,EAAe,cAAgBW,EAA9D,kBAAmGzC,EAAgB,yBAE9I,IAAK,IAAIzU,KAAOkY,EAAY,CAC1B,IAAIN,EAAUM,EAAWlY,GACzB,GAAuB,mBAAZ4X,EACT,OAAOO,EAAsB1D,EAAeD,EAAU+B,EAAcvW,EAAKyX,EAAeG,IAE1F,IAAI5mB,EAAQ4mB,EAAQnB,EAAWzW,EAAKyU,EAAeD,EAAU+B,EAAe,IAAMvW,EAAKgU,GACvF,GAAIhjB,EACF,OAAOA,CAEjB,CACM,OAAO,IACb,GAEA,EAjTIonB,MAmTF,SAAsCF,GA6BpC,OAAO/B,GA5BP,SAAkB5kB,EAAO+kB,EAAU7B,EAAeD,EAAU+B,GAC1D,IAAIE,EAAYllB,EAAM+kB,GAClBY,EAAWR,EAAYD,GAC3B,GAAiB,WAAbS,EACF,OAAO,IAAIV,EAAc,WAAahC,EAAW,KAAO+B,EAAe,cAAgBW,EAA9D,kBAAmGzC,EAAgB,yBAG9I,IAAI4D,EAAUhG,EAAO,CAAA,EAAI9gB,EAAM+kB,GAAW4B,GAC1C,IAAK,IAAIlY,KAAOqY,EAAS,CACvB,IAAIT,EAAUM,EAAWlY,GACzB,GAAI4T,EAAIsE,EAAYlY,IAA2B,mBAAZ4X,EACjC,OAAOO,EAAsB1D,EAAeD,EAAU+B,EAAcvW,EAAKyX,EAAeG,IAE1F,IAAKA,EACH,OAAO,IAAIpB,EACT,WAAahC,EAAW,KAAO+B,EAAe,UAAYvW,EAAM,kBAAoByU,EAApF,mBACmB8C,KAAKC,UAAUjmB,EAAM+kB,GAAW,KAAM,MACzD,iBAAmBiB,KAAKC,UAAUzF,OAAOiB,KAAKkF,GAAa,KAAM,OAGrE,IAAIlnB,EAAQ4mB,EAAQnB,EAAWzW,EAAKyU,EAAeD,EAAU+B,EAAe,IAAMvW,EAAKgU,GACvF,GAAIhjB,EACF,OAAOA,CAEjB,CACM,OAAO,IACb,GAGA,GAzUE,SAASqmB,EAAGvO,EAAGsF,GAEb,OAAItF,IAAMsF,EAGK,IAANtF,GAAW,EAAIA,GAAM,EAAIsF,EAGzBtF,GAAMA,GAAKsF,GAAMA,CAE9B,CAUE,SAASoI,EAAchnB,EAAS4B,GAC9BknB,KAAK9oB,QAAUA,EACf8oB,KAAKlnB,KAAOA,GAAwB,iBAATA,EAAoBA,EAAM,CAAE,EACvDknB,KAAKzD,MAAQ,EACjB,CAIE,SAASsB,EAA2BoC,GAClC,GAA6B,eAAzBrL,QAAQC,IAAIC,SACd,IAAIoL,EAA0B,CAAE,EAC5BC,EAA6B,EAEnC,SAASC,EAAUC,EAAYpnB,EAAO+kB,EAAU7B,EAAeD,EAAU+B,EAAcqC,GAIrF,GAHAnE,EAAgBA,GAAiBiB,EACjCa,EAAeA,GAAgBD,EAE3BsC,IAAW5E,EAAsB,CACnC,GAAIuB,EAAqB,CAEvB,IAAItC,EAAM,IAAImB,MACZ,qLAKF,MADAnB,EAAI9kB,KAAO,sBACL8kB,CAChB,CAAe,GAA6B,eAAzB/F,QAAQC,IAAIC,UAAgD,oBAAZtW,QAAyB,CAElF,IAAI+hB,EAAWpE,EAAgB,IAAM6B,GAElCkC,EAAwBK,IAEzBJ,EAA6B,IAE7B1E,EACE,2EACuBwC,EAAe,cAAgB9B,EADtD,wNAMF+D,EAAwBK,IAAY,EACpCJ,IAEZ,CACA,CACM,OAAuB,MAAnBlnB,EAAM+kB,GACJqC,EACsB,OAApBpnB,EAAM+kB,GACD,IAAIE,EAAc,OAAShC,EAAW,KAAO+B,EAA3B,+BAAiF9B,EAAgB,+BAErH,IAAI+B,EAAc,OAAShC,EAAW,KAAO+B,EAA3B,+BAAiF9B,EAAgB,oCAErH,KAEA8D,EAAShnB,EAAO+kB,EAAU7B,EAAeD,EAAU+B,EAElE,CAEI,IAAIuC,EAAmBJ,EAAU5E,KAAK,MAAM,GAG5C,OAFAgF,EAAiBH,WAAaD,EAAU5E,KAAK,MAAM,GAE5CgF,CACX,CAEE,SAASjD,EAA2BmC,GAiBlC,OAAO7B,GAhBP,SAAkB5kB,EAAO+kB,EAAU7B,EAAeD,EAAU+B,EAAcqC,GACxE,IAAInC,EAAYllB,EAAM+kB,GAEtB,OADeI,EAAYD,KACVuB,EAMR,IAAIxB,EACT,WAAahC,EAAW,KAAO+B,EAA/B,cAHgBkB,EAAehB,GAGmD,kBAAoBhC,EAAtG,gBAA+IuD,EAAe,KAC9J,CAACA,aAAcA,IAGZ,IACb,GAEA,CAsKE,SAASG,EAAsB1D,EAAeD,EAAU+B,EAAcvW,EAAKlT,GACzE,OAAO,IAAI0pB,GACR/B,GAAiB,eAAiB,KAAOD,EAAW,UAAY+B,EAAe,IAAMvW,EAAtF,6FACiFlT,EAAO,KAE9F,CAwDE,SAASkqB,EAAOP,GACd,cAAeA,GACb,IAAK,SACL,IAAK,SACL,IAAK,YACH,OAAO,EACT,IAAK,UACH,OAAQA,EACV,IAAK,SACH,GAAI9e,MAAMC,QAAQ6e,GAChB,OAAOA,EAAUsC,MAAM/B,GAEzB,GAAkB,OAAdP,GAAsBnB,EAAemB,GACvC,OAAO,EAGT,IAAIuC,EAjbV,SAAuBC,GACrB,IAAID,EAAaC,IAAkBzD,GAAmByD,EAAczD,IAAoByD,EAjB/D,eAkBzB,GAA0B,mBAAfD,EACT,OAAOA,CAEb,CA4ayBE,CAAczC,GAC/B,IAAIuC,EAqBF,OAAO,EApBP,IACIG,EADA1D,EAAWuD,EAAWtF,KAAK+C,GAE/B,GAAIuC,IAAevC,EAAU2C,SAC3B,OAASD,EAAO1D,EAAS4D,QAAQC,MAC/B,IAAKtC,EAAOmC,EAAK7pB,OACf,OAAO,OAKX,OAAS6pB,EAAO1D,EAAS4D,QAAQC,MAAM,CACrC,IAAIC,EAAQJ,EAAK7pB,MACjB,GAAIiqB,IACGvC,EAAOuC,EAAM,IAChB,OAAO,CAGzB,CAMQ,OAAO,EACT,QACE,OAAO,EAEf,CA2BE,SAAS7C,EAAYD,GACnB,IAAIS,SAAkBT,EACtB,OAAI9e,MAAMC,QAAQ6e,GACT,QAELA,aAAqB+C,OAIhB,SAlCX,SAAkBtC,EAAUT,GAE1B,MAAiB,WAAbS,KAKCT,IAK8B,WAA/BA,EAAU,kBAKQ,mBAAXjJ,QAAyBiJ,aAAqBjJ,OAK7D,CAcQiM,CAASvC,EAAUT,GACd,SAEFS,CACX,CAIE,SAASO,EAAehB,GACtB,GAAI,MAAOA,EACT,MAAO,GAAKA,EAEd,IAAIS,EAAWR,EAAYD,GAC3B,GAAiB,WAAbS,EAAuB,CACzB,GAAIT,aAAqBiD,KACvB,MAAO,OACF,GAAIjD,aAAqB+C,OAC9B,MAAO,QAEf,CACI,OAAOtC,CACX,CAIE,SAASW,EAAyBvoB,GAChC,IAAIxC,EAAO2qB,EAAenoB,GAC1B,OAAQxC,GACN,IAAK,QACL,IAAK,SACH,MAAO,MAAQA,EACjB,IAAK,UACL,IAAK,OACL,IAAK,SACH,MAAO,KAAOA,EAChB,QACE,OAAOA,EAEf,CAcE,OAxbA0pB,EAAcvE,UAAYmC,MAAMnC,UAobhC0D,EAAetB,eAAiBA,EAChCsB,EAAeb,kBAAoBT,EAAeS,kBAClDa,EAAegE,UAAYhE,EAEpBA,CACR,wCCxlBD,IAAI3B,EAA4D7D,KAEhE,SAASyJ,IAAgB,CACzB,SAASC,IAAyB,QAClCA,EAAuB/E,kBAAoB8E,EAE3CE,GAAiB,WACf,SAASC,EAAKxoB,EAAO+kB,EAAU7B,EAAeD,EAAU+B,EAAcqC,GACpE,GAAIA,IAAW5E,EAAf,CAIA,IAAIf,EAAM,IAAImB,MACZ,mLAKF,MADAnB,EAAI9kB,KAAO,sBACL8kB,CAPV,EAUE,SAAS+G,IACP,OAAOD,CAEX,CAJEA,EAAKpB,WAAaoB,EAMlB,IAAIpE,EAAiB,CACnBC,MAAOmE,EACPjE,OAAQiE,EACRhE,KAAMgE,EACN/D,KAAM+D,EACN3S,OAAQ2S,EACRxI,OAAQwI,EACRtS,OAAQsS,EACR9D,OAAQ8D,EAER7D,IAAK6D,EACL3D,QAAS4D,EACTvT,QAASsT,EACTpD,YAAaoD,EACbnD,WAAYoD,EACZvhB,KAAMshB,EACN9C,SAAU+C,EACV7C,MAAO6C,EACPtC,UAAWsC,EACX/B,MAAO+B,EACP5B,MAAO4B,EAEP3F,eAAgBwF,EAChB/E,kBAAmB8E,GAKrB,OAFAjE,EAAegE,UAAYhE,EAEpBA,CACR,wCCzDD,QAA6B,eAAzBzI,QAAQC,IAAIC,SAA2B,CACzC,IAAI4H,EAAU7E,KAKd8J,GAAA3M,QAAqD4G,KAACc,EAAQvF,UADpC,KAE5B,MAGEwK,GAAA3M,QAAiB2H,yGCNnB,IAAI5E,EAAqB7C,OAAOC,IAAI,8BAClC6C,EAAoB9C,OAAOC,IAAI,gBAC/B8C,EAAsB/C,OAAOC,IAAI,kBACjC+C,EAAyBhD,OAAOC,IAAI,qBACpCgD,EAAsBjD,OAAOC,IAAI,kBAE/ByM,EAAsB1M,OAAOC,IAAI,kBACnCkD,EAAqBnD,OAAOC,IAAI,iBAChCqD,EAAyBtD,OAAOC,IAAI,qBACpCsD,EAAsBvD,OAAOC,IAAI,kBACjCuD,EAA2BxD,OAAOC,IAAI,uBACtCwD,EAAkBzD,OAAOC,IAAI,cAC7ByD,EAAkB1D,OAAOC,IAAI,cAC7B0M,EAA6B3M,OAAOC,IAAI,yBACxC2M,EAAyB5M,OAAOC,IAAI,0BACtC,SAASyC,EAAOqB,GACd,GAAI,iBAAoBA,GAAU,OAASA,EAAQ,CACjD,IAAIhD,EAAWgD,EAAOhD,SACtB,OAAQA,GACN,KAAK8B,EACH,OAAUkB,EAASA,EAAOzkB,MACxB,KAAKyjB,EACL,KAAKE,EACL,KAAKD,EACL,KAAKO,EACL,KAAKC,EACL,KAAKmJ,EACH,OAAO5I,EACT,QACE,OAAUA,EAASA,GAAUA,EAAOhD,UAClC,KAAKoC,EACL,KAAKG,EACL,KAAKI,EACL,KAAKD,EAEL,KAAKiJ,EACH,OAAO3I,EACT,QACE,OAAOhD,GAGjB,KAAK+B,EACH,OAAO/B,EAEf,CACA,QACA8L,GAAAzL,gBAA0BsL,EAC1BG,GAAA5I,gBAA0Bd,EAC1B0J,GAAAxL,QAAkBwB,EAClBgK,GAAAvL,WAAqBgC,EACrBuJ,GAAAtL,SAAmBwB,EACnB8J,GAAArL,KAAekC,EACfmJ,GAAA3I,KAAeT,EACfoJ,GAAApL,OAAiBqB,EACjB+J,GAAAnL,SAAmBuB,EACnB4J,GAAAlL,WAAqBqB,EACrB6J,GAAAjL,SAAmB2B,EACnBsJ,GAAAC,aAAuBtJ,EACEqJ,GAAA9K,kBAAG,SAAUgC,GACpC,OAAOrB,EAAOqB,KAAY2I,CAC3B,EACwBG,GAAA7K,kBAAG,SAAU+B,GACpC,OAAOrB,EAAOqB,KAAYZ,CAC3B,EACgB0J,GAAA5K,UAAG,SAAU8B,GAC5B,MACE,iBAAoBA,GACpB,OAASA,GACTA,EAAOhD,WAAa8B,CAEvB,EACmBgK,GAAA3K,aAAG,SAAU6B,GAC/B,OAAOrB,EAAOqB,KAAYT,CAC3B,EACiBuJ,GAAA1K,WAAG,SAAU4B,GAC7B,OAAOrB,EAAOqB,KAAYhB,CAC3B,EACa8J,GAAAzK,OAAG,SAAU2B,GACzB,OAAOrB,EAAOqB,KAAYL,CAC3B,EACamJ,GAAAxK,OAAG,SAAU0B,GACzB,OAAOrB,EAAOqB,KAAYN,CAC3B,EACeoJ,GAAAxI,SAAG,SAAUN,GAC3B,OAAOrB,EAAOqB,KAAYjB,CAC3B,EACiB+J,GAAAvK,WAAG,SAAUyB,GAC7B,OAAOrB,EAAOqB,KAAYd,CAC3B,EACmB4J,GAAAtK,aAAG,SAAUwB,GAC/B,OAAOrB,EAAOqB,KAAYf,CAC3B,EACiB6J,GAAArK,WAAG,SAAUuB,GAC7B,OAAOrB,EAAOqB,KAAYR,CAC3B,EACqBsJ,GAAAE,eAAG,SAAUhJ,GACjC,OAAOrB,EAAOqB,KAAYP,CAC3B,EACyBqJ,GAAApK,mBAAG,SAAUnjB,GACrC,MAAO,iBAAoBA,GACzB,mBAAsBA,GACtBA,IAASyjB,GACTzjB,IAAS2jB,GACT3jB,IAAS0jB,GACT1jB,IAASikB,GACTjkB,IAASkkB,GACR,iBAAoBlkB,GACnB,OAASA,IACRA,EAAKyhB,WAAa2C,GACjBpkB,EAAKyhB,WAAa0C,GAClBnkB,EAAKyhB,WAAaoC,GAClB7jB,EAAKyhB,WAAa2L,GAClBptB,EAAKyhB,WAAauC,GAClBhkB,EAAKyhB,WAAa6L,QAClB,IAAWttB,EAAK0tB,YAGvB,EACDH,GAAAnK,OAAiBA;;;;;;;;;kCCtHjB,eAAiBhD,QAAQC,IAAIC,UAC3B,WACE,SAAS8C,EAAOqB,GACd,GAAI,iBAAoBA,GAAU,OAASA,EAAQ,CACjD,IAAIhD,EAAWgD,EAAOhD,SACtB,OAAQA,GACN,KAAK8B,EACH,OAAUkB,EAASA,EAAOzkB,MACxB,KAAKyjB,EACL,KAAKE,EACL,KAAKD,EACL,KAAKO,EACL,KAAKC,EACL,KAAKmJ,EACH,OAAO5I,EACT,QACE,OAAUA,EAASA,GAAUA,EAAOhD,UAClC,KAAKoC,EACL,KAAKG,EACL,KAAKI,EACL,KAAKD,EAEL,KAAKiJ,EACH,OAAO3I,EACT,QACE,OAAOhD,GAGjB,KAAK+B,EACH,OAAO/B,EAEnB,CACA,CACI,IAAI8B,EAAqB7C,OAAOC,IAAI,8BAClC6C,EAAoB9C,OAAOC,IAAI,gBAC/B8C,EAAsB/C,OAAOC,IAAI,kBACjC+C,EAAyBhD,OAAOC,IAAI,qBACpCgD,EAAsBjD,OAAOC,IAAI,kBAE/ByM,EAAsB1M,OAAOC,IAAI,kBACnCkD,EAAqBnD,OAAOC,IAAI,iBAChCqD,EAAyBtD,OAAOC,IAAI,qBACpCsD,EAAsBvD,OAAOC,IAAI,kBACjCuD,EAA2BxD,OAAOC,IAAI,uBACtCwD,EAAkBzD,OAAOC,IAAI,cAC7ByD,EAAkB1D,OAAOC,IAAI,cAC7B0M,EAA6B3M,OAAOC,IAAI,yBACxC2M,EAAyB5M,OAAOC,IAAI,0BACtCmE,GAAAhD,gBAA0BsL,EAC1BtI,GAAAH,gBAA0Bd,EAC1BiB,GAAA/C,QAAkBwB,EAClBuB,GAAA9C,WAAqBgC,EACrBc,GAAA7C,SAAmBwB,EACnBqB,GAAA5C,KAAekC,EACfU,GAAAF,KAAeT,EACfW,GAAA3C,OAAiBqB,EACjBsB,GAAA1C,SAAmBuB,EACnBmB,GAAAzC,WAAqBqB,EACrBoB,GAAAxC,SAAmB2B,EACnBa,GAAA0I,aAAuBtJ,EACvBY,GAAyBrC,kBAAG,SAAUgC,GACpC,OAAOrB,EAAOqB,KAAY2I,CAC3B,EACDtI,GAAyBpC,kBAAG,SAAU+B,GACpC,OAAOrB,EAAOqB,KAAYZ,CAC3B,EACDiB,GAAiBnC,UAAG,SAAU8B,GAC5B,MACE,iBAAoBA,GACpB,OAASA,GACTA,EAAOhD,WAAa8B,CAEvB,EACDuB,GAAoBlC,aAAG,SAAU6B,GAC/B,OAAOrB,EAAOqB,KAAYT,CAC3B,EACDc,GAAkBjC,WAAG,SAAU4B,GAC7B,OAAOrB,EAAOqB,KAAYhB,CAC3B,EACDqB,GAAchC,OAAG,SAAU2B,GACzB,OAAOrB,EAAOqB,KAAYL,CAC3B,EACDU,GAAc/B,OAAG,SAAU0B,GACzB,OAAOrB,EAAOqB,KAAYN,CAC3B,EACDW,GAAgBC,SAAG,SAAUN,GAC3B,OAAOrB,EAAOqB,KAAYjB,CAC3B,EACDsB,GAAkB9B,WAAG,SAAUyB,GAC7B,OAAOrB,EAAOqB,KAAYd,CAC3B,EACDmB,GAAoB7B,aAAG,SAAUwB,GAC/B,OAAOrB,EAAOqB,KAAYf,CAC3B,EACDoB,GAAkB5B,WAAG,SAAUuB,GAC7B,OAAOrB,EAAOqB,KAAYR,CAC3B,EACDa,GAAsB2I,eAAG,SAAUhJ,GACjC,OAAOrB,EAAOqB,KAAYP,CAC3B,EACDY,GAA0B3B,mBAAG,SAAUnjB,GACrC,MAAO,iBAAoBA,GACzB,mBAAsBA,GACtBA,IAASyjB,GACTzjB,IAAS2jB,GACT3jB,IAAS0jB,GACT1jB,IAASikB,GACTjkB,IAASkkB,GACR,iBAAoBlkB,GACnB,OAASA,IACRA,EAAKyhB,WAAa2C,GACjBpkB,EAAKyhB,WAAa0C,GAClBnkB,EAAKyhB,WAAaoC,GAClB7jB,EAAKyhB,WAAa2L,GAClBptB,EAAKyhB,WAAauC,GAClBhkB,EAAKyhB,WAAa6L,QAClB,IAAWttB,EAAK0tB,YAGvB,EACD5I,GAAA1B,OAAiBA,CAClB,CAxHD,sCCV2B,eAAzBhD,QAAQC,IAAIC,SACdC,GAAAC,QAAwD6C,KAExD9C,GAAAC,QAAyD4G,6BCDpD,SAASuG,GAAcrd,GAC5B,GAAoB,iBAATA,GAA8B,OAATA,EAC9B,OAAO,EAET,MAAM6U,EAAYF,OAAO2I,eAAetd,GACxC,QAAsB,OAAd6U,GAAsBA,IAAcF,OAAOE,WAAkD,OAArCF,OAAO2I,eAAezI,IAA0BzE,OAAOmN,eAAevd,GAAWoQ,OAAOiI,YAAYrY,EACtK,CACA,SAASwd,GAAUzH,GACjB,GAAiB7W,EAAMgZ,eAAenC,IAAWlD,GAAAA,mBAAmBkD,KAAYsH,GAActH,GAC5F,OAAOA,EAET,MAAM0H,EAAS,CAAE,EAIjB,OAHA9I,OAAOiB,KAAKG,GAAQrG,SAAQ9M,IAC1B6a,EAAO7a,GAAO4a,GAAUzH,EAAOnT,OAE1B6a,CACT,CAoBe,SAASC,GAAUxV,EAAQ6N,EAAQjP,EAAU,CAC1D6W,OAAO,IAEP,MAAMF,EAAS3W,EAAQ6W,MAAQ,IAC1BzV,GACDA,EAiBJ,OAhBImV,GAAcnV,IAAWmV,GAActH,IACzCpB,OAAOiB,KAAKG,GAAQrG,SAAQ9M,IACT1D,EAAMgZ,eAAenC,EAAOnT,KAASiQ,sBAAmBkD,EAAOnT,IAC9E6a,EAAO7a,GAAOmT,EAAOnT,GACZya,GAActH,EAAOnT,KAEhC+R,OAAOE,UAAUD,eAAe0B,KAAKpO,EAAQtF,IAAQya,GAAcnV,EAAOtF,IAExE6a,EAAO7a,GAAO8a,GAAUxV,EAAOtF,GAAMmT,EAAOnT,GAAMkE,GACzCA,EAAQ6W,MACjBF,EAAO7a,GAAOya,GAActH,EAAOnT,IAAQ4a,GAAUzH,EAAOnT,IAAQmT,EAAOnT,GAE3E6a,EAAO7a,GAAOmT,EAAOnT,MAIpB6a,CACT,CC5Ce,SAASG,GAAkBC,GACxC,MAAM1G,OAGJA,EAAS,CACP2G,GAAI,EAEJC,GAAI,IAEJC,GAAI,IAEJC,GAAI,KAEJC,GAAI,MACLC,KACDA,EAAO,KAAIpC,KACXA,EAAO,KACJvd,GACDqf,EACEO,EAnCsBjH,KAC5B,MAAMkH,EAAqB1J,OAAOiB,KAAKuB,GAAQpW,KAAI6B,IAAQ,CACzDA,MACAsT,IAAKiB,EAAOvU,QACP,GAGP,OADAyb,EAAmBC,MAAK,CAACC,EAAaC,IAAgBD,EAAYrI,IAAMsI,EAAYtI,MAC7EmI,EAAmBI,QAAO,CAACC,EAAKC,KAC9B,IACFD,EACH,CAACC,EAAI/b,KAAM+b,EAAIzI,OAEhB,KAuBkB0I,CAAsBzH,GACrCvB,EAAOjB,OAAOiB,KAAKwI,GACzB,SAASS,EAAGjc,GAEV,MAAO,qBAD8B,iBAAhBuU,EAAOvU,GAAoBuU,EAAOvU,GAAOA,IAC1Bub,IACxC,CACE,SAASW,EAAKlc,GAEZ,MAAO,sBAD8B,iBAAhBuU,EAAOvU,GAAoBuU,EAAOvU,GAAOA,GAC1BmZ,EAAO,MAAMoC,IACrD,CACE,SAASY,EAAQC,EAAOC,GACtB,MAAMC,EAAWtJ,EAAKuJ,QAAQF,GAC9B,MAAO,qBAA8C,iBAAlB9H,EAAO6H,GAAsB7H,EAAO6H,GAASA,IAAQb,uBAA6C,IAAfe,GAAqD,iBAA3B/H,EAAOvB,EAAKsJ,IAA0B/H,EAAOvB,EAAKsJ,IAAaD,GAAOlD,EAAO,MAAMoC,IACvO,CAkBE,MAAO,CACLvI,OACAuB,OAAQiH,EACRS,KACAC,OACAC,UACAK,KAvBF,SAAcxc,GACZ,OAAIgT,EAAKuJ,QAAQvc,GAAO,EAAIgT,EAAKlb,OACxBqkB,EAAQnc,EAAKgT,EAAKA,EAAKuJ,QAAQvc,GAAO,IAExCic,EAAGjc,EACd,EAmBIyc,IAlBF,SAAazc,GAEX,MAAM0c,EAAW1J,EAAKuJ,QAAQvc,GAC9B,OAAiB,IAAb0c,EACKT,EAAGjJ,EAAK,IAEb0J,IAAa1J,EAAKlb,OAAS,EACtBokB,EAAKlJ,EAAK0J,IAEZP,EAAQnc,EAAKgT,EAAKA,EAAKuJ,QAAQvc,GAAO,IAAI2c,QAAQ,SAAU,qBACvE,EASIpB,UACG3f,EAEP,CChFA,MAAMqc,GAAQ,CACZ/e,aAAc,GCAV0jB,GAA8C,eAAzB1P,QAAQC,IAAIC,SAA4BuM,GAAUjC,UAAU,CAACiC,GAAUvS,OAAQuS,GAAUlS,OAAQkS,GAAUpI,OAAQoI,GAAU/D,QAAU,CAAE,ECApK,SAASiH,GAAMf,EAAK1e,GAClB,OAAKA,EAGE0d,GAAUgB,EAAK1e,EAAM,CAC1B2d,OAAO,IAHAe,CAKX,CCDO,MAAMvH,GAAS,CACpB2G,GAAI,EAEJC,GAAI,IAEJC,GAAI,IAEJC,GAAI,KAEJC,GAAI,MAEAwB,GAAqB,CAGzB9J,KAAM,CAAC,KAAM,KAAM,KAAM,KAAM,MAC/BiJ,GAAIjc,GAAO,qBAAqBuU,GAAOvU,SAEnC+c,GAA0B,CAC9BC,iBAAkBC,IAAkB,CAClChB,GAAIjc,IACF,IAAIkd,EAAwB,iBAARld,EAAmBA,EAAMuU,GAAOvU,IAAQA,EAI5D,MAHsB,iBAAXkd,IACTA,EAAS,GAAGA,OAEPD,EAAgB,cAAcA,gBAA4BC,KAAY,yBAAyBA,SAIrG,SAASC,GAAkB5rB,EAAOklB,EAAW2G,GAClD,MAAMtpB,EAAQvC,EAAMuC,OAAS,CAAE,EAC/B,GAAI6D,MAAMC,QAAQ6e,GAAY,CAC5B,MAAM4G,EAAmBvpB,EAAMmnB,aAAe6B,GAC9C,OAAOrG,EAAUoF,QAAO,CAACC,EAAK1e,EAAMkgB,KAClCxB,EAAIuB,EAAiBpB,GAAGoB,EAAiBrK,KAAKsK,KAAWF,EAAmB3G,EAAU6G,IAC/ExB,IACN,GACP,CACE,GAAyB,iBAAdrF,EAAwB,CACjC,MAAM4G,EAAmBvpB,EAAMmnB,aAAe6B,GAC9C,OAAO/K,OAAOiB,KAAKyD,GAAWoF,QAAO,CAACC,EAAKxuB,KACzC,GCpBwBiwB,EDoBNF,EAAiBrK,KCnBtB,OAD2B1jB,EDoBChC,ICnBrBgC,EAAMkuB,WAAW,OAASD,EAAephB,MAAK6D,GAAO1Q,EAAMkuB,WAAW,IAAIxd,QAAa1Q,EAAMmuB,MAAM,SDmBjE,CACpD,MAAMC,EClBP,SAA2B5pB,EAAO6pB,GACvC,MAAMC,EAAUD,EAAUF,MAAM,uBAChC,IAAKG,EAAS,CACZ,GAA6B,eAAzB1Q,QAAQC,IAAIC,SACd,MAAM,IAAIgH,MAA+B,eAAzBlH,QAAQC,IAAIC,SAA4B,gCAAmCuQ,qKAAgLE,GAAoB,GAAI,IAAIF,OAEzS,OAAO,IACX,CACE,MAAS,CAAAG,EAAgBb,GAAiBW,EACpCtuB,EAAQuc,OAAOH,OAAOoS,GAAkBA,GAAkB,GAAKA,EACrE,OAAOhqB,EAAMkpB,iBAAiBC,GAAehB,GAAG3sB,EAClD,CDO6ByuB,CAAkBjqB,EAAMkpB,iBAAmBlpB,EAAQipB,GAAyBzvB,GAC7FowB,IACF5B,EAAI4B,GAAgBN,EAAmB3G,EAAUnpB,GAAaA,GAExE,MAEW,GAAIykB,OAAOiB,KAAKqK,EAAiB9I,QAAUA,IAAQyJ,SAAS1wB,GAAa,CAE5EwuB,EADiBuB,EAAiBpB,GAAG3uB,IACrB8vB,EAAmB3G,EAAUnpB,GAAaA,EAClE,KAAa,CACL,MAAM2wB,EAAS3wB,EACfwuB,EAAImC,GAAUxH,EAAUwH,EAChC,CCjCO,IAAuBV,EAAgBjuB,EDkCxC,OAAOwsB,IACN,GACP,CAEE,OADesB,EAAmB3G,EAEpC,CE7De,SAASyH,GAAWzW,GACjC,GAAsB,iBAAXA,EACT,MAAM,IAAI2M,MAA+B,eAAzBlH,QAAQC,IAAIC,SAA4B,uDAAyDyQ,GAAoB,IAEvI,OAAOpW,EAAOsE,OAAO,GAAGC,cAAgBvE,EAAOwE,MAAM,EACvD,CCPO,SAASkS,GAAQpC,EAAKjjB,EAAMslB,GAAY,GAC7C,IAAKtlB,GAAwB,iBAATA,EAClB,OAAO,KAIT,GAAIijB,GAAOA,EAAIsC,MAAQD,EAAW,CAChC,MAAM9K,EAAM,QAAQxa,IAAOga,MAAM,KAAK+I,QAAO,CAACC,EAAK1e,IAAS0e,GAAOA,EAAI1e,GAAQ0e,EAAI1e,GAAQ,MAAM2e,GACjG,GAAW,MAAPzI,EACF,OAAOA,CAEb,CACE,OAAOxa,EAAKga,MAAM,KAAK+I,QAAO,CAACC,EAAK1e,IAC9B0e,GAAoB,MAAbA,EAAI1e,GACN0e,EAAI1e,GAEN,MACN2e,EACL,CACO,SAASuC,GAAcC,EAAchjB,EAAWijB,EAAgBC,EAAYD,GACjF,IAAIlvB,EAWJ,OATEA,EAD0B,mBAAjBivB,EACDA,EAAaC,GACZ7mB,MAAMC,QAAQ2mB,GACfA,EAAaC,IAAmBC,EAEhCN,GAAQI,EAAcC,IAAmBC,EAE/CljB,IACFjM,EAAQiM,EAAUjM,EAAOmvB,EAAWF,IAE/BjvB,CACT,CACA,SAAS1C,GAAMsX,GACb,MAAMrQ,KACJA,EAAI6qB,YACJA,EAAcxa,EAAQrQ,KAAI8qB,SAC1BA,EAAQpjB,UACRA,GACE2I,EAIE0a,EAAKrtB,IACT,GAAmB,MAAfA,EAAMsC,GACR,OAAO,KAET,MAAM4iB,EAAYllB,EAAMsC,GAElB0qB,EAAeJ,GADP5sB,EAAMuC,MACgB6qB,IAAa,CAAE,EAcnD,OAAOxB,GAAkB5rB,EAAOklB,GAbL+H,IACzB,IAAIlvB,EAAQgvB,GAAcC,EAAchjB,EAAWijB,GAKnD,OAJIA,IAAmBlvB,GAAmC,iBAAnBkvB,IAErClvB,EAAQgvB,GAAcC,EAAchjB,EAAW,GAAG1H,IAA0B,YAAnB2qB,EAA+B,GAAKN,GAAWM,KAAmBA,KAEzG,IAAhBE,EACKpvB,EAEF,CACLovB,CAACA,GAAcpvB,OASrB,OAJAsvB,EAAGC,UAAqC,eAAzB3R,QAAQC,IAAIC,SAA4B,CACrDvZ,CAACA,GAAO+oB,IACN,CAAE,EACNgC,EAAGE,YAAc,CAACjrB,GACX+qB,CACT,CCpEA,MAAMG,GAAa,CACjB/Q,EAAG,SACHC,EAAG,WAEC+Q,GAAa,CACjBxnB,EAAG,MACHF,EAAG,QACHiW,EAAG,SACHQ,EAAG,OACHjF,EAAG,CAAC,OAAQ,SACZsF,EAAG,CAAC,MAAO,WAEP6Q,GAAU,CACdC,QAAS,KACTC,QAAS,KACTC,SAAU,KACVC,SAAU,MAMNC,GC3BS,SAAiBV,GAC9B,MAAMW,EAAQ,CAAE,EAChB,OAAOxS,SACcrb,IAAf6tB,EAAMxS,KACRwS,EAAMxS,GAAO6R,EAAG7R,IAEXwS,EAAMxS,GAEjB,CDmByByS,EAAQ3rB,IAE/B,GAAIA,EAAKiE,OAAS,EAAG,CACnB,IAAImnB,GAAQprB,GAGV,MAAO,CAACA,GAFRA,EAAOorB,GAAQprB,EAIrB,CACE,MAAOwa,EAAGd,GAAK1Z,EAAKif,MAAM,IACpB2M,EAAWV,GAAW1Q,GACtBrP,EAAYggB,GAAWzR,IAAM,GACnC,OAAO5V,MAAMC,QAAQoH,GAAaA,EAAUb,KAAIuhB,GAAOD,EAAWC,IAAO,CAACD,EAAWzgB,MAE1E2gB,GAAa,CAAC,IAAK,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,SAAU,YAAa,cAAe,eAAgB,aAAc,UAAW,UAAW,eAAgB,oBAAqB,kBAAmB,cAAe,mBAAoB,kBAC5OC,GAAc,CAAC,IAAK,KAAM,KAAM,KAAM,KAAM,KAAM,KAAM,UAAW,aAAc,eAAgB,gBAAiB,cAAe,WAAY,WAAY,gBAAiB,qBAAsB,mBAAoB,eAAgB,oBAAqB,mBAChQC,GAAc,IAAIF,MAAeC,IAChC,SAASE,GAAgBhsB,EAAO6qB,EAAUoB,EAAczJ,GAC7D,MAAM0J,EAAe7B,GAAQrqB,EAAO6qB,GAAU,IAASoB,EACvD,MAA4B,iBAAjBC,GAAqD,iBAAjBA,EACtC1M,GACc,iBAARA,EACFA,GAEoB,eAAzBpG,QAAQC,IAAIC,UACK,iBAARkG,GACTxc,QAAQ9F,MAAM,iBAAiBslB,8CAAqDhD,MAG5D,iBAAjB0M,EACLA,EAAaxC,WAAW,SAAmB,IAARlK,EAC9B,EAEL0M,EAAaxC,WAAW,SAAmB,IAARlK,EAC9B0M,EAEF,QAAQ1M,OAAS0M,KAEnBA,EAAe1M,GAGtB3b,MAAMC,QAAQooB,GACT1M,IACL,GAAmB,iBAARA,EACT,OAAOA,EAET,MAAM2M,EAAMC,KAAKD,IAAI3M,GACQ,eAAzBpG,QAAQC,IAAIC,WACTvB,OAAOsU,UAAUF,GAEXA,EAAMD,EAAaloB,OAAS,GACrChB,QAAQ9F,MAAM,CAAC,4BAA4BivB,gBAAmB,6BAA6B1I,KAAKC,UAAUwI,MAAkB,GAAGC,OAASD,EAAaloB,OAAS,0CAA0C8a,KAAK,OAF7M9b,QAAQ9F,MAAM,CAAC,oBAAoB2tB,qJAAiKA,oBAA2B/L,KAAK,QAKxO,MAAMwN,EAAcJ,EAAaC,GACjC,OAAI3M,GAAO,EACF8M,EAEkB,iBAAhBA,GACDA,EAEiB,iBAAhBA,GAA4BA,EAAY5C,WAAW,QACrD,aAAa4C,KAEf,IAAIA,KAGa,mBAAjBJ,EACFA,GAEoB,eAAzB9S,QAAQC,IAAIC,UACdtW,QAAQ9F,MAAM,CAAC,oBAAoB2tB,cAAqBqB,iBAA6B,kDAAkDpN,KAAK,OAEvI,OACT,CACO,SAASyN,GAAmBvsB,GACjC,OAAOgsB,GAAgBhsB,EAAO,UAAW,EAAG,UAC9C,CACO,SAASsQ,GAASkc,EAAa7J,GACpC,MAAyB,iBAAdA,GAAuC,MAAbA,EAC5BA,EAEF6J,EAAY7J,EACrB,CAOA,SAAS8J,GAAmBhvB,EAAOyhB,EAAMnf,EAAMysB,GAG7C,IAAKtN,EAAKgL,SAASnqB,GACjB,OAAO,KAET,MACMupB,EAbD,SAA+BoD,EAAeF,GACnD,OAAO7J,GAAa+J,EAAc3E,QAAO,CAACC,EAAK4C,KAC7C5C,EAAI4C,GAAeta,GAASkc,EAAa7J,GAClCqF,IACN,GACL,CAQ6B2E,CADLnB,GAAiBzrB,GACyBysB,GAEhE,OAAOnD,GAAkB5rB,EADPA,EAAMsC,GACmBupB,EAC7C,CACA,SAASxwB,GAAM2E,EAAOyhB,GACpB,MAAMsN,EAAcD,GAAmB9uB,EAAMuC,OAC7C,OAAOie,OAAOiB,KAAKzhB,GAAO4M,KAAItK,GAAQ0sB,GAAmBhvB,EAAOyhB,EAAMnf,EAAMysB,KAAczE,OAAOgB,GAAO,GAC1G,CACO,SAAS6D,GAAOnvB,GACrB,OAAO3E,GAAM2E,EAAOouB,GACtB,CAMO,SAASvlB,GAAQ7I,GACtB,OAAO3E,GAAM2E,EAAOquB,GACtB,CE7IA,SAASe,MAAWC,GAClB,MAAMC,EAAWD,EAAO/E,QAAO,CAACC,EAAKlvB,KACnCA,EAAMkyB,YAAYhS,SAAQjZ,IACxBioB,EAAIjoB,GAAQjH,KAEPkvB,IACN,IAIG8C,EAAKrtB,GACFwgB,OAAOiB,KAAKzhB,GAAOsqB,QAAO,CAACC,EAAKjoB,IACjCgtB,EAAShtB,GACJgpB,GAAMf,EAAK+E,EAAShtB,GAAMtC,IAE5BuqB,GACN,IAIL,OAFA8C,EAAGC,UAAqC,eAAzB3R,QAAQC,IAAIC,SAA4BwT,EAAO/E,QAAO,CAACC,EAAKlvB,IAAUmlB,OAAOM,OAAOyJ,EAAKlvB,EAAMiyB,YAAY,CAAE,GAAI,CAAE,EAClID,EAAGE,YAAc8B,EAAO/E,QAAO,CAACC,EAAKlvB,IAAUkvB,EAAIgF,OAAOl0B,EAAMkyB,cAAc,IACvEF,CACT,CCjBO,SAASmC,GAAgBzxB,GAC9B,MAAqB,iBAAVA,EACFA,EAEF,GAAGA,WACZ,CACA,SAAS0xB,GAAkBntB,EAAM0H,GAC/B,OAAO3O,GAAM,CACXiH,OACA8qB,SAAU,UACVpjB,aAEJ,CHsHAmlB,GAAO7B,UAAqC,eAAzB3R,QAAQC,IAAIC,SAA4BuS,GAAW9D,QAAO,CAACE,EAAK/b,KACjF+b,EAAI/b,GAAO4c,GACJb,IACN,CAAA,GAAM,CAAE,EACX2E,GAAO5B,YAAca,GAIrBvlB,GAAQykB,UAAqC,eAAzB3R,QAAQC,IAAIC,SAA4BwS,GAAY/D,QAAO,CAACE,EAAK/b,KACnF+b,EAAI/b,GAAO4c,GACJb,IACN,CAAA,GAAM,CAAE,EACX3hB,GAAQ0kB,YAAcc,GAIuB,eAAzB1S,QAAQC,IAAIC,UAA4ByS,GAAYhE,QAAO,CAACE,EAAK/b,KACnF+b,EAAI/b,GAAO4c,GACJb,IACN,CAAA,GGxII,MAAMkF,GAASD,GAAkB,SAAUD,IACrCG,GAAYF,GAAkB,YAAaD,IAC3CI,GAAcH,GAAkB,cAAeD,IAC/CK,GAAeJ,GAAkB,eAAgBD,IACjDM,GAAaL,GAAkB,aAAcD,IAC7CO,GAAcN,GAAkB,eAChCO,GAAiBP,GAAkB,kBACnCQ,GAAmBR,GAAkB,oBACrCS,GAAoBT,GAAkB,qBACtCU,GAAkBV,GAAkB,mBACpCW,GAAUX,GAAkB,UAAWD,IACvCa,GAAeZ,GAAkB,gBAIjC9nB,GAAe3H,IAC1B,QAA2BG,IAAvBH,EAAM2H,cAAqD,OAAvB3H,EAAM2H,aAAuB,CACnE,MAAMonB,EAAcR,GAAgBvuB,EAAMuC,MAAO,qBAAsB,EAAG,gBACpEspB,EAAqB3G,IAAc,CACvCvd,aAAckL,GAASkc,EAAa7J,KAEtC,OAAO0G,GAAkB5rB,EAAOA,EAAM2H,aAAckkB,EACxD,CACE,OAAO,MAETlkB,GAAa2lB,UAAqC,eAAzB3R,QAAQC,IAAIC,SAA4B,CAC/DlU,aAAc0jB,IACZ,CAAE,EACN1jB,GAAa4lB,YAAc,CAAC,gBACZ6B,GAAQM,GAAQC,GAAWC,GAAaC,GAAcC,GAAYC,GAAaC,GAAgBC,GAAkBC,GAAmBC,GAAiBxoB,GAAcyoB,GAASC,ICvCrL,MAAMC,GAAMtwB,IACjB,QAAkBG,IAAdH,EAAMswB,KAAmC,OAAdtwB,EAAMswB,IAAc,CACjD,MAAMvB,EAAcR,GAAgBvuB,EAAMuC,MAAO,UAAW,EAAG,OACzDspB,EAAqB3G,IAAc,CACvCoL,IAAKzd,GAASkc,EAAa7J,KAE7B,OAAO0G,GAAkB5rB,EAAOA,EAAMswB,IAAKzE,EAC/C,CACE,OAAO,MAETyE,GAAIhD,UAAqC,eAAzB3R,QAAQC,IAAIC,SAA4B,CACtDyU,IAAKjF,IACH,CAAE,EACNiF,GAAI/C,YAAc,CAAC,OAIZ,MAAMgD,GAAYvwB,IACvB,QAAwBG,IAApBH,EAAMuwB,WAA+C,OAApBvwB,EAAMuwB,UAAoB,CAC7D,MAAMxB,EAAcR,GAAgBvuB,EAAMuC,MAAO,UAAW,EAAG,aACzDspB,EAAqB3G,IAAc,CACvCqL,UAAW1d,GAASkc,EAAa7J,KAEnC,OAAO0G,GAAkB5rB,EAAOA,EAAMuwB,UAAW1E,EACrD,CACE,OAAO,MAET0E,GAAUjD,UAAqC,eAAzB3R,QAAQC,IAAIC,SAA4B,CAC5D0U,UAAWlF,IACT,CAAE,EACNkF,GAAUhD,YAAc,CAAC,aAIlB,MAAMiD,GAASxwB,IACpB,QAAqBG,IAAjBH,EAAMwwB,QAAyC,OAAjBxwB,EAAMwwB,OAAiB,CACvD,MAAMzB,EAAcR,GAAgBvuB,EAAMuC,MAAO,UAAW,EAAG,UACzDspB,EAAqB3G,IAAc,CACvCsL,OAAQ3d,GAASkc,EAAa7J,KAEhC,OAAO0G,GAAkB5rB,EAAOA,EAAMwwB,OAAQ3E,EAClD,CACE,OAAO,MAET2E,GAAOlD,UAAqC,eAAzB3R,QAAQC,IAAIC,SAA4B,CACzD2U,OAAQnF,IACN,CAAE,EACNmF,GAAOjD,YAAc,CAAC,UCrDf,SAASkD,GAAiB1yB,EAAOmvB,GACtC,MAAkB,SAAdA,EACKA,EAEFnvB,CACT,CD4EaqxB,GAAQkB,GAAKC,GAAWC,GA3BXn1B,GAAM,CAC9BiH,KAAM,eAEejH,GAAM,CAC3BiH,KAAM,YAEoBjH,GAAM,CAChCiH,KAAM,iBAEuBjH,GAAM,CACnCiH,KAAM,oBAEoBjH,GAAM,CAChCiH,KAAM,iBAE2BjH,GAAM,CACvCiH,KAAM,wBAEwBjH,GAAM,CACpCiH,KAAM,qBAEyBjH,GAAM,CACrCiH,KAAM,sBAEgBjH,GAAM,CAC5BiH,KAAM,cE9ED,SAASouB,GAAgB3yB,GAC9B,OAAOA,GAAS,GAAe,IAAVA,EAAyB,IAARA,EAAH,IAAoBA,CACzD,CDmBgBqxB,GAhBK/zB,GAAM,CACzBiH,KAAM,QACN8qB,SAAU,UACVpjB,UAAWymB,KAEUp1B,GAAM,CAC3BiH,KAAM,UACN6qB,YAAa,kBACbC,SAAU,UACVpjB,UAAWymB,KAEkBp1B,GAAM,CACnCiH,KAAM,kBACN8qB,SAAU,UACVpjB,UAAWymB,MChBN,MAAMxtB,GAAQ5H,GAAM,CACzBiH,KAAM,QACN0H,UAAW0mB,KAEAljB,GAAWxN,IACtB,QAAuBG,IAAnBH,EAAMwN,UAA6C,OAAnBxN,EAAMwN,SAAmB,CAC3D,MAAMqe,EAAqB3G,IACzB,MAAMnpB,EAAaiE,EAAMuC,OAAOmnB,aAAa1G,SAASkC,IAAcyL,GAAkBzL,GACtF,OAAKnpB,EAKkC,OAAnCiE,EAAMuC,OAAOmnB,aAAaM,KACrB,CACLxc,SAAU,GAAGzR,IAAaiE,EAAMuC,MAAMmnB,YAAYM,QAG/C,CACLxc,SAAUzR,GAVH,CACLyR,SAAUkjB,GAAgBxL,KAYhC,OAAO0G,GAAkB5rB,EAAOA,EAAMwN,SAAUqe,EACpD,CACE,OAAO,MAETre,GAAS+f,YAAc,CAAC,YACjB,MAAMqD,GAAWv1B,GAAM,CAC5BiH,KAAM,WACN0H,UAAW0mB,KAEAhpB,GAASrM,GAAM,CAC1BiH,KAAM,SACN0H,UAAW0mB,KAEAhjB,GAAYrS,GAAM,CAC7BiH,KAAM,YACN0H,UAAW0mB,KAEAG,GAAYx1B,GAAM,CAC7BiH,KAAM,YACN0H,UAAW0mB,KAEYr1B,GAAM,CAC7BiH,KAAM,OACN6qB,YAAa,QACbnjB,UAAW0mB,KAEar1B,GAAM,CAC9BiH,KAAM,OACN6qB,YAAa,SACbnjB,UAAW0mB,KAKEtB,GAAQnsB,GAAOuK,GAAUojB,GAAUlpB,GAAQgG,GAAWmjB,GAH5Cx1B,GAAM,CAC7BiH,KAAM,eCvDR,MAAMwuB,GAAkB,CAEtBpB,OAAQ,CACNtC,SAAU,UACVpjB,UAAWwlB,IAEbG,UAAW,CACTvC,SAAU,UACVpjB,UAAWwlB,IAEbI,YAAa,CACXxC,SAAU,UACVpjB,UAAWwlB,IAEbK,aAAc,CACZzC,SAAU,UACVpjB,UAAWwlB,IAEbM,WAAY,CACV1C,SAAU,UACVpjB,UAAWwlB,IAEbO,YAAa,CACX3C,SAAU,WAEZ4C,eAAgB,CACd5C,SAAU,WAEZ6C,iBAAkB,CAChB7C,SAAU,WAEZ8C,kBAAmB,CACjB9C,SAAU,WAEZ+C,gBAAiB,CACf/C,SAAU,WAEZgD,QAAS,CACPhD,SAAU,UACVpjB,UAAWwlB,IAEba,aAAc,CACZjD,SAAU,WAEZzlB,aAAc,CACZylB,SAAU,qBACV/xB,MAAOsM,IAGT7D,MAAO,CACLspB,SAAU,UACVpjB,UAAWymB,IAEb7oB,QAAS,CACPwlB,SAAU,UACVD,YAAa,kBACbnjB,UAAWymB,IAEbpnB,gBAAiB,CACf+jB,SAAU,UACVpjB,UAAWymB,IAGb/T,EAAG,CACDrhB,MAAOwN,IAETkoB,GAAI,CACF11B,MAAOwN,IAETmoB,GAAI,CACF31B,MAAOwN,IAETooB,GAAI,CACF51B,MAAOwN,IAETqoB,GAAI,CACF71B,MAAOwN,IAETsoB,GAAI,CACF91B,MAAOwN,IAETuoB,GAAI,CACF/1B,MAAOwN,IAETA,QAAS,CACPxN,MAAOwN,IAETwoB,WAAY,CACVh2B,MAAOwN,IAETC,aAAc,CACZzN,MAAOwN,IAETyoB,cAAe,CACbj2B,MAAOwN,IAET0oB,YAAa,CACXl2B,MAAOwN,IAETglB,SAAU,CACRxyB,MAAOwN,IAETilB,SAAU,CACRzyB,MAAOwN,IAET2oB,cAAe,CACbn2B,MAAOwN,IAET4oB,mBAAoB,CAClBp2B,MAAOwN,IAET6oB,iBAAkB,CAChBr2B,MAAOwN,IAET8oB,aAAc,CACZt2B,MAAOwN,IAET+oB,kBAAmB,CACjBv2B,MAAOwN,IAETgpB,gBAAiB,CACfx2B,MAAOwN,IAET4T,EAAG,CACDphB,MAAO8zB,IAET2C,GAAI,CACFz2B,MAAO8zB,IAETjrB,GAAI,CACF7I,MAAO8zB,IAET4C,GAAI,CACF12B,MAAO8zB,IAEThrB,GAAI,CACF9I,MAAO8zB,IAETpnB,GAAI,CACF1M,MAAO8zB,IAET6C,GAAI,CACF32B,MAAO8zB,IAETA,OAAQ,CACN9zB,MAAO8zB,IAETvmB,UAAW,CACTvN,MAAO8zB,IAEThsB,YAAa,CACX9H,MAAO8zB,IAETxmB,aAAc,CACZtN,MAAO8zB,IAETjsB,WAAY,CACV7H,MAAO8zB,IAETxB,QAAS,CACPtyB,MAAO8zB,IAETvB,QAAS,CACPvyB,MAAO8zB,IAET8C,aAAc,CACZ52B,MAAO8zB,IAET+C,kBAAmB,CACjB72B,MAAO8zB,IAETgD,gBAAiB,CACf92B,MAAO8zB,IAETiD,YAAa,CACX/2B,MAAO8zB,IAETkD,iBAAkB,CAChBh3B,MAAO8zB,IAETmD,eAAgB,CACdj3B,MAAO8zB,IAGToD,aAAc,CACZpF,aAAa,EACbnjB,UAAWjM,IAAU,CACnB,eAAgB,CACdqG,QAASrG,MAIfqG,QAAS,CAAE,EACXouB,SAAU,CAAE,EACZC,aAAc,CAAE,EAChBC,WAAY,CAAE,EACdC,WAAY,CAAE,EAEdC,UAAW,CAAE,EACblqB,cAAe,CAAE,EACjBmqB,SAAU,CAAE,EACZ/sB,eAAgB,CAAE,EAClBH,WAAY,CAAE,EACdmtB,aAAc,CAAE,EAChBC,MAAO,CAAE,EACTjuB,KAAM,CAAE,EACRyI,SAAU,CAAE,EACZU,WAAY,CAAE,EACd+kB,UAAW,CAAE,EACbC,aAAc,CAAE,EAChBC,YAAa,CAAE,EAEf5C,IAAK,CACHj1B,MAAOi1B,IAETE,OAAQ,CACNn1B,MAAOm1B,IAETD,UAAW,CACTl1B,MAAOk1B,IAET4C,WAAY,CAAE,EACdC,QAAS,CAAE,EACXC,aAAc,CAAE,EAChBC,gBAAiB,CAAE,EACnBC,aAAc,CAAE,EAChBC,oBAAqB,CAAE,EACvBC,iBAAkB,CAAE,EACpBC,kBAAmB,CAAE,EACrBjd,SAAU,CAAE,EAEZhT,SAAU,CAAE,EACZqE,OAAQ,CACNslB,SAAU,UAEZhkB,IAAK,CAAE,EACPuqB,MAAO,CAAE,EACTC,OAAQ,CAAE,EACVzqB,KAAM,CAAE,EAER0qB,UAAW,CACTzG,SAAU,WAGZnqB,MAAO,CACL+G,UAAW0mB,IAEbljB,SAAU,CACRnS,MAAOmS,IAETojB,SAAU,CACR5mB,UAAW0mB,IAEbhpB,OAAQ,CACNsC,UAAW0mB,IAEbhjB,UAAW,CACT1D,UAAW0mB,IAEbG,UAAW,CACT7mB,UAAW0mB,IAEbxiB,UAAW,CAAE,EAEb4lB,KAAM,CACJ1G,SAAU,QAEZ2G,WAAY,CACV3G,SAAU,cAEZ3iB,SAAU,CACR2iB,SAAU,cAEZ4G,UAAW,CACT5G,SAAU,cAEZljB,WAAY,CACVkjB,SAAU,cAEZ6G,cAAe,CAAE,EACjBC,cAAe,CAAE,EACjBC,WAAY,CAAE,EACd/lB,UAAW,CAAE,EACbgmB,WAAY,CACVjH,aAAa,EACbC,SAAU,eCtKd,MAAMiH,GA5GC,WACL,SAASC,EAAchyB,EAAMyf,EAAKxf,EAAOgyB,GACvC,MAAMv0B,EAAQ,CACZsC,CAACA,GAAOyf,EACRxf,SAEIoQ,EAAU4hB,EAAOjyB,GACvB,IAAKqQ,EACH,MAAO,CACLrQ,CAACA,GAAOyf,GAGZ,MAAMoL,YACJA,EAAc7qB,EAAI8qB,SAClBA,EAAQpjB,UACRA,EAAS3O,MACTA,GACEsX,EACJ,GAAW,MAAPoP,EACF,OAAO,KAIT,GAAiB,eAAbqL,GAAqC,YAARrL,EAC/B,MAAO,CACLzf,CAACA,GAAOyf,GAGZ,MAAMiL,EAAeJ,GAAQrqB,EAAO6qB,IAAa,CAAE,EACnD,GAAI/xB,EACF,OAAOA,EAAM2E,GAef,OAAO4rB,GAAkB5rB,EAAO+hB,GAbLkL,IACzB,IAAIlvB,EAAQ8U,GAASma,EAAchjB,EAAWijB,GAK9C,OAJIA,IAAmBlvB,GAAmC,iBAAnBkvB,IAErClvB,EAAQ8U,GAASma,EAAchjB,EAAW,GAAG1H,IAA0B,YAAnB2qB,EAA+B,GAAKN,GAAWM,KAAmBA,KAEpG,IAAhBE,EACKpvB,EAEF,CACLovB,CAACA,GAAcpvB,KAIvB,CA4DE,OA3DA,SAASs2B,EAAgBr0B,GACvB,MAAMiE,GACJA,EAAE1B,MACFA,EAAQ,CAAA,GACNvC,GAAS,CAAE,EACf,IAAKiE,EACH,OAAO,KAET,MAAMswB,EAAShyB,EAAMiyB,mBAAqB1D,GAO1C,SAAS2D,EAASC,GAChB,IAAIC,EAAWD,EACf,GAAuB,mBAAZA,EACTC,EAAWD,EAAQnyB,QACd,GAAuB,iBAAZmyB,EAEhB,OAAOA,EAET,IAAKC,EACH,OAAO,KAET,MAAMC,EZQL,SAAqCC,EAAmB,IAC7D,MAAMC,EAAqBD,EAAiBpT,MAAM6I,QAAO,CAACC,EAAK9b,KAE7D8b,EAD2BsK,EAAiBnK,GAAGjc,IACrB,CAAE,EACrB8b,IACN,IACH,OAAOuK,GAAsB,CAAE,CACjC,CYf+BC,CAA4BxyB,EAAMmnB,aACrDsL,EAAkBxU,OAAOiB,KAAKmT,GACpC,IAAI75B,EAAM65B,EA2BV,OA1BApU,OAAOiB,KAAKkT,GAAUpZ,SAAQ0Z,IAC5B,MAAMl3B,GAlFIm3B,EAkFaP,EAASM,GAlFbzZ,EAkFwBjZ,EAjFvB,mBAAZ2yB,EAAyBA,EAAQ1Z,GAAO0Z,GADxD,IAAkBA,EAAS1Z,EAmFnB,GAAIzd,QACF,GAAqB,iBAAVA,EACT,GAAIw2B,EAAOU,GACTl6B,EAAMuwB,GAAMvwB,EAAKu5B,EAAcW,EAAUl3B,EAAOwE,EAAOgyB,QAClD,CACL,MAAM5D,EAAoB/E,GAAkB,CAC1CrpB,SACCxE,GAAOwZ,IAAM,CACd0d,CAACA,GAAW1d,OAhG5B,YAAgC4d,GAC9B,MAAMrO,EAAUqO,EAAQ7K,QAAO,CAAC7I,EAAMzB,IAAWyB,EAAK8N,OAAO/O,OAAOiB,KAAKzB,KAAU,IAC7EoV,EAAQ,IAAIzd,IAAImP,GACtB,OAAOqO,EAAQ3N,OAAMxH,GAAUoV,EAAM1kB,OAAS8P,OAAOiB,KAAKzB,GAAQzZ,QACpE,CA8FkB8uB,CAAoB1E,EAAmB5yB,GAMzChD,EAAMuwB,GAAMvwB,EAAK41B,GALjB51B,EAAIk6B,GAAYZ,EAAgB,CAC9BpwB,GAAIlG,EACJwE,SAKlB,MAEYxH,EAAMuwB,GAAMvwB,EAAKu5B,EAAcW,EAAUl3B,EAAOwE,EAAOgyB,OX3G5D,SAA8BhyB,EAAOxH,GAC1C,IAAKwH,EAAMkpB,iBACT,OAAO1wB,EAET,MAAMu6B,EAAS9U,OAAOiB,KAAK1mB,GAAK4R,QAAO8B,GAAOA,EAAIwd,WAAW,gBAAe9B,MAAK,CAACrN,EAAGd,KACnF,MAAMuZ,EAAQ,yBACd,QAASzY,EAAEoP,MAAMqJ,KAAS,IAAM,KAAOvZ,EAAEkQ,MAAMqJ,KAAS,IAAM,MAEhE,OAAKD,EAAO/uB,OAGL+uB,EAAOhL,QAAO,CAACC,EAAK9b,KACzB,MAAM1Q,EAAQhD,EAAI0T,GAGlB,cAFO8b,EAAI9b,GACX8b,EAAI9b,GAAO1Q,EACJwsB,IACN,IACExvB,IARIA,CAUX,CW4Fay6B,CAAqBjzB,EZb3B,SAAiCypB,EAAgB3wB,GACtD,OAAO2wB,EAAe1B,QAAO,CAACC,EAAK9b,KACjC,MAAMgnB,EAAmBlL,EAAI9b,GAK7B,QAJ4BgnB,GAA6D,IAAzCjV,OAAOiB,KAAKgU,GAAkBlvB,gBAErEgkB,EAAI9b,GAEN8b,IACNlvB,EACL,CYIyCq6B,CAAwBV,EAAiBj6B,GAClF,CACI,OAAOqL,MAAMC,QAAQpC,GAAMA,EAAG2I,IAAI6nB,GAAYA,EAASxwB,EAC3D,CAEA,CACwB0xB,GC9DT,SAASptB,GAAYkG,EAAK4gB,GAEvC,MAAM9sB,EAAQwkB,KACd,GAAIxkB,EAAMuqB,KAAM,CACd,IAAKvqB,EAAMqzB,eAAennB,IAAgD,mBAAjClM,EAAMszB,uBAC7C,MAAO,CAAE,EAGX,IAAIC,EAAWvzB,EAAMszB,uBAAuBpnB,GAC5C,MAAiB,MAAbqnB,EACKzG,IAELyG,EAASrJ,SAAS,UAAYqJ,EAASrJ,SAAS,QAElDqJ,EAAW,WAAWA,EAAS1K,QAAQ,QAAS,UAE3C,CACL0K,CAACA,GAAWzG,GAElB,CACE,OAAI9sB,EAAM2F,QAAQkN,OAAS3G,EAClB4gB,EAEF,CAAE,CACX,CC/EA,SAASthB,GAASgoB,EAAe,MAC/B,MAAMC,EAAejrB,EAAMkrB,WAAWC,GACtC,OAAQF,IALaxL,EAKiBwL,EAJH,IAA5BxV,OAAOiB,KAAK+I,GAAKjkB,QAI6CyvB,EAAfD,EALxD,IAAuBvL,CAMvB,CFmHA6J,GAAgB9G,YAAc,CAAC,MGzHxB,MAAM4I,GCIb,SAAqBxjB,EAAU,MAAOyI,GACpC,MACEsO,YAAamL,EAAmB,CAAE,EAClC3sB,QAASkuB,EAAe,CAAE,EAC1B9tB,QAAS+tB,EACT3P,MAAO4P,EAAa,CAAE,KACnBjsB,GACDsI,EACE+W,EAAcD,GAAkBoL,GAChCvsB,ECZO,SAAuB+tB,EAAe,EAIrDrsB,EAAY8kB,GAAmB,CAC7BxmB,QAAS+tB,KAGT,GAAIA,EAAaE,IACf,OAAOF,EAET,MAAM/tB,EAAU,IAAIkuB,KACW,eAAzB7a,QAAQC,IAAIC,WACR2a,EAAUjwB,QAAU,GACxBhB,QAAQ9F,MAAM,mEAAmE+2B,EAAUjwB,YAG7D,IAArBiwB,EAAUjwB,OAAe,CAAC,GAAKiwB,GAChC5pB,KAAI6pB,IACd,MAAMnN,EAAStf,EAAUysB,GACzB,MAAyB,iBAAXnN,EAAsB,GAAGA,MAAaA,KACnDjI,KAAK,MAGV,OADA/Y,EAAQiuB,KAAM,EACPjuB,CACT,CDbkBouB,CAAcL,GAC9B,IAAIM,EAAWpN,GAAU,CACvBG,cACAjc,UAAW,MACXmpB,WAAY,CAAE,EAEd1uB,QAAS,CACPkN,KAAM,WACHghB,GAEL9tB,UACAoe,MAAO,IACFA,MACA4P,IAEJjsB,GAcH,OAbAssB,EfSa,SAA6BE,GAC1C,MAAMC,EAAmB,CAACC,EAAYn6B,IAASm6B,EAAW3L,QAAQ,SAAUxuB,EAAO,cAAcA,IAAS,cAC1G,SAASo6B,EAAS9vB,EAAMtK,GACtBsK,EAAKwjB,GAAK,IAAItP,IAAS0b,EAAiBD,EAAWnN,YAAYgB,MAAMtP,GAAOxe,GAC5EsK,EAAKyjB,KAAO,IAAIvP,IAAS0b,EAAiBD,EAAWnN,YAAYiB,QAAQvP,GAAOxe,GAChFsK,EAAK0jB,QAAU,IAAIxP,IAAS0b,EAAiBD,EAAWnN,YAAYkB,WAAWxP,GAAOxe,GACtFsK,EAAK+jB,KAAO,IAAI7P,IAAS0b,EAAiBD,EAAWnN,YAAYuB,QAAQ7P,GAAOxe,GAChFsK,EAAKgkB,IAAM,IAAI9P,KACb,MAAMuQ,EAASmL,EAAiBD,EAAWnN,YAAYwB,OAAO9P,GAAOxe,GACrE,OAAI+uB,EAAOc,SAAS,eAEXd,EAAOP,QAAQ,eAAgB,IAAIA,QAAQ,aAAc,UAAUA,QAAQ,aAAc,UAAUA,QAAQ,MAAO,MAEpHO,EAEb,CACE,MAAMzkB,EAAO,CAAE,EACTukB,EAAmB7uB,IACvBo6B,EAAS9vB,EAAMtK,GACRsK,GAGT,OADA8vB,EAASvL,GACF,IACFoL,EACHpL,mBAEJ,CenCawL,CAAoBN,GAC/BA,EAASpuB,YAAcA,GACvBouB,EAAWvb,EAAKkP,QAAO,CAACC,EAAKkM,IAAalN,GAAUgB,EAAKkM,IAAWE,GACpEA,EAASnC,kBAAoB,IACxB1D,MACAzmB,GAAOmqB,mBAEZmC,EAASO,YAAc,SAAYl3B,GACjC,OAAOq0B,GAAgB,CACrBpwB,GAAIjE,EACJuC,MAAOwkB,MAEV,EACM4P,CACT,CD3CkCQ,GGanB,SAASC,GAAap3B,GACnC,MACEiE,GAAIozB,KACDhtB,GACDrK,GACEs3B,YACJA,EAAWC,WACXA,GAtBev3B,KACjB,MAAM2rB,EAAS,CACb2L,YAAa,CAAE,EACfC,WAAY,CAAA,GAERhD,EAASv0B,GAAOuC,OAAOiyB,mBAAqB1D,GAQlD,OAPAtQ,OAAOiB,KAAKzhB,GAAOub,SAAQjZ,IACrBiyB,EAAOjyB,GACTqpB,EAAO2L,YAAYh1B,GAAQtC,EAAMsC,GAEjCqpB,EAAO4L,WAAWj1B,GAAQtC,EAAMsC,MAG7BqpB,GAUH6L,CAAWntB,GACf,IAAIotB,EAoBJ,OAlBEA,EADErxB,MAAMC,QAAQgxB,GACN,CAACC,KAAgBD,GACF,mBAATA,EACN,IAAIjc,KACZ,MAAMuQ,EAAS0L,KAAQjc,GACvB,OAAK8N,GAAcyC,GAGZ,IACF2L,KACA3L,GAJI2L,GAQD,IACLA,KACAD,GAGA,IACFE,EACHtzB,GAAIwzB,EAER,CClDA,MAAMC,GAAmBxU,GAAiBA,EAepCyU,GAd2B,MAC/B,IAAIC,EAAWF,GACf,MAAO,CACL,SAAAG,CAAUC,GACRF,EAAWE,CACZ,EACDF,SAAS1U,GACA0U,EAAS1U,GAElB,KAAA6U,GACEH,EAAWF,EACjB,IAG2BM,GCdpB,MAAMC,GAAqB,CAChCC,OAAQ,SACRrkB,QAAS,UACTskB,UAAW,YACXjtB,SAAU,WACVzL,MAAO,QACPuM,SAAU,WACVE,QAAS,UACTksB,aAAc,eACdp1B,KAAM,OACNq1B,SAAU,WACVnmB,SAAU,WACVjG,SAAU,YCZZ,MCKMxE,GCES,SAAmBkL,EAAU,IAC1C,MAAM2lB,QACJA,EAAOvC,aACPA,EAAYwC,iBACZA,EAAmB,cAAaC,kBAChCA,GACE7lB,EACE8lB;;;;;;;;ACHO,SAAgBC,EAAK/lB,GAClC,MAAMgmB,EAAgBC,GAASF,EAAK/lB,GACpC,MAA6B,eAAzBgJ,QAAQC,IAAIC,SACP,IAAIwT,KACT,MAAMxqB,EAAsC,IAAI6zB,KAMhD,OALsB,IAAlBrJ,EAAO9oB,OACThB,QAAQ9F,MAAM,CAAC,uCAAuCoF,uCAAgD,gFAAgFwc,KAAK,OAClLgO,EAAOzkB,MAAKvP,QAAmB8E,IAAV9E,KAC9BkK,QAAQ9F,MAAM,mBAAmBoF,wDAE5B8zB,KAAiBtJ,IAGrBsJ,CACT,CDXkBx2B,CAAO,MAAO,CAC5BE,kBAAmBC,GAAiB,UAATA,GAA6B,OAATA,GAA0B,OAATA,GADlDH,CAEbkyB,IACG5sB,EAAmBsD,EAAMC,YAAW,SAAa6tB,EAAS79B,GAC9D,MAAMuH,ERdV,SAAkBwzB,EAAeI,IAC/B,OAAO2C,GAAuB/C,EAChC,CQYkBhoB,CAASgoB,IACjBhqB,UACJA,EAASlH,UACTA,EAAY,SACTwF,GACD+sB,GAAayB,GACjB,OAAoBr1B,EAAKi1B,EAAS,CAChCM,GAAIl0B,EACJ7J,IAAKA,EACL+Q,UAAWvF,GAAKuF,EAAWysB,EAAoBA,EAAkBD,GAAoBA,GACrFh2B,MAAO+1B,GAAU/1B,EAAM+1B,IAAoB/1B,KACxC8H,GAET,IACE,OAAO5C,CACT,CD5BYuxB,CAAU,CACpBT,iBGNa,SAAgCrV,EAAerV,EAAOorB,EAAoB,OACvF,MAAMtN,EAAS,CAAE,EAIjB,OAHA9d,EAAM0N,SAAQ2d,IACZvN,EAAOuN,GLWI,SAA8BhW,EAAegW,EAAMD,EAAoB,OACpF,MAAME,EAAmBlB,GAAmBiB,GAC5C,OAAOC,EAAmB,GAAGF,KAAqBE,IAAqB,GAAGxB,GAAmBC,SAAS1U,MAAkBgW,GAC1H,CKdmBE,CAAqBlW,EAAegW,EAAMD,MAEpDtN,CACT,CJNmB0N,CAAuB,SAAU,CAAC,SCMtBC,KAC7Bd,kBAAmBb,GAAmBC,WAEf,eAAzBjc,QAAQC,IAAIC,WAA4BpU,GAAI6lB,UAAmC,CAQ7E5pB,SAAU0kB,GAAUlhB,KAKpBrC,UAAWujB,GAAUhD,YAIrBnhB,GAAImkB,GAAUjC,UAAU,CAACiC,GAAUvD,QAAQuD,GAAUjC,UAAU,CAACiC,GAAU3D,KAAM2D,GAAUpI,OAAQoI,GAAU5D,QAAS4D,GAAU3D,KAAM2D,GAAUpI,WIzBjJ,MAAMuZ,GACJv5B,GAEOwD,EAACgQ,EAAS,IAAKxT,EAAO8R,UAAW,CAAE0nB,WAAY,CAAEvnB,QAAQ,MCK5DwnB,GACJvkB,IAEA,GAAIA,GAASwkB,UAAW,CACtB,MAAM15B,EAAQkV,EAAQwkB,UAChBC,EAAczkB,GAASykB,aAAe,KACtCC,EAAc1kB,GAAS0kB,aAAe,KACtCC,EAAa3kB,GAAS2kB,YAAc,KACpCnkB,EAAiBR,GAASwkB,WAAWhkB,WAAa,KAClDC,EAAYT,GAASwkB,WAAW/jB,WAAa,KACnD,OAAM3V,GAAS25B,GAAeE,GAAcnkB,GAAaC,OAG/BxV,IAAlBH,GAAO85B,QAAyB95B,GAAO85B,QAC5C5kB,EAAQ6kB,aAAatN,SAAS/W,GAkK/BlS,EAAA4M,EAAA,CAAA,GAjKA5M,EAACw2B,GACCtpB,KACE1Q,GAAOi6B,WAAWC,WAAa,CAC7BpQ,GAAI,GACJD,GAAI,GACJD,GAAI,IAGR3lB,GAAI,CACF4E,QAAS,EACT5F,MAAO,QACRS,SAEc,SAAdiS,GAAsC,WAAdA,EACvBnS,EAAC+1B,IACCY,WAAS,EACT5+B,KAAMoa,EACNzK,YACElL,GAAOkL,WAAYgK,EAAQklB,eAAe3N,SAAS/W,IAIrDokB,OAAQ95B,GAAO85B,SAAU,EACzBzyB,MAAOrH,GAAOq6B,WACdt8B,MAAO87B,EAAWnkB,GAClBjE,SAAWpE,IACT,IAAIyF,EAAW,KACW,IAAtBzF,EAAM0G,OAAOhW,QAEb+U,EADgB,WAAd6C,GAA0ByE,GAAU/M,EAAM0G,OAAOhW,OACxCuc,OAAOjN,EAAM0G,OAAOhW,OAEpBsP,EAAM0G,OAAOhW,OAG5B47B,EAAYW,SAAS5kB,EAAW5C,GAC5B9S,GAAOi6B,WAAWM,uBACpBv6B,GAAOi6B,WAAWM,sBAChBznB,EACA6mB,EACAC,IAIN31B,GAAIjE,GAAOi6B,WAAW5+B,MACtBoE,MAAkDU,MAA3Cw5B,EAAYa,UAAUC,OAAO/kB,GACpCtD,WAAYunB,GAAaa,WAAWC,OAClC/kB,IACCzX,SAASy8B,aAES,SAArB16B,GAAO2V,UACTnS,EAAC0N,GACC,CAAAM,OAAQxR,GAAO26B,YAAc/pB,GAC7B3M,GAAIjE,GAAOi6B,WAAW5+B,OAAS,CAAE4H,MAAO,QACxCiI,YACElL,GAAOkL,WAAYgK,EAAQklB,eAAe3N,SAAS/W,IAIrDrO,MAAOrH,GAAOq6B,WACdxoB,iBAAmBF,IACjBgoB,EAAYW,SAAS5kB,EAAW/D,GAC5B3R,GAAOi6B,WAAWM,uBACpBv6B,GAAOi6B,WAAWM,sBAChB5oB,EACAgoB,EACAC,IAIN77B,MAAO87B,EAAWnkB,GAClBjW,MAAkDU,MAA3Cw5B,EAAYa,UAAUC,OAAO/kB,GACpCvD,aAAcwnB,GAAaa,WAAWC,OACpC/kB,IACCzX,SAASy8B,aAES,aAArB16B,GAAO2V,UACTnS,EAAC6O,IACCb,OAAQxR,GAAO26B,YAAc9pB,GAC7B5M,GAAIjE,GAAOi6B,WAAW5+B,OAAS,CAAE4H,MAAO,QACxCiI,YACElL,GAAOkL,WAAYgK,EAAQklB,eAAe3N,SAAS/W,IAIrDrO,MAAOrH,GAAOq6B,WACdxoB,iBAAmBF,IACjBgoB,EAAYW,SAAS5kB,EAAW/D,GAC5B3R,GAAOi6B,WAAWM,uBACpBv6B,GAAOi6B,WAAWM,sBAChB5oB,EACAgoB,EACAC,IAIN77B,MAAO87B,EAAWnkB,GAClBjW,MAAkDU,MAA3Cw5B,EAAYa,UAAUC,OAAO/kB,GACpCvD,aAAcwnB,GAAaa,WAAWC,OACpC/kB,IACCzX,SAASy8B,aAES,aAArB16B,GAAO2V,UACTnS,EAACiQ,GAAQ,CACPpM,MAAOrH,GAAOq6B,WACdxoB,iBAAmBF,IACjBgoB,EAAYW,SAAS5kB,EAAW/D,GAC5B3R,GAAOi6B,WAAWM,uBACpBv6B,GAAOi6B,WAAWM,sBAChB5oB,EACAgoB,EACAC,IAIN77B,MAAO87B,EAAWnkB,GAClB5B,aAAc9T,GAAO8T,cAAgB,OACrCE,eAAgBhU,GAAOgU,gBAAkB,QACzC9I,YACElL,GAAOkL,WAAYgK,EAAQklB,eAAe3N,SAAS/W,IAIrDzR,GAAIjE,GAAOi6B,WAAW5+B,QAED,aAArB2E,GAAO2V,UACTnS,EAAC+O,GACC,CAAAtO,GAAIjE,GAAOi6B,WAAW5+B,OAAS,CAAE4H,MAAO,QACxCoE,MAAOrH,GAAOq6B,WACdnvB,YACElL,GAAOkL,WAAYgK,EAAQklB,eAAe3N,SAAS/W,IAIrD7D,iBAAkB,CAACF,EAAQoD,KACzB,IAAIjC,EAAW,KACXnB,IACFmB,EAAWnB,EAAI,IAEjBgoB,EAAYW,SAAS5kB,EAAW5C,GAC5B9S,GAAOi6B,WAAWM,uBACpBv6B,GAAOi6B,WAAWM,sBAChBznB,EACA6mB,EACAC,EACA7kB,IAINpC,QAAS3S,GAAO2S,SAAW,GAC3BO,aAAclT,GAAO46B,oBAAsB,GAC3ChoB,WAAY5S,GAAO66B,kBAAoB,GACvC98B,MAAO87B,EAAWnkB,GAClBvD,aAAcwnB,GAAaa,WAAWC,OACpC/kB,IACCzX,SAASy8B,aAGdl3B,EAAA4M,EAAA,CAAA1M,SAAA,yBAjKGF,QAwKT,OAAOA,SCvLLs3B,GAAsCx9B,IAC1C,MAAMuS,EAAUnJ,MACVsI,mBAAEA,EAAoBD,QAASgsB,GACnCjsB,GAAsB,CACpBQ,KAAMhS,GAAQwS,qBAAuB,GACrCX,MAAO,eACPM,qBAAsB,KACpBnS,GAAQyS,SAASzS,GAAQgT,WAG/B,OACEhT,SAAQwJ,WAER+I,EAAQlJ,iBAAiBrJ,EAAOwJ,WAG9BnD,EAAAyM,EAAA,CAAA1M,SAAA,CACEF,EAACwL,EAAqB,IACtBrL,EAAC6L,EACC,CAAA7K,QAASrH,GAAQkT,iBAAiBC,oBAClC3M,MAAOxG,GAAQkT,iBAAiBG,kBAChC5M,QAAS,KACP,GAAIzG,GAAQyS,SAAU,CACpB,GAAIzS,GAAQ+S,sBACL/S,EAAO+S,oBAAoB/S,EAAOgT,QACrC,QAGmC,IAAnChT,GAAQiT,uBACVwqB,GAA2B,GAE3Bz9B,GAAQyS,SAASzS,EAAOgT,UAG7B5M,SAAA,CAEApG,GAAQgH,KACPd,EAACa,IACCC,KAAMhH,EAAOgH,KACbjJ,MAAO,CAAE8H,YAAa,EAAGD,WAAY,KAGvCM,QAEFA,kBAAMlG,GAAQ+J,cAKb7D,SC7CLw3B,GACJh7B,GAGEwD,cACEG,EAACq2B,GAAMiB,WAAS,EAACh3B,GAAIjE,GAAO3E,MAAOsK,WAAW,aAC3CjC,SAAA,CAAA1D,GAAOqH,MACN7D,EAACw2B,EACC,CAAAtpB,KAAM,GACNzM,GAAI,CAAE4E,QAAS,EAAGqB,WAAY,OAAQ9F,QAAS,QAE9CV,SAAA1D,GAAOsE,KACNX,EAAAyM,EAAA,CAAA1M,SAAA,CACEF,EAACa,GAAe,CACdC,KAAMtE,EAAMsE,KACZjJ,MAAO,CAAE8H,YAAa,EAAGD,WAAY,KAEvCM,EAAM,MAAA,CAAAE,SAAA1D,EAAMqH,WAGd7D,EAAA4M,EAAA,CAAA1M,SAAG1D,EAAMqH,UAIb7D,QAEDxD,GAAOqV,SACJrV,EAAMqV,SAASzI,KAAKsI,GACG,UAAjBA,EAAQ3Z,KAERiI,EAACw3B,GACK,IAAA9lB,EAAQlV,MACZ25B,YAAa35B,EAAM25B,YACnBE,WAAY75B,EAAM65B,WAClBD,YAAa55B,EAAM45B,YACnBG,aAAc/5B,EAAM+5B,aACpBK,eAAgBp6B,EAAMo6B,iBAGA,UAAjBllB,EAAQ3Z,MAAqC,UAAjB2Z,EAAQE,KAE3C5R,EAACi2B,IACCC,UAAWxkB,EAAQlV,MACnB25B,YAAa35B,EAAM25B,YACnBE,WAAY75B,EAAM65B,WAClBD,YAAa55B,EAAM45B,YACnBG,aAAc/5B,EAAM+5B,aACpBK,eAAgBp6B,EAAMo6B,iBAGA,UAAjBllB,EAAQ3Z,MAAqC,SAAjB2Z,EAAQE,KAE3C5R,EAACw2B,EAAK,CACJtpB,KACEwE,GAASlV,OAAOi6B,WAAWC,WAAa,CACtCpQ,GAAI,EACJD,GAAI,EACJD,GAAI,IAGR3lB,GAAI,CAAE4E,QAAS,EAAG5F,MAAO,QAEzBS,SAAAF,EAAC0R,EAAQhO,KACP,CAAAyyB,YAAa35B,EAAM25B,YACnBE,WAAY75B,EAAM65B,WAClBD,YAAa55B,EAAM45B,qBAfpB,IAqBT,KAEH55B,GAAOrC,QACN6F,EAACw2B,EAAK,CAACtpB,KAAM,CAAEkZ,GAAI,IAAM3lB,GAAI,CAAE4E,QAAS,GAAGnF,SACxC1D,EAAMrC,QAAQiP,KAAKtP,GACXkG,EAACs3B,GAAU,IAAKx9B,EAAQgT,OAAQtQ,EAAM65B,iBAIjDr2B,EAAA4M,EAAA,CAAA,QCvEJ8qB,GACJl7B,IAEA,MAAMmV,EAASI,GAAavV,EAAMqV,WAC3B0kB,EAAcoB,GAAmBj/B,EAAmB,KACpDk+B,EAAgBgB,GAAqBl/B,EAAmB,IACzDm/B,EAAazlB,GAAEoK,OAAOxK,GAA0BL,IAEhDwkB,EAAc2B,GAAkB,CACpCC,SAAUC,GAAYH,KAElBxB,EAAaF,EAAY8B,QACzBC,EAAiBC,KACjBC,EAAkC57B,GAAO47B,2BAwCzChC,EAAc,CAClBiC,cAAe,CAACnmB,EAAmBomB,KACjCnC,EAAYW,SAAS5kB,EAAWomB,IAElCC,UAAYrmB,IACVylB,GAAiBa,GACG,IAAIA,EAAWtmB,MAIrCumB,UAAYvmB,IACVylB,GAAiBa,GACGA,EAAUrvB,QAAQ4K,GAAMA,IAAM7B,OAIpDwmB,aAAexmB,IACb0lB,GAAmBY,GACC,IAAIA,EAAWtmB,MAIrCymB,YAAczmB,IACZ0lB,GAAmBY,GACCA,EAAUrvB,QAAQ4K,GAAMA,IAAM7B,QAUtD,OAJArZ,GAAU,KApES0D,WACjB,IAAIq8B,EAAW,KASf,GARIp8B,GAAOq8B,eACTD,EAAWp8B,EAAMq8B,eAEjBT,GACAF,EAAeE,KAEfQ,EAAWV,EAAeE,IAExBQ,EAAU,CACZ,MAAME,QAA6Bt8B,EAAMiY,WAAWskB,eAClDH,GAEEE,GACF3C,EAAY5B,MAAM,IAAKuE,MAsD3BE,KACC,CAACx8B,GAAOq8B,iBAGT14B,EACEyM,EAAA,CAAA1M,SAAA,CAAAF,EAACiE,GAAG,CACFxD,GAAI,CACFG,QAAS,OACTU,KAAM,EACN7B,MAAO,OACPyE,OAAQ,cACRgB,cAAe,SACf/C,WAAY,SACZ6sB,SAAU,QAGZ9uB,SAAAF,EAACw2B,EAAM,CAAA/1B,GAAI,CAAEhB,MAAO,QAAUg4B,WAC3B,EAAAv3B,SAAA1D,EAAMqV,SAASzI,KAAK6vB,GACM,UAArBA,EAAYlhC,KAEZiI,EAACw3B,GAAgB,IACXyB,EAAYz8B,MAChB25B,YAAaA,EACbE,WAAYA,EACZD,YAAaA,EACbG,aAAcA,EACdK,eAAgBA,IAIC,UAArBqC,EAAYlhC,MACS,UAArBkhC,EAAYrnB,KAGV5R,EAACi2B,GAAgB,CACfC,UAAW+C,EAAYz8B,MACvB25B,YAAaA,EACbE,WAAYA,EACZD,YAAaA,EACbG,aAAcA,EACdK,eAAgBA,IAIC,UAArBqC,EAAYlhC,MACS,SAArBkhC,EAAYrnB,KAGV5R,EAACw2B,EAAK,CACJtpB,KACE+rB,GAAaz8B,OAAOi6B,WAAWC,WAAa,CAC1CpQ,GAAI,EACJD,GAAI,EACJF,GAAI,IAGR1lB,GAAI,CAAE4E,QAAS,EAAG5F,MAAO,QAEzBS,SAAAF,EAACi5B,EAAYv1B,KAAI,CACfyyB,YAAaA,EACbE,WAAYA,WAjBb,QA0Bbl2B,EAAC8D,GAAG,CACFxD,GAAI,CACFG,QAAS,OACTnB,MAAO,OACP0C,WAAY,SACZG,eAAgB,cACjBpC,SAAA,CAEA1D,GAAOrC,QACNqC,EAAMrC,QAAQiP,KAAKtP,IACwB,IAArCA,GAAQkT,iBAAiBksB,QACpBl5B,EAACs3B,GAAe,IAAAx9B,EAAQgT,OAAQupB,IAEhCr2B,UAIXA,EAAK4M,EAAA,CAAA,GAEP5M,EAAA,MAAA,CAAKnI,MAAO,CAAEyJ,KAAM,KACpBtB,EAACgM,EAAM,CACL7K,QACE3E,GAAO28B,iBAAiBlsB,oBACpBzQ,EAAM28B,gBAAgBlsB,oBACtB,YAENxM,GAAI,CAAEwY,EAAG,GACTmgB,UACE58B,GAAO28B,iBAAiBr4B,KACtBd,EAACa,GAAe,CAACC,KAAMtE,EAAM28B,gBAAgBr4B,OAC3C,KAENR,MACE9D,GAAO28B,iBAAiBhsB,kBACpB3Q,EAAM28B,gBAAgBhsB,kBACtB,UAEN5M,QAAS41B,EAAYkD,cAClB7Z,IACCzd,QAAQC,IAAI,cAAewd,GA7JpBjjB,OAAOuQ,IACxB,KAAItQ,GAAO88B,mBAAsB98B,EAAM88B,kBAAkBxsB,KAGrDA,EAAQ,CACV,MAAMysB,QAAyB/8B,EAAMiY,WAAW+kB,WAAW1sB,GACvDysB,IACFpD,EAAY5B,MAAM,IAAKgF,IACnB/8B,GAAOi9B,6BACTj9B,EAAMi9B,4BAA4BF,GAEhC/8B,GAAOk9B,iBACTl9B,EAAMk9B,qBAkJFF,CAAWha,MAEZyX,IACC96B,GAAMF,MACJ,wEAEF8F,QAAQC,IAAI,wBAAyBi1B,eAIxCz6B,GAAO28B,iBAAiBt1B,OAAS,SAEpC7D,EAACgM,GACC7K,QACE3E,GAAOm9B,mBAAmB1sB,oBACtBzQ,EAAMm9B,kBAAkB1sB,oBACxB,YAENmsB,UACE58B,GAAOm9B,mBAAmB74B,KACxBd,EAACa,GAAgB,CAAAC,KAAMtE,EAAMm9B,kBAAkB74B,OAC7C,KAENR,MACE9D,GAAOm9B,mBAAmBxsB,kBACtB3Q,EAAMm9B,kBAAkBxsB,kBACxB,QAEN1M,GAAI,CAAEwY,EAAG,GACT1Y,QAAS,KACH/D,GAAOk9B,iBACTl9B,EAAMk9B,kBAERvD,EAAY5B,MAAM,KAGnBr0B,SAAA1D,GAAOm9B,mBAAmB91B,OAAS,kBC9NjC+1B,GAAap9B,IACxB,MAAOq9B,EAAaC,GAAkBphC,GAAS,GA6E/C,MAAO,CAAEmhC,cAAaC,iBAAgBC,OA3ECC,GAEnCh6B,EAACi6B,EAAK,CACJz6B,KAAMq6B,EACNp5B,GAAI,CAAE6D,OAASvF,GAAUA,EAAMuF,OAAO41B,QACtCC,QAAS,MACFN,GAAer9B,GAAO49B,iBACzB59B,EAAM49B,mBAIVl6B,SAAAC,EAAC8D,EAAG,CACFxD,GAAI,CACFR,SAAU,WACV2F,IAAK,MACLD,KAAM,MACNuE,UAAW,MACX1D,UAAW,wBACXtC,OAAQ1H,GAAO0H,QAAU,MACzBzE,MAAOjD,GAAOiD,OAAS,MACvB2tB,SAAU5wB,EAAM4wB,UAAY,IAC5BC,UAAW7wB,EAAM6wB,WAAa,IAC9B2B,SAAU,SACV5qB,QAAS,uBACTxD,QAAS,OACTsE,cAAe,SACf/C,WAAY,SACZG,eAAgB,cACjBpC,SAAA,CAEDF,EAACtB,EAAO,CAAAuB,SAAS,SAAQC,SACvBC,EAACC,GAAQe,QAAQ,QAAOjB,SAAA,CACtBF,EAACa,GAAe,CACdC,KAAMtE,GAAO69B,YAAc,kBAC3BxiC,MAAO,CAAE8H,YAAa,KAExBK,EAACkB,EAAW,CAAAC,QAAQ,KAAKb,MAAM,UAAUe,UAAU,MAChDnB,SAAA1D,GAAO89B,aAAe,WAEzBt6B,EAAA,MAAA,CAAKnI,MAAO,CAAEkS,SAAU,KACxB/J,EAACK,EAAU,CACTE,QAAS,KACPu5B,GAAe,GAEYn9B,MAAzBH,EAAM49B,iBACmB,MAAzB59B,EAAM49B,iBAEN59B,EAAM49B,mBAGV95B,MAAM,qBAENN,EAACa,IAAgBC,KAAK,wBAI5Bd,EAACu6B,EAAK,CACJ95B,GAAI,CAEFG,QAAS,OACTsE,cAAe,SACf/C,WAAY,SACZ1C,MAAO,OACPyE,OAAQ,OACRmB,QAAS,EAET2pB,SAAU,UACX9uB,SAEA85B,GAAa95B,kBCnD1B,IAAIs6B,IAA0B,EAU9B,MAAMC,GAAiBplB,IACrB,IACE,MAAMqlB,EAAQnhC,aAAaC,QAAQ6b,GACnC,OAAOqlB,EAAQlY,KAAKmY,MAAMD,GAAS,CAAE,EACrC,MAAOl4B,GAEP,OADAT,QAAQ9F,MAAM,4BAA6BuG,GACpC,CAAE,IAIPo4B,GAAgB,CAACvlB,EAAsBwlB,KAC3C,MAAMC,EAAUL,GAAcplB,GAC9B9b,aAAaiI,QACX6T,EACAmN,KAAKC,UAAU,IAAKqY,KAAYD,MAI9BE,GAAoB,CAAC,YAAa,WAElCC,GAA6Cx+B,IACjD,MAAMiG,EAAEA,GAAMqE,KACR6K,EAASI,GAAavV,EAAMy+B,cAC5B1E,EAAe,GACf2E,EAAa3zB,EAAM4zB,SACvB,IAAO3+B,GAAO6Y,aAAeolB,GAAcj+B,EAAM6Y,cAAgB,CAAE,GACnE,IAEF,IAAK,MAAMvE,KAASa,GACe,IAA7Bb,GAAOsqB,WAAW9E,QACpBC,EAAahtB,KAAKuH,EAAMoB,WAG5B,IAAImpB,EAAoD,CAAE,EAC1D,GAAIH,GAAYI,sBAAuB,CACrCD,EAAyBH,EAAWI,sBACpC,MAAMC,EAAiBve,OAAOiB,KAAKod,GACnC,IAAK,MAAMvqB,KAASylB,EACbgF,EAAetS,SAASnY,KAC3BuqB,EAAuBvqB,IAAS,QAIpC,IAAK,MAAMA,KAASylB,EAClB8E,EAAuBvqB,IAAS,EAIpC,MAAM0qB,EAAiBngC,GACpBzB,GAAqBA,EAAMoF,UAAUvF,gBAgBjC6hC,EAAuBG,GAC5Bl0B,EAAM7O,SAAoC2iC,IACrCK,EAAaC,GAAkBp0B,EAAM7O,SAC1CwiC,EAAWQ,aAAe,KAErBE,EAAcC,GAAmBt0B,EAAM7O,SAE3CwiC,EAAWU,cAAgB,KACvBE,EAAsBC,GAC3BrjC,EAA+BwiC,EAAWc,qBAAuB,IACnE,IAAIC,EAAUf,GAAYgB,eAAev2B,MAAQ,GACjDs2B,EAAUA,EAAQ9yB,QACf2D,IAAiBiuB,GAAkB9R,SAASnc,KAE/C,IAAIqvB,EAAWjB,GAAYgB,eAAe/L,OAAS,IAAM,GACzDgM,EAAWA,EAAShzB,QACjB2D,IAAiBiuB,GAAkB9R,SAASnc,KAG/C,MAAOovB,EAAeE,GAAoB1jC,EAAiC,CACzEiN,KAAM,IAAwB,QAAnB61B,EAA2BT,GAAoB,MAAQkB,GAClE9L,MAAO,IACkB,QAAnBqL,EAA2BT,GAAoB,MAChDoB,KAID9vB,EAAUnJ,KACV8F,EAAWC,MACVozB,EAAgBC,GAAqB5jC,EAAc,OACnD6jC,EAAcC,GAAmB9jC,EAAc,OAC/C+jC,EAAeC,GAAoBhkC,EAA4B,CAAA,IAE/D+a,EAAmBkpB,GACxBjkC,EAAgC,CAAEmb,IAAK,IAAIM,IAAOpc,KAAM,YAC1D,IAAI2b,EAAwB,KACxBlX,GAAOkX,gBACTA,EAAgBlX,GAAOkX,eAEzB,MAAMkpB,EAAUpgC,EAAMogC,QAChBC,EAAmBzqB,GAAEoK,OAAOxK,GAA0BL,IACtDmrB,EvDpHyB,EAACnrB,EAAQorB,EAAmBt6B,KAC3D,MAAMu6B,EAAqC,GAC3C,IAAK,MAAMC,KAActrB,EACvB,GAC4B,SAA1BsrB,GAAY9qB,WACc,WAA1B8qB,GAAY9qB,UACZ,CACA,MAAMlB,EAA6B,IAC9BgsB,GAAY7B,WAAW8B,SAC1BC,SACEF,GAAY7B,WAAW8B,UAAUC,UAAYJ,EAC/ChlC,KAA+B,UAAzBklC,GAAY9qB,UAAwB,SAAW,SACrDrB,MAAOmsB,GAAY/qB,UACnBkrB,WAAY36B,EAAEw6B,GAAYpG,YAAcoG,GAAY/qB,WACpDmrB,YAAa,SACbC,MAAO,SACPhH,OAAQ2G,GAAY3G,OACpBiH,WAAYN,GAAY7B,WAAWmC,WACnCj8B,KAAM,EACN8rB,SAAU,KAEZ4P,EAAQzzB,KAAK0H,QACR,GAA8B,SAA1BgsB,GAAY9qB,UAAsB,CAC3C,MAAMlB,GD7D4BP,EC6DoB,IACjDusB,GAAY7B,WAAW8B,SAC1BC,SACEF,GAAY7B,WAAW8B,UAAUC,UAAYJ,EAC/CjsB,MAAOmsB,GAAY/qB,UACnBkrB,WAAY36B,EAAEw6B,GAAYpG,YAAcoG,GAAY/qB,WACpDmrB,YAAa,SACbC,MAAO,SACPhH,OAAQ2G,GAAY3G,OACpBiH,WAAYN,GAAY7B,WAAWmC,WACnCj8B,KAAM,EACN8rB,SAAU,KDvEmB,IAC9B1c,EACH3Y,KAAM,SACN4Y,eAAiB5T,GAEbiD,EAAC0N,GACC,CAAAjN,GAAI,CAAEhB,MAAO,QACboE,MAAM,GACNtJ,MAAOwC,EAAOxC,MACd8T,iBAAmBF,IACjBpR,EAAO6T,IAAIC,iBAAiB,CAC1BrN,GAAIzG,EAAOyG,GACXsN,MAAO/T,EAAO+T,MACdvW,MAAO4T,OAMjB4C,YAAa,CAACxW,EAAYyW,EAAUC,KAClC,IAAI9C,EAAI,KAIR,OAHc,OAAV5T,IACF4T,EAAIJ,GAAOxT,GAAOyT,OAAOZ,KAEpBe,GAET+C,eAAgB,CAAC3W,EAAYyW,EAAUC,IAC9BD,EAAIC,EAAOH,SC8ClBksB,EAAQzzB,KAAK0H,QACR,GAA8B,aAA1BgsB,GAAY9qB,UAA0B,CAC/C,MAAMlB,EAA6BR,GAAuB,IACrDwsB,GAAY7B,WAAW8B,SAC1BC,SACEF,GAAY7B,WAAW8B,UAAUC,UAAYJ,EAC/CjsB,MAAOmsB,GAAY/qB,UACnBkrB,WAAY36B,EAAEw6B,GAAYpG,YAAcoG,GAAY/qB,WACpDmrB,YAAa,SACbC,MAAO,SACPhH,OAAQ2G,GAAY3G,OACpBiH,WAAYN,GAAY7B,WAAWmC,WACnCj8B,KAAM,EACN8rB,SAAU,MAEZ4P,EAAQzzB,KAAK0H,QACR,GAA8B,aAA1BgsB,GAAY9qB,UAA0B,CAC/C,MAAMlB,EAASO,GAAuB,IACjCyrB,GAAY7B,WAAW8B,SAC1BC,SACEF,GAAY7B,WAAW8B,UAAUC,UAAYJ,EAC/CjsB,MAAOmsB,GAAY/qB,UACnBkrB,WAAY36B,EAAEw6B,GAAYpG,YAAcoG,GAAY/qB,WACpDmrB,YAAa,SACbC,MAAO,SACPhH,OAAQ2G,GAAY3G,OACpBiH,WAAYN,GAAY7B,WAAWmC,WACnCjtB,aAAc2sB,GAAY3sB,aAC1BE,eAAgBysB,GAAYzsB,eAC5B/Q,MAAO,MAETu9B,EAAQzzB,KAAK0H,QACR,GAA8B,aAA1BgsB,GAAY9qB,UAA0B,CAC/C,MAAMlB,EAA6BE,GAAoB,IAClD8rB,GAAY7B,WAAW8B,SAC1BC,SACEF,GAAY7B,WAAW8B,UAAUC,UAAYJ,EAC/CjsB,MAAOmsB,GAAY/qB,UACnBkrB,WAAY36B,EAAEw6B,GAAYpG,YAAcoG,GAAY/qB,WACpDmrB,YAAa,SACbC,MAAO,SACPhH,OAAQ2G,GAAY3G,OACpBiH,WAAYN,GAAY7B,WAAWmC,WACnCnuB,WAAY6tB,GAAY5F,kBAAoB,QAC5C3nB,aAAcutB,GAAY7F,oBAAsB,UAChDjoB,QAAS8tB,GAAY9tB,SAAW,GAChC7N,KAAM,EACN8rB,SAAU,MAEZ4P,EAAQzzB,KAAK0H,GD3HoB,IAACP,EC8HtC,OAAOssB,GuD4BkBQ,CACvB7rB,EAC8B,QAA9BnV,GAAO4X,UAAUA,WAAsB,EACvC3R,GAEF,IAAIg7B,GAAgB,EAChBjhC,GAAO+W,YAAYjQ,YACrBm6B,EAAgBpxB,EAAQlJ,iBAAiB3G,EAAM+W,WAAWjQ,YAE5D,IAAIo6B,GAAkB,EAClBlhC,GAAOmhC,cAAcr6B,YACvBo6B,EAAkBrxB,EAAQlJ,iBAAiB3G,EAAMmhC,aAAar6B,YAGhE,MAmDMkI,mBAAEA,EAAoBD,QAASqyB,GACnCtyB,GAAsB,CACpBK,MAAO,eACPG,KAAM,gDACNG,qBA1BuB1P,UACzB,IAAI4rB,GAAS,EACPkU,IAA4C,IAA1BA,GAAgBwB,QACtC1V,QAAe3rB,EAAMiY,WAAWqpB,iBAC9BzB,EAAe3oB,KAGfyU,IACE3rB,GAAOmhC,cAAcI,0BACjBvhC,EAAMmhC,aAAaI,mBAAmB1B,GAG9CO,GAASoB,GACSA,EAAQ70B,QACrB2D,GACCA,EAAO4G,IAAkB2oB,EAAe3oB,WAclD,IAAIuqB,EACAC,EACAC,GACAC,GACAC,GACAC,GAE8B,UAA9B9hC,GAAO4X,UAAUA,WACnB6pB,EAAkBzhC,GAAO4X,UAAUmqB,OAAOC,aAAe,cACzDN,EAAiB1hC,GAAO4X,UAAUmqB,OAAOE,YAAc,MACvDN,GAAqB3hC,GAAO4X,UAAUmqB,OAAOG,eAC7CN,GAAoB5hC,GAAO4X,UAAUmqB,OAAOI,cAC5CN,GAAgB7hC,GAAO4X,UAAUmqB,OAAOK,WAAa,SACrDN,GAAiB9hC,GAAO4X,UAAUmqB,OAAOM,YAAc,eAGzD,MAAQ9E,OAAQ+E,GAAYhF,eAAgBiF,IAAuBnF,GAAU,CAC3E11B,OAAQ+5B,EACR5Q,UAAW8Q,GACX/Q,SAAUgR,GACVhE,gBAAiB,KACf59B,EAAMiY,WAAW/H,WAAWlQ,GAAOkY,2BAErCjV,MAAOy+B,EACP7D,WAAYgE,GACZ/D,YAAagE,KAgTTU,GAAmC,CACvCjnC,KAAM,UACN+Y,MAAO,UACPssB,WAAY,GACZC,YAAa,SACb59B,OACGjD,GAAO8X,WAAuC,GAA1B9X,EAAM8X,WAAWvR,OAAc,IACnDvG,GAAO+W,YAAc/W,GAAO+W,YAAY0rB,UAAY,GAAK,IACzDziC,GAAOmhC,cAAgBnhC,GAAOmhC,cAAcsB,UAAY,GAAK,GAChEC,WA/J8BniC,IAC9B,MAAM+P,EAAc/P,EAAOiU,IACrB7W,EAA+D,GACrE,GAAiC,QAA7BqC,GAAO4X,UAAUA,gBAEezX,IAAhCH,GAAO2iC,uBACN3iC,EAAM2iC,sBACP,CACA,MAAMC,EACJ3C,EAAc3vB,EAAO4G,KAAiB9B,OAASytB,GAAaC,KAC9D,GAAgC,QAA5B9iC,EAAM4X,SAASA,UAAsBgrB,EACnC3B,IACFtjC,EAAQoP,KACNvJ,EAACwX,GACC,CAAA1W,KAAMd,EAACa,GAAe,CAACC,KAAK,SAC5B+C,MAAOpB,EAAE,kBACTlC,QAAS,KAvGI,CAACuM,IAC1B,MAAMtJ,EAAKsJ,EAAO4G,GAClBgpB,EAAiB,IACZD,EACHj5B,CAACA,GAAK,CAAEoO,KAAMytB,GAAaE,SAoGfC,CAAmB1yB,OAIzB3S,EAAQoP,KACNvJ,EAACwX,GACC,CAAA1W,KAAMd,EAACa,GAAe,CAACC,KAAK,WAC5B+C,MAAOpB,EAAE,oBACTlC,QAAS,KA9CU,CAACuM,IAChC,MAAMtJ,EAAKsJ,EAAO4G,GACdlQ,GAAMkT,GAASlT,IAAOA,EAAK,GAC7Bk5B,EAAiB,IACZD,EACHj5B,CAACA,GAAK,CAAEoO,KAAMytB,GAAaE,KAAME,qBAAqB,KAExD7C,GAASoB,IACP,MAAM0B,EAAU1B,EAAQ70B,QACrB2D,GAAgBA,EAAO4G,IAAkBlQ,IAE5C,OAAOk8B,MAGThD,EAAiB,IACZD,EACHj5B,CAACA,GAAK,CAAEoO,KAAMytB,GAAaE,KAAME,qBAAqB,MA+B5CE,CAAyB7yB,IAE3BxM,MAAM,kBAIP,CACL,GAAI9D,GAAO+W,aAA+C,IAAjC/W,GAAO+W,YAAY0rB,UAAoB,CAC9D,IAAIW,GAA+B,EAC/BpjC,GAAO+W,YAAY+D,2BACrBsoB,EACEpjC,GAAO+W,YAAY+D,yBAAyBxK,IAEhD,IAAI+yB,GAAgC,EAChCrjC,GAAO+W,YAAYgE,4BACrBsoB,EACErjC,GAAO+W,YAAYgE,0BAA0BzK,IAE7C2wB,GAAiBmC,GACnBzlC,EAAQoP,KACNvJ,EAACwX,GAAmB,CAClB9P,SAAUm4B,EACV/+B,KACEd,EAAC4U,EAAO,CAACjJ,MAAOlJ,EAAE,kBAChBvC,SAAAF,EAACa,GAAe,CACdC,KAAM,OACNjJ,MAAO,CACLyI,MAAOu/B,EACH,YACAljC,OAKZ8a,WACEjb,GAAO+W,YAAYgB,iBAAiBkD,aAAc,EAEpD5T,MAAOpB,EAAE,kBACT8F,UAAU,cACVjI,MAAM,UACNC,QAAS,KACHk9B,IAAkBoC,GA9LftjC,OAAOuQ,IAC9B,GAAIA,EAEF,GADA0vB,EAAgB1vB,GACgB,SAA5BtQ,EAAM4X,SAASA,SACjBpL,EAASxM,EAAM4X,SAASmqB,MAAMuB,UAAY,IAAMhzB,EAAO4G,SAClD,GAAgC,UAA5BlX,EAAM4X,SAASA,SACxB2qB,IAAmB,QACd,GAAkC,QAA9BviC,GAAO4X,UAAUA,SAAoB,CAC9C,MAAM5Q,EAAKsJ,EAAO4G,GAClBgpB,EAAiB,IACZD,EACHj5B,CAACA,GAAK,CAAEoO,KAAMytB,GAAaC,UAoLfS,CAAiBjzB,OAO7B,GAAItQ,GAAOmhC,eAAmD,IAAnCnhC,GAAOmhC,cAAcsB,UAAoB,CAClE,IAAIe,GAAiC,EACjCxjC,GAAOmhC,cAAcrmB,2BACvB0oB,EACExjC,GAAOmhC,cAAcrmB,yBAAyBxK,IAElD,IAAImzB,GAAkC,EAClCzjC,GAAOmhC,cAAcpmB,4BACvB0oB,EACEzjC,GAAOmhC,cAAcpmB,0BAA0BzK,IAE/C4wB,GAAmBsC,GACrB7lC,EAAQoP,KACNvJ,EAACwX,GAAmB,CAClB9P,SAAUu4B,EACVn/B,KACEd,EAAC4U,EAAO,CAACjJ,MAAOlJ,EAAE,oBAChBvC,SAAAF,EAACa,GAAe,CACdC,KAAM,QACNjJ,MAAO,CACLyI,MAAO2/B,EACH,YACAtjC,OAKZ8a,WACEjb,GAAOmhC,cAAcppB,iBAAiBkD,aAAc,EAEtD5T,MAAOpB,EAAE,oBACT8F,UAAU,cACVjI,MAAM,UACNC,QAAS,KACP,GAAIm9B,IAAoBuC,EAAiC,CACvD,GAAIzjC,GAAOmhC,cAAc9wB,sBAClBrQ,EAAMmhC,aAAa9wB,oBAAoBC,GAC1C,OAGJwvB,EAAkBxvB,GAClB8wB,GAA4B,UAU9C,GAAIphC,GAAO8X,WACT,IAAK,MAAMlI,KAAa5P,EAAM8X,WAGxBlI,GAAWmI,iBAAiBC,cACgB,IAA5CpI,GAAWmI,iBAAiBC,aAG9Bra,EAAQoP,KACNvJ,EAACmX,OACK/K,EACJU,OAAQA,EACRJ,WAAYnQ,UACVC,EAAMiY,WAAW/H,WAAWlQ,GAAOkY,8BAQ/C,OAAOva,IAeT,IAAI+lC,GAA+C,SAEjBvjC,IAAhCH,GAAO2iC,uBACN3iC,EAAM2iC,sBACN3iC,GAAO8X,YAAc9X,GAAO8X,WAAWvR,OAAS,IAEjDm9B,GAAkB32B,KAAKy1B,IAGzBkB,GAAoB,IAAIA,MAAsBpD,GAI9CjkC,GAAU,UACgB8D,IAApBH,GAAO2jC,WAA6C,IAAnB3jC,EAAM2jC,UACzC3jC,EAAMiY,WAAW/H,WAAWlQ,GAAOkY,4BAEpC,IAEH,MAiDM0rB,GAA6C74B,EAAM4zB,SAAQ,KAC/D,MAAMkF,EAAWH,GAAkB92B,KAAKk3B,IAAS,IAC5CA,EACH7gC,MAAOm8B,EAAa0E,EAAIxvB,QAAUwvB,EAAI7gC,UAIxC,GAAIi8B,EAAY34B,OAAQ,CACtB,MAAMw9B,EAAa,IAAIC,IAAIH,EAASj3B,KAAKk3B,GAAQ,CAACA,EAAIxvB,MAAOwvB,MAC7D,OAAO5E,EAAYtyB,KAAK0H,GAAUyvB,EAAWzjC,IAAIgU,KAAS3H,OAAO9B,SAGnE,OAAOg5B,IACN,CAAC3E,EAAaE,EAAcsE,KAC/B,OACE//B,EACEyM,EAAA,CAAA1M,SAAA,CAAAF,EAACwL,EAAkB,CAAA,GACY,UAA9BhP,GAAO4X,UAAUA,SAChBpU,EAAC8+B,GACE,CAAA5+B,SAAA1D,GAAO4X,UAAUmqB,OAAOkC,cACvBzgC,EAACxD,EAAM4X,SAASmqB,MAAMkC,cAAa,CACjC5H,eACE0D,EAAeA,EAAa7oB,QAAiB/W,EAE/C+8B,gBAAiB,KACfqF,IAAmB,GACnBviC,EAAMiY,WAAW/H,WAAWlQ,GAAOkY,6BAIvC1U,EAAC03B,GAAY,CACXmB,eACE0D,EAAeA,EAAa7oB,QAAiB/W,EAE/C+8B,gBAAiB,KACfqF,IAAmB,GACnBviC,EAAMiY,WAAW/H,WAAWlQ,GAAOkY,2BAErC7C,SAAUrV,EAAMy+B,aAChBxmB,WAAYjY,EAAMiY,WAClBisB,iBAAkBlkC,GAAO+W,YAAYjQ,UACrCm2B,4BACEj9B,GAAO+W,YAAYwqB,mBAErBzE,kBAAmB98B,GAAO+W,YAAY1G,oBACtC1S,QAASqC,GAAO8X,eAKtBtU,EAAK4M,EAAA,CAAA,QAEiBjQ,IAAvBH,GAAOmkC,aAA8BnkC,GAAOmkC,YAqC3C3gC,EAAK4M,EAAA,CAAA,GApCLzM,EAAC8D,EAAG,CAACxD,GAAI,CAAEG,QAAS,uBACSjE,IAA1BH,GAAOokC,gBAAiCpkC,GAAOokC,eAS9C5gC,EAAK4M,EAAA,CAAA,GARL5M,EAACK,EACC,CAAAE,QAAS,KACPyI,EAAS,KAAM,CAAE4e,SAAS,KAC3B1nB,SAEDF,EAACa,GAAe,CAACC,KAAK,iBAK1BX,EAAC8D,EACC,CAAAxD,GAAI,CACFa,KAAM,EACNV,QAAS,OACTuB,WAAY,SACZG,eAAgB,UAGjBpC,SAAA,CAAA1D,GAAOqkC,SACN7gC,EAACa,GAAe,CACdC,KAAMtE,EAAMqkC,SACZhpC,MAAO,CAAE8H,YAAa,EAAGD,WAAY,KAGvCM,EAAA4M,EAAA,CAAA,GAEF5M,EAACkB,EAAW,CAAAC,QAAQ,KAAIjB,SACrB1D,GAAOskC,UACJ/pB,GAAsBtU,EAAEjG,GAAOskC,YAC/B,WAQXtkC,GAAOukC,oBACRvkC,GAAOkY,0BACPlY,GAAOwkC,4BACL7gC,EAAC8gC,EAAU,CAAAC,iBACT,EAAAhhC,SAAA,CAAAF,EAACmhC,EAAiB,CAAAC,WAAYphC,EAACqhC,GAAkB,CAAA,YAC/ClhC,EAAC8D,EACC,CAAAxD,GAAI,CACFG,QAAS,OACTuB,WAAY,SACZG,eAAgB,UACjBpC,SAAA,CAEDF,EAACa,GAAe,CACdhJ,MAAO,CAAE6H,WAAY,EAAGC,YAAa,GACrCmB,KAAK,WAEPd,EAACkB,GAAWG,UAAU,OAA2BnB,SAAA,iBAGrDF,EAACshC,EAAgB,CAAAphC,SACfF,EAACiE,EAAG,CAAA/D,SACFF,EAAC03B,GAAY,CACXyB,gBAAiB,CACft1B,MAAOpB,EAAE,oBACT3B,KAAM,SACNmM,oBAAqB,WACrBE,kBAAmB,WAErBwsB,kBAAmB,CACjB91B,MAAOpB,EAAE,mBACT3B,KAAM,SACNmM,oBAAqB,WACrBE,kBAAmB,SAErBsH,WAAY,CACVqpB,iBAAkBvhC,UACT,EAETi9B,WAAYj9B,MAAOQ,IACHJ,MAAVI,EACFP,EAAMwkC,4BAA4BjkC,GAElCP,EAAMwkC,4BAA4B,IAEpCxkC,EAAMiY,WAAW/H,WAAW3P,IAE9B2P,WAAYnQ,YACZw8B,eAAgBx8B,aAElBsV,SAAUrV,EAAMukC,4BAMxB/gC,EAAK4M,EAAA,CAAA,GAGP5M,EAACuhC,GAAe,IACV/kC,GAAO0gC,SACX7yB,MAAO,CAAEhI,QAAS+Q,IAClB9E,UAAW,CACTjM,QAAS,CACPiR,cAAe,IACV9W,EACHiX,kBAAmBA,EACnBpX,KAAMG,GAAOH,MAEfgY,sBA7hBoB,KAC5B,GAAkC,SAA9B7X,GAAO4X,UAAUA,SACnBpL,EAASxM,EAAM4X,SAASmqB,MAAMuB,gBACzB,GAAkC,UAA9BtjC,GAAO4X,UAAUA,SAC1B2qB,IAAmB,QACd,GAAkC,QAA9BviC,GAAO4X,UAAUA,SAAoB,CAC9ComB,IAAgD,EAChD,MAAMgH,EAAiB,CAAE,EACzBA,EAAU9tB,GAAiB8mB,GAC3BgH,EAAU3D,OAAQ,EAClB,IAAK,MAAMlO,KAAcmN,EAED,WAApBnN,GAAY53B,MACZ43B,GAAY7e,OAAS4C,GAEjBic,GAAY7e,QACd0wB,EAAU7R,EAAW7e,OAAS,MAIpC8rB,GAAS6E,GAAiB,CAACD,KAAcC,KACzC/E,GAAkBgF,IAAmB,IAChCA,EACHlH,CAACA,IAAwB,CAAE5oB,KAAMytB,GAAaC,YAugB1ChqB,eAxrBa,KACjB9Y,GAAO6Y,cACT9b,aAAaooC,WAAWnlC,EAAM6Y,cAEhComB,EAAyB,CAAA,GACzBE,EAAe,IACfE,EAAgB,CAAA,GAChBE,EAAwB,IACxBK,EAAiB,CACfz2B,KAAM,IAAwB,QAAnB61B,EAA2BT,GAAoB,IAC1D5K,MAAO,IAAwB,QAAnBqL,EAA2BT,GAAoB,SAirBzD6G,SAAW90B,GACFA,EAAO4G,GAEhBmuB,aAAa,EACbC,KAAMtlC,GAAOH,KACb2gC,QAASoD,GACT2B,qBACA3tB,SAAS,MACTqoB,cAC6B,OAA3BjgC,EAAM4X,SAASA,SAAoBqoB,OAAgB9/B,EAErDqlC,sBAC6B,OAA3BxlC,EAAM4X,SAASA,SAnoBY6tB,IACjCvF,EAAiBuF,SAooBPtlC,EAENulC,sBAAsB,WACtBC,iBA1emB5lC,MAAOuQ,IAC9B,GAAgC,QAA5BtQ,EAAM4X,SAASA,SAAoB,CACrC,IAAImlB,EAAmB,KACvB,MAAM5qB,EA9Ba,CAAC7B,IACtB,IACE+vB,EAAiBlC,MAAM7tB,GACvB,MAAOoR,GACPnc,QAAQC,IAAI,qBAAsBkc,GAClC,IAAIvP,EAAoB,KAUxB,OAREA,EADEuP,aAAe9L,GAAEgwB,SACJlkB,EAAI+Y,OAChB7tB,KACEnN,GAAU,mBAAqBA,EAAM8H,KAAO,OAAS9H,EAAMxB,UAE7DojB,KAAK,KAEO,sBAEVlP,IAec0zB,CAAev1B,GACpC,GAAI6B,EAAc,CAChB,MAAMsoB,EAAStoB,EAAaoP,MAAM,KAWlC,MAVA5hB,GAAMF,MACJ+D,EAAA,MAAA,CAAKnI,MAAO,CAAA,EAAEqI,SACX+2B,EAAO7tB,KAAKnN,GACXkE,EAAAyM,EAAA,CAAA1M,SAAA,CACEF,EAAM,MAAA,CAAAE,SAAAjE,IACN+D,EAAC8K,EAAO,CAAA,WAKV,IAAIuU,MAAM1Q,GAElB,GAAInS,GAAO+W,YAAY1G,sBAChBrQ,EAAM+W,WAAW1G,oBAAoBC,GACxC,MAAM,IAAIuS,MAAM,8CAGpB,MAAMijB,EAAqB,IAAKx1B,GAShC,GAPEA,EAAO4G,IACPgD,GAAS5J,EAAO4G,KAChBoD,OAAOhK,EAAO4G,IAAkB,IAEhC4uB,EAAc5uB,GAAiB,MAEjC6lB,QAAoB/8B,EAAMiY,WAAW+kB,WAAW8I,GAC7B,MAAf/I,EACF,MAAM,IAAIla,MACR,8DAoBJ,OAjBI7iB,GAAO+W,YAAYwqB,0BACfvhC,EAAM+W,WAAWwqB,mBAAmBjxB,IAEtB,IAAlBA,GAAQ+wB,OACVjB,GAASoB,IACP,MAAM0B,EAAU1B,EAAQ70B,QACrB4K,GAAWA,EAAEL,KAAmB5G,EAAO4G,KAE1C,MAAO,CAAC6lB,KAAgBmG,OAIW,IAArCljC,GAAO4X,UAAUmuB,iBACjB/lC,GAAOiY,YAAY/H,YAEnBlQ,GAAOiY,YAAY/H,WAAWlQ,GAAOkY,0BAEhC6kB,IAqbL9lB,kBAAmBA,EACnB+uB,0BAjPsBC,IAC1B9F,EAAqB8F,IAiPjBnH,sBAAuBA,EACvBoH,8BA1OgCC,IACpClH,EAAyBkH,GACrBnmC,GAAO6Y,cACTulB,GAAcp+B,EAAM6Y,aAAc,CAAEimB,sBAAuBqH,KAwOzDC,oBAnOJ7lC,IAEA,MAAMkU,OAAEA,EAAM4xB,YAAEA,GAAgB9lC,EAChC4+B,GAAgBmH,IACd,MAAMC,EAAeD,EAAU//B,OAC3B,IAAI+/B,GACJ5C,GAAkB92B,KAAKk3B,GAAQA,EAAIxvB,QACjCkyB,EAAYD,EAAavb,QAAQvW,EAAOH,OAC9C,OAAoB,IAAhBkyB,IAEJD,EAAaE,OAAOD,EAAW,GAC/BD,EAAaE,OAAOJ,EAAa,EAAG5xB,EAAOH,OAEvCtU,GAAO6Y,cACTulB,GAAcp+B,EAAM6Y,aAAc,CAAEqmB,YAAaqH,KANtBA,MA4N3BG,oBAvMJnmC,IAEA,MAAMomC,EAAgB,IACjBvH,EACH,CAAC7+B,EAAO2T,OAAOI,OAAQ/T,EAAO0C,OAEhCo8B,EAAgBsH,GACZ3mC,GAAO6Y,cACTulB,GAAcp+B,EAAM6Y,aAAc,CAAEumB,aAAcuH,KAgMhDC,iBAAkBtH,EAClBuH,yBAA2BV,IAjNJ,CAACA,IAC5B5G,EAAwB4G,GACpBnmC,GAAO6Y,cACTulB,GAAcp+B,EAAM6Y,aAAc,CAAE2mB,oBAAqB2G,KA+MrDW,CAAqBX,IAEvBzG,cAAeA,EACfqH,sBAhpB6BtB,IACjC,IAAIhG,EAAUgG,GAAUt8B,MAAQ,GAChCs2B,EAAUA,EAAQ9yB,QACf2D,IAAiBiuB,GAAkB9R,SAASnc,KAE/C,IAAIqvB,EAAW8F,GAAU9R,OAAS,GAClCgM,EAAWA,EAAShzB,QACjB2D,IAAiBiuB,GAAkB9R,SAASnc,KAE/C,MAAM02B,EAA0C,CAC9C79B,KAAM,IACmB,QAAnB61B,EAA2BT,GAAoB,MAChDkB,GAEL9L,MAAO,IACkB,QAAnBqL,EAA2BT,GAAoB,MAChDoB,IAGPC,EAAiBoH,GACbhnC,GAAO6Y,cACTulB,GAAcp+B,EAAM6Y,aAAc,CAAE6mB,cAAesH,WChLnDC,GAAmBtqC,GAAY,CACnCC,KAAM,cACNsqC,aAR6D,CAC7DC,OAAQ,CAAE,EACVC,UAAW,GACXC,kBAAkB,GAMlBnqC,SAAU,CACRoqC,kBAAmB,CAAClqC,EAAOE,KACzBF,EAAM+pC,OAAS7pC,EAAOC,QACtBH,EAAMgqC,UAAY5mB,OAAOiB,KAAKnkB,EAAOC,UAEvCgqC,aAAc,CAACnqC,EAAOE,KACpBF,EAAM+pC,OAAO7pC,EAAOC,QAAQiqC,UAAU3nC,KAAOvC,EAAOC,QAAQsC,MAE9D4nC,kBAAmB,KACjBrqC,MAAMiqC,kBAAmB,OAKlBE,aAAEA,GAAYD,kBAAEA,GAAiBG,kBAAEA,IAC9CR,GAAiBtpC,QACnB,IAAe+pC,GAAAT,GAAiBppC,QCtBhC,MAAM8pC,GACJC,IAEA,MAAMC,EAAehpC,GAAazB,GAAeA,EAAM0qC,aAAaX,SAC9D7oC,EAAWC,IACXsR,EAAUnJ,MACV5G,iBAAEA,EAAgBY,kBAAEA,EAAiBE,oBAAEA,GAC3ClC,KA0FF,MAAO,CAAEwR,WAzFUnQ,MAAOQ,IACxB,GAAIqnC,GAAiBG,eAAgB,CACnC,MAAMX,EAAY5mB,OAAOiB,KAAKomB,GAC9B,IAAK,MAAML,KAAYJ,EACrB,GAAII,IAAaI,EAAgBG,sBAEU5nC,IAAtC0nC,EAAaL,IAAW1gC,WACe,OAAtC+gC,EAAaL,IAAW1gC,WACxB+I,EAAQlJ,iBAAiBkhC,EAAaL,IAAW1gC,aACpB,IAA/B+gC,EAAaL,IAAWnsB,IACxB,OACMvb,EAAiB,CACrBG,YAAa4nC,EAAaL,GAAUnsB,IACpCjb,UAAU,EACVI,gBAAkBjB,IAChBjB,EAASipC,GAAa,CAAEC,WAAU3nC,KAAMN,EAASM,QACjD+nC,EAAgBxH,QAAQ7gC,EAASM,OAEnCY,gBAAiB,KACfnC,EAASipC,GAAa,CAAEC,WAAU3nC,KAAM,MACxC+nC,EAAgBxH,QAAQ,OAG5B,YAIGwH,GAAiBI,eACpBloC,EAAiB,CACrBG,YAAa2nC,EAAgBI,QAC7B5nC,UAAU,EACVF,WAAYK,GAAU,CAAE,EACxBC,gBAAkBjB,IAChBqoC,EAAgBxH,QAAQ7gC,EAASM,UAwDpB08B,eArCEx8B,MAAOkoC,IAC5B,IAAI33B,EAAc,KAClB,GAAIs3B,GAAiBM,SAAU,CAC7B,MAAMhoC,EAAkB,CAAE,EAE1BA,EADyB0nC,GAAiBO,mBAAqB,MAChCF,QACzBnoC,EAAiB,CACrBG,YAAa2nC,EAAgBM,SAC7B9nC,UAAU,EACVF,aACAM,gBAAkBjB,IAChB+Q,EAAS/Q,EAASM,QAIxB,OAAOyQ,GAsB4B0sB,WAnDlBj9B,MAAOuQ,IACxB,IAAIysB,EAAc,KAWlB,OAVI6K,GAAiBQ,YACb1nC,EAAkB,CACtBT,YAAa2nC,EAAgBQ,KAC7BvoC,KAAMyQ,EACNlQ,UAAU,EACVI,gBAAkBjB,IAChBw9B,EAAcx9B,EAASM,QAItBk9B,GAuCwCuE,iBApBxBvhC,MAAOkoC,IAC9B,IAAItc,GAAS,EACb,GAAIic,GAAiBS,WAAY,CAC/B,MAAMnoC,EAAkB,CAAE,EAE1BA,EADyB0nC,GAAiBU,qBAAuB,MAClCL,QACzBrnC,EAAoB,CACxBX,YAAa2nC,EAAgBS,WAC7BjoC,UAAU,EACVF,aACAM,gBAAiB,KACfmrB,GAAS,GAEXlrB,gBAAiB,KACfkrB,GAAS,KAIf,OAAOA,KCzGX,SAAST,GAAIpO,EAAGd,GACd,OAAOc,EAAEnQ,QAAQ5O,QAAUie,EAAEgP,QAAQjtB,IACvC,CAEA,SAASwqC,GAAazrB,EAAGd,GACvB,OAAOc,EAAEnQ,QAAQ5O,QAAUie,EAAEgP,QAAQjtB,IACvC,CAcM,MAAAyqC,GAA4C,EAChD51B,aAAa,KACbM,eAAe,OACfP,UAAU,GACV81B,kBAAkB,GAClBC,mBAEA,MAAO70B,EAAS80B,GAAc59B,EAAM7O,SAAS,KACtCiN,EAAMy/B,GAAW79B,EAAM7O,SAASyW,IAChCghB,EAAOkV,GAAY99B,EAAM7O,SAASusC,IAElCK,EAAiBC,GAAsBh+B,EAAM7O,SAAiB,KAC9D8sC,EAAkBC,GAAuBl+B,EAAM7O,SAAiB,IAEjEgtC,EAAcX,GAAa10B,EAAS1K,GACpCggC,EAAeZ,GAAa10B,EAAS8f,GAErCyV,EAAgBrrC,GAAU,KAC9B,MAAMsrC,EAAex1B,EAAQmX,QAAQjtB,GAC/BurC,EAAa,IAAIz1B,IAEF,IAAjBw1B,EACFC,EAAWv8B,KAAKhP,GAEhBurC,EAAW7C,OAAO4C,EAAc,GAGlCV,EAAWW,IAGPC,EAAmBp8B,GAAUo7B,GAAa10B,EAAS1G,GAAO5G,OAE1DijC,EAAmBr8B,GAAU,KA5CrC,IAAe2P,EAAGd,EA6CVutB,EAAgBp8B,KAAWA,EAAM5G,OACnCoiC,EAAWzd,GAAIrX,EAAS1G,IAExBw7B,GAhDS7rB,EAgDQjJ,EAhDLmI,EAgDc7O,EA/CvB,IAAI2P,KAAMoO,GAAIlP,EAAGc,OAuElB2sB,EAAa,CACjBt6B,EACAu6B,EACAC,KAEA,MAAMx8B,EAAQu8B,EAAgB/8B,QAAQ+F,IACpC,GAAIA,EAAOQ,GAAe,CACxB,MAAMnV,EAAgB2U,EAAOQ,GAC7B,GACW,SAATy2B,GACA5rC,EACG6rC,oBACAnd,SAASqc,EAAgBc,qBAE5B,OAAO,EACF,GACI,UAATD,GACA5rC,EACG6rC,oBACAnd,SAASuc,EAAiBY,qBAE7B,OAAO,EAGX,OAAO,KAET,OACEjmC,EAACkmC,GAAI,CAAC5lC,GAAI,CAAEyD,OAAQ,QAAQhE,SAAA,CAC1BF,EAACsmC,GAAU,CACT7lC,GAAI,CAAEktB,GAAI,EAAGC,GAAI,GACjB2Y,OACEvmC,EAACoQ,GAAQ,CACP7P,QAASylC,EAAgBr8B,GACzB0G,QACE01B,EAAgBp8B,KAAWA,EAAM5G,QAA2B,IAAjB4G,EAAM5G,OAEnDyjC,cACET,EAAgBp8B,KAAWA,EAAM5G,QACN,IAA3BgjC,EAAgBp8B,GAElBjC,SAA2B,IAAjBiC,EAAM5G,OAChB0jC,WAAY,CACV,aAAc,wBAIpB96B,MAAOA,EACP+6B,UAAW,GAAGX,EAAgBG,QAC5BA,EAAgBnjC,oBAGpB/C,EAACiE,EAAG,CAACxD,GAAI,CAAEhB,MAAO,OAAQ4F,QAAS,GACjCnF,SAAAF,EAAC+1B,GAAiB,CAChBY,WAAS,EACT9yB,MAAM,SACNtJ,MAAgB,SAAT4rC,EAAkBb,EAAkBE,EAC3Cv3B,SAAWpE,IACI,SAATs8B,EACFZ,EAAmB17B,EAAM0G,OAAOhW,OAEhCkrC,EAAoB57B,EAAM0G,OAAOhW,YAKzCyF,EAAC8K,GAAU,CAAA,GACX9K,EAAC2mC,GACC,CAAAlmC,GAAI,CACFhB,MAAO,OACPyE,OAAQ,OACRE,QAAS,YACT4qB,SAAU,QAEZ4X,OACA,EAAAvlC,UAAU,MACVwlC,KAAK,OAAM3mC,SAEVyJ,EAAMP,KAAK7O,IACgCA,EAAM6U,GAG9CjP,EAAC2mC,EAAc,CAEbD,KAAK,WACLtmC,QAASqlC,EAAarrC,GACtBkG,GAAI,CAAEsmC,OAAQ,WAEd7mC,SAAA,CAAAF,EAACgnC,GACC,CAAA9mC,SAAAF,EAACoQ,GAAQ,CACPC,SAAoC,IAA3BA,EAAQmX,QAAQjtB,GACzB0sC,YACAC,eAAa,MAGjBlnC,EAACmnC,GAAY,CACX3jC,GAAIjJ,EAAM6U,GACV7J,QAAShL,EAAMmV,OAdZnV,EAAM6U,aAuBzB,OACEjP,EAACq2B,EACC,CAAAiB,WACA,EAAA3yB,QAAS,EACTrE,GAAI,CACFsJ,SAAU,EACVilB,SAAU,OACVrD,OAAQ,EACR/qB,QAAS,OACTnB,MAAO,QAET6C,eAAe,SACfH,WAAW,SAEXjC,SAAA,CAAAF,EAACw2B,EAAK,CAAC/1B,GAAI,CAAEyD,OAAQ,OAAQ5C,KAAM,YAChC2kC,EAAW,kBAAmBtgC,EAAM,UAEvC3F,EAACw2B,EACC,CAAAt2B,SAAAC,EAACq2B,EAAK,CAACiB,WAAS,EAACxtB,UAAU,SAAS9H,WAAW,SAC7CjC,SAAA,CAAAF,EAACgM,GACC,CAAAvL,GAAI,CAAE+tB,GAAI,IACVrtB,QAAQ,WACR+L,KAAK,QACL3M,QApJiB,KACzB8kC,GAAU+B,IACR,IAAIC,EAAWlX,EAAMpE,OAAO2Z,GAE5B,OADAR,EAAamC,GACNA,KAETjC,EAAQ1d,GAAI/hB,EAAM+/B,IAClBP,EAAWzd,GAAIrX,EAASq1B,KA8IhBh+B,SAAiC,IAAvBg+B,EAAY3iC,OACX,aAAA,sBAGJ7C,SAAA,MACTF,EAACgM,GACC,CAAAvL,GAAI,CAAE+tB,GAAI,IACVrtB,QAAQ,WACR+L,KAAK,QACL3M,QApJgB,KACxB6kC,EAAQz/B,EAAKomB,OAAO4Z,IACpBN,GAAU+B,IACR,IAAIC,EAAW3f,GAAIyI,EAAOwV,GAE1B,OADAT,EAAamC,GACNA,KAETlC,EAAWzd,GAAIrX,EAASs1B,KA8IhBj+B,SAAkC,IAAxBi+B,EAAa5iC,OACZ,aAAA,yCAMjB/C,EAACw2B,EAAM,CAAA/1B,GAAI,CAAEyD,OAAQ,OAAQ5C,KAAM,GAAGpB,SACnC+lC,EAAW,qBAAsB9V,EAAO,eC7O3CmX,GAA2C9qC,IAE/C,MAAM+qC,EAAY/qC,EAAMH,KAAK+M,KAAI,CAAC0D,EAAayb,KACtC,CACL/kB,GAAI+kB,EACJhuB,MAAOuS,EAAOtQ,EAAM4S,YACpBvL,MAAOiJ,EAAOtQ,EAAMgrC,YAAc,OAItC,OADAzlC,QAAQC,IAAI,YAAaulC,GAEvBvnC,EAACynC,GAAQ,CACPC,OAAQ,CACN,CACErrC,KAAMkrC,OCdVI,GAA2CnrC,GAE7CwD,EAAC4nC,IACCC,QAASrrC,EAAMH,KACfyrC,MAAO,CAAC,CAAEC,QAASvrC,EAAM4S,WAAY44B,UAAW,SAChDN,OAAQlrC,EAAMgrC,YAAYzpB,MAAM,KAAK3U,KAAKo+B,IACjC,CAAEO,QAASP,EAAY3jC,MAAO2jC,QCNvCS,GAA4CzrC,GAE9CwD,EAACkoC,IACCL,QAASrrC,EAAMH,KACfyrC,MAAO,CAAC,CAAEC,QAASvrC,EAAM4S,WAAY44B,UAAW,SAChDN,OAAQlrC,EAAMgrC,YAAYzpB,MAAM,KAAK3U,KAAKo+B,IACjC,CAAEO,QAASP,EAAY3jC,MAAO2jC,QCLvCW,GAAoD3rC,GAEtD2D,EACEyM,EAAA,CAAA1M,SAAA,CAAAC,EAACe,EAAU,CAACT,GAAI,CAAEwG,SAAU,GAAIP,WAAY,QAAQxG,SAAA,CACjD1D,EAAM4rC,YAAW,MAAK5rC,EAAMsQ,OAAOtQ,EAAMgrC,eAE5CxnC,EAACqoC,GAAK,CAAC5oC,MAAO,IAAKyE,OAAQ,IAAK3J,MAAOiC,EAAMsQ,OAAOtQ,EAAM4S,iBCP1Dk5B,GAAuD9rC,GAEzD2D,EAACo6B,EAAK,CACJ95B,GAAI,CACFG,QAAS,OACTsE,cAAe,SACfhB,OAAQ,IACRmB,QAAS,EACT0E,SAAU,EACVzH,eAAgB,SAChBH,WAAY,UACbjC,SAAA,CAEDF,EAACiE,EACC,CAAAxD,GAAI,CACFG,QAAS,OACTnB,MAAO,OACP6C,eAAgB,eAChBH,WAAY,UAGdjC,SAAAF,EAACkB,EAAU,CAACT,GAAI,CAAEwG,SAAU,GAAIP,WAAY,QAAQxG,SACjD1D,EAAM4rC,gBAGXpoC,EAACiE,EACC,CAAAxD,GAAI,CACFa,KAAM,EACNV,QAAS,OACTnB,MAAO,OACP6C,eAAgB,eAChBH,WAAY,UAIdjC,SAAAF,EAAA,MAAA,CAAAE,SAAM,GAAG1D,EAAMsQ,OAAOtQ,EAAMgrC,iBAC1BhrC,EAAMsQ,OAAOtQ,EAAM4S,kBAIvBpP,EAACiE,EACC,CAAAxD,GAAI,CACFG,QAAS,OACTnB,MAAO,OACP6C,eAAgB,eAChBH,WAAY,eCxCtB,SAASomC,GACP/rC,GAEA,OACE2D,EAAC8D,GAAI,CAAAxD,GAAI,CAAEG,QAAS,OAAQuB,WAAY,UAAUjC,SAAA,CAChDF,EAACiE,GAAG,CAACxD,GAAI,CAAEhB,MAAO,OAAQiB,GAAI,GAC5BR,SAAAF,EAACwoC,GAAe,CAAArnC,QAAQ,iBAAkB3E,MAE5CwD,EAACiE,GAAI,CAAAxD,GAAI,CAAE2sB,SAAU,IAAIltB,SACvBF,EAACkB,GAAU,CACTC,QAAQ,QACRV,GAAI,CAAEH,MAAO,2BACb,GAAG6qB,KAAKsd,MAAMjsC,EAAMjC,gBAI9B,CAEA,MAAMmuC,GACJlsC,GAGE2D,EAAC8D,GAAI,CAAAxD,GAAI,CAAEhB,MAAO,QAChBS,SAAA,CAAAC,EAACe,GAAW,CAAAT,GAAI,CAAEwG,SAAU,GAAIP,WAAY,QACzCxG,SAAA,CAAA1D,EAAM4rC,YAAW,MAAK5rC,EAAMsQ,OAAOtQ,EAAMgrC,eAE5CxnC,EAACuoC,GAAwB,CAAAhuC,MAAOiC,EAAMsQ,OAAOtQ,EAAM4S,iBCAnDu5B,GAAkD,EACtDzoC,WACA0oC,gBAGE5oC,EAAC6oC,GAAI,CACH37B,KAAM,CAAEiZ,GAAI,GAAIC,GAAI,EAAGC,GAAI,GAC3B5lB,GAAI,CACF0B,WAAY,SACZG,eAAgB,SAChB+C,QAAS,EACTzE,QAAS,OACTsE,cAA6B,QAAd0jC,EAAuB,cAAWjsC,EACjDuH,OAAQ,KAGThE,SAAAA,IAKD4oC,GAA+CtsC,GAEjD2D,EAAAyM,EAAA,CAAA1M,SAAA,CACEF,EAACkB,EAAW,CAAAT,GAAI,CAAEwG,SAAU,GAAIP,WAAY,QACzCxG,SAAA1D,EAAMusC,iBAET/oC,EAAC6oC,GACC,CAAApR,WACA,EAAAh3B,GAAI,CACFsJ,SAAU,EACVtK,MAAO,OACP0K,UAAW,OACX9E,QAAS,GAGVnF,SAAA1D,EAAMwsC,iBAAiB5/B,KAAI,CAAC6/B,EAAkB1gB,IAEhB,SAA3B0gB,EAAYL,YACe,UAA3BK,EAAYL,YACe,aAA3BK,EAAYL,WAGV5oC,EAAA4M,EAAA,CAAA1M,SACG+oC,EAAY5sC,KAAK+M,KAAI,CAAC0D,EAAayb,KAClC,MAAM2gB,EAAmD,CACvDd,YAAaa,EAAYb,YACzBt7B,SACA06B,WAAYyB,EAAYzB,WACxBp4B,WAAY65B,EAAY75B,YAE1B,OACEjP,EAACwoC,GAAe,CAEdC,WAAYK,EAAYL,qBAEI,SAA3BK,EAAYL,WACX5oC,EAACsoC,GAAqB,IAAAY,IACpB,KACwB,UAA3BD,EAAYL,WACX5oC,EAACmoC,GAAa,IAAKe,IACjB,KACwB,aAA3BD,EAAYL,WACX5oC,EAAC0oC,GAAoB,IAAKQ,IACxB,OAXC3gB,QAmBbpoB,EAACwoC,GAAe,CAAaC,WAAYK,EAAYL,qBACvB,QAA3BK,EAAYL,WACX5oC,EAACsnC,GAAqB,IAAA2B,IACpB,KACwB,SAA3BA,EAAYL,WACX5oC,EAACioC,GAAiB,IAAKgB,IACrB,KACwB,QAA3BA,EAAYL,WACX5oC,EAAC2nC,GAAgB,IAAKsB,IACpB,OATgB1gB,UC7F9B4gB,GAA2D3sC,IAC/D,MAAOyoC,EAAiBmE,GAAsB1wC,EAAS,IAClD8D,EAAM6sC,0BAELnsC,kBAAEA,GAAsBhC,KAe9B,OACEiF,EAAAyM,EAAA,CAAA1M,SAAA,CACEF,EAACglC,IACCt1B,aAAa,gBACbP,QAAS3S,EAAM8sC,qBACfl6B,WAAW,KACX61B,gBAAiBA,EACjBC,aAAckE,IAEhBjpC,EAAC8D,EAAG,CACFxD,GAAI,CACFG,QAAS,OACTuB,WAAY,SACZG,eAAgB,WAChB7C,MAAO,QAGTS,SAAA,CAAAF,EAACgM,EACC,CAAA7K,QAAQ,YACRZ,QAjCoBhE,gBACpBW,EAAkB,CACtBT,YAAa,gCACbG,UAAU,EACVF,WAAY,CAAE6sC,OAAQ/sC,EAAM+sC,QAC5BltC,KAAM4oC,EACNjoC,gBAAiB,KACfb,GAAMqtC,QAAQ,gDACVhtC,EAAMitC,cACRjtC,EAAMitC,mBAyBNhpC,GAAI,CAAEd,YAAa,EAAGD,WAAY,qBAIpCM,EAACgM,EAAO,CAAA7K,QAAQ,YAAYb,MAAM,QAAQC,QAAS/D,EAAMitC,wCCpDpDC,GAAoC,CAC/C,CACE3lC,KAAM,IACN1C,UCHmB,KACrB,MAAMsoC,EAAUtuC,GAAazB,GAAUA,EAAM+vC,QAAQpvC,QACrD,OACE4F,EAAC8D,EAAG,CACFxD,GAAI,CACFG,QAAS,OACTsE,cAAe,SACf/C,WAAY,SACZG,eAAgB,SAChBhB,KAAM,EACN2F,SAAU,GACVP,WAAY,QAGdxG,SAAA,CAAAF,EAAA,MAAA,CAAKgB,IAAI,WAAWnJ,MAAO,CAAE8zB,OAAQ,KACrC3rB,EAA6D,MAAA,CAAAE,SAAA,uDAC7DC,EAAK,MAAA,CAAAtI,MAAO,CAAEoP,SAAU,IAAI/G,SAAA,CAAA,kBAE1BF,EAACa,GAAe,CACdC,KAAK,OACLjJ,MAAO,CAAE6H,WAAY,GAAIC,YAAa,MAGpC,qDACNQ,+BAAewpC,EAAO,eCzB6B,ICyCV,CAC7C,CACE5lC,KAAM,oBACN1C,UCzC6B,KAC/B,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,8BACTK,WAAY,0BACZD,KAAM,0BACNF,SAAU,0BACV9H,QAASA,IAsFX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aAzF0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,+BACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,6BACZ3kB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,6BACZ3kB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,sBACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,sBACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,uBACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,qBACZ3kB,UAAW,SACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,oBACZ3kB,UAAW,SACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,oBACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,mBAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,wBD9D9CA,UAAW,mBAEb,CACES,KAAM,oBACN1C,UE/C4B,KAC9B,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BI,eAAgB,oBAChBM,WAAY,yBACZD,KAAM,yBACNF,SAAU,yBACV9H,QAASA,IA2DX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,MAAOmuB,iBAAiB,GAC9CtH,aA9D0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2BACZ3kB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,kCACZ3kB,UAAW,uBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2BACZ3kB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,sBACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,wCACZ3kB,UAAW,4BACXxD,UAAU,EACVyD,UAAW,OACXipB,UAAW,CACT9E,QAAQ,MAaZ5iB,cAAe,KACfotB,UAAU,mBACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,kBAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,uBF7B9CA,UAAW,kBAEb,CACES,KAAM,mBACN1C,UGpD4B,KAC9B,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,6BACTK,WAAY,yBACZD,KAAM,yBACNF,SAAU,yBACV9H,QAASA,IA0BX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aA7B0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,6BACZ3kB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,sBACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,oBACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,mBAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,wBHS9CA,UAAW,mBAEb,CACES,KAAM,uBACN1C,UIzDgC,KAClC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,iCACTK,WAAY,6BACZD,KAAM,6BACNF,SAAU,6BACV9H,QAASA,IAwDX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aA3D0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,gCACZ3kB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,0BACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,4BACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,6BACZ3kB,UAAW,YACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2BACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,yBACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,wBAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,6BJhB9CA,UAAW,wBAEb,CACES,KAAM,wBACN1C,UK9DiC,KACnC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,kCACTK,WAAY,8BACZD,KAAM,8BACNF,SAAU,8BACV9H,QAASA,IAwDX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aA3D0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,sCACZ3kB,UAAW,kBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,6BACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,8BACZ3kB,UAAW,YACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,qBACZ3kB,UAAW,IACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,qBACZ3kB,UAAW,IACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,0BACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,yBAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,8BLX9CA,UAAW,yBAEb,CACES,KAAM,mBACN1C,UMnE4B,KAC9B,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,6BACTK,WAAY,yBACZD,KAAM,yBACNF,SAAU,yBACV9H,QAASA,IAkEX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aArE0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2BACZ3kB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2BACZ3kB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,4BACZ3kB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,oBACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,sCACZ3kB,UAAW,0BACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,8BACZ3kB,UAAW,kBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,mBACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,kBAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,uBNhB9CA,UAAW,kBAEb,CACES,KAAM,yBACN1C,UOxEkC,KACpC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,mCACTK,WAAY,+BACZD,KAAM,+BACNF,SAAU,+BACV9H,QAASA,IA8CX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aAjD0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,gCACZ3kB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2BACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,6BACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,gCACZ3kB,UAAW,cACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,0BACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,yBAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,8BPS9CA,UAAW,yBAEb,CACES,KAAM,oBACN1C,UQ7E4B,KAC9B,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BI,eAAgB,oBAChBM,WAAY,yBACZD,KAAM,yBACNF,SAAU,yBACV9H,QAASA,IA8CX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,MAAOmuB,iBAAiB,GAC9CtH,aAjD0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,+BACZ3kB,UAAW,kBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,wBACZ3kB,UAAW,YACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,uBACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,yBACZ3kB,UAAW,YACXxD,UAAU,EACVyD,UAAW,cAYbuB,cAAe,KACfotB,UAAU,oBACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,mBAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,wBRc9CA,UAAW,mBAEb,CACES,KAAM,4BACN1C,USlFqC,KACvC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,sCACTK,WAAY,kCACZD,KAAM,kCACNF,SAAU,kCACV9H,QAASA,IAkEX,OACE58B,EAACg7B,GACC,CAAAvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aArE0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,qCACZ3kB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,qCACZ3kB,UAAW,eACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,+BACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2CACZ3kB,UAAW,oBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,8BACZ3kB,UAAW,SACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iCACZ3kB,UAAW,YACXxD,UAAU,EACVyD,UAAW,cAYbuB,cAAe,KACfotB,UAAU,8BACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,6BAC1Cq6B,aAAc,CACZsB,WAAW,EACX37B,UAAW,kCTHfA,UAAW,6BAEb,CACES,KAAM,8BACN1C,UUvFuC,KACzC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BI,eAAgB,oBAChBM,WAAY,oCACZD,KAAM,oCACNF,SAAU,oCACV9H,QAASA,IAkEX,OACE58B,EAACg7B,GACC,CAAAvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,MAAOmuB,iBAAiB,GAC9CtH,aArE0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,wCACZ3kB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,4CACZ3kB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,wCACZ3kB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,uCACZ3kB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,4CACZ3kB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,gCACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,cAYbuB,cAAe,KACfotB,UAAU,+BACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,8BAC1Cq6B,aAAc,CACZsB,WAAW,EACX37B,UAAW,mCVEfA,UAAW,8BAEb,CACES,KAAM,kBACN1C,UW5F2B,KAC7B,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,4BACTK,WAAY,wBACZD,KAAM,wBACNF,SAAU,wBACV9H,QAASA,IA4EX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aA/E0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iBACZ3kB,UAAW,QACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,yBACZ3kB,UAAW,eACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2BACZ3kB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,yBACZ3kB,UAAW,eACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,gCACZ3kB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,gCACZ3kB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2BACZ3kB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,kBACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,iBAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,sBXD9CA,UAAW,iBAEb,CACES,KAAM,yBACN1C,UYjGkC,KACpC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BI,eAAgB,yBAChBM,WAAY,+BACZD,KAAM,+BACNF,SAAU,+BACV9H,QAASA,IAgGX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,MAAOmuB,iBAAiB,GAC9CtH,aAnG0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2BACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,kCACZ3kB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2CACZ3kB,UAAW,uBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,qCACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2CACZ3kB,UAAW,wBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,mCACZ3kB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,kCACZ3kB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,yCACZ3kB,UAAW,sBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,0CACZ3kB,UAAW,uBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,0BACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,yBAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,8BZhB9CA,UAAW,yBAEb,CACES,KAAM,6BACN1C,UatGsC,KACxC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,uCACTK,WAAY,mCACZD,KAAM,mCACNF,SAAU,mCACV9H,QAASA,IA8CX,OACE58B,EAACg7B,GACC,CAAAvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aAjD0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,qCACZ3kB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iDACZ3kB,UAAW,wBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,wCACZ3kB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,oCACZ3kB,UAAW,aACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,+BACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,8BAC1Cq6B,aAAc,CACZsB,WAAW,EACX37B,UAAW,mCbqCfA,UAAW,8BAEb,CACES,KAAM,6BACN1C,Uc3GsC,KACxC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,uCACTK,WAAY,mCACZD,KAAM,mCACNF,SAAU,mCACV9H,QAASA,IA8CX,OACE58B,EAACg7B,GACC,CAAAvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aAjD0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,+CACZ3kB,UAAW,uBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,+CACZ3kB,UAAW,uBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,sCACZ3kB,UAAW,eACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,4CACZ3kB,UAAW,oBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,+BACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,8BAC1Cq6B,aAAc,CACZsB,WAAW,EACX37B,UAAW,mCd0CfA,UAAW,8BAEb,CACES,KAAM,gBACN1C,UehHyB,KAC3B,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,0BACTK,WAAY,sBACZD,KAAM,sBACNF,SAAU,sBACV9H,QAASA,IAkEX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aArE0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iBACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2BACZ3kB,UAAW,kBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2BACZ3kB,UAAW,kBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,qBACZ3kB,UAAW,aACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,sBACZ3kB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,kBACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,gBACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,eAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,oBf6B9CA,UAAW,eAEb,CACES,KAAM,wBACN1C,UgBrHiC,KACnC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,kCACTK,WAAY,8BACZD,KAAM,8BACNF,SAAU,8BACV9H,QAASA,IAoCX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aAvC0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,0BACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,mCACZ3kB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,4BACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,yBACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,wBAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,6BhBgE9CA,UAAW,wBAEb,CACES,KAAM,mBACN1C,UiB1H2B,KAC7B,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,4BACTK,WAAY,wBACZD,KAAM,wBACNF,SAAU,wBACV9H,QAASA,IA4EX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aA/E0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,yBACZ3kB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,uCACZ3kB,UAAW,yBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,uBACZ3kB,UAAW,YACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,oBACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,oBACZ3kB,UAAW,SACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,6BACZ3kB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,kCACZ3kB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,cAYbuB,cAAe,KACfotB,UAAU,mBACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,kBAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,uBjB6B9CA,UAAW,kBAEb,CACES,KAAM,+BACN1C,UkB/HwC,KAC1C,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,yCACTK,WAAY,qCACZD,KAAM,qCACNF,SAAU,qCACV9H,QAASA,IAgGX,OACE58B,EAACg7B,IACCvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aAnG0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,yDACZ3kB,UAAW,6BACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2CACZ3kB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,8CACZ3kB,UAAW,oBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,4CACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,sCACZ3kB,UAAW,aACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,0CACZ3kB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2CACZ3kB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,+CACZ3kB,UAAW,sBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,4CACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,cAYbuB,cAAe,KACfotB,UAAU,iCACVD,SAAS,cACTttB,WAAY,CACV0rB,WAAW,EACX37B,UAAW,gCAEbq6B,aAAc,CACZsB,WAAW,EACX37B,UAAW,qClBSfA,UAAW,gCAEb,CACES,KAAM,uBACN1C,UmBpIgC,KAClC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,iCACTK,WAAY,6BACZD,KAAM,6BACNF,SAAU,6BACV9H,QAASA,IA8CX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aAjD0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,yBACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,kCACZ3kB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,gCACZ3kB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,gCACZ3kB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,wBACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,uBAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,4BnBqE9CA,UAAW,uBAEb,CACES,KAAM,sBACN1C,UoBzI+B,KACjC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,gCACTK,WAAY,4BACZD,KAAM,4BACNF,SAAU,4BACV9H,QAASA,IAoHX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aAvH0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,wBACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,sCACZ3kB,UAAW,oBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,6BACZ3kB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,mCACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,mCACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,sCACZ3kB,UAAW,oBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,4BACZ3kB,UAAW,aACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,6BACZ3kB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2BACZ3kB,UAAW,aACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iCACZ3kB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,sCACZ3kB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,uBACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,sBAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,2BpBI9CA,UAAW,sBAEb,CACES,KAAM,kBACN1C,UqB9I2B,KAC7B,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,4BACTK,WAAY,wBACZD,KAAM,wBACNF,SAAU,wBACV9H,QAASA,IAoCX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aAvC0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,sBACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,sBACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,WAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,yBACZ3kB,UAAW,cACXxD,UAAU,EACVyD,UAAW,YAYbuB,cAAe,KACfotB,UAAU,mBACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,kBAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,uBrByF9CA,UAAW,kBAEb,CACES,KAAM,sBACN1C,UsBnJ+B,KACjC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,gCACTK,WAAY,4BACZD,KAAM,4BACNF,SAAU,4BACV9H,QAASA,IAsFX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aAzF0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,uBACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,uCACZ3kB,UAAW,wBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2CACZ3kB,UAAW,4BACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iCACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iCACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,qCACZ3kB,UAAW,sBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iCACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,wCACZ3kB,UAAW,uBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,sBACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,qBAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,0BtB4C9CA,UAAW,qBAEb,CACES,KAAM,2BACN1C,UuBxJoC,KACtC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,qCACTK,WAAY,iCACZD,KAAM,iCACNF,SAAU,iCACV9H,QAASA,IAgGX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aAnG0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,oDACZ3kB,UAAW,8BACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,wDACZ3kB,UAAW,kCACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,8CACZ3kB,UAAW,yBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,8CACZ3kB,UAAW,yBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iCACZ3kB,UAAW,aACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,uCACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,yCACZ3kB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,mCACZ3kB,UAAW,eACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,8BACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,4BACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,2BAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,gCvBuC9CA,UAAW,2BAEb,CACES,KAAM,sBACN1C,UwB7J+B,KACjC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,gCACTK,WAAY,4BACZD,KAAM,4BACNF,SAAU,4BACV9H,QAASA,IAoCX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aAvC0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iCACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,yBACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iCACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,mBACfotB,UAAU,sBACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,qBAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,0BxBwG9CA,UAAW,qBAEb,CACES,KAAM,iCACN1C,UyBlK0C,KAC5C,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,2CACTK,WAAY,uCACZD,KAAM,uCACNF,SAAU,uCACV9H,QAASA,IA8CX,OACE58B,EAACg7B,IACCvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aAjD0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,4CACZ3kB,UAAW,kBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,mDACZ3kB,UAAW,yBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,4CACZ3kB,UAAW,kBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,qCACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,cAYbuB,cAAe,KACfotB,UAAU,kCACVD,SAAS,cACTttB,WAAY,CACV0rB,WAAW,EACX37B,UAAW,iCAEbq6B,aAAc,CACZsB,WAAW,EACX37B,UAAW,sCzB8FfA,UAAW,iCAEb,CACES,KAAM,0BACN1C,U0BvKmC,KACrC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,oCACTK,WAAY,gCACZD,KAAM,gCACNF,SAAU,gCACV9H,QAASA,IAwDX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aA3D0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,4BACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,sCACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,8BACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,8BACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,+BACZ3kB,UAAW,YACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,2BACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,0BAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,+B1B8F9CA,UAAW,0BAEb,CACES,KAAM,0BACN1C,U2B5KmC,KACrC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,oCACTK,WAAY,gCACZD,KAAM,gCACNF,SAAU,gCACV9H,QAASA,IAwDX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aA3D0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,4BACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,sCACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,8CACZ3kB,UAAW,yBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,8CACZ3kB,UAAW,yBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,gDACZ3kB,UAAW,2BACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,2BACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,0BAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,+B3BmG9CA,UAAW,0BAEb,CACES,KAAM,0BACN1C,U4BjLmC,KACrC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,oCACTK,WAAY,gCACZD,KAAM,gCACNF,SAAU,gCACV9H,QAASA,IA8CX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aAjD0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,8BACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,+BACZ3kB,UAAW,YACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,sCACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,6BACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,2BACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,0BAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,+B5BkH9CA,UAAW,0BAEb,CACES,KAAM,8BACN1C,U6BtLuC,KACzC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,wCACTK,WAAY,oCACZD,KAAM,oCACNF,SAAU,oCACV9H,QAASA,IAkEX,OACE58B,EAACg7B,GACC,CAAAvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aArE0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,kCACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,mCACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2CACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iCACZ3kB,UAAW,SACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,oCACZ3kB,UAAW,YACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,kCACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,gCACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,+BAC1Cq6B,aAAc,CACZsB,WAAW,EACX37B,UAAW,oC7BiGfA,UAAW,+BAEb,CACES,KAAM,gBACN1C,U8B3LyB,KAC3B,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,0BACTK,WAAY,sBACZD,KAAM,sBACNF,SAAU,sBACV9H,QAASA,IA8HX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aAjI0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2BACZ3kB,UAAW,kBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,8BACZ3kB,UAAW,oBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,yBACZ3kB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,qBACZ3kB,UAAW,aACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,oCACZ3kB,UAAW,yBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,4BACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,4BACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,4BACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,0BACZ3kB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,qBACZ3kB,UAAW,aACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,qBACZ3kB,UAAW,aACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,4BACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,cAYbuB,cAAe,KACfotB,UAAU,gBACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,eAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,oB9B4C9CA,UAAW,eAEb,CACES,KAAM,yBACN1C,U+BhMkC,KACpC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,mCACTK,WAAY,+BACZD,KAAM,+BACNF,SAAU,+BACV9H,QAASA,IAkEX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aArE0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iCACZ3kB,UAAW,eACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2BACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,uCACZ3kB,UAAW,oBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,0BACZ3kB,UAAW,SACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,6BACZ3kB,UAAW,YACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,6BACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,0BACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,yBAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,8B/B6G9CA,UAAW,yBAEb,CACES,KAAM,cACN1C,UgCnMuB,KACzB,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BI,eAAgB,cAChBM,WAAY,oBACZD,KAAM,oBACNF,SAAU,oBACV9H,QAASA,KAEJgN,EAAcC,GAAmBnxC,EAAc,OAChD4D,iBAAEA,GAAqBpB,MACtB4uC,EAAyBC,GAA8BrxC,EAC5D,KAGAsxC,EACAC,GACEvxC,EAAc,KAEhBqhC,OAAQmQ,EACRpQ,eAAgBqQ,GACdvQ,GAAU,CACZn6B,MAAO,MACP46B,WAAY,MACZC,YAAa,qBA8Df,OACEn6B,EACEyM,EAAA,CAAA1M,SAAA,CAAAF,EAACkqC,EAAqB,CAAAhqC,SACpBF,EAACmpC,GAAmB,CAClBI,OAAQK,GAAcpmC,GACtB8lC,qBAAsBU,EACtBX,uBAAwBS,EACxBL,aAAc,KACZU,GAA8B,QAIpCnqC,EAACg7B,GAAY,CACX1mB,WAAY,CACV,CACExT,KAAM,MACN+C,MAAO,cACP0I,SAAUhQ,MAAOF,IACfwtC,EAAgBxtC,GA9EAE,OAAOF,UAC3BC,EAAiB,CACrBG,YAAa,gCACbG,UAAU,EACVF,WAAY,CACV6sC,OAAQltC,EAAKmH,IAEfxG,gBAAkBjB,IAChBouC,GAA8B,GAC9BJ,EAA2BhuC,EAASM,KAAK+tC,qBACzCH,EAAoCluC,EAASM,KAAKitC,0BAqE5Ce,CAAoBhuC,MAI1BoY,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,MAAOmuB,iBAAiB,GAC9CtH,aAzEwC,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iBACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,mBACZ3kB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iBACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,mCACZ3kB,UAAW,4BACXxD,UAAU,EACVyD,UAAW,OACXipB,UAAW,CACT9E,QAAQ,MAkCV5iB,cAAe,KACfotB,UAAU,cACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,aAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,qBhC8EhDA,UAAW,aAEb,CACES,KAAM,wBACN1C,UiC1MgC,KAClC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,iCACTK,WAAY,6BACZD,KAAM,6BACNF,SAAU,6BACV9H,QAASA,IAoCX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aAvC0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,8BACZ3kB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2BACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,yBACZ3kB,UAAW,SACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,wBACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,uBAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,4BjCqJ9CA,UAAW,uBAEb,CACES,KAAM,qBACN1C,UkC/M8B,KAChC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,+BACTK,WAAY,2BACZD,KAAM,2BACNF,SAAU,2BACV9H,QAASA,IAoCX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aAvC0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,uBACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,wBACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,wBACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,sBACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,qBAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,0BlC0J9CA,UAAW,qBAEb,CACES,KAAM,qBACN1C,UmCpN8B,KAChC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,+BACTK,WAAY,2BACZD,KAAM,2BACNF,SAAU,2BACV9H,QAASA,IAoHX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aAvH0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2BACZ3kB,UAAW,aACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,+BACZ3kB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,oCACZ3kB,UAAW,sBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iCACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iCACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2BACZ3kB,UAAW,aACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2BACZ3kB,UAAW,aACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iCACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,4BACZ3kB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,sBACZ3kB,UAAW,SACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,8BACZ3kB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,sBACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,qBAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,0BnC+E9CA,UAAW,qBAEb,CACES,KAAM,gBACN1C,UoCzNyB,KAC3B,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,0BACTK,WAAY,sBACZD,KAAM,sBACNF,SAAU,sBACV9H,QAASA,IAkJX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aArJ0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,uBACZ3kB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iBACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,gBACZ3kB,UAAW,SACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,+BACZ3kB,UAAW,sBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,+BACZ3kB,UAAW,sBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,cACZ3kB,UAAW,OACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,qBACZ3kB,UAAW,aACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,eACZ3kB,UAAW,QACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,6BACZ3kB,UAAW,oBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,6BACZ3kB,UAAW,oBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,4BACZ3kB,UAAW,oBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,qBACZ3kB,UAAW,aACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,qBACZ3kB,UAAW,aACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,eACZ3kB,UAAW,QACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,gBACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,eAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,oBpCsD9CA,UAAW,eAEb,CACES,KAAM,0BACN1C,UqC9NmC,KACrC,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,oCACTK,WAAY,gCACZD,KAAM,gCACNF,SAAU,gCACV9H,QAASA,IA4JX,OACE58B,EAACg7B,GAAY,CACXvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aA/J0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,0CACZ3kB,UAAW,sBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2CACZ3kB,UAAW,uBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,mCACZ3kB,UAAW,eACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,kCACZ3kB,UAAW,eACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,oCACZ3kB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2CACZ3kB,UAAW,uBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,4CACZ3kB,UAAW,wBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,sCACZ3kB,UAAW,kBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,kCACZ3kB,UAAW,eACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,0CACZ3kB,UAAW,sBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,uCACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,0CACZ3kB,UAAW,sBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,0CACZ3kB,UAAW,sBACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,6BACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,mCACZ3kB,UAAW,eACXxD,UAAU,EACVyD,UAAW,cAYbuB,cAAe,KACfotB,UAAU,2BACVD,SAAS,cACTttB,WAAY,CAAE0rB,WAAW,EAAM37B,UAAW,0BAC1Cq6B,aAAc,CAAEsB,WAAW,EAAM37B,UAAW,+BrCiD9CA,UAAW,0BAEb,CACES,KAAM,gCACN1C,UsCnOyC,KAC3C,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,0CACTK,WAAY,sCACZD,KAAM,sCACNF,SAAU,sCACV9H,QAASA,IA4EX,OACE58B,EAACg7B,IACCvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aA/E0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,gDACZ3kB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,gDACZ3kB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,mDACZ3kB,UAAW,uBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,gDACZ3kB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,+CACZ3kB,UAAW,oBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,2CACZ3kB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,gDACZ3kB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,kCACVD,SAAS,cACTttB,WAAY,CACV0rB,WAAW,EACX37B,UAAW,iCAEbq6B,aAAc,CACZsB,WAAW,EACX37B,UAAW,sCtCiIfA,UAAW,iCAEb,CACES,KAAM,wCACN1C,UuCxOgD,KAClD,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,iDACTK,WAAY,6CACZD,KAAM,6CACNF,SAAU,6CACV9H,QAASA,IA4EX,OACE58B,EAACg7B,IACCvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aA/E0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,6CACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,kDACZ3kB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iDACZ3kB,UAAW,eACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,+CACZ3kB,UAAW,aACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,sDACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,mDACZ3kB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,wDACZ3kB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,0CACVD,SAAS,cACTttB,WAAY,CACV0rB,WAAW,EACX37B,UAAW,yCAEbq6B,aAAc,CACZsB,WAAW,EACX37B,UAAW,8CvCsIfA,UAAW,yCAEb,CACES,KAAM,oCACN1C,UwC7O6C,KAC/C,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,8CACTK,WAAY,0CACZD,KAAM,0CACNF,SAAU,0CACV9H,QAASA,IAoCX,OACE58B,EAACg7B,IACCvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aAvC0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,mDACZ3kB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,wCACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iDACZ3kB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,uCACVD,SAAS,cACTttB,WAAY,CACV0rB,WAAW,EACX37B,UAAW,sCAEbq6B,aAAc,CACZsB,WAAW,EACX37B,UAAW,2CxCmLfA,UAAW,sCAEb,CACES,KAAM,iCACN1C,UyClP0C,KAC5C,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,2CACTK,WAAY,uCACZD,KAAM,uCACNF,SAAU,uCACV9H,QAASA,IA0GX,OACE58B,EAACg7B,IACCvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aA7G0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,8CACZ3kB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,0CACZ3kB,UAAW,cACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,8CACZ3kB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,+CACZ3kB,UAAW,kBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,uCACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,0CACZ3kB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,6CACZ3kB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,0CACZ3kB,UAAW,cACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,wCACZ3kB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,kDACZ3kB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,oCACVD,SAAS,cACTttB,WAAY,CACV0rB,WAAW,EACX37B,UAAW,mCAEbq6B,aAAc,CACZsB,WAAW,EACX37B,UAAW,wCzCkHfA,UAAW,mCAEb,CACES,KAAM,iCACN1C,U0CvPyC,KAC3C,MAAOhF,EAAMugC,GAAWlkC,EAAS,IAC3B+b,EAAa0vB,GAAc,CAC/BK,QAAS,0CACTK,WAAY,sCACZD,KAAM,sCACNF,SAAU,sCACV9H,QAASA,IAsFX,OACE58B,EAACg7B,IACCvmB,WAAYA,EACZpY,KAAMA,EACNugC,QAASA,EACTxoB,SAAU,CAAEA,SAAU,OACtB6mB,aAzF0C,CAC5C,CACEljC,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,gDACZ3kB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,gDACZ3kB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iDACZ3kB,UAAW,sBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,mCACZ3kB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,yCACZ3kB,UAAW,cACXxD,UAAU,EACVyD,UAAW,aAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,uDACZ3kB,UAAW,0BACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,iDACZ3kB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,SAGf,CACEpa,KAAM,QACN6Z,KAAM,QACNpV,MAAO,CACLq6B,WAAY,gDACZ3kB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfotB,UAAU,kCACVD,SAAS,cACTttB,WAAY,CACV0rB,WAAW,EACX37B,UAAW,iCAEbq6B,aAAc,CACZsB,WAAW,EACX37B,UAAW,sC1C2IfA,UAAW,oC2CpPTgnC,GAAwB,KAC5B,MAAMt7B,EAAiB3T,GAAazB,GAAqBA,EAAMoF,YACzD1D,EAAUD,GAAazB,GAAqBA,EAAM0B,QAAQf,QAC1DgwC,EAAiBlvC,GACpBzB,GAAqBA,EAAM0B,QAAQf,MAAMgwC,iBAE5C,OACEvqC,EAACwqC,EACC,CAAAjwC,MAAuC,QAAhCyU,EAAevV,aAAyB4R,GAAWN,YAE1D/K,EAACiE,EACC,CAAAxD,GAAI,CACFG,QAAS,OACTsE,cAAe,SAEf5C,eAAgB,aAChBhB,KAAM,EACN0tB,SAAU,SACV3pB,QAAS,GACVnF,SAEDC,EAACsqC,GACE,CAAAvqC,SAAA,CAAA5E,EAAQgO,2BACLogC,GAActgC,KAAI,CAACshC,EAAoBniB,IAEnCvoB,EAAC2qC,GAAK,CAEJ5mC,KAAM2mC,EAAM3mC,KACZ6mC,UAAWF,EAAMrpC,WAFZ,MAAQknB,KAMnB,KACHgiB,EAAenhC,KAAI,CAACshC,EAAoBniB,IAErCvoB,EAAC2qC,GAAK,CAEJ5mC,KAAM2mC,EAAM3mC,KACZ6mC,UAAWF,EAAMrpC,WAFZ,KAAOknB,aC1BtBsiB,GAASlsC,EAAO,MAAPA,EAAc,EAAGI,YAAa,CAC3CU,MAAO,GACPyE,OAAQ,EACRynB,OAAQ,GACR9lB,gBAAiBlB,GAAK,KACtBR,aAAc,EAEdyB,IAAK,KAEF7G,EAAMgG,YAAY,OAAQ,CAC3Bc,gBAAiBlB,GAAK,WAIF,SAAAmmC,GAAatuC,GACnC,MAAM7D,OAAEA,GAAW6D,EACbwC,EAAY3D,GAAazB,GAAqBA,EAAMoF,YACpD1D,EAAUD,GAAazB,GAAqBA,EAAM0B,QAAQf,QAC1DO,EAAWC,IACXgwC,EAAgB1D,IACpBvsC,EAASZ,GAAiBL,gBAAgBwtC,KAM5C,OACErnC,EAACgrC,GAAe,CACdvT,eAJS96B,IAAXhE,EAAuB,IAAMA,IAASjB,SAASoU,UAAOnP,EAKpDgO,OAAO,SACPnL,KAAMR,EAAU3F,cAChB8gC,QAAS,KACP4Q,GAAa,IAEfE,OAAQ,KACNF,GAAa,IAEfG,eA/CiB,GAgDjBC,oBAAoB,EACpBC,WAAY,CACVC,aAAa,GACdnrC,SAEDC,EAAC8D,EACC,CAAAxD,GAAI,CACFG,QAAS,OACTsE,cAAe,SACf/C,WAAY,SACZ+B,OAAQ,OACR8qB,SAAU,UAGZ9uB,SAAA,CAAAF,EAAC6qC,GAAS,CAAA,GACV7qC,EAACiE,EAAG,CACFxD,GAAI,CACFsJ,SAAU,EACVnJ,QAAS,OACT0B,eAAgB,SAChB7C,MAAO,MACP0K,UAAW,QAGbjK,SAAAF,EAAC+I,GAAiB,CAAA,KAEpB5I,EAAC8D,EACC,CAAAxD,GAAI,CACFG,QAAS,OACTuB,WAAY,SACZG,eAAgB,eAChB8C,UAAW,EACX3F,MAAO,QACRS,SAAA,CAEDF,EAACkB,EAAU,CAACT,GAAI,CAAEwG,SAAU,IAAM3G,MAAM,eAAcJ,SACnD5E,EAAQiG,UAEXpB,EAACe,EAAW,CAAAT,GAAI,CAAEwG,SAAU,IAAM3G,MAAM,eACnCJ,SAAA,CAAA,KAAA5E,EAAQuP,qBAMvB,CClGA,MAAMygC,GAAwB,KAC5B,MAAMC,EAAclwC,GACjBzB,GAAqBA,EAAM2xC,YAAYhxC,QAE1C,OACEyF,EAACwrC,GACC/qC,GAAI,CAAEH,MAAO,OAAQgE,OAASvF,GAAUA,EAAMuF,OAAO41B,OAAS,GAC9D16B,KAAM+rC,EAAY/wC,kBAElBwF,EAACyrC,GAAiBnrC,MAAM,eCKxBorC,GAAkB,KACtB,MAAMC,EAAUtwC,GAAazB,GAAqBA,EAAM0B,QAAQf,SACzDuH,EAAU8pC,GAAelzC,EAAS,KAClCmzC,EAAUC,GAAepzC,EAAS,KAClCqzC,EAAkBC,GAAuBtzC,GAAS,GACnDuzC,EAAmB5wC,GACtBzB,GAAqBA,EAAMmG,YAAYxF,QAEpCO,EAAWC,IACXmxC,EAAc3vC,UAClB,GAAgB,MAAZuF,GAAgC,IAAZA,EAEtB,YADA3F,GAAMF,MAAM,mCAGd,GAAgB,MAAZ4vC,GAAgC,IAAZA,EAEtB,YADA1vC,GAAMF,MAAM,mCAGd+vC,GAAoB,GACpB,IAAIjwC,EAAgB,KACpB,IAWE,GAVAA,QAAiBP,GAAM2B,KACrB,GAAGwuC,EAAQvwC,4BACX,CACE0G,WACA+pC,YAEF,CACEjwC,iBAAiB,IAGA,MAAjBG,EAASM,MAAkC,KAAlBN,EAASM,KAAa,CACjD2vC,GAAoB,GACpB,MAAMjsC,EAAc,CAClBtC,iBAAiB,EACjBC,YAAa3B,EAASM,KAAKqB,YAC3BC,YAAa5B,EAASM,MAExBvB,EAASgD,GAAmBF,iBAAiBmC,KAE/C,MAAOyC,GACPwpC,GAAoB,GACpB7vC,GAAMF,MACJuG,GAAGzG,UAAUM,MACX,wDAIF8vC,EAAc9wC,GACjBzB,GAAqBA,EAAMmG,YAAYxF,QAEpC6xC,EAAazY,EAAY,CAC7BP,WAAY,CACViZ,eAAgB,CACdC,eAAgB,+GAKZX,EAAQY,UAAU/mC,MAAMgnC,cACxBh/B,qKAYR9I,QAAS,CACPkN,KAAM,OACNrM,QAAS,CACPE,KACEkmC,EAAQY,UAAU/mC,MAAMgnC,cAAgBh/B,IAE5Ci/B,UAAW,CACThnC,KACEkmC,EAAQY,UAAU/mC,MAAMknC,gBACxBj/B,OAiCR,OAHA5U,GAAU,KA1Be0D,WACvB,GAAIovC,GAASvwC,YACwB,MAA/B+wC,EAAY1uC,gBACd,IACE,IAAI1B,QAAiBP,GAAMsB,IACzB,GAAG6uC,EAAQvwC,+BACX,CACEQ,iBAAiB,IAGrB,GAAgB,MAAZG,GAAqC,MAAjBA,EAASM,KAAc,CAC7C,MAAM0D,EAAc,CAClBtC,iBAAiB,EACjBC,YAAa3B,EAASM,KAAKqB,YAC3BC,YAAa5B,EAASM,MAExBvB,EAASgD,GAAmBF,iBAAiBmC,SAE7CjF,EAASgD,GAAmBD,sBAE9B,MAAO5B,GACPnB,EAASgD,GAAmBD,wBAMlC8uC,KACC,CAAChB,IAEF3rC,EAAC4sC,EAAa,CAAC7tC,MAAOqtC,EAAUlsC,SAC9BF,EAACu6B,EACC,CAAA95B,GAAI,CACFG,QAAS,OACTsD,OAAQ,QACRzE,MAAO,OACP0E,aAAc,EACdhC,WAAY,SACZG,eAAgB,UACjBpC,SAEoC,GAApC+rC,EAAiBxuC,gBAChB0C,EAAC8D,EAAG,CACFxD,GAAI,CACFG,QAAS,OACTsE,cAAe,SACf/C,WAAY,SACZG,eAAgB,UAGlBpC,SAAA,CAAAF,EAAA,MAAA,CAAKgB,IAAK2qC,GAAS1qC,QAASxB,MAAO,IAAKyE,OAAQ,MAChDlE,EAACkB,EAAU,CAACT,GAAI,CAAEwY,EAAG,GAAK9X,QAAQ,KAAKb,MAAM,yBAC1CqrC,GAASpqC,UAEZpB,EAACe,EAAU,CACTT,GAAI,CACF6E,aAAc,EACd7F,MAAO,OACPmL,UAAW,QACX3D,SAAU,IAEZ9F,QAAQ,UACRb,MAAM,gBAEHJ,SAAA,CAAA,KAAAyrC,EAAQ9gC,cAEb7K,EAACgQ,EACC,CAAAnM,MAAM,WACNpD,GAAI,CAAEhB,MAAO,IAAKwZ,EAAG,GACrB1e,MAAOuH,EACPmM,SAAWpE,IACT+hC,EAAY/hC,EAAM0G,OAAOhW,QAE3BsyC,UAAYhjC,IACQ,UAAdA,EAAMoB,KACRihC,OAINlsC,EAACgQ,GACCnM,MAAM,WACNpD,GAAI,CAAEhB,MAAO,IAAKwZ,EAAG,GACrB1e,MAAOsxC,EACP9zC,KAAK,WACLkW,SAAWpE,IACTiiC,EAAYjiC,EAAM0G,OAAOhW,QAE3BsyC,UAAYhjC,IACQ,UAAdA,EAAMoB,KACRihC,OAINlsC,EAACgM,EAAM,CACL8gC,QAASf,EACTxrC,QAAS2rC,EACT/qC,QAAQ,YACRb,MAAM,UACNG,GAAI,CAAEwY,EAAG,GAGF/Y,SAAA,aAGXC,EACEyM,EAAA,CAAA1M,SAAA,CAAAF,EAACyrC,EAAgB,CAAChrC,GAAI,CAAEd,YAAa,KACrCK,EAAyD,MAAA,CAAAE,SAAA,2DC5L/D6sC,GAAOpuC,EAAO,OAAQ,CAC1BE,kBAAoBC,GAAkB,SAATA,GADlBH,EAIV,EAAGI,MAAOoiB,EAAK3hB,WAChB,MAAMR,EAAY3D,GAAazB,GAAeA,EAAMoF,YAC9ClE,EAAWC,KACXC,KAAEA,EAAIC,KAAEA,GAASJ,KACjBypC,EAAejpC,GAAazB,GAAeA,EAAM0qC,gBAChDT,EAAkBI,GAAqBvrC,GAAkB,GAC1DqG,EAAQwL,IACR/R,EAAWF,MACX6K,iBAAEA,GAAqBD,MAGvB5G,iBAAEA,GAAqBpB,KAsC7B,OANArC,GAAU,KACJyrC,EAAaV,WAhCMrnC,WAEvB,IAAKsnC,EAAkB,CACrBI,GAAkB,GAClBjpC,EAAK,2BACL,MAAM2oC,EAASW,EAAaX,OACtBC,EAAYU,EAAaV,UAC/B,IAAK,IAAII,KAAYJ,OAEgBjnC,IAAhCgnC,EAAOK,IAAW1gC,WACe,OAAhCqgC,EAAOK,IAAW1gC,YAClBH,EAAiBwgC,EAAOK,IAAW1gC,YACZ,IAAzBqgC,EAAOK,IAAWnsB,MACY,IAA9B8rB,EAAOK,GAAU7D,gBAEX7jC,EAAiB,CACrBG,YAAaknC,EAAOK,GAAUnsB,IAC9Bjb,UAAU,EACVI,gBAAkBjB,IAChBjB,EAASipC,GAAa,CAAEC,WAAU3nC,KAAMN,EAASM,SAEnDY,gBAAiB,KACfnC,EAASipC,GAAa,CAAEC,WAAU3nC,KAAM,SAKhDpB,MAMA+xC,KAED,CAAC1I,EAAaV,YAEV,CACLhjC,QAAS,OACTsE,cAAe,SACf8pB,SAAU,SACVjlB,SAAU,EACVtK,OAAQjH,GAAYgH,EAAO,qBAAmC,OAC9DyK,UAAWjL,EAAUvF,aACrB6I,eAAgB,aAChBrD,YACW,IAATO,EACIT,EAAMG,YAAYzD,OAAO,CAAC,SAAU,SAAU,CAC5C0D,OAAQJ,EAAMG,YAAYC,OAAOS,QACjCP,SAAUN,EAAMG,YAAYG,SAASQ,iBAEvCd,EAAMG,YAAYzD,OAAO,CAAC,SAAU,SAAU,CAC5C0D,OAAQJ,EAAMG,YAAYC,OAAOC,MACjCC,SAAUN,EAAMG,YAAYG,SAASC,gBAE7CI,WACGlH,GAAuC,QAA3BwG,EAAUvF,eAAmC,IAAT+F,EAE7C,EADAvG,GAAe,KAErB0G,YACGnH,GAAuC,QAA3BwG,EAAUvF,eAAmC,IAAT+F,EAE7C,EADAvG,GAAe,SAKX,SAAUg0C,KACtB,MAAMj+B,EAAiB3T,GAAazB,GAAeA,EAAMoF,YACnDxG,EAAWF,KACXyH,EAAgC1E,GACnCzB,GAAeA,EAAMmG,cAExB,OACEI,EAAC+sC,GAAa,CAAAhtC,SAAA,CACZF,EAACmtC,GAAc,CAACC,WAAW,EAAMntC,SAAS,kBAC1CD,EAACsrC,GAAW,KAC2B,IAAtCvrC,EAAYxF,MAAMkD,gBACjB0C,EAAC4sC,GAAI,CAACvtC,KAAMwP,EAAe3V,cAAa6G,SAAA,CACtCF,EAACqtC,GAAW,CAAA,GACZrtC,EAACF,OACCtH,EAAyB,KAAdwH,EAACsK,OACb9R,EAAWwH,EAAC8qC,OAAkB,KAC/B9qC,EAACkC,GAAY,CAAA,GACblC,EAACsqC,UAGHtqC,EAAC0rC,SAIT,CCpGA,MAoBM4B,GAAen0C,GAAY,CAC/BC,KAAM,UACNsqC,aAtBgC,CAChCnpC,MAAO,CACLgzC,cAAe,KACfnyC,WAAY,KACZmG,QAAS,KACTsJ,WAAY,KACZ5J,QAAS,KACTusC,cAAe,KACflkC,4BAA4B,EAC5BihC,eAAgB,GAChB/gC,wBAAyB,GACzBikC,sBAAuB,CAAE,EACzBC,6BAA8B,CAAE,EAChCnB,SAAU,CACRoB,MAAO,CAAEnB,aAAc,UAAWE,eAAgB,WAClDlnC,KAAM,CAAEgnC,aAAc,UAAWE,eAAgB,cAQrDhzC,SAAU,CACRk0C,WAAY,CAACh0C,EAAOE,KAClBF,EAAMW,MAAQT,EAAOC,YAKd8zC,GAAiBP,GAAanzC,QAC3C,IAAe2zC,GAAAR,GAAajzC,QCxDrB,MAAM0zC,GAA+C,CAC1DC,qBAAsB,CACpB7N,UAAU,EACV9jC,KAAM,CAAC,CAAE9B,MAAO,SAAW,CAAEA,MAAO,UAAY,CAAEA,MAAO,QACzDsd,IAAK,IAEPo2B,qBAAsB,CACpB9N,UAAU,EACVtoB,IAAK,GACLxb,KAAM,CACJ,CAAE9B,MAAO,YACT,CAAEA,MAAO,QACT,CAAEA,MAAO,QACT,CAAEA,MAAO,UACT,CAAEA,MAAO,cAGb2zC,kBAAmB,CACjB/N,UAAU,EACVtoB,IAAK,GACLxb,KAAM,CAAC,CAAE9B,MAAO,SAAW,CAAEA,MAAO,UAAY,CAAEA,MAAO,eAE3D4zC,kBAAmB,CACjBhO,UAAU,EACVtoB,IAAK,GACLxb,KAAM,CACJ,CAAEjD,KAAM,aACR,CAAEA,KAAM,eACR,CAAEA,KAAM,YACR,CAAEA,KAAM,QACR,CAAEA,KAAM,oBACR,CAAEA,KAAM,oBAGZg1C,yBAA0B,CACxBjO,UAAU,EACVtoB,IAAK,GACLxb,KAAM,CAAC,CAAEjD,KAAM,MAAQ,CAAEA,KAAM,QAEjCi1C,kBAAmB,CACjBlO,UAAU,EACV9jC,KAAM,GACNiH,UAAW,oBACXuU,IAAK,yCAEPy2B,kBAAmB,CACjBnO,UAAU,EACV9jC,KAAM,GACNiH,UAAW,oBACXuU,IAAK,8BAEP02B,uBAAwB,CACtBpO,UAAU,EACV9jC,KAAM,GACNiH,UAAW,oBACXuU,IAAK,oCAEP22B,kBAAmB,CACjBrO,UAAU,EACV9jC,KAAM,GACNiH,UAAW,oBACXuU,IAAK,8BAEP42B,YAAa,CACXtO,UAAU,EACV9jC,KAAM,GACNiH,UAAW,oBACXuU,IAAK,0BCrDH62B,GAA0BlyC,IAC9B,MAAM1B,EAAWC,IACjB4zC,GAAYC,cAAcpyC,EAAMgxC,eAChC,MAAMqB,EAAkC,CACtCzb,WAAY,CACViZ,eAAgB,CACdC,eAAgB,+GAKZ9vC,EAAM+vC,UAAUoB,OAAOnB,cACvBl/B,qKAYR5I,QAAS,CACPkN,KAAM,QACNrM,QAAS,CACPE,KACEjJ,EAAM+vC,UAAUoB,OAAOnB,cAAgBl/B,IAE3Cm/B,UAAW,CACThnC,KACEjJ,EAAM+vC,UAAUoB,OAAOjB,gBACvBn/B,IAEJuhC,WAAY,CACVC,QAAS,UACTC,MAAO,aAIPC,EAAiC,CACrC7b,WAAY,CACViZ,eAAgB,CACdC,eAAgB,+GAKZ9vC,EAAM+vC,UAAU/mC,MAAMgnC,cAAgBh/B,qKAY9C9I,QAAS,CACPkN,KAAM,OACNrM,QAAS,CACPE,KACEjJ,EAAM+vC,UAAU/mC,MAAMgnC,cAAgBh/B,IAE1Ci/B,UAAW,CACThnC,KACEjJ,EAAM+vC,UAAU/mC,MAAMknC,gBACtBj/B,MAKR,IAAI62B,EAAe,CAAE,EACjB9nC,EAAM8M,6BACRg7B,EAAe,IAAKyJ,KAElBvxC,EAAMkxC,+BACRpJ,EAAe,IACVA,KACA9nC,EAAMkxC,+BAGb5yC,EAASgpC,GAAkBQ,IAC3B,MAAMt1B,EAAiB3T,GAAazB,GAAeA,EAAMoF,YACzD,IAAIkwC,EAAe,IAAKL,GACS,SAA7B7/B,EAAe1V,YACjB41C,EAAe,IAAKD,IAEtB,MAAMlwC,EAAQ40B,EAAY,CACxB1pB,UAAW+E,EAAevV,gBACvBy1C,IAML,OAJAr2C,GAAU,KACRnB,SAASiU,MAAQnP,EAAM+wC,cACvBzyC,EAAS+yC,GAAeD,WAAWpxC,MAClC,IAEDwD,EAAC4sC,EAAa,CAAC7tC,MAAOA,EAAKmB,SACzBF,EAACitC,GAAS,CAAA,MCrGhBkC,EAAQC,IAAIC,GACZF,EAAQC,IAAIE,GACZH,EAAQC,IAAIG,GAEC,MAAAC,GAA8BhzC,IACzC,MAAMizC,EAAiB,CACrBzwC,UAAW5E,GACX2F,YAAahC,GACbwtC,YAAa3wC,GACb0pC,aAAcJ,GACd5oC,QAASwyC,MACNtxC,EAAMixC,uBAELiC,EAAQC,GAAe,CAC3Bt1C,QAASo1C,IAsBX,OACEzvC,EAAC4vC,EAAQ,CAACF,MAAOA,EACfxvC,SAAAF,EAAC0uC,GAAQ,IAAAlyC","x_google_ignoreList":[0,13,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77]}
1
+ {"version":3,"file":"index.mjs","sources":["../node_modules/style-inject/dist/style-inject.es.js","../src/hooks/UseMobile.tsx","../src/redux/features/common/AppLayoutSlice.ts","../src/redux/features/common/LoadingMaskSlice.ts","../src/hooks/useLoadingMask.tsx","../src/hooks/useAxios.tsx","../src/redux/features/common/UserSessionSlice.ts","../src/locales/english/index.ts","../src/locales/index.ts","../src/locales/arabic/index.ts","../src/locales/i18n.ts","../src/layout/TopBar.tsx","../src/layout/DrawerHeader.tsx","../node_modules/clsx/dist/clsx.mjs","../src/hooks/UseSession.tsx","../src/navigationItems/index.tsx","../src/navigationItems/Administration/index.tsx","../src/navigationItems/Administration/adminNavigationItems.tsx","../src/layout/NavigationTree.tsx","../src/layout/SideBar.tsx","../src/components/common/LayoutHandlers.tsx","../src/hooks/UseConfirmationWindow.tsx","../src/components/templates/DataEntryTemplates/TemplateDataGrid/TemplateGridMultiRecordAction.tsx","../src/util/constants.ts","../src/components/templates/DataEntryTemplates/TemplateDataForm/FormFields/Datefield.tsx","../src/components/templates/DataEntryTemplates/TemplateDataForm/FormFields/DatetimeField.tsx","../src/components/templates/DataEntryTemplates/TemplateDataForm/FormFields/ComboBox.tsx","../src/components/templates/DataEntryTemplates/TemplateDataForm/FormFields/CheckBox.tsx","../src/components/templates/DataEntryTemplates/TemplateDataGrid/DataGridColumnsUtil.tsx","../src/components/templates/DataEntryTemplates/DataEntryUtil.ts","../src/components/templates/DataEntryTemplates/TemplateDataGrid/TemplateGridTopBar.tsx","../src/util/AppUtils.ts","../src/components/templates/DataEntryTemplates/TemplateDataGrid/TemplateGridRecordAction.tsx","../node_modules/@mui/system/node_modules/@mui/utils/esm/formatMuiErrorMessage/formatMuiErrorMessage.js","../node_modules/prop-types/node_modules/react-is/index.js","../node_modules/prop-types/node_modules/react-is/cjs/react-is.production.min.js","../node_modules/prop-types/node_modules/react-is/cjs/react-is.development.js","../node_modules/object-assign/index.js","../node_modules/prop-types/lib/ReactPropTypesSecret.js","../node_modules/prop-types/lib/has.js","../node_modules/prop-types/checkPropTypes.js","../node_modules/prop-types/factoryWithTypeCheckers.js","../node_modules/prop-types/factoryWithThrowingShims.js","../node_modules/prop-types/index.js","../node_modules/react-is/cjs/react-is.production.js","../node_modules/react-is/cjs/react-is.development.js","../node_modules/react-is/index.js","../node_modules/@mui/system/node_modules/@mui/utils/esm/deepmerge/deepmerge.js","../node_modules/@mui/system/esm/createBreakpoints/createBreakpoints.js","../node_modules/@mui/system/esm/createTheme/shape.js","../node_modules/@mui/system/esm/responsivePropType/responsivePropType.js","../node_modules/@mui/system/esm/merge/merge.js","../node_modules/@mui/system/esm/breakpoints/breakpoints.js","../node_modules/@mui/system/esm/cssContainerQueries/cssContainerQueries.js","../node_modules/@mui/system/node_modules/@mui/utils/esm/capitalize/capitalize.js","../node_modules/@mui/system/esm/style/style.js","../node_modules/@mui/system/esm/spacing/spacing.js","../node_modules/@mui/system/esm/memoize/memoize.js","../node_modules/@mui/system/esm/compose/compose.js","../node_modules/@mui/system/esm/borders/borders.js","../node_modules/@mui/system/esm/cssGrid/cssGrid.js","../node_modules/@mui/system/esm/palette/palette.js","../node_modules/@mui/system/esm/sizing/sizing.js","../node_modules/@mui/system/esm/styleFunctionSx/defaultSxConfig.js","../node_modules/@mui/system/esm/styleFunctionSx/styleFunctionSx.js","../node_modules/@mui/system/esm/createTheme/applyStyles.js","../node_modules/@mui/system/esm/useThemeWithoutDefault/useThemeWithoutDefault.js","../node_modules/@mui/system/esm/useTheme/useTheme.js","../node_modules/@mui/system/esm/createTheme/createTheme.js","../node_modules/@mui/system/esm/createTheme/createSpacing.js","../node_modules/@mui/system/esm/styleFunctionSx/extendSxProp.js","../node_modules/@mui/system/node_modules/@mui/utils/esm/ClassNameGenerator/ClassNameGenerator.js","../node_modules/@mui/system/node_modules/@mui/utils/esm/generateUtilityClass/generateUtilityClass.js","../node_modules/@mui/system/esm/Box/boxClasses.js","../node_modules/@mui/system/esm/Box/Box.js","../node_modules/@mui/system/esm/createBox/createBox.js","../node_modules/@mui/styled-engine/esm/index.js","../node_modules/@mui/system/node_modules/@mui/utils/esm/generateUtilityClasses/generateUtilityClasses.js","../src/components/templates/DataEntryTemplates/TemplateDataForm/FormFields/TemplateTextField.tsx","../src/components/templates/DataEntryTemplates/TemplateDataForm/FormElementField.tsx","../src/components/templates/DataEntryTemplates/TemplateDataForm/FormAction.tsx","../src/components/templates/DataEntryTemplates/TemplateDataForm/FormElementGroup.tsx","../src/components/templates/DataEntryTemplates/TemplateDataForm/TemplateForm.tsx","../src/hooks/UseWindow.tsx","../src/components/templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid.tsx","../src/redux/features/common/CommonStoreSlice.ts","../src/hooks/useApiActions.ts","../src/components/templates/TransferList.tsx","../src/components/templates/visuals/charts/TemplatePieChart.tsx","../src/components/templates/visuals/charts/TemplateBarChart.tsx","../src/components/templates/visuals/charts/TemplateLineChart.tsx","../src/components/templates/visuals/charts/TemplateGauge.tsx","../src/components/templates/visuals/charts/TemplateDataCard.tsx","../src/components/templates/visuals/charts/TemplateLineProgress.tsx","../src/components/templates/visuals/TemplateDashboard.tsx","../src/components/admin/RoleAuthoritiesForm.tsx","../src/routes/index.ts","../src/components/common/Home.tsx","../src/routes/administration/index.ts","../src/routes/administration/adminRoutes.tsx","../src/components/admin/AttachmentGrid.tsx","../src/components/admin/AuthorityGrid.tsx","../src/components/admin/BluePrintGrid.tsx","../src/components/admin/BluePrintPageGrid.tsx","../src/components/admin/BluePrintPointGrid.tsx","../src/components/admin/DashboardGrid.tsx","../src/components/admin/DashboardWidgetGrid.tsx","../src/components/admin/DataQueryGrid.tsx","../src/components/admin/DataQueryParameterGrid.tsx","../src/components/admin/DatasourceConnectionGrid.tsx","../src/components/admin/EmployeeGrid.tsx","../src/components/admin/EntityParameterGrid.tsx","../src/components/admin/ExcelUploaderDetailGrid.tsx","../src/components/admin/ExcelUploaderHeaderGrid.tsx","../src/components/admin/LookupGrid.tsx","../src/components/admin/MailAttachmentGrid.tsx","../src/components/admin/MailBodyGrid.tsx","../src/components/admin/MailNotificationQueueGrid.tsx","../src/components/admin/MailRecipientGrid.tsx","../src/components/admin/MailTemplateGrid.tsx","../src/components/admin/NewTableGrid.tsx","../src/components/admin/NotificationGrid.tsx","../src/components/admin/NotificationQueueGrid.tsx","../src/components/admin/OrganizationGrid.tsx","../src/components/admin/OrganizationApplicationGrid.tsx","../src/components/admin/OrganizationRankGrid.tsx","../src/components/admin/OrganizationUnitGrid.tsx","../src/components/admin/OrganizationUserGrid.tsx","../src/components/admin/OrganizationUserRoleGrid.tsx","../src/components/admin/ReportGrid.tsx","../src/components/admin/ReportParameterGrid.tsx","../src/components/admin/RoleGrid.tsx","../src/components/admin/RoleAuthorityGrid.tsx","../src/components/admin/UserAccountGrid.tsx","../src/components/admin/UserRequestGrid.tsx","../src/components/admin/WidgetGrid.tsx","../src/components/admin/WorkflowDocumentGrid.tsx","../src/components/admin/WorkflowDocumentActionGrid.tsx","../src/components/admin/WorkflowDocumentActionHistoryGrid.tsx","../src/components/admin/WorkflowDocumentActionMailGrid.tsx","../src/components/admin/WorkflowDocumentMailLogGrid.tsx","../src/components/admin/WorkflowDocumentStatusGrid.tsx","../src/layout/MainContent.tsx","../src/layout/MobileDrawer.tsx","../src/components/common/LoadingMask.tsx","../src/components/common/Login.tsx","../src/layout/Layout.tsx","../src/redux/features/common/AppInfoSlice.ts","../src/redux/features/administration/AdministrationStoresMetaData.ts","../src/components/App.tsx","../src/components/BaseApp.tsx"],"sourcesContent":["function styleInject(css, ref) {\n if ( ref === void 0 ) ref = {};\n var insertAt = ref.insertAt;\n\n if (!css || typeof document === 'undefined') { return; }\n\n var head = document.head || document.getElementsByTagName('head')[0];\n var style = document.createElement('style');\n style.type = 'text/css';\n\n if (insertAt === 'top') {\n if (head.firstChild) {\n head.insertBefore(style, head.firstChild);\n } else {\n head.appendChild(style);\n }\n } else {\n head.appendChild(style);\n }\n\n if (style.styleSheet) {\n style.styleSheet.cssText = css;\n } else {\n style.appendChild(document.createTextNode(css));\n }\n}\n\nexport default styleInject;\n","import { useEffect, useState } from \"react\";\r\n\r\nexport const useIsMobile = (breakpoint = 768) => {\r\n const [isMobile, setIsMobile] = useState(window.innerWidth < breakpoint);\r\n\r\n useEffect(() => {\r\n const handleResize = () => setIsMobile(window.innerWidth < breakpoint);\r\n window.addEventListener(\"resize\", handleResize);\r\n return () => window.removeEventListener(\"resize\", handleResize);\r\n }, [breakpoint]);\r\n\r\n return isMobile;\r\n};\r\n","import { createSlice } from \"@reduxjs/toolkit\";\r\n\r\nexport const DRAWER_WIDTH = 350;\r\n\r\ninterface AppLayoutState {\r\n sideBarOpened: boolean;\r\n themeMode: \"light\" | \"dark\" | string;\r\n appDirection: \"ltr\" | \"rtl\";\r\n}\r\n\r\nconst initialState: AppLayoutState = {\r\n sideBarOpened: false,\r\n themeMode: localStorage.getItem(\"themeMode\") || \"light\",\r\n appDirection: localStorage.getItem(\"language\") == \"ar\" ? \"rtl\" : \"ltr\",\r\n};\r\n\r\nconst AppLayoutSlice = createSlice({\r\n name: \"AppLayout\",\r\n initialState,\r\n reducers: {\r\n toggleSideBarState: (state) => {\r\n state.sideBarOpened = !state.sideBarOpened;\r\n },\r\n setSideBarState: (state, action) => {\r\n state.sideBarOpened = action.payload;\r\n },\r\n setThemeMode: (state, action) => {\r\n state.themeMode = action.payload;\r\n },\r\n setAppDirection: (state, action) => {\r\n state.appDirection = action.payload;\r\n },\r\n },\r\n});\r\n\r\nexport const AppLayoutActions = AppLayoutSlice.actions;\r\nexport default AppLayoutSlice.reducer;\r\n","import { createSlice, PayloadAction } from \"@reduxjs/toolkit\";\r\n\r\ninterface LoadingMaskStateValue {\r\n value: { isOpened: boolean; message?: string | null };\r\n}\r\n\r\nconst initialState: LoadingMaskStateValue = {\r\n value: { isOpened: false, message: null },\r\n};\r\n\r\nconst loadingMaskSlice = createSlice({\r\n name: \"loadingMask\",\r\n initialState,\r\n reducers: {\r\n showLoadingMask: (\r\n state,\r\n action: PayloadAction<string | null | undefined>\r\n ) => {\r\n state.value.isOpened = true;\r\n state.value.message = action.payload;\r\n },\r\n hideLoadingMask: (state) => {\r\n state.value.isOpened = false;\r\n state.value.message = null;\r\n },\r\n },\r\n});\r\n\r\nexport const { showLoadingMask, hideLoadingMask } = loadingMaskSlice.actions;\r\nexport default loadingMaskSlice.reducer;\r\n","import { useDispatch } from \"react-redux\";\r\nimport { hideLoadingMask, showLoadingMask } from \"../redux/features/common/LoadingMaskSlice\";\r\n\r\n\r\nconst useLoadingMask = () => {\r\n const dispatch = useDispatch();\r\n const show = (message?: string) => {\r\n dispatch(showLoadingMask(message));\r\n };\r\n const hide = () => {\r\n dispatch(hideLoadingMask());\r\n };\r\n return { show, hide };\r\n};\r\n\r\nexport default useLoadingMask;\r\n","import { toast } from \"react-toastify\";\r\nimport axios from \"axios\";\r\nimport { useSelector } from \"react-redux\";\r\nimport { RootState } from \"../redux/store\";\r\nimport useLoadingMask from \"./useLoadingMask\";\r\n\r\nexport interface APIRequest {\r\n endPointURI: string;\r\n parameters?: any;\r\n data?: any;\r\n showMask?: Boolean;\r\n loadingMessage?: string;\r\n successCallBkFn?: Function;\r\n failureCallBkFn?: Function;\r\n}\r\n\r\nconst useAxios = () => {\r\n const mask = useLoadingMask();\r\n const apiBaseUrl = useSelector(\r\n (state: RootState) => state.AppInfo.value.apiBaseUrl\r\n );\r\n const axiosInstance = axios.create({\r\n baseURL: apiBaseUrl,\r\n timeout: 600000,\r\n withCredentials: true,\r\n });\r\n\r\n axiosInstance.defaults.withCredentials = true;\r\n axiosInstance.interceptors.response.use(\r\n (response: any) => {\r\n return response;\r\n },\r\n (error: any) => {\r\n if (\r\n error\r\n ? error.response\r\n ? error.response.status\r\n ? error.response.status === 401\r\n : false\r\n : false\r\n : false\r\n ) {\r\n toast.error(\"your session is now expired, you need to login again\", {\r\n autoClose: false,\r\n });\r\n } else if (\r\n error\r\n ? error.response\r\n ? error.response.status\r\n ? error.response.status === 403\r\n : false\r\n : false\r\n : false\r\n ) {\r\n toast.error(\"you aren't authorized to process this request\");\r\n } else if (\r\n error\r\n ? error.response\r\n ? error.response.status\r\n ? error.response.status === 500\r\n : false\r\n : false\r\n : false\r\n ) {\r\n toast.error(error.response.data);\r\n } else {\r\n toast.error(\r\n \"failed to communicate with the server ... try again later\"\r\n );\r\n }\r\n return \"ERROR\";\r\n }\r\n );\r\n const handleGetRequest = async (\r\n props: APIRequest = { endPointURI: \"\", parameters: {} }\r\n ) => {\r\n if (\r\n props.showMask !== undefined &&\r\n props.showMask != null &&\r\n props.showMask === true\r\n ) {\r\n mask.show(props.loadingMessage);\r\n }\r\n const response: any = await axiosInstance.get(props.endPointURI, {\r\n params: { ...props.parameters },\r\n withCredentials: true,\r\n // withCredentials: true,\r\n });\r\n if (\r\n props.showMask !== undefined &&\r\n props.showMask != null &&\r\n props.showMask === true\r\n ) {\r\n mask.hide();\r\n }\r\n if (response !== \"ERROR\") {\r\n if (\r\n props.successCallBkFn !== undefined &&\r\n props.successCallBkFn != null\r\n ) {\r\n props.successCallBkFn(response);\r\n }\r\n return response;\r\n } else {\r\n if (\r\n props.failureCallBkFn !== undefined &&\r\n props.failureCallBkFn != null\r\n ) {\r\n props.failureCallBkFn(response);\r\n }\r\n return \"ERROR\";\r\n }\r\n };\r\n\r\n const HandleDownloadHTTPPostPDF = async (\r\n props: APIRequest = { endPointURI: \"\", parameters: {}, data: {} }\r\n ) => {\r\n if (\r\n props.showMask !== undefined &&\r\n props.showMask != null &&\r\n props.showMask === true\r\n ) {\r\n mask.show(props.loadingMessage);\r\n }\r\n const response: any = await axiosInstance.post(\r\n props.endPointURI,\r\n props.data,\r\n {\r\n responseType: \"blob\",\r\n }\r\n );\r\n if (\r\n props.showMask !== undefined &&\r\n props.showMask != null &&\r\n props.showMask === true\r\n ) {\r\n mask.hide();\r\n }\r\n if (response !== \"ERROR\") {\r\n if (\r\n props.successCallBkFn !== undefined &&\r\n props.successCallBkFn != null\r\n ) {\r\n props.successCallBkFn(response);\r\n }\r\n return response;\r\n } else {\r\n if (\r\n props.failureCallBkFn !== undefined &&\r\n props.failureCallBkFn != null\r\n ) {\r\n props.failureCallBkFn(response);\r\n }\r\n return \"ERROR\";\r\n }\r\n // axiosInstance\r\n // .request({\r\n // url: props.endPointURI,\r\n // method: \"POST\",\r\n // data: props.data,\r\n // responseType: \"blob\",\r\n // })\r\n // .then((response) => {\r\n // const url = window.URL.createObjectURL(\r\n // new Blob([response.data], { type: \"application/pdf\" })\r\n // );\r\n // const link = document.createElement(\"a\");\r\n // link.href = url;\r\n // link.setAttribute(\"download\", \"example.pdf\"); // specify download filename\r\n // document.body.appendChild(link);\r\n // link.click();\r\n // link.remove();\r\n // })\r\n // .catch((error) => {\r\n // console.error(\"Download error:\", error);\r\n // })\r\n // .finally(() => {\r\n\r\n // });\r\n };\r\n const handlePostRequest = async (\r\n props: APIRequest = { endPointURI: \"\", parameters: {}, data: {} }\r\n ) => {\r\n if (\r\n props.showMask !== undefined &&\r\n props.showMask != null &&\r\n props.showMask === true\r\n ) {\r\n mask.show(props.loadingMessage);\r\n }\r\n let response: any = await axiosInstance.post(\r\n props.endPointURI,\r\n props.data,\r\n {\r\n params: props.parameters,\r\n }\r\n );\r\n if (\r\n props.showMask !== undefined &&\r\n props.showMask != null &&\r\n props.showMask === true\r\n ) {\r\n mask.hide();\r\n }\r\n if (response !== \"ERROR\") {\r\n if (\r\n props.successCallBkFn !== undefined &&\r\n props.successCallBkFn != null\r\n ) {\r\n props.successCallBkFn(response);\r\n }\r\n return response;\r\n } else {\r\n if (\r\n props.failureCallBkFn !== undefined &&\r\n props.failureCallBkFn != null\r\n ) {\r\n props.failureCallBkFn(response);\r\n }\r\n return \"ERROR\";\r\n }\r\n };\r\n const handleDeleteRequest = async (\r\n props: APIRequest = { endPointURI: \"\", parameters: {} }\r\n ) => {\r\n if (\r\n props.showMask !== undefined &&\r\n props.showMask != null &&\r\n props.showMask === true\r\n ) {\r\n mask.show(props.loadingMessage);\r\n }\r\n let response: any = await axiosInstance.delete(props.endPointURI, {\r\n params: {\r\n ...props.parameters,\r\n },\r\n });\r\n if (\r\n props.showMask !== undefined &&\r\n props.showMask != null &&\r\n props.showMask === true\r\n ) {\r\n mask.hide();\r\n }\r\n if (response !== \"ERROR\") {\r\n if (\r\n props.successCallBkFn !== undefined &&\r\n props.successCallBkFn != null\r\n ) {\r\n props.successCallBkFn(response);\r\n }\r\n return response;\r\n } else {\r\n if (\r\n props.failureCallBkFn !== undefined &&\r\n props.failureCallBkFn != null\r\n ) {\r\n props.failureCallBkFn(response);\r\n }\r\n return \"ERROR\";\r\n }\r\n };\r\n return {\r\n handleGetRequest,\r\n handlePostRequest,\r\n handleDeleteRequest,\r\n HandleDownloadHTTPPostPDF,\r\n };\r\n};\r\n\r\nexport default useAxios;\r\n","import { createSlice } from \"@reduxjs/toolkit\";\r\n\r\nexport interface OrganizationProps {\r\n organizationCode?: string;\r\n organizationName?: string;\r\n}\r\nexport interface UserProfileProps {\r\n username?: string;\r\n currentOrganizationCode?: string;\r\n userOrganizations?: Array<OrganizationProps>;\r\n employeeNumber?: string;\r\n employeeName?: string;\r\n divisionCode?: string;\r\n divisionName?: string;\r\n departmentCode?: string;\r\n departmentName?: string;\r\n rankCode?: string;\r\n rankName?: string;\r\n sectionCode?: string;\r\n sectionName?: string;\r\n subsectionCode?: string;\r\n subsectionName?: string;\r\n extNumber?: string;\r\n mobileNumber?: string;\r\n email?: string;\r\n}\r\n\r\nexport interface UserSessionProps {\r\n value: {\r\n isAuthenticated: boolean | null;\r\n userProfile: UserProfileProps | null;\r\n authorities: Array<{ authority: string }>;\r\n };\r\n}\r\n\r\nconst initialState: UserSessionProps = {\r\n value: {\r\n isAuthenticated: null,\r\n authorities: [],\r\n userProfile: null,\r\n },\r\n};\r\n\r\nconst UserSessionSlice = createSlice({\r\n name: \"UserSession\",\r\n initialState,\r\n reducers: {\r\n setAuthenticated: (state, action) => {\r\n state.value = action.payload;\r\n },\r\n setUnAuthenticated: (state) => {\r\n state.value = {\r\n isAuthenticated: false,\r\n authorities: [],\r\n userProfile: null,\r\n };\r\n },\r\n },\r\n});\r\n\r\nexport const UserSessionActions = UserSessionSlice.actions;\r\nexport default UserSessionSlice.reducer;\r\n","import common from \"./common.json\";\r\nimport AdminLocalsEn from \"./adminLocalsEn.json\";\r\nexport const ENGLISH_TRANS = {\r\n ...common,\r\n ...AdminLocalsEn,\r\n};\r\n","import { ARABIC_TRANS } from \"./arabic\";\r\nimport { ENGLISH_TRANS } from \"./english\";\r\n\r\nconst resources = {\r\n en: { translation: ENGLISH_TRANS },\r\n ar: { translation: ARABIC_TRANS },\r\n};\r\n\r\nexport default resources;\r\n","import common from \"./common.json\";\r\nimport adminLocalsAr from \"./adminLocalsAr.json\";\r\n\r\nexport const ARABIC_TRANS = {\r\n ...common,\r\n ...adminLocalsAr,\r\n};\r\n","import i18n from \"i18next\";\r\nimport { initReactI18next } from \"react-i18next\";\r\nimport resources from \".\";\r\ni18n.use(initReactI18next).init({\r\n resources: resources, // Where we're gonna put translations' files\r\n lng: localStorage.getItem(\"language\") || \"en\", // Set the initial language of the App\r\n fallbackLng: \"en\",\r\n});\r\n\r\nexport const changeLanguage = (lng: string) => {\r\n i18n.changeLanguage(lng);\r\n localStorage.setItem(\"language\", lng); // Persist user choice\r\n};\r\n\r\nexport default i18n;\r\n","import { Avatar, IconButton, styled, Typography } from \"@mui/material\";\r\nimport MuiAppBar, { AppBarProps as MuiAppBarProps } from \"@mui/material/AppBar\";\r\nimport Toolbar from \"@mui/material/Toolbar\";\r\nimport { useDispatch, useSelector } from \"react-redux\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport { RootState } from \"../redux/store\";\r\nimport { useIsMobile } from \"../hooks/UseMobile\";\r\nimport {\r\n AppLayoutActions,\r\n DRAWER_WIDTH,\r\n} from \"../redux/features/common/AppLayoutSlice\";\r\nimport useAxios from \"../hooks/useAxios\";\r\nimport { UserSessionActions } from \"../redux/features/common/UserSessionSlice\";\r\nimport i18n, { changeLanguage } from \"../locales/i18n\";\r\n\r\ninterface AppBarProps extends MuiAppBarProps {\r\n open?: boolean;\r\n}\r\n\r\nconst AppBar = styled(MuiAppBar, {\r\n shouldForwardProp: (prop) => prop !== \"open\",\r\n})<AppBarProps>(({ theme }) => {\r\n const AppLayout = useSelector((state: RootState) => state.AppLayout);\r\n const isMobile = useIsMobile();\r\n return {\r\n transition: theme.transitions.create([\"margin\", \"width\"], {\r\n easing: theme.transitions.easing.sharp,\r\n duration: theme.transitions.duration.leavingScreen,\r\n }),\r\n variants: [\r\n {\r\n props: ({ open }) => open,\r\n style: {\r\n width: !isMobile ? `calc(100% - ${DRAWER_WIDTH}px)` : undefined,\r\n marginLeft:\r\n !isMobile && AppLayout.appDirection === \"ltr\"\r\n ? `${DRAWER_WIDTH}px`\r\n : undefined,\r\n marginRight:\r\n !isMobile && AppLayout.appDirection === \"rtl\"\r\n ? `${DRAWER_WIDTH}px`\r\n : undefined,\r\n transition: theme.transitions.create([\"margin\", \"width\"], {\r\n easing: theme.transitions.easing.easeOut,\r\n duration: theme.transitions.duration.enteringScreen,\r\n }),\r\n },\r\n },\r\n ],\r\n };\r\n});\r\n\r\nconst TopBar: React.FC = () => {\r\n const AppInfo = useSelector((state: RootState) => state.AppInfo.value);\r\n const AppLayout = useSelector((state: RootState) => state.AppLayout);\r\n const UserSession = useSelector((state: RootState) => state.UserSession);\r\n const { handleGetRequest } = useAxios();\r\n const isMobile = useIsMobile();\r\n const dispatch = useDispatch();\r\n const handleLogout = async () => {\r\n try {\r\n await handleGetRequest({ endPointURI: \"api/auth/logout\" });\r\n } catch (error) {\r\n console.log(\"logout error\", error);\r\n }\r\n dispatch(UserSessionActions.setUnAuthenticated());\r\n };\r\n const toggleSideBar = () => {\r\n dispatch(AppLayoutActions.toggleSideBarState());\r\n };\r\n return (\r\n <AppBar position=\"fixed\" open={AppLayout.sideBarOpened}>\r\n <Toolbar>\r\n <IconButton\r\n color=\"inherit\"\r\n aria-label=\"open drawer\"\r\n onClick={toggleSideBar}\r\n edge=\"start\"\r\n sx={[\r\n {\r\n mr: AppLayout.appDirection === \"ltr\" ? 2 : undefined,\r\n ml: AppLayout.appDirection === \"rtl\" ? 2 : undefined,\r\n },\r\n AppLayout.sideBarOpened && { display: \"none\" },\r\n ]}\r\n >\r\n <FontAwesomeIcon icon=\"bars\" />\r\n </IconButton>\r\n <Avatar src={AppInfo.appLogo} sx={{ marginRight: 1, marginLeft: 1 }} />\r\n <Typography variant=\"h6\" noWrap component=\"div\" sx={{ flex: 1 }}>\r\n {isMobile ? \"\" : AppInfo.appName}\r\n </Typography>\r\n <IconButton\r\n color=\"inherit\"\r\n onClick={() => {\r\n dispatch(\r\n AppLayoutActions.setThemeMode(\r\n AppLayout.themeMode === \"light\" ? \"dark\" : \"light\"\r\n )\r\n );\r\n localStorage.setItem(\r\n \"themeMode\",\r\n AppLayout.themeMode === \"light\" ? \"dark\" : \"light\"\r\n );\r\n }}\r\n >\r\n {AppLayout.themeMode === \"light\" ? (\r\n <FontAwesomeIcon icon=\"moon\" />\r\n ) : (\r\n <FontAwesomeIcon icon={{ prefix: \"far\", iconName: \"sun\" }} />\r\n )}\r\n </IconButton>\r\n <IconButton\r\n color=\"inherit\"\r\n onClick={() => {\r\n let nextLanguage = i18n.language === \"ar\" ? \"en\" : \"ar\";\r\n changeLanguage(nextLanguage);\r\n dispatch(\r\n AppLayoutActions.setAppDirection(\r\n nextLanguage === \"ar\" ? \"rtl\" : \"ltr\"\r\n )\r\n );\r\n }}\r\n >\r\n <FontAwesomeIcon icon=\"language\" />\r\n </IconButton>\r\n <Avatar />\r\n <div style={{ marginLeft: 5, marginRight: 5 }}>\r\n {isMobile ? \"\" : UserSession.value?.userProfile?.username}\r\n </div>\r\n <IconButton color=\"inherit\" onClick={handleLogout}>\r\n <FontAwesomeIcon\r\n rotation={AppLayout.appDirection === \"rtl\" ? 180 : undefined}\r\n icon=\"arrow-right-from-bracket\"\r\n />\r\n </IconButton>\r\n </Toolbar>\r\n </AppBar>\r\n );\r\n};\r\n\r\nexport default TopBar;\r\n","import { styled } from \"@mui/material\";\r\n\r\nexport const DrawerHeader = styled(\"div\")(({ theme }) => ({\r\n display: \"flex\",\r\n alignItems: \"center\", \r\n // padding: theme.spacing(0, 1),\r\n // necessary for content to be below app bar\r\n ...theme.mixins.toolbar,\r\n justifyContent: \"flex-end\",\r\n}));\r\n","function r(e){var t,f,n=\"\";if(\"string\"==typeof e||\"number\"==typeof e)n+=e;else if(\"object\"==typeof e)if(Array.isArray(e)){var o=e.length;for(t=0;t<o;t++)e[t]&&(f=r(e[t]))&&(n&&(n+=\" \"),n+=f)}else for(f in e)e[f]&&(n&&(n+=\" \"),n+=f);return n}export function clsx(){for(var e,t,f=0,n=\"\",o=arguments.length;f<o;f++)(e=arguments[f])&&(t=r(e))&&(n&&(n+=\" \"),n+=t);return n}export default clsx;","import { useSelector } from \"react-redux\";\r\nimport { RootState } from \"../redux/store\";\r\n\r\n\r\nconst useSession = () => {\r\n const UserSession = useSelector((state: RootState) => state.UserSession);\r\n const isUserAuthorized = (authorityCode: string): boolean => {\r\n if (UserSession?.value?.authorities) {\r\n // if (UserSession.value.authorities.includes(\"DEVELOPMENT_ADMIN\")) {\r\n // return true;\r\n // }\r\n for (let grantedAuthority of UserSession.value.authorities) {\r\n if (\r\n grantedAuthority?.authority === \"DEVELOPMENT_ADMIN\" ||\r\n grantedAuthority?.authority === authorityCode\r\n ) {\r\n return true;\r\n }\r\n }\r\n }\r\n return false;\r\n };\r\n return { UserSession, isUserAuthorized };\r\n};\r\n\r\nexport default useSession;\r\n","import { TreeViewBaseItem } from \"@mui/x-tree-view/models\";\r\nimport { AdministrationItems } from \"./Administration\";\r\nimport { IconProp } from \"@fortawesome/fontawesome-svg-core\";\r\n\r\nexport type ExtendedTreeItemProps = {\r\n icon: IconProp;\r\n id: string;\r\n label: string;\r\n action?: \"NAVIGATION\";\r\n authority?: string;\r\n actionPayload?: {\r\n path?: string;\r\n parameters?: object;\r\n };\r\n children?: ExtendedTreeItemProps[];\r\n};\r\n\r\nexport const findNavigationItemById = (\r\n id: string,\r\n nodes: ExtendedTreeItemProps[]\r\n): ExtendedTreeItemProps | undefined => {\r\n for (const node of nodes) {\r\n if (node.id === id) return node;\r\n if (node.children) {\r\n const found = findNavigationItemById(id, node.children);\r\n if (found) return found;\r\n }\r\n }\r\n return undefined;\r\n};\r\n\r\nexport const NavigationItems: TreeViewBaseItem<ExtendedTreeItemProps>[] = [\r\n ...AdministrationItems, \r\n];\r\n","import { TreeViewBaseItem } from \"@mui/x-tree-view/models\";\r\nimport { ExtendedTreeItemProps } from \"..\";\r\nimport { adminNavigationItems } from \"./adminNavigationItems\";\r\n\r\nexport const AdministrationItems: TreeViewBaseItem<ExtendedTreeItemProps>[] = [\r\n ...adminNavigationItems\r\n// {\r\n// id: \"1\",\r\n// label: \"System Administration\",\r\n// icon: \"gears\",\r\n// authority: \"DEVELOPMENT_ADMIN\",\r\n// children: [\r\n// {\r\n// id: \"1.1\",\r\n// label: \"Security\",\r\n// icon: \"shield\",\r\n// action: \"NAVIGATION\",\r\n// actionPayload: { path: \"Security\" },\r\n// children: [\r\n// {\r\n// id: \"1.1.1\",\r\n// label: \"Roles\",\r\n// icon: \"tag\",\r\n// action: \"NAVIGATION\",\r\n// actionPayload: { path: \"admin/security/roles\" },\r\n// },\r\n// {\r\n// id: \"1.1.2\",\r\n// label: \"Authorities\",\r\n// icon: \"key\",\r\n// action: \"NAVIGATION\",\r\n// actionPayload: { path: \"admin/security/authorities\" },\r\n// children: [],\r\n// },\r\n// ],\r\n// },\r\n// {\r\n// id: \"1.2\",\r\n// label: \"Development Tools\",\r\n// icon: \"code\",\r\n// authority: \"DEVELOPMENT_ADMIN\",\r\n// children: [\r\n// {\r\n// id: \"1.2.1\",\r\n// label: \"Datasources\",\r\n// icon: \"database\",\r\n// authority: \"DEVELOPMENT_ADMIN\",\r\n// action: \"NAVIGATION\",\r\n// actionPayload: { path: \"admin/datasources\" },\r\n// },\r\n// {\r\n// id: \"1.2.2\",\r\n// label: \"Parameters\",\r\n// icon: \"p\",\r\n// authority: \"DEVELOPMENT_ADMIN\",\r\n// action: \"NAVIGATION\",\r\n// actionPayload: { path: \"admin/parameters\" },\r\n// },\r\n// {\r\n// id: \"1.2.3\",\r\n// label: \"System Queries\",\r\n// icon: \"file-code\",\r\n// authority: \"DEVELOPMENT_ADMIN\",\r\n// action: \"NAVIGATION\",\r\n// actionPayload: { path: \"admin/queries\" },\r\n// },\r\n// ],\r\n// },\r\n// ],\r\n// },\r\n];\r\n","import { TreeViewBaseItem } from \"@mui/x-tree-view/models\";\r\nimport { ExtendedTreeItemProps } from \"..\";\r\n\r\nexport const adminNavigationItems: TreeViewBaseItem<ExtendedTreeItemProps>[] = [\r\n {\r\n id: \"admin\",\r\n label: \"SYSTEM_ADMINISTRATION\",\r\n authority: \"DEVELOPMENT_ADMIN\",\r\n icon: \"cogs\",\r\n children: [\r\n {\r\n id: \"admin.systemManagement\",\r\n label: \"SYSTEM_MANAGEMENT\",\r\n icon: \"gear\",\r\n children: [\r\n {\r\n id: \"admin.systemManagement.Organization\",\r\n label: \"ORGANIZATION_PLURAL\",\r\n icon: \"globe\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/organizations\" },\r\n },\r\n {\r\n id: \"admin.systemManagement.OrganizationApplication\",\r\n label: \"ORGANIZATION_APPLICATION_PLURAL\",\r\n icon: \"diagram-project\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/organizationapplications\" },\r\n },\r\n ],\r\n },\r\n {\r\n id: \"admin.security\",\r\n label: \"SECURITY_ADMINISTRATION\",\r\n icon: \"shield\",\r\n children: [\r\n {\r\n id: \"admin.security.Authority\",\r\n label: \"AUTHORITY_PLURAL\",\r\n icon: \"key\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/authorities\" },\r\n },\r\n {\r\n id: \"admin.Role\",\r\n label: \"ROLE_PLURAL\",\r\n icon: \"tag\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/roles\" },\r\n },\r\n {\r\n id: \"admin.security.Employee\",\r\n label: \"EMPLOYEE_PLURAL\",\r\n icon: \"user\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/employees\" },\r\n },\r\n ],\r\n },\r\n {\r\n id: \"admin.devtools\",\r\n label: \"DEVELOPMENT_TOOLS\",\r\n icon: \"code\",\r\n children: [\r\n {\r\n id: \"admin.devtools.DatasourceConnection\",\r\n label: \"DATASOURCE_CONNECTION_PLURAL\",\r\n icon: \"plug\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/datasourceconnections\" },\r\n },\r\n {\r\n id: \"admin.devtools.EntityParameter\",\r\n label: \"ENTITY_PARAMETER_PLURAL\",\r\n icon: \"p\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/entityparameters\" },\r\n },\r\n {\r\n id: \"admin.devtools.DataQuery\",\r\n label: \"DATA_QUERY_PLURAL\",\r\n icon: \"file-code\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/dataqueries\" },\r\n },\r\n {\r\n id: \"admin.devtools.ExcelUploaderHeader\",\r\n label: \"EXCEL_UPLOADER_HEADER_PLURAL\",\r\n icon: \"file-excel\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/exceluploaderheaders\" },\r\n },\r\n {\r\n id: \"admin.devtools.Report\",\r\n label: \"REPORT_PLURAL\",\r\n icon: \"file\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/reports\" },\r\n },\r\n {\r\n id: \"admin.devtools.WorkflowDocument\",\r\n label: \"WORKFLOW_DOCUMENT_PLURAL\",\r\n icon: \"chart-diagram\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/workflowdocuments\" },\r\n },\r\n {\r\n id: \"admin.devtools.BluePrint\",\r\n label: \"BLUE_PRINT_PLURAL\",\r\n icon: \"fingerprint\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/blueprints\" },\r\n },\r\n {\r\n id: \"admin.devtools.Widget\",\r\n label: \"WIDGET_PLURAL\",\r\n icon: \"chart-pie\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/widgets\" },\r\n },\r\n {\r\n id: \"admin.devtools.Dashboard\",\r\n label: \"DASHBOARD_PLURAL\",\r\n icon: \"square-poll-vertical\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/dashboards\" },\r\n },\r\n {\r\n id: \"admin.devtools.MailTemplate\",\r\n label: \"MAIL_TEMPLATE_PLURAL\",\r\n icon: \"envelope\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/mailtemplates\" },\r\n },\r\n {\r\n id: \"admin.devtools.Notification\",\r\n label: \"NOTIFICATION_PLURAL\",\r\n icon: \"bell\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/notifications\" },\r\n },\r\n ],\r\n },\r\n {\r\n id: \"admin.followup\",\r\n label: \"SYSTEM_MONITORING\",\r\n icon: \"tv\",\r\n children: [\r\n {\r\n id: \"admin.WorkflowDocumentMailLog\",\r\n label: \"WORKFLOW_DOCUMENT_MAIL_LOG_PLURAL\",\r\n icon: \"envelopes-bulk\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/workflowdocumentmaillogs\" },\r\n },\r\n {\r\n id: \"admin.MailNotificationQueue\",\r\n label: \"MAIL_NOTIFICATION_QUEUE_PLURAL\",\r\n icon: \"envelope-open-text\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/mailnotificationqueues\" },\r\n },\r\n {\r\n id: \"admin.NotificationQueue\",\r\n label: \"NOTIFICATION_QUEUE_PLURAL\",\r\n icon: \"bell\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/notificationqueues\" },\r\n },\r\n ],\r\n },\r\n\r\n {\r\n id: \"admin.Lookup\",\r\n label: \"LOOKUP_PLURAL\",\r\n icon: \"list-check\",\r\n action: \"NAVIGATION\",\r\n actionPayload: { path: \"admin/lookups\" },\r\n },\r\n ],\r\n },\r\n];\r\n","import * as React from \"react\";\r\nimport clsx from \"clsx\";\r\nimport { animated, useSpring } from \"@react-spring/web\";\r\nimport { styled, alpha } from \"@mui/material/styles\";\r\nimport { TransitionProps } from \"@mui/material/transitions\";\r\nimport Box from \"@mui/material/Box\";\r\nimport Collapse from \"@mui/material/Collapse\";\r\nimport Typography from \"@mui/material/Typography\";\r\nimport { RichTreeView } from \"@mui/x-tree-view/RichTreeView\";\r\nimport { treeItemClasses } from \"@mui/x-tree-view/TreeItem\";\r\nimport {\r\n useTreeItem2,\r\n UseTreeItem2Parameters,\r\n} from \"@mui/x-tree-view/useTreeItem2\";\r\nimport {\r\n TreeItem2Checkbox,\r\n TreeItem2Content,\r\n TreeItem2IconContainer,\r\n TreeItem2Label,\r\n TreeItem2Root,\r\n} from \"@mui/x-tree-view/TreeItem2\";\r\nimport { TreeItem2Icon } from \"@mui/x-tree-view/TreeItem2Icon\";\r\nimport { TreeItem2Provider } from \"@mui/x-tree-view/TreeItem2Provider\";\r\nimport { TreeItem2DragAndDropOverlay } from \"@mui/x-tree-view/TreeItem2DragAndDropOverlay\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport { useNavigate } from \"react-router-dom\";\r\nimport { useTranslation } from \"react-i18next\";\r\nimport { useDispatch, useSelector } from \"react-redux\";\r\nimport { RootState } from \"../redux/store\";\r\nimport { IconProp } from \"@fortawesome/fontawesome-svg-core\";\r\nimport { useIsMobile } from \"../hooks/UseMobile\";\r\nimport useSession from \"../hooks/UseSession\";\r\nimport { findNavigationItemById, NavigationItems } from \"../navigationItems\";\r\nimport { DRAWER_WIDTH } from \"../redux/features/common/AppLayoutSlice\";\r\n\r\nfunction DotIcon() {\r\n return (\r\n <Box\r\n sx={{\r\n width: 6,\r\n height: 6,\r\n borderRadius: \"70%\",\r\n bgcolor: \"warning.main\",\r\n display: \"inline-block\",\r\n verticalAlign: \"middle\",\r\n zIndex: 1,\r\n mx: 1,\r\n }}\r\n />\r\n );\r\n}\r\ndeclare module \"react\" {\r\n interface CSSProperties {\r\n \"--tree-view-color\"?: string;\r\n \"--tree-view-bg-color\"?: string;\r\n }\r\n}\r\n\r\nconst StyledTreeItemRoot = styled(TreeItem2Root)(({ theme }) => ({\r\n color: theme.palette.grey[400],\r\n position: \"relative\",\r\n [`& .${treeItemClasses.groupTransition}`]: {\r\n marginLeft: theme.spacing(2.5),\r\n },\r\n ...theme.applyStyles(\"light\", {\r\n color: theme.palette.grey[800],\r\n }),\r\n})) as unknown as typeof TreeItem2Root;\r\n\r\nconst CustomTreeItemContent = styled(TreeItem2Content)(({ theme }) => ({\r\n flexDirection: \"row-reverse\",\r\n borderRadius: theme.spacing(0.7),\r\n marginBottom: theme.spacing(0.5),\r\n marginTop: theme.spacing(0.5),\r\n padding: theme.spacing(0.5),\r\n paddingRight: theme.spacing(1),\r\n [`&.Mui-expanded `]: {\r\n \"&:not(.Mui-focused, .Mui-selected, .Mui-selected.Mui-focused) .labelIcon\":\r\n {\r\n color: theme.palette.primary.dark,\r\n ...theme.applyStyles(\"light\", {\r\n color: theme.palette.primary.main,\r\n }),\r\n },\r\n \"&::before\": {\r\n content: '\"\"',\r\n display: \"block\",\r\n position: \"absolute\",\r\n left: \"16px\",\r\n top: \"44px\",\r\n height: \"calc(100% - 48px)\",\r\n width: \"1.5px\",\r\n backgroundColor: theme.palette.grey[700],\r\n ...theme.applyStyles(\"light\", {\r\n backgroundColor: theme.palette.grey[300],\r\n }),\r\n },\r\n },\r\n \"&:hover\": {\r\n backgroundColor: alpha(theme.palette.primary.main, 0.1),\r\n color: \"white\",\r\n ...theme.applyStyles(\"light\", {\r\n color: theme.palette.primary.main,\r\n }),\r\n },\r\n [`&.Mui-focused, &.Mui-selected, &.Mui-selected.Mui-focused`]: {\r\n backgroundColor: theme.palette.primary.dark,\r\n color: theme.palette.primary.contrastText,\r\n ...theme.applyStyles(\"light\", {\r\n backgroundColor: theme.palette.primary.main,\r\n }),\r\n },\r\n}));\r\n\r\nconst AnimatedCollapse = animated(Collapse);\r\n\r\nfunction TransitionComponent(props: TransitionProps) {\r\n const style = useSpring({\r\n to: {\r\n opacity: props.in ? 1 : 0,\r\n transform: `translate3d(0,${props.in ? 0 : 20}px,0)`,\r\n },\r\n });\r\n\r\n return <AnimatedCollapse style={style} {...props} />;\r\n}\r\n\r\nconst StyledTreeItemLabelText = styled(Typography)({\r\n color: \"inherit\",\r\n fontWeight: 500,\r\n}) as unknown as typeof Typography;\r\n\r\ninterface CustomLabelProps {\r\n children: any;\r\n icon: IconProp;\r\n expandable?: boolean;\r\n}\r\n\r\nfunction CustomLabel({\r\n icon,\r\n expandable,\r\n children,\r\n ...other\r\n}: CustomLabelProps) {\r\n const { t } = useTranslation();\r\n const appLayoutState = useSelector((state: RootState) => state.AppLayout);\r\n return (\r\n <TreeItem2Label\r\n {...other}\r\n sx={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n padding: 1,\r\n }}\r\n >\r\n <FontAwesomeIcon\r\n style={{\r\n marginRight: appLayoutState.appDirection === \"ltr\" ? 7 : undefined,\r\n marginLeft: appLayoutState.appDirection === \"rtl\" ? 7 : undefined,\r\n fontSize: \"1.2rem\",\r\n }}\r\n icon={icon}\r\n />\r\n <StyledTreeItemLabelText variant=\"body2\" sx={{ fontSize: 16 }}>\r\n {t(children)}\r\n </StyledTreeItemLabelText>\r\n {expandable && <DotIcon />}\r\n </TreeItem2Label>\r\n );\r\n}\r\n\r\nconst isExpandable = (reactChildren: React.ReactNode) => {\r\n if (Array.isArray(reactChildren)) {\r\n return reactChildren.length > 0 && reactChildren.some(isExpandable);\r\n }\r\n return Boolean(reactChildren);\r\n};\r\n\r\ninterface CustomTreeItemProps\r\n extends Omit<UseTreeItem2Parameters, \"rootRef\">,\r\n Omit<React.HTMLAttributes<HTMLLIElement>, \"onFocus\"> {}\r\n\r\nconst CustomTreeItem = React.forwardRef(function CustomTreeItem(\r\n props: CustomTreeItemProps,\r\n ref: React.Ref<HTMLLIElement>\r\n) {\r\n const { id, itemId, label, disabled, children, ...other } = props;\r\n const {\r\n getRootProps,\r\n getContentProps,\r\n getIconContainerProps,\r\n getCheckboxProps,\r\n getLabelProps,\r\n getGroupTransitionProps,\r\n getDragAndDropOverlayProps,\r\n status,\r\n publicAPI,\r\n } = useTreeItem2({ id, itemId, children, label, disabled, rootRef: ref });\r\n const item = publicAPI.getItem(itemId);\r\n const expandable = isExpandable(children);\r\n return (\r\n <TreeItem2Provider itemId={itemId}>\r\n <StyledTreeItemRoot {...getRootProps(other)}>\r\n <CustomTreeItemContent\r\n {...getContentProps({\r\n className: clsx(\"content\", {\r\n \"Mui-expanded\": status.expanded,\r\n \"Mui-selected\": status.selected,\r\n \"Mui-focused\": status.focused,\r\n \"Mui-disabled\": status.disabled,\r\n }),\r\n })}\r\n >\r\n <TreeItem2IconContainer {...getIconContainerProps()}>\r\n <TreeItem2Icon status={status} />\r\n </TreeItem2IconContainer>\r\n <TreeItem2Checkbox {...getCheckboxProps()} />\r\n <CustomLabel\r\n {...getLabelProps({\r\n icon: item?.icon || \"book\",\r\n expandable: expandable && status.expanded,\r\n })}\r\n />\r\n <TreeItem2DragAndDropOverlay {...getDragAndDropOverlayProps()} />\r\n </CustomTreeItemContent>\r\n {children && <TransitionComponent {...getGroupTransitionProps()} />}\r\n </StyledTreeItemRoot>\r\n </TreeItem2Provider>\r\n );\r\n});\r\n\r\nexport default function NavigationTree() {\r\n const navigate = useNavigate();\r\n const appLayoutState = useSelector((state: RootState) => state.AppLayout);\r\n const AppInfo = useSelector((state: RootState) => state.AppInfo.value);\r\n const dispatch = useDispatch();\r\n const isMobile = useIsMobile();\r\n const { isUserAuthorized } = useSession();\r\n const filterData = (data) => {\r\n return data\r\n .filter(\r\n (item: any) =>\r\n item.authority === undefined ||\r\n item.authority == null ||\r\n isUserAuthorized(item.authority)\r\n )\r\n .map((item: any) => {\r\n if (item.children) {\r\n item.children = filterData(item.children);\r\n }\r\n return item;\r\n });\r\n };\r\n\r\n const mergedNavigationItems = [];\r\n if (AppInfo.enableAdministrationModule) {\r\n mergedNavigationItems.push(...NavigationItems);\r\n }\r\n mergedNavigationItems.push(...AppInfo.businessNavigationItems);\r\n const authoriedNavigationItems = filterData(mergedNavigationItems);\r\n\r\n return (\r\n <RichTreeView\r\n items={authoriedNavigationItems}\r\n onItemClick={(event, itemId) => {\r\n const navigationItem = findNavigationItemById(\r\n itemId,\r\n mergedNavigationItems\r\n );\r\n if (\r\n navigationItem?.action === \"NAVIGATION\" &&\r\n navigationItem?.actionPayload != null &&\r\n (navigationItem.children === undefined ||\r\n navigationItem.children === null ||\r\n navigationItem.children.length == 0)\r\n ) {\r\n navigate(navigationItem?.actionPayload?.path || \"\");\r\n // dispatch(AppLayoutActions.toggleSideBarState());\r\n }\r\n }}\r\n sx={{\r\n height: \"fit-content\",\r\n flexGrow: 1,\r\n maxWidth: DRAWER_WIDTH,\r\n direction: appLayoutState.appDirection,\r\n maxHeight: isMobile ? 300 : undefined,\r\n overflowY: \"auto\",\r\n overflowX: \"auto\",\r\n }}\r\n slots={{ item: CustomTreeItem }}\r\n />\r\n );\r\n}\r\n","import Divider from \"@mui/material/Divider\";\r\nimport IconButton from \"@mui/material/IconButton\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport Drawer from \"@mui/material/Drawer\";\r\nimport { useDispatch, useSelector } from \"react-redux\";\r\nimport { DrawerHeader } from \"./DrawerHeader\";\r\nimport { Box, Typography, useTheme } from \"@mui/material\";\r\nimport { RootState } from \"../redux/store\";\r\nimport {\r\n AppLayoutActions,\r\n DRAWER_WIDTH,\r\n} from \"../redux/features/common/AppLayoutSlice\";\r\nimport NavigationTree from \"./NavigationTree\";\r\n\r\nconst SideBar: React.FC = () => {\r\n const AppInfo = useSelector((state: RootState) => state.AppInfo.value);\r\n const theme = useTheme();\r\n const AppLayout = useSelector((state: RootState) => state.AppLayout);\r\n const dispatch = useDispatch();\r\n const toggleSideBar = () => {\r\n dispatch(AppLayoutActions.toggleSideBarState());\r\n };\r\n return (\r\n <Drawer\r\n sx={{\r\n width: DRAWER_WIDTH,\r\n flexShrink: 0,\r\n \"& .MuiDrawer-paper\": {\r\n width: DRAWER_WIDTH,\r\n boxSizing: \"border-box\",\r\n },\r\n }}\r\n variant=\"persistent\"\r\n anchor={AppLayout.appDirection === \"ltr\" ? \"left\" : \"right\"}\r\n open={AppLayout.sideBarOpened}\r\n >\r\n <DrawerHeader>\r\n <Box sx={{ width: \"100%\" }}>\r\n <Typography\r\n color=\"primary\"\r\n sx={{\r\n width: \"100%\",\r\n textAlign: \"center\",\r\n fontSize: 18,\r\n fontWeight: \"bold\",\r\n }}\r\n >\r\n System Content\r\n </Typography>\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"space-around\",\r\n marginTop: 1,\r\n }}\r\n >\r\n <Typography sx={{ fontSize: 12 }} color=\"textDisabled\">\r\n {AppInfo.appName}\r\n </Typography>\r\n <Typography sx={{ fontSize: 12 }} color=\"textDisabled\">\r\n V.{AppInfo.appVersion}\r\n </Typography>\r\n </Box>\r\n </Box>\r\n <IconButton onClick={toggleSideBar}>\r\n {theme.direction === \"ltr\" ? (\r\n <FontAwesomeIcon icon=\"angle-left\" />\r\n ) : (\r\n <FontAwesomeIcon icon=\"angle-right\" />\r\n )}\r\n </IconButton>\r\n </DrawerHeader>\r\n <Divider />\r\n <NavigationTree />\r\n </Drawer>\r\n );\r\n};\r\n\r\nexport default SideBar;\r\n","import rtlPlugin from \"stylis-plugin-rtl\";\r\nimport { prefixer } from \"stylis\";\r\nimport createCache from \"@emotion/cache\";\r\n\r\nexport const cacheRtl = createCache({\r\n key: \"muirtl\",\r\n stylisPlugins: [prefixer, rtlPlugin],\r\n});\r\n\r\nexport const cacheLtr = createCache({\r\n key: \"mui\",\r\n});","import {\r\n Button,\r\n Dialog,\r\n DialogActions,\r\n DialogContent,\r\n DialogContentText,\r\n DialogTitle,\r\n} from \"@mui/material\";\r\nimport { useState } from \"react\";\r\nimport { useTranslation } from \"react-i18next\";\r\n\r\ninterface ConfirmationWindowProps {\r\n title: string;\r\n body: string;\r\n onConfirmationCallBk: () => void;\r\n}\r\n\r\nexport const useConfirmationWindow = (props: ConfirmationWindowProps) => {\r\n const [open, setOpen] = useState<boolean>(false);\r\n const { t } = useTranslation();\r\n const ConfirmationWindow: React.FC = () => {\r\n return (\r\n <Dialog open={open}>\r\n <DialogTitle>{props.title}</DialogTitle>\r\n <DialogContent>\r\n <DialogContentText>{props.body}</DialogContentText>\r\n </DialogContent>\r\n <DialogActions>\r\n <Button\r\n variant=\"contained\"\r\n color=\"primary\"\r\n onClick={() => {\r\n setOpen(false);\r\n }}\r\n >\r\n {t(\"NO_LABEL\")}\r\n </Button>\r\n <Button\r\n variant=\"contained\"\r\n color=\"error\"\r\n onClick={() => {\r\n props.onConfirmationCallBk();\r\n setOpen(false);\r\n }}\r\n autoFocus\r\n >\r\n {t(\"YES_LABEL\")}\r\n </Button>\r\n </DialogActions>\r\n </Dialog>\r\n );\r\n };\r\n return { ConfirmationWindow, open, setOpen };\r\n};\r\n","import { Button } from \"@mui/material\";\r\nimport { RecordAction } from \"../DataEntryTypes\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport { toast } from \"react-toastify\";\r\nimport { useTranslation } from \"react-i18next\";\r\nimport useSession from \"../../../../hooks/UseSession\";\r\nimport { useConfirmationWindow } from \"../../../../hooks/UseConfirmationWindow\";\r\n\r\nconst TemplateGridMultiRecordAction: React.FC<RecordAction> = (\r\n rowAction: RecordAction\r\n) => {\r\n const { t } = useTranslation();\r\n const session = useSession();\r\n const { ConfirmationWindow, setOpen } = useConfirmationWindow({\r\n body: t(rowAction?.confirmationMessage || \"ACTION_CONFIRMATION\"),\r\n title: t(\"CONFIRMATION\"),\r\n onConfirmationCallBk: async () => {\r\n await rowAction?.actionFn(\r\n rowAction.recordsToProcessActionOn,\r\n rowAction.recordIdsToProcessActionOn\r\n );\r\n if (rowAction?.reloadData) {\r\n rowAction.reloadData();\r\n }\r\n },\r\n });\r\n let isActionAllowed = true;\r\n if (rowAction.authority) {\r\n isActionAllowed = session.isUserAuthorized(rowAction.authority);\r\n }\r\n\r\n if (isActionAllowed) {\r\n return (\r\n <>\r\n <ConfirmationWindow />\r\n <Button\r\n onClick={async () => {\r\n if (\r\n rowAction?.recordsToProcessActionOn &&\r\n rowAction?.recordsToProcessActionOn.length > 0\r\n ) {\r\n if (rowAction?.preActionValidation) {\r\n for (const record of rowAction.recordsToProcessActionOn) {\r\n if (!rowAction.preActionValidation(record)) {\r\n return;\r\n }\r\n }\r\n }\r\n if (rowAction?.isConfirmationRequired === true) {\r\n setOpen(true);\r\n } else {\r\n await rowAction.actionFn(\r\n rowAction.recordsToProcessActionOn,\r\n rowAction.recordIdsToProcessActionOn\r\n );\r\n if (rowAction?.reloadData) {\r\n rowAction.reloadData();\r\n }\r\n }\r\n } else {\r\n toast.error(t(\"AT_LEAST_ONE_RECORD_SELECTED_MESSAGE\"));\r\n }\r\n }}\r\n variant={\r\n rowAction?.label\r\n ? \"outlined\"\r\n : rowAction?.formActionProps?.actionButtonVariant\r\n ? rowAction.formActionProps.actionButtonVariant\r\n : \"text\"\r\n }\r\n size=\"small\"\r\n color={rowAction?.formActionProps?.actionButtonColor || \"primary\"}\r\n >\r\n {rowAction?.icon ? (\r\n <FontAwesomeIcon\r\n style={{ marginRight: 5, marginLeft: 5 }}\r\n icon={rowAction.icon}\r\n />\r\n ) : (\r\n <></>\r\n )}\r\n {rowAction?.label ? t(rowAction.label) : <></>}\r\n </Button>\r\n </>\r\n );\r\n }\r\n};\r\n\r\nexport default TemplateGridMultiRecordAction;\r\n","export const DATE_FORMAT = \"YYYY-MM-DD\";\r\nexport const DATE_TIME_FORMAT = \"YYYY-MM-DD HH:mm:ss\";\r\nexport const LIGHT_THEME_INITIAL_MAIN_COLOR = \"#37505C\";\r\nexport const LIGHT_THEME_INITIAL_SECANDARY_COLOR = \"#ff6d00\";\r\nexport const DARK_THEME_INITIAL_MAIN_COLOR = \"#ea690e\";\r\nexport const DARK_THEME_INITIAL_SECANDARY_COLOR = \"#74776B\";\r\n","import { DatePicker, LocalizationProvider } from \"@mui/x-date-pickers\";\r\nimport { AdapterMoment } from \"@mui/x-date-pickers/AdapterMoment\";\r\nimport moment from \"moment\";\r\nimport { DATE_FORMAT } from \"../../../../../util/constants\";\r\nimport { useTranslation } from \"react-i18next\";\r\n\r\ninterface DatefieldProps {\r\n value: string | null;\r\n label: string;\r\n disabled?: boolean;\r\n required?: boolean;\r\n sx?: any;\r\n format?: string;\r\n errorMessage?: any;\r\n onChangeCallBack: Function;\r\n [x: string | number | symbol]: unknown;\r\n}\r\n\r\nconst Datefield: React.FC<DatefieldProps> = (props) => {\r\n const { t } = useTranslation();\r\n return (\r\n <LocalizationProvider dateAdapter={AdapterMoment}>\r\n <DatePicker\r\n value={\r\n props.value != null && props.value !== undefined && props.value !== \"\"\r\n ? moment(props.value, props?.format || DATE_FORMAT)\r\n : null\r\n }\r\n sx={props.sx}\r\n label={t(props.label)}\r\n format={props?.format || DATE_FORMAT}\r\n disabled={props.disabled}\r\n onChange={(momentValue) => {\r\n let v = null;\r\n if (momentValue != null && momentValue.isValid()) {\r\n v = momentValue.format(props?.format || DATE_FORMAT);\r\n }\r\n if (\r\n props.onChangeCallBack !== undefined &&\r\n props.onChangeCallBack != null\r\n ) {\r\n props.onChangeCallBack(v);\r\n }\r\n }}\r\n slotProps={{\r\n textField: {\r\n InputLabelProps: { shrink: true },\r\n variant: \"outlined\",\r\n required: props.required,\r\n error:\r\n props.errorMessage !== undefined && props.errorMessage != null,\r\n helperText:\r\n props.errorMessage !== undefined && props.errorMessage != null ? (\r\n <>{t(props.errorMessage)}</>\r\n ) : (\r\n <></>\r\n ),\r\n },\r\n }}\r\n />\r\n </LocalizationProvider>\r\n );\r\n};\r\n\r\nexport default Datefield;\r\n","import { DateTimePicker, LocalizationProvider } from \"@mui/x-date-pickers\";\r\nimport { AdapterMoment } from \"@mui/x-date-pickers/AdapterMoment\";\r\nimport moment from \"moment\";\r\nimport { useTranslation } from \"react-i18next\";\r\nimport { DATE_TIME_FORMAT } from \"../../../../../util/constants\";\r\n\r\ninterface DatetimeFieldProps {\r\n value: string | null;\r\n label: string;\r\n disabled?: boolean;\r\n required?: boolean;\r\n format?: string;\r\n sx?: any;\r\n errorMessage?: any;\r\n onChangeCallBack: Function;\r\n [x: string | number | symbol]: unknown;\r\n}\r\n\r\nconst DatetimeField: React.FC<DatetimeFieldProps> = (props) => {\r\n const { t } = useTranslation();\r\n return (\r\n <LocalizationProvider dateAdapter={AdapterMoment}>\r\n <DateTimePicker\r\n value={\r\n props.value != null && props.value !== undefined && props.value !== \"\"\r\n ? moment(props.value, props?.format || DATE_TIME_FORMAT)\r\n : null\r\n }\r\n label={t(props.label)}\r\n sx={props.sx}\r\n format={props?.format || DATE_TIME_FORMAT}\r\n disabled={props.disabled}\r\n onChange={(momentValue) => {\r\n let v = null;\r\n if (momentValue != null && momentValue.isValid()) {\r\n v = momentValue.format(props?.format || DATE_TIME_FORMAT);\r\n }\r\n if (\r\n props.onChangeCallBack !== undefined &&\r\n props.onChangeCallBack != null\r\n ) {\r\n props.onChangeCallBack(v);\r\n }\r\n }}\r\n slotProps={{\r\n textField: {\r\n variant: \"outlined\",\r\n required: props.required,\r\n error:\r\n props.errorMessage !== undefined && props.errorMessage != null,\r\n helperText:\r\n props.errorMessage !== undefined && props.errorMessage != null ? (\r\n <>{t(props.errorMessage)}</>\r\n ) : (\r\n <></>\r\n ),\r\n },\r\n }}\r\n />\r\n </LocalizationProvider>\r\n );\r\n};\r\n\r\nexport default DatetimeField;\r\n","import { useSelector } from \"react-redux\";\r\nimport { RootState } from \"../../../../../redux/store\";\r\nimport { Autocomplete, Popper, TextField } from \"@mui/material\";\r\nimport { useTranslation } from \"react-i18next\";\r\n\r\ninterface ComboBoxProps {\r\n value: any;\r\n onChangeCallBack: Function;\r\n label: string;\r\n disabled?: boolean;\r\n required?: boolean;\r\n options: Array<any>;\r\n errorMessage?: any;\r\n displayField: string;\r\n valueField: string;\r\n sx?: any;\r\n}\r\n\r\nconst ComboBox: React.FC<ComboBoxProps> = (props) => {\r\n const AppLayoutState = useSelector((state: RootState) => state.AppLayout);\r\n const { t } = useTranslation();\r\n const getValue = (v: string) => {\r\n for (let option of props.options) {\r\n if (option[props.valueField] == v) {\r\n return option;\r\n }\r\n }\r\n return null;\r\n };\r\n return (\r\n <Autocomplete\r\n sx={props.sx}\r\n value={getValue(props.value)}\r\n options={props.options}\r\n disabled={props.disabled}\r\n onChange={(event, newValue) => {\r\n if (\r\n props.onChangeCallBack !== undefined &&\r\n props.onChangeCallBack != null\r\n ) {\r\n if (newValue != null) {\r\n let v = newValue[props.valueField];\r\n props.onChangeCallBack(v, newValue);\r\n } else {\r\n props.onChangeCallBack(null, null);\r\n }\r\n }\r\n }}\r\n clearOnBlur\r\n handleHomeEndKeys\r\n getOptionLabel={(option) => {\r\n return option != null ? t(option[props.displayField]) : \"\";\r\n }}\r\n renderOption={(props1, option) => {\r\n return (\r\n <li {...props1}>\r\n {option != null ? t(option[props.displayField]) : \"\"}\r\n </li>\r\n );\r\n }}\r\n slots={{\r\n popper: (props: any) => (\r\n <Popper\r\n {...props}\r\n style={{ ...props.style, direction: AppLayoutState.appDirection }}\r\n />\r\n ),\r\n }}\r\n renderInput={(params) => {\r\n return (\r\n <TextField\r\n {...params}\r\n required={props.required || false}\r\n variant=\"outlined\"\r\n InputLabelProps={{ shrink: true }}\r\n label={t(props.label)}\r\n error={\r\n props.errorMessage != null && props.errorMessage !== undefined\r\n ? true\r\n : false\r\n }\r\n helperText={\r\n props.errorMessage != null && props.errorMessage !== undefined\r\n ? t(props.errorMessage)\r\n : \"\"\r\n }\r\n />\r\n );\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default ComboBox;\r\n","import { Checkbox, FormControlLabel } from \"@mui/material\";\r\nimport { useTranslation } from \"react-i18next\";\r\n\r\ninterface CheckBoxProps {\r\n value: any;\r\n disabled?: boolean;\r\n required?: boolean;\r\n label: string;\r\n checkedValue?: any;\r\n unCheckedValue?: any;\r\n onChangeCallBack: Function;\r\n sx?: any;\r\n}\r\n\r\nconst CheckBox: React.FC<CheckBoxProps> = (props) => {\r\n const { t } = useTranslation();\r\n return (\r\n <FormControlLabel\r\n sx={props.sx}\r\n disabled={props.disabled || false}\r\n required={props.required || false}\r\n control={\r\n <Checkbox\r\n checked={\r\n props?.checkedValue == props.value ||\r\n props.value === \"true\" ||\r\n props.value == \"1\"\r\n ? true\r\n : false\r\n }\r\n onChange={(e) => {\r\n if (\r\n props.onChangeCallBack !== undefined &&\r\n props.onChangeCallBack != null\r\n ) {\r\n if (e.target.checked) {\r\n if (\r\n props.checkedValue !== undefined &&\r\n props.checkedValue != null\r\n ) {\r\n props.onChangeCallBack(props.checkedValue);\r\n } else {\r\n props.onChangeCallBack(\"true\");\r\n }\r\n } else {\r\n if (\r\n props.unCheckedValue !== undefined &&\r\n props.unCheckedValue != null\r\n ) {\r\n props.onChangeCallBack(props.unCheckedValue);\r\n } else {\r\n props.onChangeCallBack(\"false\");\r\n }\r\n }\r\n }\r\n }}\r\n />\r\n }\r\n label={t(props.label)}\r\n />\r\n );\r\n};\r\n\r\nexport default CheckBox;\r\n","import moment from \"moment\";\r\nimport { TemplateGridColDef } from \"../DataEntryTypes\";\r\nimport Datefield from \"../TemplateDataForm/FormFields/Datefield\";\r\nimport { DATE_FORMAT, DATE_TIME_FORMAT } from \"../../../../util/constants\";\r\nimport DatetimeField from \"../TemplateDataForm/FormFields/DatetimeField\";\r\nimport ComboBox from \"../TemplateDataForm/FormFields/ComboBox\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport CheckBox from \"../TemplateDataForm/FormFields/CheckBox\";\r\n\r\nexport const generateDateColumn: any = (colDef: TemplateGridColDef) => {\r\n const column: TemplateGridColDef = {\r\n ...colDef,\r\n type: \"string\",\r\n renderEditCell: (params: any) => {\r\n return (\r\n <Datefield\r\n sx={{ width: \"100%\" }}\r\n label=\"\"\r\n value={params.value}\r\n onChangeCallBack={(v: any) => {\r\n params.api.setEditCellValue({\r\n id: params.id,\r\n field: params.field,\r\n value: v,\r\n });\r\n }}\r\n />\r\n );\r\n },\r\n valueParser: (value: any, row: any, column: any) => {\r\n let v = null;\r\n if (value !== null) {\r\n v = moment(value).format(DATE_FORMAT);\r\n }\r\n return v;\r\n },\r\n valueFormatter: (value: any, row: any, column: any) => {\r\n return row[column.field];\r\n },\r\n };\r\n return column;\r\n};\r\n\r\nexport const generateDateTimeColumn: any = (colDef: TemplateGridColDef) => {\r\n const column: TemplateGridColDef = {\r\n ...colDef,\r\n type: \"string\",\r\n renderEditCell: (params: any) => {\r\n return (\r\n <DatetimeField\r\n sx={{ width: \"100%\" }}\r\n label=\"\"\r\n value={params.value}\r\n onChangeCallBack={(v: any) => {\r\n params.api.setEditCellValue({\r\n id: params.id,\r\n field: params.field,\r\n value: v,\r\n });\r\n }}\r\n />\r\n );\r\n },\r\n valueParser: (value: any, row: any, column: any) => {\r\n let v = null;\r\n if (value !== null) {\r\n v = moment(value).format(DATE_TIME_FORMAT);\r\n }\r\n return v;\r\n },\r\n valueFormatter: (value: any, row: any, column: any) => {\r\n return row[column.field];\r\n },\r\n };\r\n return column;\r\n};\r\n\r\ntype ComboBoxColumnProps = TemplateGridColDef & {\r\n options: Array<any>;\r\n displayField: string;\r\n valueField: string;\r\n};\r\nexport const generateComboColumn: (\r\n props: ComboBoxColumnProps\r\n) => TemplateGridColDef = (colDef: ComboBoxColumnProps) => {\r\n const column: TemplateGridColDef = {\r\n ...colDef,\r\n type: \"custom\",\r\n valueGetter: (value) => {\r\n if (value) {\r\n return value + \"\";\r\n }\r\n return value;\r\n },\r\n renderCell: (parameters: any) => {\r\n let record = null;\r\n try {\r\n record = parameters.colDef.options.find(\r\n (item: any) => item[parameters.colDef.valueField] == parameters.value\r\n );\r\n } catch (e) {}\r\n return (\r\n <div>\r\n {record != null\r\n ? record[parameters.colDef.displayField]\r\n : parameters.value}\r\n </div>\r\n );\r\n },\r\n\r\n renderEditCell: (params: any) => {\r\n return (\r\n <ComboBox\r\n {...params}\r\n sx={{ width: \"100%\" }}\r\n options={colDef.options}\r\n valueField={colDef.valueField}\r\n displayField={colDef.displayField}\r\n onChangeCallBack={(v: any, selectedRecord: any) => {\r\n if (v === null) {\r\n params.api.setEditCellValue({\r\n id: params.id,\r\n field: params.field,\r\n value: null,\r\n });\r\n }\r\n params.api.setEditCellValue({\r\n id: params.id,\r\n field: params.field,\r\n value: v + \"\",\r\n });\r\n }}\r\n />\r\n );\r\n },\r\n };\r\n return column;\r\n};\r\n\r\ntype CheckBoxColumnProps = TemplateGridColDef & {\r\n checkedValue?: string;\r\n unCheckedValue?: string;\r\n};\r\n\r\nexport const generateCheckBoxColumn: (\r\n props: CheckBoxColumnProps\r\n) => TemplateGridColDef = (colDef: CheckBoxColumnProps) => {\r\n return {\r\n ...colDef,\r\n type: \"custom\",\r\n valueGetter: (value) => {\r\n if (value == null || value == undefined) {\r\n return null;\r\n } else {\r\n return value + \"\";\r\n }\r\n },\r\n renderCell: (parameters: any) => {\r\n const value = parameters?.value;\r\n if (\r\n value === colDef.checkedValue ||\r\n value === \"true\" ||\r\n value === 1 ||\r\n value === true\r\n ) {\r\n return <FontAwesomeIcon icon=\"check\" color=\"green\" />;\r\n } else {\r\n return <FontAwesomeIcon icon=\"xmark\" color=\"red\" />;\r\n }\r\n },\r\n renderEditCell: (params: any) => {\r\n return (\r\n <CheckBox\r\n {...params}\r\n checkedValue={colDef?.checkedValue || \"true\"}\r\n unCheckedValue={colDef?.unCheckedValue || \"false\"}\r\n onChangeCallBack={(v: any) => {\r\n params.api.setEditCellValue({\r\n id: params.id,\r\n field: params.field,\r\n value: v + \"\",\r\n });\r\n }}\r\n />\r\n );\r\n },\r\n };\r\n};\r\n","import { GridRowSelectionModel } from \"@mui/x-data-grid-premium\";\r\nimport {\r\n FormElementProps,\r\n RecordFieldProps,\r\n TemplateGridColDef,\r\n} from \"./DataEntryTypes\";\r\nimport {\r\n generateCheckBoxColumn,\r\n generateComboColumn,\r\n generateDateColumn,\r\n generateDateTimeColumn,\r\n} from \"./TemplateDataGrid/DataGridColumnsUtil\";\r\nimport * as z from \"zod\";\r\nimport { TFunction } from \"i18next\";\r\n\r\nexport const getElementFields: (\r\n element: FormElementProps\r\n) => Array<RecordFieldProps> = (element: FormElementProps) => {\r\n const fields: Array<RecordFieldProps> = [];\r\n if (element.type === \"field\" && element.mode === \"props\" && element?.props) {\r\n fields.push(element.props);\r\n } else if (\r\n element.type === \"group\" &&\r\n element?.props &&\r\n element?.props?.elements\r\n ) {\r\n for (const childElement of element.props.elements) {\r\n fields.push(...getElementFields(childElement));\r\n }\r\n }\r\n return fields;\r\n};\r\n\r\nexport const getAllFields: (\r\n elements: Array<FormElementProps>\r\n) => Array<RecordFieldProps> = (elements: Array<FormElementProps>) => {\r\n const fields: Array<RecordFieldProps> = [];\r\n for (const element of elements) {\r\n fields.push(...getElementFields(element));\r\n }\r\n return fields;\r\n};\r\n\r\nexport const constructGridColumnsFromFields: (\r\n fields: Array<RecordFieldProps>,\r\n isDefaultEditable: boolean,\r\n t: TFunction<\"translation\", undefined>\r\n) => Array<TemplateGridColDef> = (fields, isDefaultEditable, t) => {\r\n const columns: Array<TemplateGridColDef> = [];\r\n for (const tableField of fields) {\r\n if (\r\n tableField?.fieldType === \"text\" ||\r\n tableField?.fieldType === \"number\"\r\n ) {\r\n const column: TemplateGridColDef = {\r\n ...tableField?.gridProps?.muiProps,\r\n editable:\r\n tableField?.gridProps?.muiProps?.editable || isDefaultEditable,\r\n type: tableField?.fieldType == \"number\" ? \"number\" : \"string\",\r\n field: tableField?.fieldName,\r\n headerName: t(tableField?.fieldLabel || tableField?.fieldName),\r\n headerAlign: \"center\",\r\n align: \"center\",\r\n hidden: tableField?.hidden,\r\n searchable: tableField?.gridProps?.searchable,\r\n flex: 1,\r\n minWidth: 200,\r\n };\r\n columns.push(column);\r\n } else if (tableField?.fieldType === \"date\") {\r\n const column: TemplateGridColDef = generateDateColumn({\r\n ...tableField?.gridProps?.muiProps,\r\n editable:\r\n tableField?.gridProps?.muiProps?.editable || isDefaultEditable,\r\n field: tableField?.fieldName,\r\n headerName: t(tableField?.fieldLabel || tableField?.fieldName),\r\n headerAlign: \"center\",\r\n align: \"center\",\r\n hidden: tableField?.hidden,\r\n searchable: tableField?.gridProps?.searchable,\r\n flex: 1,\r\n minWidth: 200,\r\n });\r\n columns.push(column);\r\n } else if (tableField?.fieldType === \"datetime\") {\r\n const column: TemplateGridColDef = generateDateTimeColumn({\r\n ...tableField?.gridProps?.muiProps,\r\n editable:\r\n tableField?.gridProps?.muiProps?.editable || isDefaultEditable,\r\n field: tableField?.fieldName,\r\n headerName: t(tableField?.fieldLabel || tableField?.fieldName),\r\n headerAlign: \"center\",\r\n align: \"center\",\r\n hidden: tableField?.hidden,\r\n searchable: tableField?.gridProps?.searchable,\r\n flex: 1,\r\n minWidth: 200,\r\n });\r\n columns.push(column);\r\n } else if (tableField?.fieldType === \"checkbox\") {\r\n const column = generateCheckBoxColumn({\r\n ...tableField?.gridProps?.muiProps,\r\n editable:\r\n tableField?.gridProps?.muiProps?.editable || isDefaultEditable,\r\n field: tableField?.fieldName,\r\n headerName: t(tableField?.fieldLabel || tableField?.fieldName),\r\n headerAlign: \"center\",\r\n align: \"center\",\r\n hidden: tableField?.hidden,\r\n searchable: tableField?.gridProps?.searchable,\r\n checkedValue: tableField?.checkedValue,\r\n unCheckedValue: tableField?.unCheckedValue,\r\n width: 150,\r\n });\r\n columns.push(column);\r\n } else if (tableField?.fieldType === \"combobox\") {\r\n const column: TemplateGridColDef = generateComboColumn({\r\n ...tableField?.gridProps?.muiProps,\r\n editable:\r\n tableField?.gridProps?.muiProps?.editable || isDefaultEditable,\r\n field: tableField?.fieldName,\r\n headerName: t(tableField?.fieldLabel || tableField?.fieldName),\r\n headerAlign: \"center\",\r\n align: \"center\",\r\n hidden: tableField?.hidden,\r\n searchable: tableField?.gridProps?.searchable,\r\n valueField: tableField?.optionValueField || \"value\",\r\n displayField: tableField?.optionDisplayField || \"display\",\r\n options: tableField?.options || [],\r\n flex: 1,\r\n minWidth: 200,\r\n });\r\n columns.push(column);\r\n }\r\n }\r\n return columns;\r\n};\r\n\r\nexport const constructValidationSchema = (fields: Array<RecordFieldProps>) => {\r\n const validationSchemaObj: any = {};\r\n for (const field of fields) {\r\n if (field?.fieldName) {\r\n const fieldName = field.fieldName;\r\n if (field.fieldType === \"number\") {\r\n if (field?.required === true) {\r\n validationSchemaObj[fieldName] = z.number({\r\n required_error: \"This field is required\",\r\n invalid_type_error: \"This field must be a number\",\r\n });\r\n } else {\r\n validationSchemaObj[fieldName] = z.number().optional().nullable();\r\n }\r\n } else {\r\n if (field?.required === true) {\r\n validationSchemaObj[fieldName] = z\r\n .string({ message: \"This field is required\" })\r\n .min(1, \"This field is required\");\r\n } else {\r\n validationSchemaObj[fieldName] = z.string().optional().nullable();\r\n }\r\n }\r\n }\r\n }\r\n return validationSchemaObj;\r\n};\r\n\r\nexport type GridSelection = {\r\n selectedRecords: Array<any>;\r\n selectedRecordIds: Array<any>;\r\n};\r\n\r\nexport const getGridSelection: (\r\n rowSelectionModel: GridRowSelectionModel,\r\n data: Array<any>,\r\n keyColumnName: string\r\n) => GridSelection = (\r\n rowSelectionModel: GridRowSelectionModel,\r\n data: Array<any>,\r\n keyColumnName: string\r\n) => {\r\n const sRecords = [];\r\n const sRecordIds = [];\r\n if (\r\n rowSelectionModel.type === \"exclude\" &&\r\n rowSelectionModel.ids.size === 0\r\n ) {\r\n for (const record of data) {\r\n sRecords.push(record);\r\n sRecordIds.push(record[keyColumnName]);\r\n }\r\n } else {\r\n if (rowSelectionModel?.ids) {\r\n for (const selectedId of rowSelectionModel.ids) {\r\n const record = data.find((x) => x[keyColumnName] === selectedId);\r\n sRecords.push(record);\r\n sRecordIds.push(selectedId);\r\n }\r\n }\r\n }\r\n return { selectedRecords: sRecords, selectedRecordIds: sRecordIds };\r\n};\r\n","import {\r\n Badge,\r\n Box,\r\n Button,\r\n Divider,\r\n IconButton,\r\n InputAdornment,\r\n MenuItem,\r\n styled,\r\n TextField,\r\n Tooltip,\r\n} from \"@mui/material\";\r\nimport {\r\n Toolbar,\r\n ToolbarButton,\r\n ColumnsPanelTrigger,\r\n FilterPanelTrigger,\r\n QuickFilter,\r\n QuickFilterControl,\r\n QuickFilterClear,\r\n QuickFilterTrigger,\r\n GridViewColumnIcon,\r\n GridFilterListIcon,\r\n ExportExcel,\r\n} from \"@mui/x-data-grid-premium\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport TemplateGridMultiRecordAction from \"./TemplateGridMultiRecordAction\";\r\nimport { getGridSelection } from \"../DataEntryUtil\";\r\nimport { useTranslation } from \"react-i18next\";\r\nimport { TemplateGridTopBarProps } from \"../DataEntryTypes\";\r\nimport useSession from \"../../../../hooks/UseSession\";\r\n\r\ntype OwnerState = {\r\n expanded: boolean;\r\n};\r\n\r\nconst StyledQuickFilter = styled(QuickFilter)({\r\n display: \"grid\",\r\n alignItems: \"center\",\r\n});\r\n\r\nconst StyledToolbarButton = styled(ToolbarButton)<{ ownerState: OwnerState }>(\r\n ({ theme, ownerState }) => ({\r\n gridArea: \"1 / 1\",\r\n width: \"min-content\",\r\n height: \"min-content\",\r\n zIndex: 1,\r\n opacity: ownerState.expanded ? 0 : 1,\r\n pointerEvents: ownerState.expanded ? \"none\" : \"auto\",\r\n transition: theme.transitions.create([\"opacity\"]),\r\n })\r\n);\r\n\r\nconst StyledTextField = styled(TextField)<{\r\n ownerState: OwnerState;\r\n}>(({ theme, ownerState }) => ({\r\n gridArea: \"1 / 1\",\r\n overflowX: \"clip\",\r\n width: ownerState.expanded ? 260 : \"var(--trigger-width)\",\r\n opacity: ownerState.expanded ? 1 : 0,\r\n transition: theme.transitions.create([\"width\", \"opacity\"]),\r\n}));\r\n\r\nconst TemplateGridTopBar: React.FC<TemplateGridTopBarProps> = (\r\n props: TemplateGridTopBarProps\r\n) => {\r\n const { t } = useTranslation();\r\n const session = useSession();\r\n const isCreationAuthorized = props?.templateProps?.editAction?.authority\r\n ? session.isUserAuthorized(props.templateProps.editAction.authority)\r\n : true;\r\n const isCreationEnabled = props?.templateProps?.disableDefaultAction || true;\r\n const gridSelection = getGridSelection(\r\n props?.templateProps?.rowSelectionModel || {\r\n ids: new Set(),\r\n type: \"include\",\r\n },\r\n props?.templateProps?.data || [],\r\n props?.templateProps?.keyColumnName || \"id\"\r\n );\r\n return (\r\n <Toolbar>\r\n {isCreationEnabled &&\r\n isCreationAuthorized &&\r\n props?.templateProps?.editMode?.editMode != \"none\" ? (\r\n <Button onClick={props?.handleCreateNewRecord}>\r\n <FontAwesomeIcon\r\n icon=\"add\"\r\n style={{ marginRight: 5, marginLeft: 5 }}\r\n />\r\n {t(\"ADD_BTN_LABEL\")}\r\n </Button>\r\n ) : (\r\n <></>\r\n )}\r\n {props?.templateProps?.rowActions ? (\r\n props.templateProps.rowActions.map((rowAction) =>\r\n rowAction?.gridActionProps?.multiRecord === true ? (\r\n <TemplateGridMultiRecordAction\r\n {...rowAction}\r\n reloadData={async () => {\r\n props.templateProps.apiActions.reloadData(\r\n props?.templateProps?.gridLoadParametersValues\r\n );\r\n }}\r\n recordIdsToProcessActionOn={gridSelection.selectedRecordIds}\r\n recordsToProcessActionOn={gridSelection.selectedRecords}\r\n />\r\n ) : (\r\n <></>\r\n )\r\n )\r\n ) : (\r\n <></>\r\n )}\r\n <Box sx={{ flex: 1, mx: 0.5 }}>{props?.templateProps?.tBar}</Box>\r\n\r\n <Tooltip title=\"Columns\">\r\n <ColumnsPanelTrigger render={<ToolbarButton />}>\r\n <GridViewColumnIcon fontSize=\"small\" />\r\n </ColumnsPanelTrigger>\r\n </Tooltip>\r\n\r\n <Tooltip title=\"Filters\">\r\n <FilterPanelTrigger\r\n render={(props, state) => (\r\n <ToolbarButton {...props} color=\"default\">\r\n <Badge\r\n badgeContent={state.filterCount}\r\n color=\"primary\"\r\n variant=\"dot\"\r\n >\r\n <GridFilterListIcon fontSize=\"small\" />\r\n </Badge>\r\n </ToolbarButton>\r\n )}\r\n />\r\n </Tooltip>\r\n\r\n {props?.templateProps?.gridStateKey ? (\r\n <Tooltip title={t(\"RESET_GRID_STATE\")}>\r\n <IconButton onClick={props?.clearGridState}>\r\n <FontAwesomeIcon icon=\"eraser\" />\r\n </IconButton>\r\n </Tooltip>\r\n ) : (\r\n <></>\r\n )}\r\n\r\n <Divider\r\n orientation=\"vertical\"\r\n variant=\"middle\"\r\n flexItem\r\n sx={{ mx: 0.5 }}\r\n />\r\n\r\n <Tooltip title={t(\"EXPORT_EXECL_LABEL\")}>\r\n <ExportExcel render={<MenuItem />}>\r\n <FontAwesomeIcon icon=\"file-excel\" color=\"green\" />\r\n </ExportExcel>\r\n </Tooltip>\r\n\r\n <StyledQuickFilter>\r\n <QuickFilterTrigger\r\n render={(triggerProps, state) => (\r\n <Tooltip title={t(\"SEARCH_BTN_LABEL\")} enterDelay={0}>\r\n <StyledToolbarButton\r\n {...triggerProps}\r\n ownerState={{ expanded: state.expanded }}\r\n color=\"default\"\r\n aria-disabled={state.expanded}\r\n >\r\n <FontAwesomeIcon icon=\"search\" />\r\n </StyledToolbarButton>\r\n </Tooltip>\r\n )}\r\n />\r\n <QuickFilterControl\r\n render={({ ref, ...controlProps }, state) => (\r\n <StyledTextField\r\n {...controlProps}\r\n ownerState={{ expanded: state.expanded }}\r\n inputRef={ref}\r\n aria-label=\"Search\"\r\n placeholder={`${t(\"SEARCH_BTN_LABEL\")}...`}\r\n size=\"small\"\r\n slotProps={{\r\n input: {\r\n startAdornment: (\r\n <InputAdornment position=\"start\">\r\n <FontAwesomeIcon icon=\"search\" />\r\n </InputAdornment>\r\n ),\r\n endAdornment: state.value ? (\r\n <InputAdornment position=\"end\">\r\n <QuickFilterClear\r\n edge=\"end\"\r\n size=\"small\"\r\n aria-label=\"Clear search\"\r\n // material={{ sx: { marginRight: -0.75 } }}\r\n >\r\n <FontAwesomeIcon icon=\"xmark\" />\r\n </QuickFilterClear>\r\n </InputAdornment>\r\n ) : null,\r\n ...controlProps.slotProps?.input,\r\n },\r\n ...controlProps.slotProps,\r\n }}\r\n />\r\n )}\r\n />\r\n </StyledQuickFilter>\r\n\r\n <IconButton\r\n onClick={() => {\r\n props.templateProps.apiActions.reloadData(\r\n props?.templateProps?.gridLoadParametersValues\r\n );\r\n }}\r\n >\r\n <FontAwesomeIcon icon=\"refresh\" />\r\n </IconButton>\r\n </Toolbar>\r\n );\r\n};\r\n\r\nexport default TemplateGridTopBar;\r\n","export function hasDigitsOnly(str: string) {\r\n return /^\\d+$/.test(str);\r\n}\r\n\r\nexport function isNumber(value: any) {\r\n return typeof value === \"number\" && !isNaN(value);\r\n}\r\n\r\nexport function isNumeric(value: string) {\r\n return (\r\n typeof value === \"string\" && value.trim() !== \"\" && !isNaN(Number(value))\r\n );\r\n}\r\n\r\nexport function capitalizeFirstLetter(str: string) {\r\n if (!str) return \"\";\r\n return str.charAt(0).toUpperCase() + str.slice(1);\r\n}\r\n","import { Tooltip } from \"@mui/material\";\r\nimport { GridActionsCellItem } from \"@mui/x-data-grid-premium\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport { RecordAction } from \"../DataEntryTypes\";\r\nimport { useTranslation } from \"react-i18next\";\r\nimport useSession from \"../../../../hooks/UseSession\";\r\nimport { useConfirmationWindow } from \"../../../../hooks/UseConfirmationWindow\";\r\n\r\nconst TemplateGridRecordAction: React.FC<RecordAction> = (\r\n rowAction: RecordAction\r\n) => {\r\n const { t } = useTranslation();\r\n const session = useSession();\r\n const { ConfirmationWindow, setOpen } = useConfirmationWindow({\r\n body: t(rowAction?.confirmationMessage || \"ACTION_CONFIRMATION\"),\r\n title: t(\"CONFIRMATION\"),\r\n onConfirmationCallBk: async () => {\r\n await rowAction?.actionFn(rowAction.record);\r\n if (rowAction?.reloadData) {\r\n rowAction.reloadData();\r\n }\r\n },\r\n });\r\n let isActionAllowed = true;\r\n if (rowAction.authority) {\r\n isActionAllowed = session.isUserAuthorized(rowAction.authority);\r\n }\r\n let iconStyle: any = {};\r\n if (rowAction?.getActionIconStyleForRecord) {\r\n iconStyle = rowAction.getActionIconStyleForRecord(rowAction.record);\r\n }\r\n let isActionVisibleForRecord = true;\r\n if (rowAction?.isActionVisibleForRecord) {\r\n isActionVisibleForRecord = rowAction?.isActionVisibleForRecord(\r\n rowAction.record\r\n );\r\n }\r\n let isActionDisabledForRecord = false;\r\n if (rowAction?.isActionDisabledForRecord) {\r\n isActionDisabledForRecord = rowAction.isActionDisabledForRecord(\r\n rowAction.record\r\n );\r\n }\r\n if (isActionAllowed && isActionVisibleForRecord) {\r\n return (\r\n <>\r\n <ConfirmationWindow />\r\n <GridActionsCellItem\r\n disabled={isActionDisabledForRecord}\r\n icon={\r\n <Tooltip title={rowAction?.label ? t(rowAction.label) : \"\"}>\r\n <FontAwesomeIcon\r\n icon={rowAction.icon}\r\n style={{\r\n ...iconStyle,\r\n color: isActionDisabledForRecord\r\n ? \"gray\"\r\n : iconStyle?.color != undefined\r\n ? iconStyle.color\r\n : undefined,\r\n }}\r\n />\r\n </Tooltip>\r\n }\r\n showInMenu={rowAction?.gridActionProps?.showInMenu || false}\r\n label={\"\"}\r\n className=\"textPrimary\"\r\n color=\"inherit\"\r\n onClick={async () => {\r\n if (!isActionDisabledForRecord) {\r\n if (rowAction?.preActionValidation) {\r\n if (!rowAction.preActionValidation(rowAction.record)) {\r\n return;\r\n }\r\n }\r\n if (rowAction?.isConfirmationRequired === true) {\r\n setOpen(true);\r\n } else {\r\n await rowAction.actionFn(rowAction.record);\r\n if (rowAction?.reloadData) {\r\n rowAction.reloadData();\r\n }\r\n }\r\n }\r\n }}\r\n />\r\n </>\r\n );\r\n }\r\n};\r\n\r\nexport default TemplateGridRecordAction;\r\n","/**\n * WARNING: Don't import this directly. It's imported by the code generated by\n * `@mui/interal-babel-plugin-minify-errors`. Make sure to always use string literals in `Error`\n * constructors to ensure the plugin works as expected. Supported patterns include:\n * throw new Error('My message');\n * throw new Error(`My message: ${foo}`);\n * throw new Error(`My message: ${foo}` + 'another string');\n * ...\n * @param {number} code\n */\nexport default function formatMuiErrorMessage(code, ...args) {\n const url = new URL(`https://mui.com/production-error/?code=${code}`);\n args.forEach(arg => url.searchParams.append('args[]', arg));\n return `Minified MUI error #${code}; visit ${url} for the full message.`;\n}","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-is.production.min.js');\n} else {\n module.exports = require('./cjs/react-is.development.js');\n}\n","/** @license React v16.13.1\n * react-is.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';var b=\"function\"===typeof Symbol&&Symbol.for,c=b?Symbol.for(\"react.element\"):60103,d=b?Symbol.for(\"react.portal\"):60106,e=b?Symbol.for(\"react.fragment\"):60107,f=b?Symbol.for(\"react.strict_mode\"):60108,g=b?Symbol.for(\"react.profiler\"):60114,h=b?Symbol.for(\"react.provider\"):60109,k=b?Symbol.for(\"react.context\"):60110,l=b?Symbol.for(\"react.async_mode\"):60111,m=b?Symbol.for(\"react.concurrent_mode\"):60111,n=b?Symbol.for(\"react.forward_ref\"):60112,p=b?Symbol.for(\"react.suspense\"):60113,q=b?\nSymbol.for(\"react.suspense_list\"):60120,r=b?Symbol.for(\"react.memo\"):60115,t=b?Symbol.for(\"react.lazy\"):60116,v=b?Symbol.for(\"react.block\"):60121,w=b?Symbol.for(\"react.fundamental\"):60117,x=b?Symbol.for(\"react.responder\"):60118,y=b?Symbol.for(\"react.scope\"):60119;\nfunction z(a){if(\"object\"===typeof a&&null!==a){var u=a.$$typeof;switch(u){case c:switch(a=a.type,a){case l:case m:case e:case g:case f:case p:return a;default:switch(a=a&&a.$$typeof,a){case k:case n:case t:case r:case h:return a;default:return u}}case d:return u}}}function A(a){return z(a)===m}exports.AsyncMode=l;exports.ConcurrentMode=m;exports.ContextConsumer=k;exports.ContextProvider=h;exports.Element=c;exports.ForwardRef=n;exports.Fragment=e;exports.Lazy=t;exports.Memo=r;exports.Portal=d;\nexports.Profiler=g;exports.StrictMode=f;exports.Suspense=p;exports.isAsyncMode=function(a){return A(a)||z(a)===l};exports.isConcurrentMode=A;exports.isContextConsumer=function(a){return z(a)===k};exports.isContextProvider=function(a){return z(a)===h};exports.isElement=function(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===c};exports.isForwardRef=function(a){return z(a)===n};exports.isFragment=function(a){return z(a)===e};exports.isLazy=function(a){return z(a)===t};\nexports.isMemo=function(a){return z(a)===r};exports.isPortal=function(a){return z(a)===d};exports.isProfiler=function(a){return z(a)===g};exports.isStrictMode=function(a){return z(a)===f};exports.isSuspense=function(a){return z(a)===p};\nexports.isValidElementType=function(a){return\"string\"===typeof a||\"function\"===typeof a||a===e||a===m||a===g||a===f||a===p||a===q||\"object\"===typeof a&&null!==a&&(a.$$typeof===t||a.$$typeof===r||a.$$typeof===h||a.$$typeof===k||a.$$typeof===n||a.$$typeof===w||a.$$typeof===x||a.$$typeof===y||a.$$typeof===v)};exports.typeOf=z;\n","/** @license React v16.13.1\n * react-is.development.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\n\n\nif (process.env.NODE_ENV !== \"production\") {\n (function() {\n'use strict';\n\n// The Symbol used to tag the ReactElement-like types. If there is no native Symbol\n// nor polyfill, then a plain number is used for performance.\nvar hasSymbol = typeof Symbol === 'function' && Symbol.for;\nvar REACT_ELEMENT_TYPE = hasSymbol ? Symbol.for('react.element') : 0xeac7;\nvar REACT_PORTAL_TYPE = hasSymbol ? Symbol.for('react.portal') : 0xeaca;\nvar REACT_FRAGMENT_TYPE = hasSymbol ? Symbol.for('react.fragment') : 0xeacb;\nvar REACT_STRICT_MODE_TYPE = hasSymbol ? Symbol.for('react.strict_mode') : 0xeacc;\nvar REACT_PROFILER_TYPE = hasSymbol ? Symbol.for('react.profiler') : 0xead2;\nvar REACT_PROVIDER_TYPE = hasSymbol ? Symbol.for('react.provider') : 0xeacd;\nvar REACT_CONTEXT_TYPE = hasSymbol ? Symbol.for('react.context') : 0xeace; // TODO: We don't use AsyncMode or ConcurrentMode anymore. They were temporary\n// (unstable) APIs that have been removed. Can we remove the symbols?\n\nvar REACT_ASYNC_MODE_TYPE = hasSymbol ? Symbol.for('react.async_mode') : 0xeacf;\nvar REACT_CONCURRENT_MODE_TYPE = hasSymbol ? Symbol.for('react.concurrent_mode') : 0xeacf;\nvar REACT_FORWARD_REF_TYPE = hasSymbol ? Symbol.for('react.forward_ref') : 0xead0;\nvar REACT_SUSPENSE_TYPE = hasSymbol ? Symbol.for('react.suspense') : 0xead1;\nvar REACT_SUSPENSE_LIST_TYPE = hasSymbol ? Symbol.for('react.suspense_list') : 0xead8;\nvar REACT_MEMO_TYPE = hasSymbol ? Symbol.for('react.memo') : 0xead3;\nvar REACT_LAZY_TYPE = hasSymbol ? Symbol.for('react.lazy') : 0xead4;\nvar REACT_BLOCK_TYPE = hasSymbol ? Symbol.for('react.block') : 0xead9;\nvar REACT_FUNDAMENTAL_TYPE = hasSymbol ? Symbol.for('react.fundamental') : 0xead5;\nvar REACT_RESPONDER_TYPE = hasSymbol ? Symbol.for('react.responder') : 0xead6;\nvar REACT_SCOPE_TYPE = hasSymbol ? Symbol.for('react.scope') : 0xead7;\n\nfunction isValidElementType(type) {\n return typeof type === 'string' || typeof type === 'function' || // Note: its typeof might be other than 'symbol' or 'number' if it's a polyfill.\n type === REACT_FRAGMENT_TYPE || type === REACT_CONCURRENT_MODE_TYPE || type === REACT_PROFILER_TYPE || type === REACT_STRICT_MODE_TYPE || type === REACT_SUSPENSE_TYPE || type === REACT_SUSPENSE_LIST_TYPE || typeof type === 'object' && type !== null && (type.$$typeof === REACT_LAZY_TYPE || type.$$typeof === REACT_MEMO_TYPE || type.$$typeof === REACT_PROVIDER_TYPE || type.$$typeof === REACT_CONTEXT_TYPE || type.$$typeof === REACT_FORWARD_REF_TYPE || type.$$typeof === REACT_FUNDAMENTAL_TYPE || type.$$typeof === REACT_RESPONDER_TYPE || type.$$typeof === REACT_SCOPE_TYPE || type.$$typeof === REACT_BLOCK_TYPE);\n}\n\nfunction typeOf(object) {\n if (typeof object === 'object' && object !== null) {\n var $$typeof = object.$$typeof;\n\n switch ($$typeof) {\n case REACT_ELEMENT_TYPE:\n var type = object.type;\n\n switch (type) {\n case REACT_ASYNC_MODE_TYPE:\n case REACT_CONCURRENT_MODE_TYPE:\n case REACT_FRAGMENT_TYPE:\n case REACT_PROFILER_TYPE:\n case REACT_STRICT_MODE_TYPE:\n case REACT_SUSPENSE_TYPE:\n return type;\n\n default:\n var $$typeofType = type && type.$$typeof;\n\n switch ($$typeofType) {\n case REACT_CONTEXT_TYPE:\n case REACT_FORWARD_REF_TYPE:\n case REACT_LAZY_TYPE:\n case REACT_MEMO_TYPE:\n case REACT_PROVIDER_TYPE:\n return $$typeofType;\n\n default:\n return $$typeof;\n }\n\n }\n\n case REACT_PORTAL_TYPE:\n return $$typeof;\n }\n }\n\n return undefined;\n} // AsyncMode is deprecated along with isAsyncMode\n\nvar AsyncMode = REACT_ASYNC_MODE_TYPE;\nvar ConcurrentMode = REACT_CONCURRENT_MODE_TYPE;\nvar ContextConsumer = REACT_CONTEXT_TYPE;\nvar ContextProvider = REACT_PROVIDER_TYPE;\nvar Element = REACT_ELEMENT_TYPE;\nvar ForwardRef = REACT_FORWARD_REF_TYPE;\nvar Fragment = REACT_FRAGMENT_TYPE;\nvar Lazy = REACT_LAZY_TYPE;\nvar Memo = REACT_MEMO_TYPE;\nvar Portal = REACT_PORTAL_TYPE;\nvar Profiler = REACT_PROFILER_TYPE;\nvar StrictMode = REACT_STRICT_MODE_TYPE;\nvar Suspense = REACT_SUSPENSE_TYPE;\nvar hasWarnedAboutDeprecatedIsAsyncMode = false; // AsyncMode should be deprecated\n\nfunction isAsyncMode(object) {\n {\n if (!hasWarnedAboutDeprecatedIsAsyncMode) {\n hasWarnedAboutDeprecatedIsAsyncMode = true; // Using console['warn'] to evade Babel and ESLint\n\n console['warn']('The ReactIs.isAsyncMode() alias has been deprecated, ' + 'and will be removed in React 17+. Update your code to use ' + 'ReactIs.isConcurrentMode() instead. It has the exact same API.');\n }\n }\n\n return isConcurrentMode(object) || typeOf(object) === REACT_ASYNC_MODE_TYPE;\n}\nfunction isConcurrentMode(object) {\n return typeOf(object) === REACT_CONCURRENT_MODE_TYPE;\n}\nfunction isContextConsumer(object) {\n return typeOf(object) === REACT_CONTEXT_TYPE;\n}\nfunction isContextProvider(object) {\n return typeOf(object) === REACT_PROVIDER_TYPE;\n}\nfunction isElement(object) {\n return typeof object === 'object' && object !== null && object.$$typeof === REACT_ELEMENT_TYPE;\n}\nfunction isForwardRef(object) {\n return typeOf(object) === REACT_FORWARD_REF_TYPE;\n}\nfunction isFragment(object) {\n return typeOf(object) === REACT_FRAGMENT_TYPE;\n}\nfunction isLazy(object) {\n return typeOf(object) === REACT_LAZY_TYPE;\n}\nfunction isMemo(object) {\n return typeOf(object) === REACT_MEMO_TYPE;\n}\nfunction isPortal(object) {\n return typeOf(object) === REACT_PORTAL_TYPE;\n}\nfunction isProfiler(object) {\n return typeOf(object) === REACT_PROFILER_TYPE;\n}\nfunction isStrictMode(object) {\n return typeOf(object) === REACT_STRICT_MODE_TYPE;\n}\nfunction isSuspense(object) {\n return typeOf(object) === REACT_SUSPENSE_TYPE;\n}\n\nexports.AsyncMode = AsyncMode;\nexports.ConcurrentMode = ConcurrentMode;\nexports.ContextConsumer = ContextConsumer;\nexports.ContextProvider = ContextProvider;\nexports.Element = Element;\nexports.ForwardRef = ForwardRef;\nexports.Fragment = Fragment;\nexports.Lazy = Lazy;\nexports.Memo = Memo;\nexports.Portal = Portal;\nexports.Profiler = Profiler;\nexports.StrictMode = StrictMode;\nexports.Suspense = Suspense;\nexports.isAsyncMode = isAsyncMode;\nexports.isConcurrentMode = isConcurrentMode;\nexports.isContextConsumer = isContextConsumer;\nexports.isContextProvider = isContextProvider;\nexports.isElement = isElement;\nexports.isForwardRef = isForwardRef;\nexports.isFragment = isFragment;\nexports.isLazy = isLazy;\nexports.isMemo = isMemo;\nexports.isPortal = isPortal;\nexports.isProfiler = isProfiler;\nexports.isStrictMode = isStrictMode;\nexports.isSuspense = isSuspense;\nexports.isValidElementType = isValidElementType;\nexports.typeOf = typeOf;\n })();\n}\n","/*\nobject-assign\n(c) Sindre Sorhus\n@license MIT\n*/\n\n'use strict';\n/* eslint-disable no-unused-vars */\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nfunction toObject(val) {\n\tif (val === null || val === undefined) {\n\t\tthrow new TypeError('Object.assign cannot be called with null or undefined');\n\t}\n\n\treturn Object(val);\n}\n\nfunction shouldUseNative() {\n\ttry {\n\t\tif (!Object.assign) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Detect buggy property enumeration order in older V8 versions.\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=4118\n\t\tvar test1 = new String('abc'); // eslint-disable-line no-new-wrappers\n\t\ttest1[5] = 'de';\n\t\tif (Object.getOwnPropertyNames(test1)[0] === '5') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test2 = {};\n\t\tfor (var i = 0; i < 10; i++) {\n\t\t\ttest2['_' + String.fromCharCode(i)] = i;\n\t\t}\n\t\tvar order2 = Object.getOwnPropertyNames(test2).map(function (n) {\n\t\t\treturn test2[n];\n\t\t});\n\t\tif (order2.join('') !== '0123456789') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test3 = {};\n\t\t'abcdefghijklmnopqrst'.split('').forEach(function (letter) {\n\t\t\ttest3[letter] = letter;\n\t\t});\n\t\tif (Object.keys(Object.assign({}, test3)).join('') !==\n\t\t\t\t'abcdefghijklmnopqrst') {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t} catch (err) {\n\t\t// We don't expect any of the above to throw, but better to be safe.\n\t\treturn false;\n\t}\n}\n\nmodule.exports = shouldUseNative() ? Object.assign : function (target, source) {\n\tvar from;\n\tvar to = toObject(target);\n\tvar symbols;\n\n\tfor (var s = 1; s < arguments.length; s++) {\n\t\tfrom = Object(arguments[s]);\n\n\t\tfor (var key in from) {\n\t\t\tif (hasOwnProperty.call(from, key)) {\n\t\t\t\tto[key] = from[key];\n\t\t\t}\n\t\t}\n\n\t\tif (getOwnPropertySymbols) {\n\t\t\tsymbols = getOwnPropertySymbols(from);\n\t\t\tfor (var i = 0; i < symbols.length; i++) {\n\t\t\t\tif (propIsEnumerable.call(from, symbols[i])) {\n\t\t\t\t\tto[symbols[i]] = from[symbols[i]];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n","module.exports = Function.call.bind(Object.prototype.hasOwnProperty);\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar printWarning = function() {};\n\nif (process.env.NODE_ENV !== 'production') {\n var ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n var loggedTypeFailures = {};\n var has = require('./lib/has');\n\n printWarning = function(text) {\n var message = 'Warning: ' + text;\n if (typeof console !== 'undefined') {\n console.error(message);\n }\n try {\n // --- Welcome to debugging React ---\n // This error was thrown as a convenience so that you can use this stack\n // to find the callsite that caused this warning to fire.\n throw new Error(message);\n } catch (x) { /**/ }\n };\n}\n\n/**\n * Assert that the values match with the type specs.\n * Error messages are memorized and will only be shown once.\n *\n * @param {object} typeSpecs Map of name to a ReactPropType\n * @param {object} values Runtime values that need to be type-checked\n * @param {string} location e.g. \"prop\", \"context\", \"child context\"\n * @param {string} componentName Name of the component for error messages.\n * @param {?Function} getStack Returns the component stack.\n * @private\n */\nfunction checkPropTypes(typeSpecs, values, location, componentName, getStack) {\n if (process.env.NODE_ENV !== 'production') {\n for (var typeSpecName in typeSpecs) {\n if (has(typeSpecs, typeSpecName)) {\n var error;\n // Prop type validation may throw. In case they do, we don't want to\n // fail the render phase where it didn't fail before. So we log it.\n // After these have been cleaned up, we'll let them throw.\n try {\n // This is intentionally an invariant that gets caught. It's the same\n // behavior as without this statement except with a better message.\n if (typeof typeSpecs[typeSpecName] !== 'function') {\n var err = Error(\n (componentName || 'React class') + ': ' + location + ' type `' + typeSpecName + '` is invalid; ' +\n 'it must be a function, usually from the `prop-types` package, but received `' + typeof typeSpecs[typeSpecName] + '`.' +\n 'This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.'\n );\n err.name = 'Invariant Violation';\n throw err;\n }\n error = typeSpecs[typeSpecName](values, typeSpecName, componentName, location, null, ReactPropTypesSecret);\n } catch (ex) {\n error = ex;\n }\n if (error && !(error instanceof Error)) {\n printWarning(\n (componentName || 'React class') + ': type specification of ' +\n location + ' `' + typeSpecName + '` is invalid; the type checker ' +\n 'function must return `null` or an `Error` but returned a ' + typeof error + '. ' +\n 'You may have forgotten to pass an argument to the type checker ' +\n 'creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and ' +\n 'shape all require an argument).'\n );\n }\n if (error instanceof Error && !(error.message in loggedTypeFailures)) {\n // Only monitor this failure once because there tends to be a lot of the\n // same error.\n loggedTypeFailures[error.message] = true;\n\n var stack = getStack ? getStack() : '';\n\n printWarning(\n 'Failed ' + location + ' type: ' + error.message + (stack != null ? stack : '')\n );\n }\n }\n }\n }\n}\n\n/**\n * Resets warning cache when testing.\n *\n * @private\n */\ncheckPropTypes.resetWarningCache = function() {\n if (process.env.NODE_ENV !== 'production') {\n loggedTypeFailures = {};\n }\n}\n\nmodule.exports = checkPropTypes;\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactIs = require('react-is');\nvar assign = require('object-assign');\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\nvar has = require('./lib/has');\nvar checkPropTypes = require('./checkPropTypes');\n\nvar printWarning = function() {};\n\nif (process.env.NODE_ENV !== 'production') {\n printWarning = function(text) {\n var message = 'Warning: ' + text;\n if (typeof console !== 'undefined') {\n console.error(message);\n }\n try {\n // --- Welcome to debugging React ---\n // This error was thrown as a convenience so that you can use this stack\n // to find the callsite that caused this warning to fire.\n throw new Error(message);\n } catch (x) {}\n };\n}\n\nfunction emptyFunctionThatReturnsNull() {\n return null;\n}\n\nmodule.exports = function(isValidElement, throwOnDirectAccess) {\n /* global Symbol */\n var ITERATOR_SYMBOL = typeof Symbol === 'function' && Symbol.iterator;\n var FAUX_ITERATOR_SYMBOL = '@@iterator'; // Before Symbol spec.\n\n /**\n * Returns the iterator method function contained on the iterable object.\n *\n * Be sure to invoke the function with the iterable as context:\n *\n * var iteratorFn = getIteratorFn(myIterable);\n * if (iteratorFn) {\n * var iterator = iteratorFn.call(myIterable);\n * ...\n * }\n *\n * @param {?object} maybeIterable\n * @return {?function}\n */\n function getIteratorFn(maybeIterable) {\n var iteratorFn = maybeIterable && (ITERATOR_SYMBOL && maybeIterable[ITERATOR_SYMBOL] || maybeIterable[FAUX_ITERATOR_SYMBOL]);\n if (typeof iteratorFn === 'function') {\n return iteratorFn;\n }\n }\n\n /**\n * Collection of methods that allow declaration and validation of props that are\n * supplied to React components. Example usage:\n *\n * var Props = require('ReactPropTypes');\n * var MyArticle = React.createClass({\n * propTypes: {\n * // An optional string prop named \"description\".\n * description: Props.string,\n *\n * // A required enum prop named \"category\".\n * category: Props.oneOf(['News','Photos']).isRequired,\n *\n * // A prop named \"dialog\" that requires an instance of Dialog.\n * dialog: Props.instanceOf(Dialog).isRequired\n * },\n * render: function() { ... }\n * });\n *\n * A more formal specification of how these methods are used:\n *\n * type := array|bool|func|object|number|string|oneOf([...])|instanceOf(...)\n * decl := ReactPropTypes.{type}(.isRequired)?\n *\n * Each and every declaration produces a function with the same signature. This\n * allows the creation of custom validation functions. For example:\n *\n * var MyLink = React.createClass({\n * propTypes: {\n * // An optional string or URI prop named \"href\".\n * href: function(props, propName, componentName) {\n * var propValue = props[propName];\n * if (propValue != null && typeof propValue !== 'string' &&\n * !(propValue instanceof URI)) {\n * return new Error(\n * 'Expected a string or an URI for ' + propName + ' in ' +\n * componentName\n * );\n * }\n * }\n * },\n * render: function() {...}\n * });\n *\n * @internal\n */\n\n var ANONYMOUS = '<<anonymous>>';\n\n // Important!\n // Keep this list in sync with production version in `./factoryWithThrowingShims.js`.\n var ReactPropTypes = {\n array: createPrimitiveTypeChecker('array'),\n bigint: createPrimitiveTypeChecker('bigint'),\n bool: createPrimitiveTypeChecker('boolean'),\n func: createPrimitiveTypeChecker('function'),\n number: createPrimitiveTypeChecker('number'),\n object: createPrimitiveTypeChecker('object'),\n string: createPrimitiveTypeChecker('string'),\n symbol: createPrimitiveTypeChecker('symbol'),\n\n any: createAnyTypeChecker(),\n arrayOf: createArrayOfTypeChecker,\n element: createElementTypeChecker(),\n elementType: createElementTypeTypeChecker(),\n instanceOf: createInstanceTypeChecker,\n node: createNodeChecker(),\n objectOf: createObjectOfTypeChecker,\n oneOf: createEnumTypeChecker,\n oneOfType: createUnionTypeChecker,\n shape: createShapeTypeChecker,\n exact: createStrictShapeTypeChecker,\n };\n\n /**\n * inlined Object.is polyfill to avoid requiring consumers ship their own\n * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is\n */\n /*eslint-disable no-self-compare*/\n function is(x, y) {\n // SameValue algorithm\n if (x === y) {\n // Steps 1-5, 7-10\n // Steps 6.b-6.e: +0 != -0\n return x !== 0 || 1 / x === 1 / y;\n } else {\n // Step 6.a: NaN == NaN\n return x !== x && y !== y;\n }\n }\n /*eslint-enable no-self-compare*/\n\n /**\n * We use an Error-like object for backward compatibility as people may call\n * PropTypes directly and inspect their output. However, we don't use real\n * Errors anymore. We don't inspect their stack anyway, and creating them\n * is prohibitively expensive if they are created too often, such as what\n * happens in oneOfType() for any type before the one that matched.\n */\n function PropTypeError(message, data) {\n this.message = message;\n this.data = data && typeof data === 'object' ? data: {};\n this.stack = '';\n }\n // Make `instanceof Error` still work for returned errors.\n PropTypeError.prototype = Error.prototype;\n\n function createChainableTypeChecker(validate) {\n if (process.env.NODE_ENV !== 'production') {\n var manualPropTypeCallCache = {};\n var manualPropTypeWarningCount = 0;\n }\n function checkType(isRequired, props, propName, componentName, location, propFullName, secret) {\n componentName = componentName || ANONYMOUS;\n propFullName = propFullName || propName;\n\n if (secret !== ReactPropTypesSecret) {\n if (throwOnDirectAccess) {\n // New behavior only for users of `prop-types` package\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use `PropTypes.checkPropTypes()` to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n } else if (process.env.NODE_ENV !== 'production' && typeof console !== 'undefined') {\n // Old behavior for people using React.PropTypes\n var cacheKey = componentName + ':' + propName;\n if (\n !manualPropTypeCallCache[cacheKey] &&\n // Avoid spamming the console because they are often not actionable except for lib authors\n manualPropTypeWarningCount < 3\n ) {\n printWarning(\n 'You are manually calling a React.PropTypes validation ' +\n 'function for the `' + propFullName + '` prop on `' + componentName + '`. This is deprecated ' +\n 'and will throw in the standalone `prop-types` package. ' +\n 'You may be seeing this warning due to a third-party PropTypes ' +\n 'library. See https://fb.me/react-warning-dont-call-proptypes ' + 'for details.'\n );\n manualPropTypeCallCache[cacheKey] = true;\n manualPropTypeWarningCount++;\n }\n }\n }\n if (props[propName] == null) {\n if (isRequired) {\n if (props[propName] === null) {\n return new PropTypeError('The ' + location + ' `' + propFullName + '` is marked as required ' + ('in `' + componentName + '`, but its value is `null`.'));\n }\n return new PropTypeError('The ' + location + ' `' + propFullName + '` is marked as required in ' + ('`' + componentName + '`, but its value is `undefined`.'));\n }\n return null;\n } else {\n return validate(props, propName, componentName, location, propFullName);\n }\n }\n\n var chainedCheckType = checkType.bind(null, false);\n chainedCheckType.isRequired = checkType.bind(null, true);\n\n return chainedCheckType;\n }\n\n function createPrimitiveTypeChecker(expectedType) {\n function validate(props, propName, componentName, location, propFullName, secret) {\n var propValue = props[propName];\n var propType = getPropType(propValue);\n if (propType !== expectedType) {\n // `propValue` being instance of, say, date/regexp, pass the 'object'\n // check, but we can offer a more precise error message here rather than\n // 'of type `object`'.\n var preciseType = getPreciseType(propValue);\n\n return new PropTypeError(\n 'Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + preciseType + '` supplied to `' + componentName + '`, expected ') + ('`' + expectedType + '`.'),\n {expectedType: expectedType}\n );\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createAnyTypeChecker() {\n return createChainableTypeChecker(emptyFunctionThatReturnsNull);\n }\n\n function createArrayOfTypeChecker(typeChecker) {\n function validate(props, propName, componentName, location, propFullName) {\n if (typeof typeChecker !== 'function') {\n return new PropTypeError('Property `' + propFullName + '` of component `' + componentName + '` has invalid PropType notation inside arrayOf.');\n }\n var propValue = props[propName];\n if (!Array.isArray(propValue)) {\n var propType = getPropType(propValue);\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected an array.'));\n }\n for (var i = 0; i < propValue.length; i++) {\n var error = typeChecker(propValue, i, componentName, location, propFullName + '[' + i + ']', ReactPropTypesSecret);\n if (error instanceof Error) {\n return error;\n }\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createElementTypeChecker() {\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n if (!isValidElement(propValue)) {\n var propType = getPropType(propValue);\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected a single ReactElement.'));\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createElementTypeTypeChecker() {\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n if (!ReactIs.isValidElementType(propValue)) {\n var propType = getPropType(propValue);\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected a single ReactElement type.'));\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createInstanceTypeChecker(expectedClass) {\n function validate(props, propName, componentName, location, propFullName) {\n if (!(props[propName] instanceof expectedClass)) {\n var expectedClassName = expectedClass.name || ANONYMOUS;\n var actualClassName = getClassName(props[propName]);\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + actualClassName + '` supplied to `' + componentName + '`, expected ') + ('instance of `' + expectedClassName + '`.'));\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createEnumTypeChecker(expectedValues) {\n if (!Array.isArray(expectedValues)) {\n if (process.env.NODE_ENV !== 'production') {\n if (arguments.length > 1) {\n printWarning(\n 'Invalid arguments supplied to oneOf, expected an array, got ' + arguments.length + ' arguments. ' +\n 'A common mistake is to write oneOf(x, y, z) instead of oneOf([x, y, z]).'\n );\n } else {\n printWarning('Invalid argument supplied to oneOf, expected an array.');\n }\n }\n return emptyFunctionThatReturnsNull;\n }\n\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n for (var i = 0; i < expectedValues.length; i++) {\n if (is(propValue, expectedValues[i])) {\n return null;\n }\n }\n\n var valuesString = JSON.stringify(expectedValues, function replacer(key, value) {\n var type = getPreciseType(value);\n if (type === 'symbol') {\n return String(value);\n }\n return value;\n });\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of value `' + String(propValue) + '` ' + ('supplied to `' + componentName + '`, expected one of ' + valuesString + '.'));\n }\n return createChainableTypeChecker(validate);\n }\n\n function createObjectOfTypeChecker(typeChecker) {\n function validate(props, propName, componentName, location, propFullName) {\n if (typeof typeChecker !== 'function') {\n return new PropTypeError('Property `' + propFullName + '` of component `' + componentName + '` has invalid PropType notation inside objectOf.');\n }\n var propValue = props[propName];\n var propType = getPropType(propValue);\n if (propType !== 'object') {\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected an object.'));\n }\n for (var key in propValue) {\n if (has(propValue, key)) {\n var error = typeChecker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret);\n if (error instanceof Error) {\n return error;\n }\n }\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createUnionTypeChecker(arrayOfTypeCheckers) {\n if (!Array.isArray(arrayOfTypeCheckers)) {\n process.env.NODE_ENV !== 'production' ? printWarning('Invalid argument supplied to oneOfType, expected an instance of array.') : void 0;\n return emptyFunctionThatReturnsNull;\n }\n\n for (var i = 0; i < arrayOfTypeCheckers.length; i++) {\n var checker = arrayOfTypeCheckers[i];\n if (typeof checker !== 'function') {\n printWarning(\n 'Invalid argument supplied to oneOfType. Expected an array of check functions, but ' +\n 'received ' + getPostfixForTypeWarning(checker) + ' at index ' + i + '.'\n );\n return emptyFunctionThatReturnsNull;\n }\n }\n\n function validate(props, propName, componentName, location, propFullName) {\n var expectedTypes = [];\n for (var i = 0; i < arrayOfTypeCheckers.length; i++) {\n var checker = arrayOfTypeCheckers[i];\n var checkerResult = checker(props, propName, componentName, location, propFullName, ReactPropTypesSecret);\n if (checkerResult == null) {\n return null;\n }\n if (checkerResult.data && has(checkerResult.data, 'expectedType')) {\n expectedTypes.push(checkerResult.data.expectedType);\n }\n }\n var expectedTypesMessage = (expectedTypes.length > 0) ? ', expected one of type [' + expectedTypes.join(', ') + ']': '';\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` supplied to ' + ('`' + componentName + '`' + expectedTypesMessage + '.'));\n }\n return createChainableTypeChecker(validate);\n }\n\n function createNodeChecker() {\n function validate(props, propName, componentName, location, propFullName) {\n if (!isNode(props[propName])) {\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` supplied to ' + ('`' + componentName + '`, expected a ReactNode.'));\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function invalidValidatorError(componentName, location, propFullName, key, type) {\n return new PropTypeError(\n (componentName || 'React class') + ': ' + location + ' type `' + propFullName + '.' + key + '` is invalid; ' +\n 'it must be a function, usually from the `prop-types` package, but received `' + type + '`.'\n );\n }\n\n function createShapeTypeChecker(shapeTypes) {\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n var propType = getPropType(propValue);\n if (propType !== 'object') {\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type `' + propType + '` ' + ('supplied to `' + componentName + '`, expected `object`.'));\n }\n for (var key in shapeTypes) {\n var checker = shapeTypes[key];\n if (typeof checker !== 'function') {\n return invalidValidatorError(componentName, location, propFullName, key, getPreciseType(checker));\n }\n var error = checker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret);\n if (error) {\n return error;\n }\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createStrictShapeTypeChecker(shapeTypes) {\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n var propType = getPropType(propValue);\n if (propType !== 'object') {\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type `' + propType + '` ' + ('supplied to `' + componentName + '`, expected `object`.'));\n }\n // We need to check all keys in case some are required but missing from props.\n var allKeys = assign({}, props[propName], shapeTypes);\n for (var key in allKeys) {\n var checker = shapeTypes[key];\n if (has(shapeTypes, key) && typeof checker !== 'function') {\n return invalidValidatorError(componentName, location, propFullName, key, getPreciseType(checker));\n }\n if (!checker) {\n return new PropTypeError(\n 'Invalid ' + location + ' `' + propFullName + '` key `' + key + '` supplied to `' + componentName + '`.' +\n '\\nBad object: ' + JSON.stringify(props[propName], null, ' ') +\n '\\nValid keys: ' + JSON.stringify(Object.keys(shapeTypes), null, ' ')\n );\n }\n var error = checker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret);\n if (error) {\n return error;\n }\n }\n return null;\n }\n\n return createChainableTypeChecker(validate);\n }\n\n function isNode(propValue) {\n switch (typeof propValue) {\n case 'number':\n case 'string':\n case 'undefined':\n return true;\n case 'boolean':\n return !propValue;\n case 'object':\n if (Array.isArray(propValue)) {\n return propValue.every(isNode);\n }\n if (propValue === null || isValidElement(propValue)) {\n return true;\n }\n\n var iteratorFn = getIteratorFn(propValue);\n if (iteratorFn) {\n var iterator = iteratorFn.call(propValue);\n var step;\n if (iteratorFn !== propValue.entries) {\n while (!(step = iterator.next()).done) {\n if (!isNode(step.value)) {\n return false;\n }\n }\n } else {\n // Iterator will provide entry [k,v] tuples rather than values.\n while (!(step = iterator.next()).done) {\n var entry = step.value;\n if (entry) {\n if (!isNode(entry[1])) {\n return false;\n }\n }\n }\n }\n } else {\n return false;\n }\n\n return true;\n default:\n return false;\n }\n }\n\n function isSymbol(propType, propValue) {\n // Native Symbol.\n if (propType === 'symbol') {\n return true;\n }\n\n // falsy value can't be a Symbol\n if (!propValue) {\n return false;\n }\n\n // 19.4.3.5 Symbol.prototype[@@toStringTag] === 'Symbol'\n if (propValue['@@toStringTag'] === 'Symbol') {\n return true;\n }\n\n // Fallback for non-spec compliant Symbols which are polyfilled.\n if (typeof Symbol === 'function' && propValue instanceof Symbol) {\n return true;\n }\n\n return false;\n }\n\n // Equivalent of `typeof` but with special handling for array and regexp.\n function getPropType(propValue) {\n var propType = typeof propValue;\n if (Array.isArray(propValue)) {\n return 'array';\n }\n if (propValue instanceof RegExp) {\n // Old webkits (at least until Android 4.0) return 'function' rather than\n // 'object' for typeof a RegExp. We'll normalize this here so that /bla/\n // passes PropTypes.object.\n return 'object';\n }\n if (isSymbol(propType, propValue)) {\n return 'symbol';\n }\n return propType;\n }\n\n // This handles more types than `getPropType`. Only used for error messages.\n // See `createPrimitiveTypeChecker`.\n function getPreciseType(propValue) {\n if (typeof propValue === 'undefined' || propValue === null) {\n return '' + propValue;\n }\n var propType = getPropType(propValue);\n if (propType === 'object') {\n if (propValue instanceof Date) {\n return 'date';\n } else if (propValue instanceof RegExp) {\n return 'regexp';\n }\n }\n return propType;\n }\n\n // Returns a string that is postfixed to a warning about an invalid type.\n // For example, \"undefined\" or \"of type array\"\n function getPostfixForTypeWarning(value) {\n var type = getPreciseType(value);\n switch (type) {\n case 'array':\n case 'object':\n return 'an ' + type;\n case 'boolean':\n case 'date':\n case 'regexp':\n return 'a ' + type;\n default:\n return type;\n }\n }\n\n // Returns class name of the object, if any.\n function getClassName(propValue) {\n if (!propValue.constructor || !propValue.constructor.name) {\n return ANONYMOUS;\n }\n return propValue.constructor.name;\n }\n\n ReactPropTypes.checkPropTypes = checkPropTypes;\n ReactPropTypes.resetWarningCache = checkPropTypes.resetWarningCache;\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n\nfunction emptyFunction() {}\nfunction emptyFunctionWithReset() {}\nemptyFunctionWithReset.resetWarningCache = emptyFunction;\n\nmodule.exports = function() {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret) {\n // It is still safe when called from React.\n return;\n }\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use PropTypes.checkPropTypes() to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n };\n shim.isRequired = shim;\n function getShim() {\n return shim;\n };\n // Important!\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n var ReactPropTypes = {\n array: shim,\n bigint: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\n\n any: shim,\n arrayOf: getShim,\n element: shim,\n elementType: shim,\n instanceOf: getShim,\n node: shim,\n objectOf: getShim,\n oneOf: getShim,\n oneOfType: getShim,\n shape: getShim,\n exact: getShim,\n\n checkPropTypes: emptyFunctionWithReset,\n resetWarningCache: emptyFunction\n };\n\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nif (process.env.NODE_ENV !== 'production') {\n var ReactIs = require('react-is');\n\n // By explicitly using `prop-types` you are opting into new development behavior.\n // http://fb.me/prop-types-in-prod\n var throwOnDirectAccess = true;\n module.exports = require('./factoryWithTypeCheckers')(ReactIs.isElement, throwOnDirectAccess);\n} else {\n // By explicitly using `prop-types` you are opting into new production behavior.\n // http://fb.me/prop-types-in-prod\n module.exports = require('./factoryWithThrowingShims')();\n}\n","/**\n * @license React\n * react-is.production.js\n *\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\"use strict\";\nvar REACT_ELEMENT_TYPE = Symbol.for(\"react.transitional.element\"),\n REACT_PORTAL_TYPE = Symbol.for(\"react.portal\"),\n REACT_FRAGMENT_TYPE = Symbol.for(\"react.fragment\"),\n REACT_STRICT_MODE_TYPE = Symbol.for(\"react.strict_mode\"),\n REACT_PROFILER_TYPE = Symbol.for(\"react.profiler\");\nSymbol.for(\"react.provider\");\nvar REACT_CONSUMER_TYPE = Symbol.for(\"react.consumer\"),\n REACT_CONTEXT_TYPE = Symbol.for(\"react.context\"),\n REACT_FORWARD_REF_TYPE = Symbol.for(\"react.forward_ref\"),\n REACT_SUSPENSE_TYPE = Symbol.for(\"react.suspense\"),\n REACT_SUSPENSE_LIST_TYPE = Symbol.for(\"react.suspense_list\"),\n REACT_MEMO_TYPE = Symbol.for(\"react.memo\"),\n REACT_LAZY_TYPE = Symbol.for(\"react.lazy\"),\n REACT_VIEW_TRANSITION_TYPE = Symbol.for(\"react.view_transition\"),\n REACT_CLIENT_REFERENCE = Symbol.for(\"react.client.reference\");\nfunction typeOf(object) {\n if (\"object\" === typeof object && null !== object) {\n var $$typeof = object.$$typeof;\n switch ($$typeof) {\n case REACT_ELEMENT_TYPE:\n switch (((object = object.type), object)) {\n case REACT_FRAGMENT_TYPE:\n case REACT_PROFILER_TYPE:\n case REACT_STRICT_MODE_TYPE:\n case REACT_SUSPENSE_TYPE:\n case REACT_SUSPENSE_LIST_TYPE:\n case REACT_VIEW_TRANSITION_TYPE:\n return object;\n default:\n switch (((object = object && object.$$typeof), object)) {\n case REACT_CONTEXT_TYPE:\n case REACT_FORWARD_REF_TYPE:\n case REACT_LAZY_TYPE:\n case REACT_MEMO_TYPE:\n return object;\n case REACT_CONSUMER_TYPE:\n return object;\n default:\n return $$typeof;\n }\n }\n case REACT_PORTAL_TYPE:\n return $$typeof;\n }\n }\n}\nexports.ContextConsumer = REACT_CONSUMER_TYPE;\nexports.ContextProvider = REACT_CONTEXT_TYPE;\nexports.Element = REACT_ELEMENT_TYPE;\nexports.ForwardRef = REACT_FORWARD_REF_TYPE;\nexports.Fragment = REACT_FRAGMENT_TYPE;\nexports.Lazy = REACT_LAZY_TYPE;\nexports.Memo = REACT_MEMO_TYPE;\nexports.Portal = REACT_PORTAL_TYPE;\nexports.Profiler = REACT_PROFILER_TYPE;\nexports.StrictMode = REACT_STRICT_MODE_TYPE;\nexports.Suspense = REACT_SUSPENSE_TYPE;\nexports.SuspenseList = REACT_SUSPENSE_LIST_TYPE;\nexports.isContextConsumer = function (object) {\n return typeOf(object) === REACT_CONSUMER_TYPE;\n};\nexports.isContextProvider = function (object) {\n return typeOf(object) === REACT_CONTEXT_TYPE;\n};\nexports.isElement = function (object) {\n return (\n \"object\" === typeof object &&\n null !== object &&\n object.$$typeof === REACT_ELEMENT_TYPE\n );\n};\nexports.isForwardRef = function (object) {\n return typeOf(object) === REACT_FORWARD_REF_TYPE;\n};\nexports.isFragment = function (object) {\n return typeOf(object) === REACT_FRAGMENT_TYPE;\n};\nexports.isLazy = function (object) {\n return typeOf(object) === REACT_LAZY_TYPE;\n};\nexports.isMemo = function (object) {\n return typeOf(object) === REACT_MEMO_TYPE;\n};\nexports.isPortal = function (object) {\n return typeOf(object) === REACT_PORTAL_TYPE;\n};\nexports.isProfiler = function (object) {\n return typeOf(object) === REACT_PROFILER_TYPE;\n};\nexports.isStrictMode = function (object) {\n return typeOf(object) === REACT_STRICT_MODE_TYPE;\n};\nexports.isSuspense = function (object) {\n return typeOf(object) === REACT_SUSPENSE_TYPE;\n};\nexports.isSuspenseList = function (object) {\n return typeOf(object) === REACT_SUSPENSE_LIST_TYPE;\n};\nexports.isValidElementType = function (type) {\n return \"string\" === typeof type ||\n \"function\" === typeof type ||\n type === REACT_FRAGMENT_TYPE ||\n type === REACT_PROFILER_TYPE ||\n type === REACT_STRICT_MODE_TYPE ||\n type === REACT_SUSPENSE_TYPE ||\n type === REACT_SUSPENSE_LIST_TYPE ||\n (\"object\" === typeof type &&\n null !== type &&\n (type.$$typeof === REACT_LAZY_TYPE ||\n type.$$typeof === REACT_MEMO_TYPE ||\n type.$$typeof === REACT_CONTEXT_TYPE ||\n type.$$typeof === REACT_CONSUMER_TYPE ||\n type.$$typeof === REACT_FORWARD_REF_TYPE ||\n type.$$typeof === REACT_CLIENT_REFERENCE ||\n void 0 !== type.getModuleId))\n ? !0\n : !1;\n};\nexports.typeOf = typeOf;\n","/**\n * @license React\n * react-is.development.js\n *\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\"use strict\";\n\"production\" !== process.env.NODE_ENV &&\n (function () {\n function typeOf(object) {\n if (\"object\" === typeof object && null !== object) {\n var $$typeof = object.$$typeof;\n switch ($$typeof) {\n case REACT_ELEMENT_TYPE:\n switch (((object = object.type), object)) {\n case REACT_FRAGMENT_TYPE:\n case REACT_PROFILER_TYPE:\n case REACT_STRICT_MODE_TYPE:\n case REACT_SUSPENSE_TYPE:\n case REACT_SUSPENSE_LIST_TYPE:\n case REACT_VIEW_TRANSITION_TYPE:\n return object;\n default:\n switch (((object = object && object.$$typeof), object)) {\n case REACT_CONTEXT_TYPE:\n case REACT_FORWARD_REF_TYPE:\n case REACT_LAZY_TYPE:\n case REACT_MEMO_TYPE:\n return object;\n case REACT_CONSUMER_TYPE:\n return object;\n default:\n return $$typeof;\n }\n }\n case REACT_PORTAL_TYPE:\n return $$typeof;\n }\n }\n }\n var REACT_ELEMENT_TYPE = Symbol.for(\"react.transitional.element\"),\n REACT_PORTAL_TYPE = Symbol.for(\"react.portal\"),\n REACT_FRAGMENT_TYPE = Symbol.for(\"react.fragment\"),\n REACT_STRICT_MODE_TYPE = Symbol.for(\"react.strict_mode\"),\n REACT_PROFILER_TYPE = Symbol.for(\"react.profiler\");\n Symbol.for(\"react.provider\");\n var REACT_CONSUMER_TYPE = Symbol.for(\"react.consumer\"),\n REACT_CONTEXT_TYPE = Symbol.for(\"react.context\"),\n REACT_FORWARD_REF_TYPE = Symbol.for(\"react.forward_ref\"),\n REACT_SUSPENSE_TYPE = Symbol.for(\"react.suspense\"),\n REACT_SUSPENSE_LIST_TYPE = Symbol.for(\"react.suspense_list\"),\n REACT_MEMO_TYPE = Symbol.for(\"react.memo\"),\n REACT_LAZY_TYPE = Symbol.for(\"react.lazy\"),\n REACT_VIEW_TRANSITION_TYPE = Symbol.for(\"react.view_transition\"),\n REACT_CLIENT_REFERENCE = Symbol.for(\"react.client.reference\");\n exports.ContextConsumer = REACT_CONSUMER_TYPE;\n exports.ContextProvider = REACT_CONTEXT_TYPE;\n exports.Element = REACT_ELEMENT_TYPE;\n exports.ForwardRef = REACT_FORWARD_REF_TYPE;\n exports.Fragment = REACT_FRAGMENT_TYPE;\n exports.Lazy = REACT_LAZY_TYPE;\n exports.Memo = REACT_MEMO_TYPE;\n exports.Portal = REACT_PORTAL_TYPE;\n exports.Profiler = REACT_PROFILER_TYPE;\n exports.StrictMode = REACT_STRICT_MODE_TYPE;\n exports.Suspense = REACT_SUSPENSE_TYPE;\n exports.SuspenseList = REACT_SUSPENSE_LIST_TYPE;\n exports.isContextConsumer = function (object) {\n return typeOf(object) === REACT_CONSUMER_TYPE;\n };\n exports.isContextProvider = function (object) {\n return typeOf(object) === REACT_CONTEXT_TYPE;\n };\n exports.isElement = function (object) {\n return (\n \"object\" === typeof object &&\n null !== object &&\n object.$$typeof === REACT_ELEMENT_TYPE\n );\n };\n exports.isForwardRef = function (object) {\n return typeOf(object) === REACT_FORWARD_REF_TYPE;\n };\n exports.isFragment = function (object) {\n return typeOf(object) === REACT_FRAGMENT_TYPE;\n };\n exports.isLazy = function (object) {\n return typeOf(object) === REACT_LAZY_TYPE;\n };\n exports.isMemo = function (object) {\n return typeOf(object) === REACT_MEMO_TYPE;\n };\n exports.isPortal = function (object) {\n return typeOf(object) === REACT_PORTAL_TYPE;\n };\n exports.isProfiler = function (object) {\n return typeOf(object) === REACT_PROFILER_TYPE;\n };\n exports.isStrictMode = function (object) {\n return typeOf(object) === REACT_STRICT_MODE_TYPE;\n };\n exports.isSuspense = function (object) {\n return typeOf(object) === REACT_SUSPENSE_TYPE;\n };\n exports.isSuspenseList = function (object) {\n return typeOf(object) === REACT_SUSPENSE_LIST_TYPE;\n };\n exports.isValidElementType = function (type) {\n return \"string\" === typeof type ||\n \"function\" === typeof type ||\n type === REACT_FRAGMENT_TYPE ||\n type === REACT_PROFILER_TYPE ||\n type === REACT_STRICT_MODE_TYPE ||\n type === REACT_SUSPENSE_TYPE ||\n type === REACT_SUSPENSE_LIST_TYPE ||\n (\"object\" === typeof type &&\n null !== type &&\n (type.$$typeof === REACT_LAZY_TYPE ||\n type.$$typeof === REACT_MEMO_TYPE ||\n type.$$typeof === REACT_CONTEXT_TYPE ||\n type.$$typeof === REACT_CONSUMER_TYPE ||\n type.$$typeof === REACT_FORWARD_REF_TYPE ||\n type.$$typeof === REACT_CLIENT_REFERENCE ||\n void 0 !== type.getModuleId))\n ? !0\n : !1;\n };\n exports.typeOf = typeOf;\n })();\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-is.production.js');\n} else {\n module.exports = require('./cjs/react-is.development.js');\n}\n","import * as React from 'react';\nimport { isValidElementType } from 'react-is';\n\n// https://github.com/sindresorhus/is-plain-obj/blob/main/index.js\nexport function isPlainObject(item) {\n if (typeof item !== 'object' || item === null) {\n return false;\n }\n const prototype = Object.getPrototypeOf(item);\n return (prototype === null || prototype === Object.prototype || Object.getPrototypeOf(prototype) === null) && !(Symbol.toStringTag in item) && !(Symbol.iterator in item);\n}\nfunction deepClone(source) {\n if (/*#__PURE__*/React.isValidElement(source) || isValidElementType(source) || !isPlainObject(source)) {\n return source;\n }\n const output = {};\n Object.keys(source).forEach(key => {\n output[key] = deepClone(source[key]);\n });\n return output;\n}\n\n/**\n * Merge objects deeply.\n * It will shallow copy React elements.\n *\n * If `options.clone` is set to `false` the source object will be merged directly into the target object.\n *\n * @example\n * ```ts\n * deepmerge({ a: { b: 1 }, d: 2 }, { a: { c: 2 }, d: 4 });\n * // => { a: { b: 1, c: 2 }, d: 4 }\n * ````\n *\n * @param target The target object.\n * @param source The source object.\n * @param options The merge options.\n * @param options.clone Set to `false` to merge the source object directly into the target object.\n * @returns The merged object.\n */\nexport default function deepmerge(target, source, options = {\n clone: true\n}) {\n const output = options.clone ? {\n ...target\n } : target;\n if (isPlainObject(target) && isPlainObject(source)) {\n Object.keys(source).forEach(key => {\n if (/*#__PURE__*/React.isValidElement(source[key]) || isValidElementType(source[key])) {\n output[key] = source[key];\n } else if (isPlainObject(source[key]) &&\n // Avoid prototype pollution\n Object.prototype.hasOwnProperty.call(target, key) && isPlainObject(target[key])) {\n // Since `output` is a clone of `target` and we have narrowed `target` in this block we can cast to the same type.\n output[key] = deepmerge(target[key], source[key], options);\n } else if (options.clone) {\n output[key] = isPlainObject(source[key]) ? deepClone(source[key]) : source[key];\n } else {\n output[key] = source[key];\n }\n });\n }\n return output;\n}","// Sorted ASC by size. That's important.\n// It can't be configured as it's used statically for propTypes.\nexport const breakpointKeys = ['xs', 'sm', 'md', 'lg', 'xl'];\nconst sortBreakpointsValues = values => {\n const breakpointsAsArray = Object.keys(values).map(key => ({\n key,\n val: values[key]\n })) || [];\n // Sort in ascending order\n breakpointsAsArray.sort((breakpoint1, breakpoint2) => breakpoint1.val - breakpoint2.val);\n return breakpointsAsArray.reduce((acc, obj) => {\n return {\n ...acc,\n [obj.key]: obj.val\n };\n }, {});\n};\n\n// Keep in mind that @media is inclusive by the CSS specification.\nexport default function createBreakpoints(breakpoints) {\n const {\n // The breakpoint **start** at this value.\n // For instance with the first breakpoint xs: [xs, sm).\n values = {\n xs: 0,\n // phone\n sm: 600,\n // tablet\n md: 900,\n // small laptop\n lg: 1200,\n // desktop\n xl: 1536 // large screen\n },\n unit = 'px',\n step = 5,\n ...other\n } = breakpoints;\n const sortedValues = sortBreakpointsValues(values);\n const keys = Object.keys(sortedValues);\n function up(key) {\n const value = typeof values[key] === 'number' ? values[key] : key;\n return `@media (min-width:${value}${unit})`;\n }\n function down(key) {\n const value = typeof values[key] === 'number' ? values[key] : key;\n return `@media (max-width:${value - step / 100}${unit})`;\n }\n function between(start, end) {\n const endIndex = keys.indexOf(end);\n return `@media (min-width:${typeof values[start] === 'number' ? values[start] : start}${unit}) and ` + `(max-width:${(endIndex !== -1 && typeof values[keys[endIndex]] === 'number' ? values[keys[endIndex]] : end) - step / 100}${unit})`;\n }\n function only(key) {\n if (keys.indexOf(key) + 1 < keys.length) {\n return between(key, keys[keys.indexOf(key) + 1]);\n }\n return up(key);\n }\n function not(key) {\n // handle first and last key separately, for better readability\n const keyIndex = keys.indexOf(key);\n if (keyIndex === 0) {\n return up(keys[1]);\n }\n if (keyIndex === keys.length - 1) {\n return down(keys[keyIndex]);\n }\n return between(key, keys[keys.indexOf(key) + 1]).replace('@media', '@media not all and');\n }\n return {\n keys,\n values: sortedValues,\n up,\n down,\n between,\n only,\n not,\n unit,\n ...other\n };\n}","const shape = {\n borderRadius: 4\n};\nexport default shape;","import PropTypes from 'prop-types';\nconst responsivePropType = process.env.NODE_ENV !== 'production' ? PropTypes.oneOfType([PropTypes.number, PropTypes.string, PropTypes.object, PropTypes.array]) : {};\nexport default responsivePropType;","import deepmerge from '@mui/utils/deepmerge';\nfunction merge(acc, item) {\n if (!item) {\n return acc;\n }\n return deepmerge(acc, item, {\n clone: false // No need to clone deep, it's way faster.\n });\n}\nexport default merge;","import PropTypes from 'prop-types';\nimport deepmerge from '@mui/utils/deepmerge';\nimport merge from \"../merge/index.js\";\nimport { isCqShorthand, getContainerQuery } from \"../cssContainerQueries/index.js\";\n\n// The breakpoint **start** at this value.\n// For instance with the first breakpoint xs: [xs, sm[.\nexport const values = {\n xs: 0,\n // phone\n sm: 600,\n // tablet\n md: 900,\n // small laptop\n lg: 1200,\n // desktop\n xl: 1536 // large screen\n};\nconst defaultBreakpoints = {\n // Sorted ASC by size. That's important.\n // It can't be configured as it's used statically for propTypes.\n keys: ['xs', 'sm', 'md', 'lg', 'xl'],\n up: key => `@media (min-width:${values[key]}px)`\n};\nconst defaultContainerQueries = {\n containerQueries: containerName => ({\n up: key => {\n let result = typeof key === 'number' ? key : values[key] || key;\n if (typeof result === 'number') {\n result = `${result}px`;\n }\n return containerName ? `@container ${containerName} (min-width:${result})` : `@container (min-width:${result})`;\n }\n })\n};\nexport function handleBreakpoints(props, propValue, styleFromPropValue) {\n const theme = props.theme || {};\n if (Array.isArray(propValue)) {\n const themeBreakpoints = theme.breakpoints || defaultBreakpoints;\n return propValue.reduce((acc, item, index) => {\n acc[themeBreakpoints.up(themeBreakpoints.keys[index])] = styleFromPropValue(propValue[index]);\n return acc;\n }, {});\n }\n if (typeof propValue === 'object') {\n const themeBreakpoints = theme.breakpoints || defaultBreakpoints;\n return Object.keys(propValue).reduce((acc, breakpoint) => {\n if (isCqShorthand(themeBreakpoints.keys, breakpoint)) {\n const containerKey = getContainerQuery(theme.containerQueries ? theme : defaultContainerQueries, breakpoint);\n if (containerKey) {\n acc[containerKey] = styleFromPropValue(propValue[breakpoint], breakpoint);\n }\n }\n // key is breakpoint\n else if (Object.keys(themeBreakpoints.values || values).includes(breakpoint)) {\n const mediaKey = themeBreakpoints.up(breakpoint);\n acc[mediaKey] = styleFromPropValue(propValue[breakpoint], breakpoint);\n } else {\n const cssKey = breakpoint;\n acc[cssKey] = propValue[cssKey];\n }\n return acc;\n }, {});\n }\n const output = styleFromPropValue(propValue);\n return output;\n}\nfunction breakpoints(styleFunction) {\n // false positive\n // eslint-disable-next-line react/function-component-definition\n const newStyleFunction = props => {\n const theme = props.theme || {};\n const base = styleFunction(props);\n const themeBreakpoints = theme.breakpoints || defaultBreakpoints;\n const extended = themeBreakpoints.keys.reduce((acc, key) => {\n if (props[key]) {\n acc = acc || {};\n acc[themeBreakpoints.up(key)] = styleFunction({\n theme,\n ...props[key]\n });\n }\n return acc;\n }, null);\n return merge(base, extended);\n };\n newStyleFunction.propTypes = process.env.NODE_ENV !== 'production' ? {\n ...styleFunction.propTypes,\n xs: PropTypes.object,\n sm: PropTypes.object,\n md: PropTypes.object,\n lg: PropTypes.object,\n xl: PropTypes.object\n } : {};\n newStyleFunction.filterProps = ['xs', 'sm', 'md', 'lg', 'xl', ...styleFunction.filterProps];\n return newStyleFunction;\n}\nexport function createEmptyBreakpointObject(breakpointsInput = {}) {\n const breakpointsInOrder = breakpointsInput.keys?.reduce((acc, key) => {\n const breakpointStyleKey = breakpointsInput.up(key);\n acc[breakpointStyleKey] = {};\n return acc;\n }, {});\n return breakpointsInOrder || {};\n}\nexport function removeUnusedBreakpoints(breakpointKeys, style) {\n return breakpointKeys.reduce((acc, key) => {\n const breakpointOutput = acc[key];\n const isBreakpointUnused = !breakpointOutput || Object.keys(breakpointOutput).length === 0;\n if (isBreakpointUnused) {\n delete acc[key];\n }\n return acc;\n }, style);\n}\nexport function mergeBreakpointsInOrder(breakpointsInput, ...styles) {\n const emptyBreakpoints = createEmptyBreakpointObject(breakpointsInput);\n const mergedOutput = [emptyBreakpoints, ...styles].reduce((prev, next) => deepmerge(prev, next), {});\n return removeUnusedBreakpoints(Object.keys(emptyBreakpoints), mergedOutput);\n}\n\n// compute base for responsive values; e.g.,\n// [1,2,3] => {xs: true, sm: true, md: true}\n// {xs: 1, sm: 2, md: 3} => {xs: true, sm: true, md: true}\nexport function computeBreakpointsBase(breakpointValues, themeBreakpoints) {\n // fixed value\n if (typeof breakpointValues !== 'object') {\n return {};\n }\n const base = {};\n const breakpointsKeys = Object.keys(themeBreakpoints);\n if (Array.isArray(breakpointValues)) {\n breakpointsKeys.forEach((breakpoint, i) => {\n if (i < breakpointValues.length) {\n base[breakpoint] = true;\n }\n });\n } else {\n breakpointsKeys.forEach(breakpoint => {\n if (breakpointValues[breakpoint] != null) {\n base[breakpoint] = true;\n }\n });\n }\n return base;\n}\nexport function resolveBreakpointValues({\n values: breakpointValues,\n breakpoints: themeBreakpoints,\n base: customBase\n}) {\n const base = customBase || computeBreakpointsBase(breakpointValues, themeBreakpoints);\n const keys = Object.keys(base);\n if (keys.length === 0) {\n return breakpointValues;\n }\n let previous;\n return keys.reduce((acc, breakpoint, i) => {\n if (Array.isArray(breakpointValues)) {\n acc[breakpoint] = breakpointValues[i] != null ? breakpointValues[i] : breakpointValues[previous];\n previous = i;\n } else if (typeof breakpointValues === 'object') {\n acc[breakpoint] = breakpointValues[breakpoint] != null ? breakpointValues[breakpoint] : breakpointValues[previous];\n previous = breakpoint;\n } else {\n acc[breakpoint] = breakpointValues;\n }\n return acc;\n }, {});\n}\nexport default breakpoints;","import _formatErrorMessage from \"@mui/utils/formatMuiErrorMessage\";\n/**\n * For using in `sx` prop to sort the breakpoint from low to high.\n * Note: this function does not work and will not support multiple units.\n * e.g. input: { '@container (min-width:300px)': '1rem', '@container (min-width:40rem)': '2rem' }\n * output: { '@container (min-width:40rem)': '2rem', '@container (min-width:300px)': '1rem' } // since 40 < 300 eventhough 40rem > 300px\n */\nexport function sortContainerQueries(theme, css) {\n if (!theme.containerQueries) {\n return css;\n }\n const sorted = Object.keys(css).filter(key => key.startsWith('@container')).sort((a, b) => {\n const regex = /min-width:\\s*([0-9.]+)/;\n return +(a.match(regex)?.[1] || 0) - +(b.match(regex)?.[1] || 0);\n });\n if (!sorted.length) {\n return css;\n }\n return sorted.reduce((acc, key) => {\n const value = css[key];\n delete acc[key];\n acc[key] = value;\n return acc;\n }, {\n ...css\n });\n}\nexport function isCqShorthand(breakpointKeys, value) {\n return value === '@' || value.startsWith('@') && (breakpointKeys.some(key => value.startsWith(`@${key}`)) || !!value.match(/^@\\d/));\n}\nexport function getContainerQuery(theme, shorthand) {\n const matches = shorthand.match(/^@([^/]+)?\\/?(.+)?$/);\n if (!matches) {\n if (process.env.NODE_ENV !== 'production') {\n throw new Error(process.env.NODE_ENV !== \"production\" ? `MUI: The provided shorthand ${`(${shorthand})`} is invalid. The format should be \\`@<breakpoint | number>\\` or \\`@<breakpoint | number>/<container>\\`.\\n` + 'For example, `@sm` or `@600` or `@40rem/sidebar`.' : _formatErrorMessage(18, `(${shorthand})`));\n }\n return null;\n }\n const [, containerQuery, containerName] = matches;\n const value = Number.isNaN(+containerQuery) ? containerQuery || 0 : +containerQuery;\n return theme.containerQueries(containerName).up(value);\n}\nexport default function cssContainerQueries(themeInput) {\n const toContainerQuery = (mediaQuery, name) => mediaQuery.replace('@media', name ? `@container ${name}` : '@container');\n function attachCq(node, name) {\n node.up = (...args) => toContainerQuery(themeInput.breakpoints.up(...args), name);\n node.down = (...args) => toContainerQuery(themeInput.breakpoints.down(...args), name);\n node.between = (...args) => toContainerQuery(themeInput.breakpoints.between(...args), name);\n node.only = (...args) => toContainerQuery(themeInput.breakpoints.only(...args), name);\n node.not = (...args) => {\n const result = toContainerQuery(themeInput.breakpoints.not(...args), name);\n if (result.includes('not all and')) {\n // `@container` does not work with `not all and`, so need to invert the logic\n return result.replace('not all and ', '').replace('min-width:', 'width<').replace('max-width:', 'width>').replace('and', 'or');\n }\n return result;\n };\n }\n const node = {};\n const containerQueries = name => {\n attachCq(node, name);\n return node;\n };\n attachCq(containerQueries);\n return {\n ...themeInput,\n containerQueries\n };\n}","import _formatErrorMessage from \"@mui/utils/formatMuiErrorMessage\";\n// It should to be noted that this function isn't equivalent to `text-transform: capitalize`.\n//\n// A strict capitalization should uppercase the first letter of each word in the sentence.\n// We only handle the first word.\nexport default function capitalize(string) {\n if (typeof string !== 'string') {\n throw new Error(process.env.NODE_ENV !== \"production\" ? 'MUI: `capitalize(string)` expects a string argument.' : _formatErrorMessage(7));\n }\n return string.charAt(0).toUpperCase() + string.slice(1);\n}","import capitalize from '@mui/utils/capitalize';\nimport responsivePropType from \"../responsivePropType/index.js\";\nimport { handleBreakpoints } from \"../breakpoints/index.js\";\nexport function getPath(obj, path, checkVars = true) {\n if (!path || typeof path !== 'string') {\n return null;\n }\n\n // Check if CSS variables are used\n if (obj && obj.vars && checkVars) {\n const val = `vars.${path}`.split('.').reduce((acc, item) => acc && acc[item] ? acc[item] : null, obj);\n if (val != null) {\n return val;\n }\n }\n return path.split('.').reduce((acc, item) => {\n if (acc && acc[item] != null) {\n return acc[item];\n }\n return null;\n }, obj);\n}\nexport function getStyleValue(themeMapping, transform, propValueFinal, userValue = propValueFinal) {\n let value;\n if (typeof themeMapping === 'function') {\n value = themeMapping(propValueFinal);\n } else if (Array.isArray(themeMapping)) {\n value = themeMapping[propValueFinal] || userValue;\n } else {\n value = getPath(themeMapping, propValueFinal) || userValue;\n }\n if (transform) {\n value = transform(value, userValue, themeMapping);\n }\n return value;\n}\nfunction style(options) {\n const {\n prop,\n cssProperty = options.prop,\n themeKey,\n transform\n } = options;\n\n // false positive\n // eslint-disable-next-line react/function-component-definition\n const fn = props => {\n if (props[prop] == null) {\n return null;\n }\n const propValue = props[prop];\n const theme = props.theme;\n const themeMapping = getPath(theme, themeKey) || {};\n const styleFromPropValue = propValueFinal => {\n let value = getStyleValue(themeMapping, transform, propValueFinal);\n if (propValueFinal === value && typeof propValueFinal === 'string') {\n // Haven't found value\n value = getStyleValue(themeMapping, transform, `${prop}${propValueFinal === 'default' ? '' : capitalize(propValueFinal)}`, propValueFinal);\n }\n if (cssProperty === false) {\n return value;\n }\n return {\n [cssProperty]: value\n };\n };\n return handleBreakpoints(props, propValue, styleFromPropValue);\n };\n fn.propTypes = process.env.NODE_ENV !== 'production' ? {\n [prop]: responsivePropType\n } : {};\n fn.filterProps = [prop];\n return fn;\n}\nexport default style;","import responsivePropType from \"../responsivePropType/index.js\";\nimport { handleBreakpoints } from \"../breakpoints/index.js\";\nimport { getPath } from \"../style/index.js\";\nimport merge from \"../merge/index.js\";\nimport memoize from \"../memoize/index.js\";\nconst properties = {\n m: 'margin',\n p: 'padding'\n};\nconst directions = {\n t: 'Top',\n r: 'Right',\n b: 'Bottom',\n l: 'Left',\n x: ['Left', 'Right'],\n y: ['Top', 'Bottom']\n};\nconst aliases = {\n marginX: 'mx',\n marginY: 'my',\n paddingX: 'px',\n paddingY: 'py'\n};\n\n// memoize() impact:\n// From 300,000 ops/sec\n// To 350,000 ops/sec\nconst getCssProperties = memoize(prop => {\n // It's not a shorthand notation.\n if (prop.length > 2) {\n if (aliases[prop]) {\n prop = aliases[prop];\n } else {\n return [prop];\n }\n }\n const [a, b] = prop.split('');\n const property = properties[a];\n const direction = directions[b] || '';\n return Array.isArray(direction) ? direction.map(dir => property + dir) : [property + direction];\n});\nexport const marginKeys = ['m', 'mt', 'mr', 'mb', 'ml', 'mx', 'my', 'margin', 'marginTop', 'marginRight', 'marginBottom', 'marginLeft', 'marginX', 'marginY', 'marginInline', 'marginInlineStart', 'marginInlineEnd', 'marginBlock', 'marginBlockStart', 'marginBlockEnd'];\nexport const paddingKeys = ['p', 'pt', 'pr', 'pb', 'pl', 'px', 'py', 'padding', 'paddingTop', 'paddingRight', 'paddingBottom', 'paddingLeft', 'paddingX', 'paddingY', 'paddingInline', 'paddingInlineStart', 'paddingInlineEnd', 'paddingBlock', 'paddingBlockStart', 'paddingBlockEnd'];\nconst spacingKeys = [...marginKeys, ...paddingKeys];\nexport function createUnaryUnit(theme, themeKey, defaultValue, propName) {\n const themeSpacing = getPath(theme, themeKey, true) ?? defaultValue;\n if (typeof themeSpacing === 'number' || typeof themeSpacing === 'string') {\n return val => {\n if (typeof val === 'string') {\n return val;\n }\n if (process.env.NODE_ENV !== 'production') {\n if (typeof val !== 'number') {\n console.error(`MUI: Expected ${propName} argument to be a number or a string, got ${val}.`);\n }\n }\n if (typeof themeSpacing === 'string') {\n if (themeSpacing.startsWith('var(') && val === 0) {\n return 0;\n }\n if (themeSpacing.startsWith('var(') && val === 1) {\n return themeSpacing;\n }\n return `calc(${val} * ${themeSpacing})`;\n }\n return themeSpacing * val;\n };\n }\n if (Array.isArray(themeSpacing)) {\n return val => {\n if (typeof val === 'string') {\n return val;\n }\n const abs = Math.abs(val);\n if (process.env.NODE_ENV !== 'production') {\n if (!Number.isInteger(abs)) {\n console.error([`MUI: The \\`theme.${themeKey}\\` array type cannot be combined with non integer values.` + `You should either use an integer value that can be used as index, or define the \\`theme.${themeKey}\\` as a number.`].join('\\n'));\n } else if (abs > themeSpacing.length - 1) {\n console.error([`MUI: The value provided (${abs}) overflows.`, `The supported values are: ${JSON.stringify(themeSpacing)}.`, `${abs} > ${themeSpacing.length - 1}, you need to add the missing values.`].join('\\n'));\n }\n }\n const transformed = themeSpacing[abs];\n if (val >= 0) {\n return transformed;\n }\n if (typeof transformed === 'number') {\n return -transformed;\n }\n if (typeof transformed === 'string' && transformed.startsWith('var(')) {\n return `calc(-1 * ${transformed})`;\n }\n return `-${transformed}`;\n };\n }\n if (typeof themeSpacing === 'function') {\n return themeSpacing;\n }\n if (process.env.NODE_ENV !== 'production') {\n console.error([`MUI: The \\`theme.${themeKey}\\` value (${themeSpacing}) is invalid.`, 'It should be a number, an array or a function.'].join('\\n'));\n }\n return () => undefined;\n}\nexport function createUnarySpacing(theme) {\n return createUnaryUnit(theme, 'spacing', 8, 'spacing');\n}\nexport function getValue(transformer, propValue) {\n if (typeof propValue === 'string' || propValue == null) {\n return propValue;\n }\n return transformer(propValue);\n}\nexport function getStyleFromPropValue(cssProperties, transformer) {\n return propValue => cssProperties.reduce((acc, cssProperty) => {\n acc[cssProperty] = getValue(transformer, propValue);\n return acc;\n }, {});\n}\nfunction resolveCssProperty(props, keys, prop, transformer) {\n // Using a hash computation over an array iteration could be faster, but with only 28 items,\n // it's doesn't worth the bundle size.\n if (!keys.includes(prop)) {\n return null;\n }\n const cssProperties = getCssProperties(prop);\n const styleFromPropValue = getStyleFromPropValue(cssProperties, transformer);\n const propValue = props[prop];\n return handleBreakpoints(props, propValue, styleFromPropValue);\n}\nfunction style(props, keys) {\n const transformer = createUnarySpacing(props.theme);\n return Object.keys(props).map(prop => resolveCssProperty(props, keys, prop, transformer)).reduce(merge, {});\n}\nexport function margin(props) {\n return style(props, marginKeys);\n}\nmargin.propTypes = process.env.NODE_ENV !== 'production' ? marginKeys.reduce((obj, key) => {\n obj[key] = responsivePropType;\n return obj;\n}, {}) : {};\nmargin.filterProps = marginKeys;\nexport function padding(props) {\n return style(props, paddingKeys);\n}\npadding.propTypes = process.env.NODE_ENV !== 'production' ? paddingKeys.reduce((obj, key) => {\n obj[key] = responsivePropType;\n return obj;\n}, {}) : {};\npadding.filterProps = paddingKeys;\nfunction spacing(props) {\n return style(props, spacingKeys);\n}\nspacing.propTypes = process.env.NODE_ENV !== 'production' ? spacingKeys.reduce((obj, key) => {\n obj[key] = responsivePropType;\n return obj;\n}, {}) : {};\nspacing.filterProps = spacingKeys;\nexport default spacing;","export default function memoize(fn) {\n const cache = {};\n return arg => {\n if (cache[arg] === undefined) {\n cache[arg] = fn(arg);\n }\n return cache[arg];\n };\n}","import merge from \"../merge/index.js\";\nfunction compose(...styles) {\n const handlers = styles.reduce((acc, style) => {\n style.filterProps.forEach(prop => {\n acc[prop] = style;\n });\n return acc;\n }, {});\n\n // false positive\n // eslint-disable-next-line react/function-component-definition\n const fn = props => {\n return Object.keys(props).reduce((acc, prop) => {\n if (handlers[prop]) {\n return merge(acc, handlers[prop](props));\n }\n return acc;\n }, {});\n };\n fn.propTypes = process.env.NODE_ENV !== 'production' ? styles.reduce((acc, style) => Object.assign(acc, style.propTypes), {}) : {};\n fn.filterProps = styles.reduce((acc, style) => acc.concat(style.filterProps), []);\n return fn;\n}\nexport default compose;","import responsivePropType from \"../responsivePropType/index.js\";\nimport style from \"../style/index.js\";\nimport compose from \"../compose/index.js\";\nimport { createUnaryUnit, getValue } from \"../spacing/index.js\";\nimport { handleBreakpoints } from \"../breakpoints/index.js\";\nexport function borderTransform(value) {\n if (typeof value !== 'number') {\n return value;\n }\n return `${value}px solid`;\n}\nfunction createBorderStyle(prop, transform) {\n return style({\n prop,\n themeKey: 'borders',\n transform\n });\n}\nexport const border = createBorderStyle('border', borderTransform);\nexport const borderTop = createBorderStyle('borderTop', borderTransform);\nexport const borderRight = createBorderStyle('borderRight', borderTransform);\nexport const borderBottom = createBorderStyle('borderBottom', borderTransform);\nexport const borderLeft = createBorderStyle('borderLeft', borderTransform);\nexport const borderColor = createBorderStyle('borderColor');\nexport const borderTopColor = createBorderStyle('borderTopColor');\nexport const borderRightColor = createBorderStyle('borderRightColor');\nexport const borderBottomColor = createBorderStyle('borderBottomColor');\nexport const borderLeftColor = createBorderStyle('borderLeftColor');\nexport const outline = createBorderStyle('outline', borderTransform);\nexport const outlineColor = createBorderStyle('outlineColor');\n\n// false positive\n// eslint-disable-next-line react/function-component-definition\nexport const borderRadius = props => {\n if (props.borderRadius !== undefined && props.borderRadius !== null) {\n const transformer = createUnaryUnit(props.theme, 'shape.borderRadius', 4, 'borderRadius');\n const styleFromPropValue = propValue => ({\n borderRadius: getValue(transformer, propValue)\n });\n return handleBreakpoints(props, props.borderRadius, styleFromPropValue);\n }\n return null;\n};\nborderRadius.propTypes = process.env.NODE_ENV !== 'production' ? {\n borderRadius: responsivePropType\n} : {};\nborderRadius.filterProps = ['borderRadius'];\nconst borders = compose(border, borderTop, borderRight, borderBottom, borderLeft, borderColor, borderTopColor, borderRightColor, borderBottomColor, borderLeftColor, borderRadius, outline, outlineColor);\nexport default borders;","import style from \"../style/index.js\";\nimport compose from \"../compose/index.js\";\nimport { createUnaryUnit, getValue } from \"../spacing/index.js\";\nimport { handleBreakpoints } from \"../breakpoints/index.js\";\nimport responsivePropType from \"../responsivePropType/index.js\";\n\n// false positive\n// eslint-disable-next-line react/function-component-definition\nexport const gap = props => {\n if (props.gap !== undefined && props.gap !== null) {\n const transformer = createUnaryUnit(props.theme, 'spacing', 8, 'gap');\n const styleFromPropValue = propValue => ({\n gap: getValue(transformer, propValue)\n });\n return handleBreakpoints(props, props.gap, styleFromPropValue);\n }\n return null;\n};\ngap.propTypes = process.env.NODE_ENV !== 'production' ? {\n gap: responsivePropType\n} : {};\ngap.filterProps = ['gap'];\n\n// false positive\n// eslint-disable-next-line react/function-component-definition\nexport const columnGap = props => {\n if (props.columnGap !== undefined && props.columnGap !== null) {\n const transformer = createUnaryUnit(props.theme, 'spacing', 8, 'columnGap');\n const styleFromPropValue = propValue => ({\n columnGap: getValue(transformer, propValue)\n });\n return handleBreakpoints(props, props.columnGap, styleFromPropValue);\n }\n return null;\n};\ncolumnGap.propTypes = process.env.NODE_ENV !== 'production' ? {\n columnGap: responsivePropType\n} : {};\ncolumnGap.filterProps = ['columnGap'];\n\n// false positive\n// eslint-disable-next-line react/function-component-definition\nexport const rowGap = props => {\n if (props.rowGap !== undefined && props.rowGap !== null) {\n const transformer = createUnaryUnit(props.theme, 'spacing', 8, 'rowGap');\n const styleFromPropValue = propValue => ({\n rowGap: getValue(transformer, propValue)\n });\n return handleBreakpoints(props, props.rowGap, styleFromPropValue);\n }\n return null;\n};\nrowGap.propTypes = process.env.NODE_ENV !== 'production' ? {\n rowGap: responsivePropType\n} : {};\nrowGap.filterProps = ['rowGap'];\nexport const gridColumn = style({\n prop: 'gridColumn'\n});\nexport const gridRow = style({\n prop: 'gridRow'\n});\nexport const gridAutoFlow = style({\n prop: 'gridAutoFlow'\n});\nexport const gridAutoColumns = style({\n prop: 'gridAutoColumns'\n});\nexport const gridAutoRows = style({\n prop: 'gridAutoRows'\n});\nexport const gridTemplateColumns = style({\n prop: 'gridTemplateColumns'\n});\nexport const gridTemplateRows = style({\n prop: 'gridTemplateRows'\n});\nexport const gridTemplateAreas = style({\n prop: 'gridTemplateAreas'\n});\nexport const gridArea = style({\n prop: 'gridArea'\n});\nconst grid = compose(gap, columnGap, rowGap, gridColumn, gridRow, gridAutoFlow, gridAutoColumns, gridAutoRows, gridTemplateColumns, gridTemplateRows, gridTemplateAreas, gridArea);\nexport default grid;","import style from \"../style/index.js\";\nimport compose from \"../compose/index.js\";\nexport function paletteTransform(value, userValue) {\n if (userValue === 'grey') {\n return userValue;\n }\n return value;\n}\nexport const color = style({\n prop: 'color',\n themeKey: 'palette',\n transform: paletteTransform\n});\nexport const bgcolor = style({\n prop: 'bgcolor',\n cssProperty: 'backgroundColor',\n themeKey: 'palette',\n transform: paletteTransform\n});\nexport const backgroundColor = style({\n prop: 'backgroundColor',\n themeKey: 'palette',\n transform: paletteTransform\n});\nconst palette = compose(color, bgcolor, backgroundColor);\nexport default palette;","import style from \"../style/index.js\";\nimport compose from \"../compose/index.js\";\nimport { handleBreakpoints, values as breakpointsValues } from \"../breakpoints/index.js\";\nexport function sizingTransform(value) {\n return value <= 1 && value !== 0 ? `${value * 100}%` : value;\n}\nexport const width = style({\n prop: 'width',\n transform: sizingTransform\n});\nexport const maxWidth = props => {\n if (props.maxWidth !== undefined && props.maxWidth !== null) {\n const styleFromPropValue = propValue => {\n const breakpoint = props.theme?.breakpoints?.values?.[propValue] || breakpointsValues[propValue];\n if (!breakpoint) {\n return {\n maxWidth: sizingTransform(propValue)\n };\n }\n if (props.theme?.breakpoints?.unit !== 'px') {\n return {\n maxWidth: `${breakpoint}${props.theme.breakpoints.unit}`\n };\n }\n return {\n maxWidth: breakpoint\n };\n };\n return handleBreakpoints(props, props.maxWidth, styleFromPropValue);\n }\n return null;\n};\nmaxWidth.filterProps = ['maxWidth'];\nexport const minWidth = style({\n prop: 'minWidth',\n transform: sizingTransform\n});\nexport const height = style({\n prop: 'height',\n transform: sizingTransform\n});\nexport const maxHeight = style({\n prop: 'maxHeight',\n transform: sizingTransform\n});\nexport const minHeight = style({\n prop: 'minHeight',\n transform: sizingTransform\n});\nexport const sizeWidth = style({\n prop: 'size',\n cssProperty: 'width',\n transform: sizingTransform\n});\nexport const sizeHeight = style({\n prop: 'size',\n cssProperty: 'height',\n transform: sizingTransform\n});\nexport const boxSizing = style({\n prop: 'boxSizing'\n});\nconst sizing = compose(width, maxWidth, minWidth, height, maxHeight, minHeight, boxSizing);\nexport default sizing;","import { padding, margin } from \"../spacing/index.js\";\nimport { borderRadius, borderTransform } from \"../borders/index.js\";\nimport { gap, rowGap, columnGap } from \"../cssGrid/index.js\";\nimport { paletteTransform } from \"../palette/index.js\";\nimport { maxWidth, sizingTransform } from \"../sizing/index.js\";\nconst defaultSxConfig = {\n // borders\n border: {\n themeKey: 'borders',\n transform: borderTransform\n },\n borderTop: {\n themeKey: 'borders',\n transform: borderTransform\n },\n borderRight: {\n themeKey: 'borders',\n transform: borderTransform\n },\n borderBottom: {\n themeKey: 'borders',\n transform: borderTransform\n },\n borderLeft: {\n themeKey: 'borders',\n transform: borderTransform\n },\n borderColor: {\n themeKey: 'palette'\n },\n borderTopColor: {\n themeKey: 'palette'\n },\n borderRightColor: {\n themeKey: 'palette'\n },\n borderBottomColor: {\n themeKey: 'palette'\n },\n borderLeftColor: {\n themeKey: 'palette'\n },\n outline: {\n themeKey: 'borders',\n transform: borderTransform\n },\n outlineColor: {\n themeKey: 'palette'\n },\n borderRadius: {\n themeKey: 'shape.borderRadius',\n style: borderRadius\n },\n // palette\n color: {\n themeKey: 'palette',\n transform: paletteTransform\n },\n bgcolor: {\n themeKey: 'palette',\n cssProperty: 'backgroundColor',\n transform: paletteTransform\n },\n backgroundColor: {\n themeKey: 'palette',\n transform: paletteTransform\n },\n // spacing\n p: {\n style: padding\n },\n pt: {\n style: padding\n },\n pr: {\n style: padding\n },\n pb: {\n style: padding\n },\n pl: {\n style: padding\n },\n px: {\n style: padding\n },\n py: {\n style: padding\n },\n padding: {\n style: padding\n },\n paddingTop: {\n style: padding\n },\n paddingRight: {\n style: padding\n },\n paddingBottom: {\n style: padding\n },\n paddingLeft: {\n style: padding\n },\n paddingX: {\n style: padding\n },\n paddingY: {\n style: padding\n },\n paddingInline: {\n style: padding\n },\n paddingInlineStart: {\n style: padding\n },\n paddingInlineEnd: {\n style: padding\n },\n paddingBlock: {\n style: padding\n },\n paddingBlockStart: {\n style: padding\n },\n paddingBlockEnd: {\n style: padding\n },\n m: {\n style: margin\n },\n mt: {\n style: margin\n },\n mr: {\n style: margin\n },\n mb: {\n style: margin\n },\n ml: {\n style: margin\n },\n mx: {\n style: margin\n },\n my: {\n style: margin\n },\n margin: {\n style: margin\n },\n marginTop: {\n style: margin\n },\n marginRight: {\n style: margin\n },\n marginBottom: {\n style: margin\n },\n marginLeft: {\n style: margin\n },\n marginX: {\n style: margin\n },\n marginY: {\n style: margin\n },\n marginInline: {\n style: margin\n },\n marginInlineStart: {\n style: margin\n },\n marginInlineEnd: {\n style: margin\n },\n marginBlock: {\n style: margin\n },\n marginBlockStart: {\n style: margin\n },\n marginBlockEnd: {\n style: margin\n },\n // display\n displayPrint: {\n cssProperty: false,\n transform: value => ({\n '@media print': {\n display: value\n }\n })\n },\n display: {},\n overflow: {},\n textOverflow: {},\n visibility: {},\n whiteSpace: {},\n // flexbox\n flexBasis: {},\n flexDirection: {},\n flexWrap: {},\n justifyContent: {},\n alignItems: {},\n alignContent: {},\n order: {},\n flex: {},\n flexGrow: {},\n flexShrink: {},\n alignSelf: {},\n justifyItems: {},\n justifySelf: {},\n // grid\n gap: {\n style: gap\n },\n rowGap: {\n style: rowGap\n },\n columnGap: {\n style: columnGap\n },\n gridColumn: {},\n gridRow: {},\n gridAutoFlow: {},\n gridAutoColumns: {},\n gridAutoRows: {},\n gridTemplateColumns: {},\n gridTemplateRows: {},\n gridTemplateAreas: {},\n gridArea: {},\n // positions\n position: {},\n zIndex: {\n themeKey: 'zIndex'\n },\n top: {},\n right: {},\n bottom: {},\n left: {},\n // shadows\n boxShadow: {\n themeKey: 'shadows'\n },\n // sizing\n width: {\n transform: sizingTransform\n },\n maxWidth: {\n style: maxWidth\n },\n minWidth: {\n transform: sizingTransform\n },\n height: {\n transform: sizingTransform\n },\n maxHeight: {\n transform: sizingTransform\n },\n minHeight: {\n transform: sizingTransform\n },\n boxSizing: {},\n // typography\n font: {\n themeKey: 'font'\n },\n fontFamily: {\n themeKey: 'typography'\n },\n fontSize: {\n themeKey: 'typography'\n },\n fontStyle: {\n themeKey: 'typography'\n },\n fontWeight: {\n themeKey: 'typography'\n },\n letterSpacing: {},\n textTransform: {},\n lineHeight: {},\n textAlign: {},\n typography: {\n cssProperty: false,\n themeKey: 'typography'\n }\n};\nexport default defaultSxConfig;","import capitalize from '@mui/utils/capitalize';\nimport merge from \"../merge/index.js\";\nimport { getPath, getStyleValue as getValue } from \"../style/index.js\";\nimport { handleBreakpoints, createEmptyBreakpointObject, removeUnusedBreakpoints } from \"../breakpoints/index.js\";\nimport { sortContainerQueries } from \"../cssContainerQueries/index.js\";\nimport defaultSxConfig from \"./defaultSxConfig.js\";\nfunction objectsHaveSameKeys(...objects) {\n const allKeys = objects.reduce((keys, object) => keys.concat(Object.keys(object)), []);\n const union = new Set(allKeys);\n return objects.every(object => union.size === Object.keys(object).length);\n}\nfunction callIfFn(maybeFn, arg) {\n return typeof maybeFn === 'function' ? maybeFn(arg) : maybeFn;\n}\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport function unstable_createStyleFunctionSx() {\n function getThemeValue(prop, val, theme, config) {\n const props = {\n [prop]: val,\n theme\n };\n const options = config[prop];\n if (!options) {\n return {\n [prop]: val\n };\n }\n const {\n cssProperty = prop,\n themeKey,\n transform,\n style\n } = options;\n if (val == null) {\n return null;\n }\n\n // TODO v6: remove, see https://github.com/mui/material-ui/pull/38123\n if (themeKey === 'typography' && val === 'inherit') {\n return {\n [prop]: val\n };\n }\n const themeMapping = getPath(theme, themeKey) || {};\n if (style) {\n return style(props);\n }\n const styleFromPropValue = propValueFinal => {\n let value = getValue(themeMapping, transform, propValueFinal);\n if (propValueFinal === value && typeof propValueFinal === 'string') {\n // Haven't found value\n value = getValue(themeMapping, transform, `${prop}${propValueFinal === 'default' ? '' : capitalize(propValueFinal)}`, propValueFinal);\n }\n if (cssProperty === false) {\n return value;\n }\n return {\n [cssProperty]: value\n };\n };\n return handleBreakpoints(props, val, styleFromPropValue);\n }\n function styleFunctionSx(props) {\n const {\n sx,\n theme = {}\n } = props || {};\n if (!sx) {\n return null; // Emotion & styled-components will neglect null\n }\n const config = theme.unstable_sxConfig ?? defaultSxConfig;\n\n /*\n * Receive `sxInput` as object or callback\n * and then recursively check keys & values to create media query object styles.\n * (the result will be used in `styled`)\n */\n function traverse(sxInput) {\n let sxObject = sxInput;\n if (typeof sxInput === 'function') {\n sxObject = sxInput(theme);\n } else if (typeof sxInput !== 'object') {\n // value\n return sxInput;\n }\n if (!sxObject) {\n return null;\n }\n const emptyBreakpoints = createEmptyBreakpointObject(theme.breakpoints);\n const breakpointsKeys = Object.keys(emptyBreakpoints);\n let css = emptyBreakpoints;\n Object.keys(sxObject).forEach(styleKey => {\n const value = callIfFn(sxObject[styleKey], theme);\n if (value !== null && value !== undefined) {\n if (typeof value === 'object') {\n if (config[styleKey]) {\n css = merge(css, getThemeValue(styleKey, value, theme, config));\n } else {\n const breakpointsValues = handleBreakpoints({\n theme\n }, value, x => ({\n [styleKey]: x\n }));\n if (objectsHaveSameKeys(breakpointsValues, value)) {\n css[styleKey] = styleFunctionSx({\n sx: value,\n theme\n });\n } else {\n css = merge(css, breakpointsValues);\n }\n }\n } else {\n css = merge(css, getThemeValue(styleKey, value, theme, config));\n }\n }\n });\n return sortContainerQueries(theme, removeUnusedBreakpoints(breakpointsKeys, css));\n }\n return Array.isArray(sx) ? sx.map(traverse) : traverse(sx);\n }\n return styleFunctionSx;\n}\nconst styleFunctionSx = unstable_createStyleFunctionSx();\nstyleFunctionSx.filterProps = ['sx'];\nexport default styleFunctionSx;","/**\n * A universal utility to style components with multiple color modes. Always use it from the theme object.\n * It works with:\n * - [Basic theme](https://mui.com/material-ui/customization/dark-mode/)\n * - [CSS theme variables](https://mui.com/material-ui/customization/css-theme-variables/overview/)\n * - Zero-runtime engine\n *\n * Tips: Use an array over object spread and place `theme.applyStyles()` last.\n *\n * With the styled function:\n * ✅ [{ background: '#e5e5e5' }, theme.applyStyles('dark', { background: '#1c1c1c' })]\n * 🚫 { background: '#e5e5e5', ...theme.applyStyles('dark', { background: '#1c1c1c' })}\n *\n * With the sx prop:\n * ✅ [{ background: '#e5e5e5' }, theme => theme.applyStyles('dark', { background: '#1c1c1c' })]\n * 🚫 { background: '#e5e5e5', ...theme => theme.applyStyles('dark', { background: '#1c1c1c' })}\n *\n * @example\n * 1. using with `styled`:\n * ```jsx\n * const Component = styled('div')(({ theme }) => [\n * { background: '#e5e5e5' },\n * theme.applyStyles('dark', {\n * background: '#1c1c1c',\n * color: '#fff',\n * }),\n * ]);\n * ```\n *\n * @example\n * 2. using with `sx` prop:\n * ```jsx\n * <Box sx={[\n * { background: '#e5e5e5' },\n * theme => theme.applyStyles('dark', {\n * background: '#1c1c1c',\n * color: '#fff',\n * }),\n * ]}\n * />\n * ```\n *\n * @example\n * 3. theming a component:\n * ```jsx\n * extendTheme({\n * components: {\n * MuiButton: {\n * styleOverrides: {\n * root: ({ theme }) => [\n * { background: '#e5e5e5' },\n * theme.applyStyles('dark', {\n * background: '#1c1c1c',\n * color: '#fff',\n * }),\n * ],\n * },\n * }\n * }\n * })\n *```\n */\nexport default function applyStyles(key, styles) {\n // @ts-expect-error this is 'any' type\n const theme = this;\n if (theme.vars) {\n if (!theme.colorSchemes?.[key] || typeof theme.getColorSchemeSelector !== 'function') {\n return {};\n }\n // If CssVarsProvider is used as a provider, returns '*:where({selector}) &'\n let selector = theme.getColorSchemeSelector(key);\n if (selector === '&') {\n return styles;\n }\n if (selector.includes('data-') || selector.includes('.')) {\n // '*' is required as a workaround for Emotion issue (https://github.com/emotion-js/emotion/issues/2836)\n selector = `*:where(${selector.replace(/\\s*&$/, '')}) &`;\n }\n return {\n [selector]: styles\n };\n }\n if (theme.palette.mode === key) {\n return styles;\n }\n return {};\n}","'use client';\n\nimport * as React from 'react';\nimport { ThemeContext } from '@mui/styled-engine';\nfunction isObjectEmpty(obj) {\n return Object.keys(obj).length === 0;\n}\nfunction useTheme(defaultTheme = null) {\n const contextTheme = React.useContext(ThemeContext);\n return !contextTheme || isObjectEmpty(contextTheme) ? defaultTheme : contextTheme;\n}\nexport default useTheme;","'use client';\n\nimport createTheme from \"../createTheme/index.js\";\nimport useThemeWithoutDefault from \"../useThemeWithoutDefault/index.js\";\nexport const systemDefaultTheme = createTheme();\nfunction useTheme(defaultTheme = systemDefaultTheme) {\n return useThemeWithoutDefault(defaultTheme);\n}\nexport default useTheme;","import deepmerge from '@mui/utils/deepmerge';\nimport createBreakpoints from \"../createBreakpoints/createBreakpoints.js\";\nimport cssContainerQueries from \"../cssContainerQueries/index.js\";\nimport shape from \"./shape.js\";\nimport createSpacing from \"./createSpacing.js\";\nimport styleFunctionSx from \"../styleFunctionSx/styleFunctionSx.js\";\nimport defaultSxConfig from \"../styleFunctionSx/defaultSxConfig.js\";\nimport applyStyles from \"./applyStyles.js\";\nfunction createTheme(options = {}, ...args) {\n const {\n breakpoints: breakpointsInput = {},\n palette: paletteInput = {},\n spacing: spacingInput,\n shape: shapeInput = {},\n ...other\n } = options;\n const breakpoints = createBreakpoints(breakpointsInput);\n const spacing = createSpacing(spacingInput);\n let muiTheme = deepmerge({\n breakpoints,\n direction: 'ltr',\n components: {},\n // Inject component definitions.\n palette: {\n mode: 'light',\n ...paletteInput\n },\n spacing,\n shape: {\n ...shape,\n ...shapeInput\n }\n }, other);\n muiTheme = cssContainerQueries(muiTheme);\n muiTheme.applyStyles = applyStyles;\n muiTheme = args.reduce((acc, argument) => deepmerge(acc, argument), muiTheme);\n muiTheme.unstable_sxConfig = {\n ...defaultSxConfig,\n ...other?.unstable_sxConfig\n };\n muiTheme.unstable_sx = function sx(props) {\n return styleFunctionSx({\n sx: props,\n theme: this\n });\n };\n return muiTheme;\n}\nexport default createTheme;","import { createUnarySpacing } from \"../spacing/index.js\";\n\n// The different signatures imply different meaning for their arguments that can't be expressed structurally.\n// We express the difference with variable names.\n\nexport default function createSpacing(spacingInput = 8,\n// Material Design layouts are visually balanced. Most measurements align to an 8dp grid, which aligns both spacing and the overall layout.\n// Smaller components, such as icons, can align to a 4dp grid.\n// https://m2.material.io/design/layout/understanding-layout.html\ntransform = createUnarySpacing({\n spacing: spacingInput\n})) {\n // Already transformed.\n if (spacingInput.mui) {\n return spacingInput;\n }\n const spacing = (...argsInput) => {\n if (process.env.NODE_ENV !== 'production') {\n if (!(argsInput.length <= 4)) {\n console.error(`MUI: Too many arguments provided, expected between 0 and 4, got ${argsInput.length}`);\n }\n }\n const args = argsInput.length === 0 ? [1] : argsInput;\n return args.map(argument => {\n const output = transform(argument);\n return typeof output === 'number' ? `${output}px` : output;\n }).join(' ');\n };\n spacing.mui = true;\n return spacing;\n}","import { isPlainObject } from '@mui/utils/deepmerge';\nimport defaultSxConfig from \"./defaultSxConfig.js\";\nconst splitProps = props => {\n const result = {\n systemProps: {},\n otherProps: {}\n };\n const config = props?.theme?.unstable_sxConfig ?? defaultSxConfig;\n Object.keys(props).forEach(prop => {\n if (config[prop]) {\n result.systemProps[prop] = props[prop];\n } else {\n result.otherProps[prop] = props[prop];\n }\n });\n return result;\n};\nexport default function extendSxProp(props) {\n const {\n sx: inSx,\n ...other\n } = props;\n const {\n systemProps,\n otherProps\n } = splitProps(other);\n let finalSx;\n if (Array.isArray(inSx)) {\n finalSx = [systemProps, ...inSx];\n } else if (typeof inSx === 'function') {\n finalSx = (...args) => {\n const result = inSx(...args);\n if (!isPlainObject(result)) {\n return systemProps;\n }\n return {\n ...systemProps,\n ...result\n };\n };\n } else {\n finalSx = {\n ...systemProps,\n ...inSx\n };\n }\n return {\n ...otherProps,\n sx: finalSx\n };\n}","const defaultGenerator = componentName => componentName;\nconst createClassNameGenerator = () => {\n let generate = defaultGenerator;\n return {\n configure(generator) {\n generate = generator;\n },\n generate(componentName) {\n return generate(componentName);\n },\n reset() {\n generate = defaultGenerator;\n }\n };\n};\nconst ClassNameGenerator = createClassNameGenerator();\nexport default ClassNameGenerator;","import ClassNameGenerator from \"../ClassNameGenerator/index.js\";\nexport const globalStateClasses = {\n active: 'active',\n checked: 'checked',\n completed: 'completed',\n disabled: 'disabled',\n error: 'error',\n expanded: 'expanded',\n focused: 'focused',\n focusVisible: 'focusVisible',\n open: 'open',\n readOnly: 'readOnly',\n required: 'required',\n selected: 'selected'\n};\nexport default function generateUtilityClass(componentName, slot, globalStatePrefix = 'Mui') {\n const globalStateClass = globalStateClasses[slot];\n return globalStateClass ? `${globalStatePrefix}-${globalStateClass}` : `${ClassNameGenerator.generate(componentName)}-${slot}`;\n}\nexport function isGlobalState(slot) {\n return globalStateClasses[slot] !== undefined;\n}","import generateUtilityClasses from '@mui/utils/generateUtilityClasses';\nconst boxClasses = generateUtilityClasses('MuiBox', ['root']);\nexport default boxClasses;","'use client';\n\nimport PropTypes from 'prop-types';\nimport ClassNameGenerator from '@mui/utils/ClassNameGenerator';\nimport createBox from \"../createBox/index.js\";\nimport boxClasses from \"./boxClasses.js\";\nconst Box = createBox({\n defaultClassName: boxClasses.root,\n generateClassName: ClassNameGenerator.generate\n});\nprocess.env.NODE_ENV !== \"production\" ? Box.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the d.ts file and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * @ignore\n */\n children: PropTypes.node,\n /**\n * The component used for the root node.\n * Either a string to use a HTML element or a component.\n */\n component: PropTypes.elementType,\n /**\n * The system prop that allows defining system overrides as well as additional CSS styles.\n */\n sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object])\n} : void 0;\nexport default Box;","'use client';\n\nimport * as React from 'react';\nimport clsx from 'clsx';\nimport styled from '@mui/styled-engine';\nimport styleFunctionSx, { extendSxProp } from \"../styleFunctionSx/index.js\";\nimport useTheme from \"../useTheme/index.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport default function createBox(options = {}) {\n const {\n themeId,\n defaultTheme,\n defaultClassName = 'MuiBox-root',\n generateClassName\n } = options;\n const BoxRoot = styled('div', {\n shouldForwardProp: prop => prop !== 'theme' && prop !== 'sx' && prop !== 'as'\n })(styleFunctionSx);\n const Box = /*#__PURE__*/React.forwardRef(function Box(inProps, ref) {\n const theme = useTheme(defaultTheme);\n const {\n className,\n component = 'div',\n ...other\n } = extendSxProp(inProps);\n return /*#__PURE__*/_jsx(BoxRoot, {\n as: component,\n ref: ref,\n className: clsx(className, generateClassName ? generateClassName(defaultClassName) : defaultClassName),\n theme: themeId ? theme[themeId] || theme : theme,\n ...other\n });\n });\n return Box;\n}","/**\n * @mui/styled-engine v7.1.0\n *\n * @license MIT\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use client';\n\n/* eslint-disable no-underscore-dangle */\nimport emStyled from '@emotion/styled';\nimport { serializeStyles as emSerializeStyles } from '@emotion/serialize';\nexport default function styled(tag, options) {\n const stylesFactory = emStyled(tag, options);\n if (process.env.NODE_ENV !== 'production') {\n return (...styles) => {\n const component = typeof tag === 'string' ? `\"${tag}\"` : 'component';\n if (styles.length === 0) {\n console.error([`MUI: Seems like you called \\`styled(${component})()\\` without a \\`style\\` argument.`, 'You must provide a `styles` argument: `styled(\"div\")(styleYouForgotToPass)`.'].join('\\n'));\n } else if (styles.some(style => style === undefined)) {\n console.error(`MUI: the styled(${component})(...args) API requires all its args to be defined.`);\n }\n return stylesFactory(...styles);\n };\n }\n return stylesFactory;\n}\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport function internal_mutateStyles(tag, processor) {\n // Emotion attaches all the styles as `__emotion_styles`.\n // Ref: https://github.com/emotion-js/emotion/blob/16d971d0da229596d6bcc39d282ba9753c9ee7cf/packages/styled/src/base.js#L186\n if (Array.isArray(tag.__emotion_styles)) {\n tag.__emotion_styles = processor(tag.__emotion_styles);\n }\n}\n\n// Emotion only accepts an array, but we want to avoid allocations\nconst wrapper = [];\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport function internal_serializeStyles(styles) {\n wrapper[0] = styles;\n return emSerializeStyles(wrapper);\n}\nexport { ThemeContext, keyframes, css } from '@emotion/react';\nexport { default as StyledEngineProvider } from \"./StyledEngineProvider/index.js\";\nexport { default as GlobalStyles } from \"./GlobalStyles/index.js\";","import generateUtilityClass from \"../generateUtilityClass/index.js\";\nexport default function generateUtilityClasses(componentName, slots, globalStatePrefix = 'Mui') {\n const result = {};\n slots.forEach(slot => {\n result[slot] = generateUtilityClass(componentName, slot, globalStatePrefix);\n });\n return result;\n}","import { TextField, TextFieldProps } from \"@mui/material\";\r\n\r\nconst TemplateTextField: React.FC<Omit<TextFieldProps, \"outlined\">> = (\r\n props\r\n) => {\r\n return <TextField {...props} slotProps={{ inputLabel: { shrink: true } }} />;\r\n};\r\n\r\nexport default TemplateTextField;\r\n","import { Grid2 } from \"@mui/material\";\r\nimport TemplateTextField from \"./FormFields/TemplateTextField\";\r\nimport Datefield from \"./FormFields/Datefield\";\r\nimport DatetimeField from \"./FormFields/DatetimeField\";\r\nimport ComboBox from \"./FormFields/ComboBox\";\r\nimport CheckBox from \"./FormFields/CheckBox\";\r\nimport { DATE_FORMAT, DATE_TIME_FORMAT } from \"../../../../util/constants\";\r\nimport { isNumeric } from \"../../../../util/AppUtils\";\r\nimport { FormElementFieldProps } from \"../DataEntryTypes\";\r\n\r\nconst FormElementField: React.FC<FormElementFieldProps> = (\r\n element: FormElementFieldProps\r\n) => {\r\n if (element?.fieldInfo) {\r\n const props = element.fieldInfo;\r\n const formManager = element?.formManager || null;\r\n const formActions = element?.formActions || null;\r\n const formValues = element?.formValues || null;\r\n const fieldName: any = element?.fieldInfo?.fieldName || null;\r\n const fieldType = element?.fieldInfo?.fieldType || null;\r\n if (!(props && formManager && formValues && fieldName && fieldType)) {\r\n return <></>;\r\n }\r\n return (props?.hidden === undefined || !props?.hidden) &&\r\n !element.hiddenFields.includes(fieldName) ? (\r\n <Grid2\r\n size={\r\n props?.formProps?.fieldSize || {\r\n lg: 12,\r\n md: 12,\r\n sm: 12,\r\n }\r\n }\r\n sx={{\r\n padding: 1,\r\n width: \"100%\",\r\n }}\r\n >\r\n {fieldType === \"text\" || fieldType === \"number\" ? (\r\n <TemplateTextField\r\n fullWidth\r\n type={fieldType}\r\n disabled={\r\n props?.disabled || element.disabledFields.includes(fieldName)\r\n ? true\r\n : false\r\n }\r\n hidden={props?.hidden || false}\r\n label={props?.fieldLabel}\r\n value={formValues[fieldName]}\r\n onChange={(event) => {\r\n let newValue = null;\r\n if (event.target.value != \"\") {\r\n if (fieldType === \"number\" && isNumeric(event.target.value)) {\r\n newValue = Number(event.target.value);\r\n } else {\r\n newValue = event.target.value;\r\n }\r\n }\r\n formManager.setValue(fieldName, newValue);\r\n if (props?.formProps?.onValueChangeCallBack) {\r\n props?.formProps?.onValueChangeCallBack(\r\n newValue,\r\n formManager,\r\n formActions\r\n );\r\n }\r\n }}\r\n sx={props?.formProps?.style}\r\n error={formManager.formState.errors[fieldName] != undefined}\r\n helperText={formManager?.formState?.errors[\r\n fieldName\r\n ]?.message?.toString()}\r\n />\r\n ) : props?.fieldType === \"date\" ? (\r\n <Datefield\r\n format={props?.dateFormat || DATE_FORMAT}\r\n sx={props?.formProps?.style || { width: \"100%\" }}\r\n disabled={\r\n props?.disabled || element.disabledFields.includes(fieldName)\r\n ? true\r\n : false\r\n }\r\n label={props?.fieldLabel}\r\n onChangeCallBack={(v: any) => {\r\n formManager.setValue(fieldName, v);\r\n if (props?.formProps?.onValueChangeCallBack) {\r\n props?.formProps?.onValueChangeCallBack(\r\n v,\r\n formManager,\r\n formActions\r\n );\r\n }\r\n }}\r\n value={formValues[fieldName]}\r\n error={formManager.formState.errors[fieldName] != undefined}\r\n errorMessage={formManager?.formState?.errors[\r\n fieldName\r\n ]?.message?.toString()}\r\n />\r\n ) : props?.fieldType === \"datetime\" ? (\r\n <DatetimeField\r\n format={props?.dateFormat || DATE_TIME_FORMAT}\r\n sx={props?.formProps?.style || { width: \"100%\" }}\r\n disabled={\r\n props?.disabled || element.disabledFields.includes(fieldName)\r\n ? true\r\n : false\r\n }\r\n label={props?.fieldLabel}\r\n onChangeCallBack={(v: any) => {\r\n formManager.setValue(fieldName, v);\r\n if (props?.formProps?.onValueChangeCallBack) {\r\n props?.formProps?.onValueChangeCallBack(\r\n v,\r\n formManager,\r\n formActions\r\n );\r\n }\r\n }}\r\n value={formValues[fieldName]}\r\n error={formManager.formState.errors[fieldName] != undefined}\r\n errorMessage={formManager?.formState?.errors[\r\n fieldName\r\n ]?.message?.toString()}\r\n />\r\n ) : props?.fieldType === \"checkbox\" ? (\r\n <CheckBox\r\n label={props?.fieldLabel}\r\n onChangeCallBack={(v: any) => {\r\n formManager.setValue(fieldName, v);\r\n if (props?.formProps?.onValueChangeCallBack) {\r\n props?.formProps?.onValueChangeCallBack(\r\n v,\r\n formManager,\r\n formActions\r\n );\r\n }\r\n }}\r\n value={formValues[fieldName]}\r\n checkedValue={props?.checkedValue || \"true\"}\r\n unCheckedValue={props?.unCheckedValue || \"false\"}\r\n disabled={\r\n props?.disabled || element.disabledFields.includes(fieldName)\r\n ? true\r\n : false\r\n }\r\n sx={props?.formProps?.style}\r\n />\r\n ) : props?.fieldType === \"combobox\" ? (\r\n <ComboBox\r\n sx={props?.formProps?.style || { width: \"100%\" }}\r\n label={props?.fieldLabel}\r\n disabled={\r\n props?.disabled || element.disabledFields.includes(fieldName)\r\n ? true\r\n : false\r\n }\r\n onChangeCallBack={(v: any, selectedRecord: any) => {\r\n let newValue = null;\r\n if (v) {\r\n newValue = v + \"\";\r\n }\r\n formManager.setValue(fieldName, newValue);\r\n if (props?.formProps?.onValueChangeCallBack) {\r\n props?.formProps?.onValueChangeCallBack(\r\n newValue,\r\n formManager,\r\n formActions,\r\n selectedRecord\r\n );\r\n }\r\n }}\r\n options={props?.options || []}\r\n displayField={props?.optionDisplayField || \"\"}\r\n valueField={props?.optionValueField || \"\"}\r\n value={formValues[fieldName]}\r\n errorMessage={formManager?.formState?.errors[\r\n fieldName\r\n ]?.message?.toString()}\r\n />\r\n ) : (\r\n <>Unknown field type</>\r\n )}\r\n </Grid2>\r\n ) : (\r\n <></>\r\n );\r\n } else {\r\n return <></>;\r\n }\r\n};\r\n\r\nexport default FormElementField;\r\n","import { Button } from \"@mui/material\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport { RecordAction } from \"../DataEntryTypes\";\r\nimport useSession from \"../../../../hooks/UseSession\";\r\nimport { useConfirmationWindow } from \"../../../../hooks/UseConfirmationWindow\";\r\n\r\nconst FormAction: React.FC<RecordAction> = (action: RecordAction) => {\r\n const session = useSession();\r\n const { ConfirmationWindow, setOpen: setConfirmationWindowState } =\r\n useConfirmationWindow({\r\n body: action?.confirmationMessage || \"\",\r\n title: \"Confirmation\",\r\n onConfirmationCallBk: () => {\r\n action?.actionFn(action?.record);\r\n },\r\n });\r\n if (\r\n action?.authority === undefined ||\r\n action?.authority === null ||\r\n session.isUserAuthorized(action.authority)\r\n ) {\r\n return (\r\n <>\r\n <ConfirmationWindow />\r\n <Button\r\n variant={action?.formActionProps?.actionButtonVariant}\r\n color={action?.formActionProps?.actionButtonColor}\r\n onClick={() => {\r\n if (action?.actionFn) {\r\n if (action?.preActionValidation) {\r\n if (!action.preActionValidation(action.record)) {\r\n return;\r\n }\r\n }\r\n if (action?.isConfirmationRequired === true) {\r\n setConfirmationWindowState(true);\r\n } else {\r\n action?.actionFn(action.record);\r\n }\r\n }\r\n }}\r\n >\r\n {action?.icon ? (\r\n <FontAwesomeIcon\r\n icon={action.icon}\r\n style={{ marginRight: 5, marginLeft: 5 }}\r\n />\r\n ) : (\r\n <></>\r\n )}\r\n <div>{action?.label}</div>\r\n </Button>\r\n </>\r\n );\r\n } else {\r\n return <></>;\r\n }\r\n};\r\n\r\nexport default FormAction;\r\n","import { Grid2 } from \"@mui/material\";\r\nimport FormElementField from \"./FormElementField\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport FormAction from \"./FormAction\";\r\nimport {\r\n FormElementGroupProps,\r\n FormElementProps,\r\n RecordAction,\r\n} from \"../DataEntryTypes\";\r\n\r\nconst FormElementGroup: React.FC<FormElementGroupProps> = (\r\n props: FormElementGroupProps\r\n) => {\r\n return (\r\n <>\r\n <Grid2 container sx={props?.style} alignItems=\"flex-start\">\r\n {props?.label ? (\r\n <Grid2\r\n size={12}\r\n sx={{ padding: 1, fontWeight: \"bold\", display: \"flex\" }}\r\n >\r\n {props?.icon ? (\r\n <>\r\n <FontAwesomeIcon\r\n icon={props.icon}\r\n style={{ marginRight: 5, marginLeft: 5 }}\r\n />\r\n <div>{props.label}</div>\r\n </>\r\n ) : (\r\n <>{props.label}</>\r\n )}\r\n </Grid2>\r\n ) : (\r\n <></>\r\n )}\r\n {props?.elements\r\n ? props.elements.map((element: FormElementProps) => {\r\n if (element.type === \"group\") {\r\n return (\r\n <FormElementGroup\r\n {...element.props}\r\n formManager={props.formManager}\r\n formValues={props.formValues}\r\n formActions={props.formActions}\r\n hiddenFields={props.hiddenFields}\r\n disabledFields={props.disabledFields}\r\n />\r\n );\r\n } else if (element.type === \"field\" && element.mode === \"props\") {\r\n return (\r\n <FormElementField\r\n fieldInfo={element.props}\r\n formManager={props.formManager}\r\n formValues={props.formValues}\r\n formActions={props.formActions}\r\n hiddenFields={props.hiddenFields}\r\n disabledFields={props.disabledFields}\r\n />\r\n );\r\n } else if (element.type === \"field\" && element.mode === \"node\") {\r\n return (\r\n <Grid2\r\n size={\r\n element?.props?.formProps?.fieldSize || {\r\n lg: 3,\r\n md: 6,\r\n sm: 12,\r\n }\r\n }\r\n sx={{ padding: 1, width: \"100%\" }}\r\n >\r\n <element.node\r\n formManager={props.formManager}\r\n formValues={props.formValues}\r\n formActions={props.formActions}\r\n />\r\n </Grid2>\r\n );\r\n }\r\n })\r\n : null}\r\n\r\n {props?.actions ? (\r\n <Grid2 size={{ sm: 12 }} sx={{ padding: 1 }}>\r\n {props.actions.map((action: RecordAction) => {\r\n return <FormAction {...action} record={props.formValues} />;\r\n })}\r\n </Grid2>\r\n ) : (\r\n <></>\r\n )}\r\n </Grid2>\r\n </>\r\n );\r\n};\r\n\r\nexport default FormElementGroup;\r\n","import { Box } from \"@mui/system\";\r\nimport React, { useEffect, useState } from \"react\";\r\nimport * as z from \"zod\";\r\nimport { useForm } from \"react-hook-form\";\r\nimport { zodResolver } from \"@hookform/resolvers/zod\";\r\nimport { useParams } from \"react-router-dom\";\r\nimport { Button, Grid2 } from \"@mui/material\";\r\nimport { toast } from \"react-toastify\";\r\nimport FormElementGroup from \"./FormElementGroup\";\r\nimport FormElementField from \"./FormElementField\";\r\nimport FormAction from \"./FormAction\";\r\nimport { constructValidationSchema, getAllFields } from \"../DataEntryUtil\";\r\nimport {\r\n FormElementProps,\r\n RecordAction,\r\n TemplateFormProps,\r\n} from \"../DataEntryTypes\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\n\r\nconst TemplateForm: React.FC<TemplateFormProps> = (\r\n props: TemplateFormProps\r\n) => {\r\n const fields = getAllFields(props.elements);\r\n const [hiddenFields, setHiddenFields] = useState<string[]>([]);\r\n const [disabledFields, setDisabledFields] = useState<string[]>([]);\r\n const formSchema = z.object(constructValidationSchema(fields));\r\n type FormData = z.infer<typeof formSchema>;\r\n const formManager = useForm<FormData>({\r\n resolver: zodResolver(formSchema),\r\n });\r\n const formValues = formManager.watch();\r\n const pathParameters = useParams();\r\n const formRouteRecordIdParamName: any = props?.formRouteRecordIdParamName;\r\n\r\n const loadRecord = async () => {\r\n let idToLoad = null;\r\n if (props?.recordIdToEdit) {\r\n idToLoad = props.recordIdToEdit;\r\n } else if (\r\n formRouteRecordIdParamName &&\r\n pathParameters[formRouteRecordIdParamName]\r\n ) {\r\n idToLoad = pathParameters[formRouteRecordIdParamName];\r\n }\r\n if (idToLoad) {\r\n const retrievedRecord: any = await props.apiActions.loadRecordById(\r\n idToLoad\r\n );\r\n if (retrievedRecord) {\r\n formManager.reset({ ...retrievedRecord });\r\n }\r\n }\r\n };\r\n\r\n const saveRecord = async (record: any) => {\r\n if (props?.preSaveValidation && !props.preSaveValidation(record)) {\r\n return;\r\n }\r\n if (record) {\r\n const savedRecord: any = await props.apiActions.saveRecord(record);\r\n if (savedRecord) {\r\n formManager.reset({ ...savedRecord });\r\n if (props?.formSavedSuccessfullyCallBk) {\r\n props.formSavedSuccessfullyCallBk(savedRecord);\r\n }\r\n if (props?.formCloseCallBk) {\r\n props.formCloseCallBk();\r\n }\r\n }\r\n }\r\n };\r\n\r\n const formActions = {\r\n setFieldValue: (fieldName: string, fieldValue: any) => {\r\n formManager.setValue(fieldName, fieldValue);\r\n },\r\n hideField: (fieldName: string) => {\r\n setHiddenFields((oldValues) => {\r\n const newValues = [...oldValues, fieldName];\r\n return newValues;\r\n });\r\n },\r\n showField: (fieldName: string) => {\r\n setHiddenFields((oldValues) => {\r\n const newValues = oldValues.filter((x) => x !== fieldName);\r\n return newValues;\r\n });\r\n },\r\n disableField: (fieldName: string) => {\r\n setDisabledFields((oldValues) => {\r\n const newValues = [...oldValues, fieldName];\r\n return newValues;\r\n });\r\n },\r\n enableField: (fieldName: string) => {\r\n setDisabledFields((oldValues) => {\r\n const newValues = oldValues.filter((x) => x !== fieldName);\r\n return newValues;\r\n });\r\n },\r\n };\r\n\r\n useEffect(() => {\r\n loadRecord();\r\n }, [props?.recordIdToEdit]);\r\n\r\n return (\r\n <>\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n flex: 1,\r\n width: \"100%\",\r\n height: \"fit-content\",\r\n flexDirection: \"column\",\r\n alignItems: \"center\",\r\n overflow: \"auto\",\r\n }}\r\n >\r\n <Grid2 sx={{ width: \"100%\" }} container>\r\n {props.elements.map((formElement: FormElementProps) => {\r\n if (formElement.type === \"group\") {\r\n return (\r\n <FormElementGroup\r\n {...formElement.props}\r\n formManager={formManager}\r\n formValues={formValues}\r\n formActions={formActions}\r\n hiddenFields={hiddenFields}\r\n disabledFields={disabledFields}\r\n />\r\n );\r\n } else if (\r\n formElement.type === \"field\" &&\r\n formElement.mode === \"props\"\r\n ) {\r\n return (\r\n <FormElementField\r\n fieldInfo={formElement.props}\r\n formManager={formManager}\r\n formValues={formValues}\r\n formActions={formActions}\r\n hiddenFields={hiddenFields}\r\n disabledFields={disabledFields}\r\n />\r\n );\r\n } else if (\r\n formElement.type === \"field\" &&\r\n formElement.mode === \"node\"\r\n ) {\r\n return (\r\n <Grid2\r\n size={\r\n formElement?.props?.formProps?.fieldSize || {\r\n lg: 3,\r\n md: 6,\r\n xs: 12,\r\n }\r\n }\r\n sx={{ padding: 1, width: \"100%\" }}\r\n >\r\n <formElement.node\r\n formManager={formManager}\r\n formValues={formValues}\r\n />\r\n </Grid2>\r\n );\r\n }\r\n })}\r\n </Grid2>\r\n </Box>\r\n\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n width: \"100%\",\r\n alignItems: \"center\",\r\n justifyContent: \"flex-start\",\r\n }}\r\n >\r\n {props?.actions ? (\r\n props.actions.map((action: RecordAction) => {\r\n if (action?.formActionProps?.enabled === true) {\r\n return <FormAction {...action} record={formValues} />;\r\n } else {\r\n return <></>;\r\n }\r\n })\r\n ) : (\r\n <></>\r\n )}\r\n <div style={{ flex: 1 }}></div>\r\n <Button\r\n variant={\r\n props?.saveButtonSpecs?.actionButtonVariant\r\n ? props.saveButtonSpecs.actionButtonVariant\r\n : \"contained\"\r\n }\r\n sx={{ m: 1 }}\r\n startIcon={\r\n props?.saveButtonSpecs?.icon ? (\r\n <FontAwesomeIcon icon={props.saveButtonSpecs.icon} />\r\n ) : null\r\n }\r\n color={\r\n props?.saveButtonSpecs?.actionButtonColor\r\n ? props.saveButtonSpecs.actionButtonColor\r\n : \"primary\"\r\n }\r\n onClick={formManager.handleSubmit(\r\n (values) => {\r\n console.log(\"form values\", values);\r\n saveRecord(values);\r\n },\r\n (errors) => {\r\n toast.error(\r\n \"Form Data is not valid, make sure you have all field with valid data\"\r\n );\r\n console.log(\"form validation error\", errors);\r\n }\r\n )}\r\n >\r\n {props?.saveButtonSpecs?.label || \"save\"}\r\n </Button>\r\n <Button\r\n variant={\r\n props?.cancelButtonSpecs?.actionButtonVariant\r\n ? props.cancelButtonSpecs.actionButtonVariant\r\n : \"contained\"\r\n }\r\n startIcon={\r\n props?.cancelButtonSpecs?.icon ? (\r\n <FontAwesomeIcon icon={props.cancelButtonSpecs.icon} />\r\n ) : null\r\n }\r\n color={\r\n props?.cancelButtonSpecs?.actionButtonColor\r\n ? props.cancelButtonSpecs.actionButtonColor\r\n : \"error\"\r\n }\r\n sx={{ m: 1 }}\r\n onClick={() => {\r\n if (props?.formCloseCallBk) {\r\n props.formCloseCallBk();\r\n }\r\n formManager.reset({});\r\n }}\r\n >\r\n {props?.cancelButtonSpecs?.label || \"cancel\"}\r\n </Button>\r\n </Box>\r\n </>\r\n );\r\n};\r\n\r\nexport default TemplateForm;\r\n","import { useEffect, useState } from \"react\";\r\nimport {\r\n AppBar,\r\n Box,\r\n IconButton,\r\n Modal,\r\n Paper,\r\n Toolbar,\r\n Typography,\r\n} from \"@mui/material\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\n\r\nexport interface TemplateWindowProp {\r\n height?: any;\r\n width?: any;\r\n minWidth?: any;\r\n minHeight?: any;\r\n windowIcon?: any;\r\n windowTitle?: string;\r\n onCloseCallBack?: any;\r\n}\r\n\r\ninterface WindowProps {\r\n children?: React.ReactNode;\r\n}\r\n\r\nexport const useWindow = (props: TemplateWindowProp) => {\r\n const [windowState, setWindowState] = useState(false);\r\n\r\n const Window: React.FC<WindowProps> = (windowProps: WindowProps) => {\r\n return (\r\n <Modal\r\n open={windowState}\r\n sx={{ zIndex: (theme) => theme.zIndex.drawer }}\r\n onClose={() => {\r\n if (!windowState && props?.onCloseCallBack) {\r\n props.onCloseCallBack();\r\n }\r\n }}\r\n >\r\n <Box\r\n sx={{\r\n position: \"absolute\",\r\n top: \"50%\",\r\n left: \"50%\",\r\n maxHeight: \"90%\",\r\n transform: \"translate(-50%, -50%)\",\r\n height: props?.height || \"80%\",\r\n width: props?.width || \"90%\",\r\n minWidth: props.minWidth || 400,\r\n minHeight: props.minHeight || 200,\r\n overflow: \"hidden\",\r\n bgcolor: \"modalBackground.main\",\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n alignItems: \"center\",\r\n justifyContent: \"flex-start\",\r\n }}\r\n >\r\n <AppBar position=\"static\">\r\n <Toolbar variant=\"dense\">\r\n <FontAwesomeIcon\r\n icon={props?.windowIcon || \"window-maximize\"}\r\n style={{ marginRight: 5 }}\r\n />\r\n <Typography variant=\"h6\" color=\"inherit\" component=\"div\">\r\n {props?.windowTitle || \"window\"}\r\n </Typography>\r\n <div style={{ flexGrow: 1 }}></div>\r\n <IconButton\r\n onClick={() => {\r\n setWindowState(false);\r\n if (\r\n props.onCloseCallBack != undefined &&\r\n props.onCloseCallBack != null\r\n ) {\r\n props.onCloseCallBack();\r\n }\r\n }}\r\n color=\"secondary\"\r\n >\r\n <FontAwesomeIcon icon=\"xmark-square\" />\r\n </IconButton>\r\n </Toolbar>\r\n </AppBar>\r\n <Paper\r\n sx={{\r\n // flexGrow: 1,\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n alignItems: \"center\",\r\n width: \"100%\",\r\n height: \"100%\",\r\n padding: 1,\r\n // justifyContent: \"center\",\r\n overflow: \"hidden\",\r\n }}\r\n >\r\n {windowProps?.children}\r\n </Paper>\r\n </Box>\r\n </Modal>\r\n );\r\n };\r\n return { windowState, setWindowState, Window };\r\n};\r\n","import {\r\n DataGridPremium,\r\n GridActionsCellItem,\r\n GridActionsCellItemProps,\r\n GridColumnOrderChangeParams,\r\n GridColumnResizeParams,\r\n GridColumnVisibilityModel,\r\n GridEventListener,\r\n GridExpandMoreIcon,\r\n GridPinnedColumnFields,\r\n GridRowGroupingModel,\r\n GridRowModes,\r\n GridRowModesModel,\r\n GridRowParams,\r\n GridRowSelectionModel,\r\n} from \"@mui/x-data-grid-premium\";\r\nimport { TemplateGridColDef, TemplateGridProps } from \"../DataEntryTypes\";\r\nimport TemplateGridTopBar from \"./TemplateGridTopBar\";\r\nimport { useNavigate } from \"react-router-dom\";\r\nimport React, { useEffect, useState } from \"react\";\r\nimport { z } from \"zod\";\r\nimport {\r\n constructGridColumnsFromFields,\r\n constructValidationSchema,\r\n getAllFields,\r\n} from \"../DataEntryUtil\";\r\nimport { toast } from \"react-toastify\";\r\nimport {\r\n Accordion,\r\n AccordionDetails,\r\n AccordionSummary,\r\n Box,\r\n Divider,\r\n IconButton,\r\n Tooltip,\r\n Typography,\r\n} from \"@mui/material\";\r\nimport { capitalizeFirstLetter, isNumber } from \"../../../../util/AppUtils\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport TemplateGridRecordAction from \"./TemplateGridRecordAction\";\r\nimport TemplateForm from \"../TemplateDataForm/TemplateForm\";\r\nimport { useSelector } from \"react-redux\";\r\nimport { RootState } from \"../../../../redux/store\";\r\nimport { useTranslation } from \"react-i18next\";\r\nimport useSession from \"../../../../hooks/UseSession\";\r\nimport { useConfirmationWindow } from \"../../../../hooks/UseConfirmationWindow\";\r\nimport { useWindow } from \"../../../../hooks/UseWindow\";\r\nlet currentNewRecordIndex = -1;\r\n\r\ninterface GridState {\r\n columnVisibilityModel?: GridColumnVisibilityModel;\r\n columnOrder?: string[];\r\n columnWidths?: { [key: string]: number };\r\n columnGroupingModel?: GridRowGroupingModel;\r\n pinnedColumns?: GridPinnedColumnFields;\r\n}\r\n\r\nconst loadGridState = (gridStateKey: string): GridState => {\r\n try {\r\n const saved = localStorage.getItem(gridStateKey);\r\n return saved ? JSON.parse(saved) : {};\r\n } catch (e) {\r\n console.error(\"Failed to load grid state\", e);\r\n return {};\r\n }\r\n};\r\n\r\nconst saveGridState = (gridStateKey: string, statePart: GridState) => {\r\n const current = loadGridState(gridStateKey);\r\n localStorage.setItem(\r\n gridStateKey,\r\n JSON.stringify({ ...current, ...statePart })\r\n );\r\n};\r\n\r\nconst PIN_FIXED_COLUMNS = [\"__check__\", \"actions\"];\r\n\r\nconst TemplateGrid: React.FC<TemplateGridProps> = (props) => {\r\n const { t } = useTranslation();\r\n const fields = getAllFields(props.formElements);\r\n const hiddenFields = [];\r\n const savedState = React.useMemo<GridState>(\r\n () => (props?.gridStateKey ? loadGridState(props.gridStateKey) : {}),\r\n []\r\n );\r\n for (const field of fields) {\r\n if (field?.gridProps?.hidden === true) {\r\n hiddenFields.push(field.fieldName);\r\n }\r\n }\r\n let initialVisibilityState: GridColumnVisibilityModel = {};\r\n if (savedState?.columnVisibilityModel) {\r\n initialVisibilityState = savedState.columnVisibilityModel;\r\n const existingFields = Object.keys(initialVisibilityState);\r\n for (const field of hiddenFields) {\r\n if (!existingFields.includes(field)) {\r\n initialVisibilityState[field] = false;\r\n }\r\n }\r\n } else {\r\n for (const field of hiddenFields) {\r\n initialVisibilityState[field] = false;\r\n }\r\n }\r\n\r\n const themeDirection = useSelector(\r\n (state: RootState) => state.AppLayout.appDirection\r\n );\r\n\r\n const clearGridState = () => {\r\n if (props?.gridStateKey) {\r\n localStorage.removeItem(props.gridStateKey);\r\n }\r\n setColumnVisibilityModel({});\r\n setColumnOrder([]);\r\n setColumnWidths({});\r\n setGridRowGroupingModel([]);\r\n setPinnedColumns({\r\n left: [...(themeDirection === \"ltr\" ? PIN_FIXED_COLUMNS : [])],\r\n right: [...(themeDirection === \"rtl\" ? PIN_FIXED_COLUMNS : [])],\r\n });\r\n };\r\n const [columnVisibilityModel, setColumnVisibilityModel] =\r\n React.useState<GridColumnVisibilityModel>(initialVisibilityState);\r\n const [columnOrder, setColumnOrder] = React.useState<string[]>(\r\n savedState.columnOrder || []\r\n );\r\n const [columnWidths, setColumnWidths] = React.useState<{\r\n [key: string]: number;\r\n }>(savedState.columnWidths || {});\r\n const [gridRowGroupingModel, setGridRowGroupingModel] =\r\n useState<GridRowGroupingModel>(savedState.columnGroupingModel || []);\r\n let newLeft = savedState?.pinnedColumns?.left || [];\r\n newLeft = newLeft.filter(\r\n (record: any) => !PIN_FIXED_COLUMNS.includes(record)\r\n );\r\n let newRight = savedState?.pinnedColumns?.right || [] || [];\r\n newRight = newRight.filter(\r\n (record: any) => !PIN_FIXED_COLUMNS.includes(record)\r\n );\r\n\r\n const [pinnedColumns, setPinnedColumns] = useState<GridPinnedColumnFields>({\r\n left: [...(themeDirection === \"ltr\" ? PIN_FIXED_COLUMNS : []), ...newLeft],\r\n right: [\r\n ...(themeDirection === \"rtl\" ? PIN_FIXED_COLUMNS : []),\r\n ...newRight,\r\n ],\r\n });\r\n\r\n const session = useSession();\r\n const navigate = useNavigate();\r\n const [recordToDelete, setRecordToDelete] = useState<any>(null);\r\n const [recordToEdit, setRecordToEdit] = useState<any>(null);\r\n const [rowModesModel, setRowModesModel] = useState<GridRowModesModel>({});\r\n\r\n const [rowSelectionModel, setRowSelectionModel] =\r\n useState<GridRowSelectionModel>({ ids: new Set(), type: \"include\" });\r\n let keyColumnName: string = \"id\";\r\n if (props?.keyColumnName) {\r\n keyColumnName = props?.keyColumnName;\r\n }\r\n const setData = props.setData;\r\n const validationSchema = z.object(constructValidationSchema(fields));\r\n const generatedColumns = constructGridColumnsFromFields(\r\n fields,\r\n props?.editMode?.editMode === \"row\" || false,\r\n t\r\n );\r\n let isEditAllowed = true;\r\n if (props?.editAction?.authority) {\r\n isEditAllowed = session.isUserAuthorized(props.editAction.authority);\r\n }\r\n let isDeleteAllowed = true;\r\n if (props?.deleteAction?.authority) {\r\n isDeleteAllowed = session.isUserAuthorized(props.deleteAction.authority);\r\n }\r\n\r\n const handleRowModesModelChange = (newModel: GridRowModesModel) => {\r\n setRowModesModel(newModel);\r\n };\r\n\r\n const handlePinnedColumnsChange = (newModel: GridPinnedColumnFields) => {\r\n let newLeft = newModel?.left || [];\r\n newLeft = newLeft.filter(\r\n (record: any) => !PIN_FIXED_COLUMNS.includes(record)\r\n );\r\n let newRight = newModel?.right || [];\r\n newRight = newRight.filter(\r\n (record: any) => !PIN_FIXED_COLUMNS.includes(record)\r\n );\r\n const newPinedColumns: GridPinnedColumnFields = {\r\n left: [\r\n ...(themeDirection === \"ltr\" ? PIN_FIXED_COLUMNS : []),\r\n ...newLeft,\r\n ],\r\n right: [\r\n ...(themeDirection === \"rtl\" ? PIN_FIXED_COLUMNS : []),\r\n ...newRight,\r\n ],\r\n };\r\n setPinnedColumns(newPinedColumns);\r\n if (props?.gridStateKey) {\r\n saveGridState(props.gridStateKey, { pinnedColumns: newPinedColumns });\r\n }\r\n };\r\n\r\n const handleDeleteRecord = async () => {\r\n let result = true;\r\n if (!(recordToDelete && recordToDelete?.isNew === true)) {\r\n result = await props.apiActions.deleteRecordById(\r\n recordToDelete[keyColumnName]\r\n );\r\n }\r\n if (result) {\r\n if (props?.deleteAction?.postActionCallBack) {\r\n await props.deleteAction.postActionCallBack(recordToDelete);\r\n }\r\n\r\n setData((oldData: any) => {\r\n const newData = oldData.filter(\r\n (record: any) =>\r\n record[keyColumnName] != recordToDelete[keyColumnName]\r\n );\r\n return newData;\r\n });\r\n }\r\n };\r\n\r\n const { ConfirmationWindow, setOpen: setConfirmationWindowOpened } =\r\n useConfirmationWindow({\r\n title: \"Confirmation\",\r\n body: \"Are you sure you want to delete this record ?\",\r\n onConfirmationCallBk: handleDeleteRecord,\r\n });\r\n\r\n let formModalHeight = undefined;\r\n let formModalWidth = undefined;\r\n let formModalMinHeight = undefined;\r\n let formModalMinWidth = undefined;\r\n let formModalIcon = undefined;\r\n let formModalTitle = undefined;\r\n\r\n if (props?.editMode?.editMode === \"modal\") {\r\n formModalHeight = props?.editMode?.specs?.modalHeight || \"fit-content\";\r\n formModalWidth = props?.editMode?.specs?.modalWidth || \"300\";\r\n formModalMinHeight = props?.editMode?.specs?.modalMinHeight;\r\n formModalMinWidth = props?.editMode?.specs?.modalMinWidth;\r\n formModalIcon = props?.editMode?.specs?.modalIcon || \"window\";\r\n formModalTitle = props?.editMode?.specs?.modalTitle || \"Record Form\";\r\n }\r\n\r\n const { Window: FormWindow, setWindowState: setFormWindowState } = useWindow({\r\n height: formModalHeight,\r\n minHeight: formModalMinHeight,\r\n minWidth: formModalMinWidth,\r\n onCloseCallBack: () => {\r\n props.apiActions.reloadData(props?.gridLoadParametersValues);\r\n },\r\n width: formModalWidth,\r\n windowIcon: formModalIcon,\r\n windowTitle: formModalTitle,\r\n });\r\n\r\n const handleCreateNewRecord = () => {\r\n if (props?.editMode?.editMode === \"form\") {\r\n navigate(props.editMode.specs.formRoute);\r\n } else if (props?.editMode?.editMode === \"modal\") {\r\n setFormWindowState(true);\r\n } else if (props?.editMode?.editMode === \"row\") {\r\n currentNewRecordIndex = currentNewRecordIndex - 1;\r\n const newRecord: any = {};\r\n newRecord[keyColumnName] = currentNewRecordIndex;\r\n newRecord.isNew = true;\r\n for (const gridColumn of generatedColumns) {\r\n if (\r\n gridColumn?.type != \"actions\" &&\r\n gridColumn?.field != keyColumnName\r\n ) {\r\n if (gridColumn?.field) {\r\n newRecord[gridColumn.field] = null;\r\n }\r\n }\r\n }\r\n setData((oldRows: any) => [newRecord, ...oldRows]);\r\n setRowModesModel((oldModel: any) => ({\r\n ...oldModel,\r\n [currentNewRecordIndex]: { mode: GridRowModes.Edit },\r\n }));\r\n }\r\n };\r\n\r\n const handleEditRecord = async (record: any) => {\r\n if (record) {\r\n setRecordToEdit(record);\r\n if (props.editMode.editMode === \"form\") {\r\n navigate(props.editMode.specs.formRoute + \"/\" + record[keyColumnName]);\r\n } else if (props.editMode.editMode === \"modal\") {\r\n setFormWindowState(true);\r\n } else if (props?.editMode?.editMode === \"row\") {\r\n const id = record[keyColumnName];\r\n setRowModesModel({\r\n ...rowModesModel,\r\n [id]: { mode: GridRowModes.Edit },\r\n });\r\n }\r\n }\r\n };\r\n\r\n const validateRecord = (record: any) => {\r\n try {\r\n validationSchema.parse(record);\r\n } catch (err) {\r\n console.log(\"validateRecord err\", err);\r\n let errorMessage: any = null;\r\n if (err instanceof z.ZodError) {\r\n errorMessage = err.errors\r\n .map(\r\n (error) => \"Error in field (\" + error.path + \") : \" + error.message\r\n )\r\n .join(\",\");\r\n } else {\r\n errorMessage = \"invalid record data\";\r\n }\r\n return errorMessage;\r\n }\r\n };\r\n\r\n const handleSaveRowClick = (record: any) => {\r\n const id = record[keyColumnName];\r\n setRowModesModel({\r\n ...rowModesModel,\r\n [id]: { mode: GridRowModes.View },\r\n });\r\n };\r\n\r\n const processRowUpdate = async (record: any) => {\r\n if (props.editMode.editMode === \"row\") {\r\n let savedRecord: any = null;\r\n const errorMessage = validateRecord(record);\r\n if (errorMessage) {\r\n const errors = errorMessage.split(\",\");\r\n toast.error(\r\n <div style={{}}>\r\n {errors.map((error: any) => (\r\n <>\r\n <div>{error}</div>\r\n <Divider />\r\n </>\r\n ))}\r\n </div>\r\n );\r\n throw new Error(errorMessage);\r\n }\r\n if (props?.editAction?.preActionValidation) {\r\n if (!props.editAction.preActionValidation(record)) {\r\n throw new Error(\"error on the configured presave validation\");\r\n }\r\n }\r\n const requestObject: any = { ...record };\r\n if (\r\n record[keyColumnName] &&\r\n isNumber(record[keyColumnName]) &&\r\n Number(record[keyColumnName]) < 0\r\n ) {\r\n requestObject[keyColumnName] = null;\r\n }\r\n savedRecord = await props.apiActions.saveRecord(requestObject);\r\n if (savedRecord == null) {\r\n throw new Error(\r\n \"Failed to process your request, contact your administrator\"\r\n );\r\n }\r\n if (props?.editAction?.postActionCallBack) {\r\n await props.editAction.postActionCallBack(record);\r\n }\r\n if (record?.isNew === true) {\r\n setData((oldData: any) => {\r\n const newData = oldData.filter(\r\n (x: any) => x[keyColumnName] !== record[keyColumnName]\r\n );\r\n return [savedRecord, ...newData];\r\n });\r\n }\r\n if (\r\n props?.editMode?.reloadAfterSave === true &&\r\n props?.apiActions?.reloadData\r\n ) {\r\n props?.apiActions?.reloadData(props?.gridLoadParametersValues);\r\n }\r\n return savedRecord;\r\n }\r\n };\r\n\r\n const handleCancelRowEditClick = (record: any) => {\r\n const id = record[keyColumnName];\r\n if (id && isNumber(id) && id < 0) {\r\n setRowModesModel({\r\n ...rowModesModel,\r\n [id]: { mode: GridRowModes.View, ignoreModifications: true },\r\n });\r\n setData((oldData: any) => {\r\n const newData = oldData.filter(\r\n (record: any) => record[keyColumnName] != id\r\n );\r\n return newData;\r\n });\r\n } else {\r\n setRowModesModel({\r\n ...rowModesModel,\r\n [id]: { mode: GridRowModes.View, ignoreModifications: true },\r\n });\r\n }\r\n };\r\n\r\n const getActionColumnActions = (params: GridRowParams<any>) => {\r\n const record: any = params.row;\r\n const actions: Array<React.ReactElement<GridActionsCellItemProps>> = [];\r\n if (props?.editMode?.editMode != \"none\") {\r\n if (\r\n props?.disableDefaultAction === undefined ||\r\n !props.disableDefaultAction\r\n ) {\r\n const isInEditMode: boolean =\r\n rowModesModel[record[keyColumnName]]?.mode === GridRowModes.Edit;\r\n if (props.editMode.editMode === \"row\" && isInEditMode) {\r\n if (isEditAllowed) {\r\n actions.push(\r\n <GridActionsCellItem\r\n icon={<FontAwesomeIcon icon=\"save\" />}\r\n label={t(\"SAVE_BTN_LABEL\")}\r\n onClick={() => {\r\n handleSaveRowClick(record);\r\n }}\r\n />\r\n );\r\n actions.push(\r\n <GridActionsCellItem\r\n icon={<FontAwesomeIcon icon=\"cancel\" />}\r\n label={t(\"CANCEL_BTN_LABEL\")}\r\n onClick={() => {\r\n handleCancelRowEditClick(record);\r\n }}\r\n color=\"inherit\"\r\n />\r\n );\r\n }\r\n } else {\r\n if (props?.editAction && props?.editAction?.isEnabled === true) {\r\n let isEditActionVisibleForRecord = true;\r\n if (props?.editAction?.isActionVisibleForRecord) {\r\n isEditActionVisibleForRecord =\r\n props?.editAction?.isActionVisibleForRecord(record);\r\n }\r\n let isActionEditDisabledForRecord = false;\r\n if (props?.editAction?.isActionDisabledForRecord) {\r\n isActionEditDisabledForRecord =\r\n props?.editAction?.isActionDisabledForRecord(record);\r\n }\r\n if (isEditAllowed && isEditActionVisibleForRecord) {\r\n actions.push(\r\n <GridActionsCellItem\r\n disabled={isActionEditDisabledForRecord}\r\n icon={\r\n <Tooltip title={t(\"EDIT_BTN_LABEL\")}>\r\n <FontAwesomeIcon\r\n icon={\"edit\"}\r\n style={{\r\n color: isActionEditDisabledForRecord\r\n ? \"gray\"\r\n : undefined,\r\n }}\r\n />\r\n </Tooltip>\r\n }\r\n showInMenu={\r\n props?.editAction?.gridActionProps?.showInMenu || false\r\n }\r\n label={t(\"EDIT_BTN_LABEL\")}\r\n className=\"textPrimary\"\r\n color=\"inherit\"\r\n onClick={() => {\r\n if (isEditAllowed && !isActionEditDisabledForRecord) {\r\n handleEditRecord(record);\r\n }\r\n }}\r\n />\r\n );\r\n }\r\n }\r\n if (props?.deleteAction && props?.deleteAction?.isEnabled === true) {\r\n let isDeleteActionVisibleForRecord = true;\r\n if (props?.deleteAction?.isActionVisibleForRecord) {\r\n isDeleteActionVisibleForRecord =\r\n props?.deleteAction?.isActionVisibleForRecord(record);\r\n }\r\n let isDeleteActionDisabledForRecord = false;\r\n if (props?.deleteAction?.isActionDisabledForRecord) {\r\n isDeleteActionDisabledForRecord =\r\n props?.deleteAction?.isActionDisabledForRecord(record);\r\n }\r\n if (isDeleteAllowed && isDeleteActionVisibleForRecord) {\r\n actions.push(\r\n <GridActionsCellItem\r\n disabled={isDeleteActionDisabledForRecord}\r\n icon={\r\n <Tooltip title={t(\"DELETE_BTN_LABEL\")}>\r\n <FontAwesomeIcon\r\n icon={\"trash\"}\r\n style={{\r\n color: isDeleteActionDisabledForRecord\r\n ? \"gray\"\r\n : undefined,\r\n }}\r\n />\r\n </Tooltip>\r\n }\r\n showInMenu={\r\n props?.deleteAction?.gridActionProps?.showInMenu || false\r\n }\r\n label={t(\"DELETE_BTN_LABEL\")}\r\n className=\"textPrimary\"\r\n color=\"inherit\"\r\n onClick={() => {\r\n if (isDeleteAllowed && !isDeleteActionDisabledForRecord) {\r\n if (props?.deleteAction?.preActionValidation) {\r\n if (!props.deleteAction.preActionValidation(record)) {\r\n return;\r\n }\r\n }\r\n setRecordToDelete(record);\r\n setConfirmationWindowOpened(true);\r\n }\r\n }}\r\n />\r\n );\r\n }\r\n }\r\n }\r\n }\r\n }\r\n if (props?.rowActions) {\r\n for (const rowAction of props.rowActions) {\r\n if (\r\n !(\r\n rowAction?.gridActionProps?.multiRecord &&\r\n rowAction?.gridActionProps?.multiRecord === true\r\n )\r\n ) {\r\n actions.push(\r\n <TemplateGridRecordAction\r\n {...rowAction}\r\n record={record}\r\n reloadData={async () => {\r\n props.apiActions.reloadData(props?.gridLoadParametersValues);\r\n }}\r\n />\r\n );\r\n }\r\n }\r\n }\r\n\r\n return actions;\r\n };\r\n\r\n const actionColumn: TemplateGridColDef = {\r\n type: \"actions\",\r\n field: \"actions\",\r\n headerName: \"\",\r\n headerAlign: \"center\",\r\n width:\r\n (props?.rowActions ? props.rowActions.length * 30 : 0) +\r\n (props?.editAction && props?.editAction?.isEnabled ? 30 : 0) +\r\n (props?.deleteAction && props?.deleteAction?.isEnabled ? 30 : 0),\r\n getActions: getActionColumnActions,\r\n };\r\n\r\n let structuredColumns: Array<TemplateGridColDef> = [];\r\n if (\r\n props?.disableDefaultAction === undefined ||\r\n !props.disableDefaultAction ||\r\n (props?.rowActions && props?.rowActions.length > 0)\r\n ) {\r\n structuredColumns.push(actionColumn);\r\n }\r\n\r\n structuredColumns = [...structuredColumns, ...generatedColumns];\r\n const handleRowSelection = (gridSelectionModel: GridRowSelectionModel) => {\r\n setRowSelectionModel(gridSelectionModel);\r\n };\r\n useEffect(() => {\r\n if (props?.autoLoad === undefined || props.autoLoad === true) {\r\n props.apiActions.reloadData(props?.gridLoadParametersValues);\r\n }\r\n }, []);\r\n\r\n const handleColumnVisibilityChange = (model: GridColumnVisibilityModel) => {\r\n setColumnVisibilityModel(model);\r\n if (props?.gridStateKey) {\r\n saveGridState(props.gridStateKey, { columnVisibilityModel: model });\r\n }\r\n };\r\n\r\n const handleColumnOrderChange: GridEventListener<\"columnOrderChange\"> = (\r\n params: GridColumnOrderChangeParams\r\n ) => {\r\n const { column, targetIndex } = params;\r\n setColumnOrder((prevOrder) => {\r\n const currentOrder = prevOrder.length\r\n ? [...prevOrder]\r\n : structuredColumns.map((col) => col.field);\r\n const fromIndex = currentOrder.indexOf(column.field);\r\n if (fromIndex === -1) return currentOrder;\r\n\r\n currentOrder.splice(fromIndex, 1); // remove\r\n currentOrder.splice(targetIndex, 0, column.field); // insert at new index\r\n\r\n if (props?.gridStateKey) {\r\n saveGridState(props.gridStateKey, { columnOrder: currentOrder });\r\n }\r\n\r\n return currentOrder;\r\n });\r\n };\r\n\r\n const handleRowGroupChange = (model: GridRowGroupingModel) => {\r\n setGridRowGroupingModel(model);\r\n if (props?.gridStateKey) {\r\n saveGridState(props.gridStateKey, { columnGroupingModel: model });\r\n }\r\n };\r\n\r\n const handleColumnWidthChange: GridEventListener<\"columnWidthChange\"> = (\r\n params: GridColumnResizeParams\r\n ) => {\r\n const updatedWidths = {\r\n ...columnWidths,\r\n [params.colDef.field]: params.width,\r\n };\r\n setColumnWidths(updatedWidths);\r\n if (props?.gridStateKey) {\r\n saveGridState(props.gridStateKey, { columnWidths: updatedWidths });\r\n }\r\n };\r\n\r\n const adjustedColumns: Array<TemplateGridColDef> = React.useMemo(() => {\r\n const baseCols = structuredColumns.map((col) => ({\r\n ...col,\r\n width: columnWidths[col.field] || col.width,\r\n }));\r\n\r\n // Reorder based on saved columnOrder\r\n if (columnOrder.length) {\r\n const fieldToCol = new Map(baseCols.map((col) => [col.field, col]));\r\n return columnOrder.map((field) => fieldToCol.get(field)!).filter(Boolean);\r\n }\r\n\r\n return baseCols;\r\n }, [columnOrder, columnWidths, structuredColumns]);\r\n return (\r\n <>\r\n <ConfirmationWindow />\r\n {props?.editMode?.editMode === \"modal\" ? (\r\n <FormWindow>\r\n {props?.editMode?.specs?.formComponent ? (\r\n <props.editMode.specs.formComponent\r\n recordIdToEdit={\r\n recordToEdit ? recordToEdit[keyColumnName] : undefined\r\n }\r\n formCloseCallBk={() => {\r\n setFormWindowState(false);\r\n props.apiActions.reloadData(props?.gridLoadParametersValues);\r\n }}\r\n />\r\n ) : (\r\n <TemplateForm\r\n recordIdToEdit={\r\n recordToEdit ? recordToEdit[keyColumnName] : undefined\r\n }\r\n formCloseCallBk={() => {\r\n setFormWindowState(false);\r\n props.apiActions.reloadData(props?.gridLoadParametersValues);\r\n }}\r\n elements={props.formElements}\r\n apiActions={props.apiActions}\r\n editAuthorityKey={props?.editAction?.authority}\r\n formSavedSuccessfullyCallBk={\r\n props?.editAction?.postActionCallBack\r\n }\r\n preSaveValidation={props?.editAction?.preActionValidation}\r\n actions={props?.rowActions}\r\n />\r\n )}\r\n </FormWindow>\r\n ) : (\r\n <></>\r\n )}\r\n {props?.hideInfoBar === undefined && !props?.hideInfoBar ? (\r\n <Box sx={{ display: \"flex\" }}>\r\n {props?.hideBackButton === undefined && !props?.hideBackButton ? (\r\n <IconButton\r\n onClick={() => {\r\n navigate(\"-1\", { replace: true });\r\n }}\r\n >\r\n <FontAwesomeIcon icon=\"arrow-left\" />\r\n </IconButton>\r\n ) : (\r\n <></>\r\n )}\r\n <Box\r\n sx={{\r\n flex: 1,\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n }}\r\n >\r\n {props?.girdIcon ? (\r\n <FontAwesomeIcon\r\n icon={props.girdIcon}\r\n style={{ marginRight: 5, marginLeft: 5 }}\r\n />\r\n ) : (\r\n <></>\r\n )}\r\n <Typography variant=\"h5\">\r\n {props?.gridTitle\r\n ? capitalizeFirstLetter(t(props?.gridTitle))\r\n : \"\"}\r\n </Typography>\r\n </Box>\r\n </Box>\r\n ) : (\r\n <></>\r\n )}\r\n\r\n {props?.gridLoadParameters &&\r\n props?.gridLoadParametersValues &&\r\n props?.setGridLoadParametersValues ? (\r\n <Accordion defaultExpanded>\r\n <AccordionSummary expandIcon={<GridExpandMoreIcon />}>\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n }}\r\n >\r\n <FontAwesomeIcon\r\n style={{ marginLeft: 5, marginRight: 5 }}\r\n icon=\"search\"\r\n />\r\n <Typography component=\"span\">Filters</Typography>\r\n </Box>\r\n </AccordionSummary>\r\n <AccordionDetails>\r\n <Box>\r\n <TemplateForm\r\n saveButtonSpecs={{\r\n label: t(\"SEARCH_BTN_LABEL\"),\r\n icon: \"search\",\r\n actionButtonVariant: \"outlined\",\r\n actionButtonColor: \"success\",\r\n }}\r\n cancelButtonSpecs={{\r\n label: t(\"RESET_BTN_LABEL\"),\r\n icon: \"eraser\",\r\n actionButtonVariant: \"outlined\",\r\n actionButtonColor: \"error\",\r\n }}\r\n apiActions={{\r\n deleteRecordById: async () => {\r\n return true;\r\n },\r\n saveRecord: async (params) => {\r\n if (params != undefined) {\r\n props.setGridLoadParametersValues(params);\r\n } else {\r\n props.setGridLoadParametersValues({});\r\n }\r\n props.apiActions.reloadData(params);\r\n },\r\n reloadData: async () => {},\r\n loadRecordById: async () => {},\r\n }}\r\n elements={props.gridLoadParameters}\r\n />\r\n </Box>\r\n </AccordionDetails>\r\n </Accordion>\r\n ) : (\r\n <></>\r\n )}\r\n\r\n <DataGridPremium\r\n {...props?.muiProps}\r\n slots={{ toolbar: TemplateGridTopBar }}\r\n slotProps={{\r\n toolbar: {\r\n templateProps: {\r\n ...props,\r\n rowSelectionModel: rowSelectionModel,\r\n data: props?.data,\r\n },\r\n handleCreateNewRecord,\r\n clearGridState,\r\n } as any,\r\n }}\r\n getRowId={(record: any) => {\r\n return record[keyColumnName];\r\n }}\r\n showToolbar={true}\r\n rows={props?.data}\r\n columns={adjustedColumns}\r\n checkboxSelection\r\n editMode=\"row\"\r\n rowModesModel={\r\n props.editMode.editMode == \"row\" ? rowModesModel : undefined\r\n }\r\n onRowModesModelChange={\r\n props.editMode.editMode == \"row\"\r\n ? handleRowModesModelChange\r\n : undefined\r\n }\r\n rowGroupingColumnMode=\"multiple\"\r\n processRowUpdate={processRowUpdate}\r\n rowSelectionModel={rowSelectionModel}\r\n onRowSelectionModelChange={handleRowSelection}\r\n columnVisibilityModel={columnVisibilityModel}\r\n onColumnVisibilityModelChange={handleColumnVisibilityChange}\r\n onColumnOrderChange={handleColumnOrderChange}\r\n onColumnWidthChange={handleColumnWidthChange}\r\n rowGroupingModel={gridRowGroupingModel}\r\n onRowGroupingModelChange={(model: GridRowGroupingModel) => {\r\n handleRowGroupChange(model);\r\n }}\r\n pinnedColumns={pinnedColumns}\r\n onPinnedColumnsChange={handlePinnedColumnsChange}\r\n />\r\n </>\r\n );\r\n};\r\n\r\nexport default TemplateGrid;\r\n","import { createSlice, PayloadAction } from \"@reduxjs/toolkit\";\r\n\r\nexport interface CommonStoresInterface {\r\n stores: { [key: string]: StoreMetaData };\r\n storeKeys: Array<String>;\r\n isAutoLoadLoaded: boolean;\r\n}\r\n\r\ninterface setStoreDataProps {\r\n storeKey: string;\r\n data: Array<any>;\r\n}\r\n\r\nexport interface StoreMetaData {\r\n url: string;\r\n data: Array<any>;\r\n autoLoad: boolean;\r\n authority?: string;\r\n}\r\n\r\nexport const commonStoresInitialState: CommonStoresInterface = {\r\n stores: {},\r\n storeKeys: [],\r\n isAutoLoadLoaded: false,\r\n};\r\n\r\nconst commonStoreSlice = createSlice({\r\n name: \"loadingMask\",\r\n initialState: commonStoresInitialState,\r\n reducers: {\r\n setStoresMetaData: (state, action) => {\r\n state.stores = action.payload;\r\n state.storeKeys = Object.keys(action.payload);\r\n },\r\n setStoreData: (state, action: PayloadAction<setStoreDataProps>) => {\r\n state.stores[action.payload.storeKey].data = action.payload.data;\r\n },\r\n setAutoLoadLoaded: () => {\r\n state.isAutoLoadLoaded = true;\r\n },\r\n },\r\n});\r\n\r\nexport const { setStoreData, setStoresMetaData, setAutoLoadLoaded } =\r\n commonStoreSlice.actions;\r\nexport default commonStoreSlice.reducer;\r\n","import { useDispatch, useSelector } from \"react-redux\";\r\nimport useSession from \"./UseSession\";\r\nimport useAxios from \"./useAxios\";\r\nimport { setStoreData } from \"../redux/features/common/CommonStoreSlice\";\r\n\r\nexport type ApiActionsProps = {\r\n findAll?: string;\r\n commonStoreKey?: string;\r\n setData?: any;\r\n findById?: string;\r\n findByIdParamName?: string;\r\n save?: string;\r\n deleteById?: string;\r\n deleteByIdParamName?: string;\r\n};\r\n\r\nexport type ApiActions = {\r\n reloadData: (params?: any) => Promise<void>;\r\n saveRecord: (record: any) => Promise<any | null>;\r\n loadRecordById: (recordId: any) => Promise<any>;\r\n deleteRecordById: (recordId: any) => Promise<boolean>;\r\n};\r\n\r\nconst useApiActions: (apiActionsProps: ApiActionsProps) => ApiActions = (\r\n apiActionsProps: ApiActionsProps\r\n) => {\r\n const CommonStores = useSelector((state: any) => state.commonStores.stores);\r\n const dispatch = useDispatch();\r\n const session = useSession();\r\n const { handleGetRequest, handlePostRequest, handleDeleteRequest } =\r\n useAxios();\r\n const reloadData = async (params?: any) => {\r\n if (apiActionsProps?.commonStoreKey) {\r\n const storeKeys = Object.keys(CommonStores);\r\n for (const storeKey of storeKeys) {\r\n if (storeKey === apiActionsProps.commonStoreKey) {\r\n if (\r\n (CommonStores[storeKey]?.authority === undefined ||\r\n CommonStores[storeKey]?.authority === null ||\r\n session.isUserAuthorized(CommonStores[storeKey]?.authority)) &&\r\n CommonStores[storeKey]?.url != \"\"\r\n ) {\r\n await handleGetRequest({\r\n endPointURI: CommonStores[storeKey].url,\r\n showMask: false,\r\n successCallBkFn: (response: any) => {\r\n dispatch(setStoreData({ storeKey, data: response.data }));\r\n apiActionsProps.setData(response.data);\r\n },\r\n failureCallBkFn: () => {\r\n dispatch(setStoreData({ storeKey, data: [] }));\r\n apiActionsProps.setData([]);\r\n },\r\n });\r\n break;\r\n }\r\n }\r\n }\r\n } else if (apiActionsProps?.findAll) {\r\n await handleGetRequest({\r\n endPointURI: apiActionsProps.findAll,\r\n showMask: true,\r\n parameters: params || {},\r\n successCallBkFn: (response: any) => {\r\n apiActionsProps.setData(response.data);\r\n },\r\n });\r\n }\r\n };\r\n const saveRecord = async (record: any) => {\r\n let savedRecord = null;\r\n if (apiActionsProps?.save) {\r\n await handlePostRequest({\r\n endPointURI: apiActionsProps.save,\r\n data: record,\r\n showMask: true,\r\n successCallBkFn: (response: any) => {\r\n savedRecord = response.data;\r\n },\r\n });\r\n }\r\n return savedRecord;\r\n };\r\n const loadRecordById = async (recordId: any) => {\r\n let record: any = null;\r\n if (apiActionsProps?.findById) {\r\n const parameters: any = {};\r\n const keyParameterName = apiActionsProps?.findByIdParamName || \"id\";\r\n parameters[keyParameterName] = recordId;\r\n await handleGetRequest({\r\n endPointURI: apiActionsProps.findById,\r\n showMask: true,\r\n parameters,\r\n successCallBkFn: (response: any) => {\r\n record = response.data;\r\n },\r\n });\r\n }\r\n return record;\r\n };\r\n const deleteRecordById = async (recordId: any) => {\r\n let result = true;\r\n if (apiActionsProps?.deleteById) {\r\n const parameters: any = {};\r\n const keyParameterName = apiActionsProps?.deleteByIdParamName || \"id\";\r\n parameters[keyParameterName] = recordId;\r\n await handleDeleteRequest({\r\n endPointURI: apiActionsProps.deleteById,\r\n showMask: true,\r\n parameters,\r\n successCallBkFn: () => {\r\n result = true;\r\n },\r\n failureCallBkFn: () => {\r\n result = false;\r\n },\r\n });\r\n }\r\n return result;\r\n };\r\n return { reloadData, loadRecordById, saveRecord, deleteRecordById };\r\n};\r\n\r\nexport default useApiActions;\r\n","import * as React from \"react\";\r\nimport List from \"@mui/material/List\";\r\nimport Card from \"@mui/material/Card\";\r\nimport CardHeader from \"@mui/material/CardHeader\";\r\nimport ListItem from \"@mui/material/ListItem\";\r\nimport ListItemText from \"@mui/material/ListItemText\";\r\nimport ListItemIcon from \"@mui/material/ListItemIcon\";\r\nimport Checkbox from \"@mui/material/Checkbox\";\r\nimport Button from \"@mui/material/Button\";\r\nimport Divider from \"@mui/material/Divider\";\r\nimport { Box, Grid2, ListItemButton } from \"@mui/material\";\r\nimport TemplateTextField from \"./DataEntryTemplates/TemplateDataForm/FormFields/TemplateTextField\";\r\n\r\nfunction not(a, b) {\r\n return a.filter((value) => b.indexOf(value) === -1);\r\n}\r\n\r\nfunction intersection(a, b) {\r\n return a.filter((value) => b.indexOf(value) !== -1);\r\n}\r\n\r\nfunction union(a, b) {\r\n return [...a, ...not(b, a)];\r\n}\r\n\r\nexport type TransferListProps = {\r\n valueField: string;\r\n displayField: string;\r\n options: Array<any>;\r\n selectedOptions: Array<any>;\r\n setSelection: any;\r\n};\r\n\r\nconst TransferList: React.FC<TransferListProps> = ({\r\n valueField = \"id\",\r\n displayField = \"name\",\r\n options = [],\r\n selectedOptions = [],\r\n setSelection,\r\n}) => {\r\n const [checked, setChecked] = React.useState([]);\r\n const [left, setLeft] = React.useState(options);\r\n const [right, setRight] = React.useState(selectedOptions);\r\n\r\n const [leftFilterValue, setLeftFilterValue] = React.useState<string>(\"\");\r\n const [rightFilterValue, setRightFilterValue] = React.useState<string>(\"\");\r\n\r\n const leftChecked = intersection(checked, left);\r\n const rightChecked = intersection(checked, right);\r\n\r\n const handleToggle = (value) => () => {\r\n const currentIndex = checked.indexOf(value);\r\n const newChecked = [...checked];\r\n\r\n if (currentIndex === -1) {\r\n newChecked.push(value);\r\n } else {\r\n newChecked.splice(currentIndex, 1);\r\n }\r\n\r\n setChecked(newChecked);\r\n };\r\n\r\n const numberOfChecked = (items) => intersection(checked, items).length;\r\n\r\n const handleToggleAll = (items) => () => {\r\n if (numberOfChecked(items) === items.length) {\r\n setChecked(not(checked, items));\r\n } else {\r\n setChecked(union(checked, items));\r\n }\r\n };\r\n\r\n const handleCheckedRight = () => {\r\n setRight((oldState) => {\r\n let newState = right.concat(leftChecked);\r\n setSelection(newState);\r\n return newState;\r\n });\r\n setLeft(not(left, leftChecked));\r\n setChecked(not(checked, leftChecked));\r\n };\r\n\r\n const handleCheckedLeft = () => {\r\n setLeft(left.concat(rightChecked));\r\n setRight((oldState) => {\r\n let newState = not(right, rightChecked);\r\n setSelection(newState);\r\n return newState;\r\n });\r\n setChecked(not(checked, rightChecked));\r\n };\r\n\r\n const customList = (\r\n title: string,\r\n unfilteredItems: Array<any>,\r\n side: \"left\" | \"right\"\r\n ) => {\r\n const items = unfilteredItems.filter((option: any) => {\r\n if (option[displayField]) {\r\n const value: string = option[displayField];\r\n if (\r\n side === \"left\" &&\r\n value\r\n .toLocaleLowerCase()\r\n .includes(leftFilterValue.toLocaleLowerCase())\r\n ) {\r\n return true;\r\n } else if (\r\n side === \"right\" &&\r\n value\r\n .toLocaleLowerCase()\r\n .includes(rightFilterValue.toLocaleLowerCase())\r\n ) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n });\r\n return (\r\n <Card sx={{ height: \"100%\" }}>\r\n <CardHeader\r\n sx={{ px: 2, py: 1 }}\r\n avatar={\r\n <Checkbox\r\n onClick={handleToggleAll(items)}\r\n checked={\r\n numberOfChecked(items) === items.length && items.length !== 0\r\n }\r\n indeterminate={\r\n numberOfChecked(items) !== items.length &&\r\n numberOfChecked(items) !== 0\r\n }\r\n disabled={items.length === 0}\r\n inputProps={{\r\n \"aria-label\": \"all items selected\",\r\n }}\r\n />\r\n }\r\n title={title}\r\n subheader={`${numberOfChecked(unfilteredItems)} / ${\r\n unfilteredItems.length\r\n } Selected`}\r\n />\r\n <Box sx={{ width: \"100%\", padding: 1 }}>\r\n <TemplateTextField\r\n fullWidth\r\n label=\"search\"\r\n value={side === \"left\" ? leftFilterValue : rightFilterValue}\r\n onChange={(event) => {\r\n if (side === \"left\") {\r\n setLeftFilterValue(event.target.value);\r\n } else {\r\n setRightFilterValue(event.target.value);\r\n }\r\n }}\r\n />\r\n </Box>\r\n <Divider />\r\n <List\r\n sx={{\r\n width: \"100%\",\r\n height: \"100%\",\r\n bgcolor: \"secondary\",\r\n overflow: \"auto\",\r\n }}\r\n dense\r\n component=\"div\"\r\n role=\"list\"\r\n >\r\n {items.map((value) => {\r\n const labelId = `transfer-list-all-item-${value[valueField]}-label`;\r\n\r\n return (\r\n <ListItemButton\r\n key={value[valueField]}\r\n role=\"listitem\"\r\n onClick={handleToggle(value)}\r\n sx={{ cursor: \"pointer\" }} \r\n >\r\n <ListItemIcon>\r\n <Checkbox\r\n checked={checked.indexOf(value) !== -1}\r\n tabIndex={-1}\r\n disableRipple\r\n />\r\n </ListItemIcon>\r\n <ListItemText\r\n id={value[valueField]}\r\n primary={value[displayField]}\r\n />\r\n </ListItemButton>\r\n );\r\n })}\r\n </List>\r\n </Card>\r\n );\r\n };\r\n return (\r\n <Grid2\r\n container\r\n spacing={2}\r\n sx={{\r\n flexGrow: 1,\r\n overflow: \"auto\",\r\n margin: 1,\r\n display: \"flex\",\r\n width: \"100%\",\r\n }}\r\n justifyContent=\"center\"\r\n alignItems=\"center\"\r\n >\r\n <Grid2 sx={{ height: \"100%\", flex: 1 }}>\r\n {customList(\"Available Items\", left, \"left\")}\r\n </Grid2>\r\n <Grid2>\r\n <Grid2 container direction=\"column\" alignItems=\"center\">\r\n <Button\r\n sx={{ my: 0.5 }}\r\n variant=\"outlined\"\r\n size=\"small\"\r\n onClick={handleCheckedRight}\r\n disabled={leftChecked.length === 0}\r\n aria-label=\"move selected right\"\r\n >\r\n &gt;\r\n </Button>\r\n <Button\r\n sx={{ my: 0.5 }}\r\n variant=\"outlined\"\r\n size=\"small\"\r\n onClick={handleCheckedLeft}\r\n disabled={rightChecked.length === 0}\r\n aria-label=\"move selected left\"\r\n >\r\n &lt;\r\n </Button>\r\n </Grid2>\r\n </Grid2>\r\n <Grid2 sx={{ height: \"100%\", flex: 1 }}>\r\n {customList(\"Currently Selected\", right, \"right\")}\r\n </Grid2>\r\n </Grid2>\r\n );\r\n};\r\n\r\nexport default TransferList;\r\n","import { PieChart } from \"@mui/x-charts/PieChart\";\r\nimport { WidgetProps } from \"../TemplateDashboard\";\r\n\r\nconst TemplatePieChart: React.FC<WidgetProps> = (props) => {\r\n // construct data object\r\n const chartData = props.data.map((record: any, index: any) => {\r\n return {\r\n id: index,\r\n value: record[props.valueField],\r\n label: record[props.labelField] + \"\",\r\n };\r\n });\r\n console.log(\"chartData\", chartData);\r\n return (\r\n <PieChart\r\n series={[\r\n {\r\n data: chartData,\r\n },\r\n ]}\r\n />\r\n );\r\n};\r\n\r\nexport default TemplatePieChart;\r\n","import { BarChart } from \"@mui/x-charts\";\r\nimport { WidgetProps } from \"../TemplateDashboard\";\r\n\r\nconst TemplateBarChart: React.FC<WidgetProps> = (props) => {\r\n return (\r\n <BarChart\r\n dataset={props.data}\r\n xAxis={[{ dataKey: props.valueField, scaleType: \"band\" }]}\r\n series={props.labelField?.split(\",\").map((labelField) => {\r\n return { dataKey: labelField, label: labelField };\r\n })}\r\n />\r\n );\r\n};\r\n\r\nexport default TemplateBarChart;\r\n","import { LineChart } from \"@mui/x-charts\";\r\nimport { WidgetProps } from \"../TemplateDashboard\";\r\n\r\nconst TemplateLineChart: React.FC<WidgetProps> = (props) => {\r\n return (\r\n <LineChart\r\n dataset={props.data}\r\n xAxis={[{ dataKey: props.valueField, scaleType: \"band\" }]}\r\n series={props.labelField?.split(\",\").map((labelField) => {\r\n return { dataKey: labelField, label: labelField };\r\n })}\r\n />\r\n );\r\n};\r\n\r\nexport default TemplateLineChart;\r\n","import { Gauge } from \"@mui/x-charts\";\r\nimport { SingleRecordWidgetProps } from \"../TemplateDashboard\";\r\nimport { Typography } from \"@mui/material\";\r\n\r\nconst TemplateGauge: React.FC<SingleRecordWidgetProps> = (props: any) => {\r\n return (\r\n <>\r\n <Typography sx={{ fontSize: 16, fontWeight: \"bold\" }}>\r\n {props.widgetTitle} - {props.record[props.labelField]}\r\n </Typography>\r\n <Gauge width={200} height={200} value={props.record[props.valueField]} />\r\n </>\r\n );\r\n};\r\n\r\nexport default TemplateGauge;\r\n","import { Box, Paper, Typography } from \"@mui/material\";\r\nimport { SingleRecordWidgetProps } from \"../TemplateDashboard\";\r\n\r\nconst TemplateDataCard: React.FC<SingleRecordWidgetProps> = (props: any) => {\r\n return (\r\n <Paper\r\n sx={{\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n height: 150,\r\n padding: 1,\r\n flexGrow: 1,\r\n justifyContent: \"center\",\r\n alignItems: \"center\",\r\n }}\r\n >\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n width: \"100%\",\r\n justifyContent: \"space-evenly\",\r\n alignItems: \"center\",\r\n }}\r\n >\r\n <Typography sx={{ fontSize: 16, fontWeight: \"bold\" }}>\r\n {props.widgetTitle}\r\n </Typography>\r\n </Box>\r\n <Box\r\n sx={{\r\n flex: 1,\r\n display: \"flex\",\r\n width: \"100%\",\r\n justifyContent: \"space-evenly\",\r\n alignItems: \"center\",\r\n }}\r\n >\r\n {/* <div>left</div> */}\r\n <div>{`${props.record[props.labelField]} : ${\r\n props.record[props.valueField]\r\n }`}</div>\r\n {/* <div>right</div> */}\r\n </Box>\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n width: \"100%\",\r\n justifyContent: \"space-evenly\",\r\n alignItems: \"center\",\r\n }}\r\n >\r\n {/* <div>left</div>\r\n <div>center</div>\r\n <div>right</div> */}\r\n </Box>\r\n </Paper>\r\n );\r\n};\r\n\r\nexport default TemplateDataCard;\r\n","import * as React from \"react\";\r\nimport LinearProgress, {\r\n LinearProgressProps,\r\n} from \"@mui/material/LinearProgress\";\r\nimport Typography from \"@mui/material/Typography\";\r\nimport Box from \"@mui/material/Box\";\r\nimport { SingleRecordWidgetProps } from \"../TemplateDashboard\";\r\n\r\nfunction LinearProgressWithLabel(\r\n props: LinearProgressProps & { value: number }\r\n) {\r\n return (\r\n <Box sx={{ display: \"flex\", alignItems: \"center\" }}>\r\n <Box sx={{ width: \"100%\", mr: 1 }}>\r\n <LinearProgress variant=\"determinate\" {...props} />\r\n </Box>\r\n <Box sx={{ minWidth: 35 }}>\r\n <Typography\r\n variant=\"body2\"\r\n sx={{ color: \"text.secondary\" }}\r\n >{`${Math.round(props.value)}%`}</Typography>\r\n </Box>\r\n </Box>\r\n );\r\n}\r\n\r\nconst TemplateLineProgress: React.FC<SingleRecordWidgetProps> = (\r\n props: any\r\n) => {\r\n return (\r\n <Box sx={{ width: \"100%\" }}>\r\n <Typography sx={{ fontSize: 16, fontWeight: \"bold\" }}>\r\n {props.widgetTitle} - {props.record[props.labelField]}\r\n </Typography>\r\n <LinearProgressWithLabel value={props.record[props.valueField]} />\r\n </Box>\r\n );\r\n};\r\n\r\nexport default TemplateLineProgress;\r\n","import Grid from \"@mui/material/Grid2\";\r\nimport TemplatePieChart from \"./charts/TemplatePieChart\";\r\nimport TemplateBarChart from \"./charts/TemplateBarChart\";\r\nimport TemplateLineChart from \"./charts/TemplateLineChart\";\r\nimport TemplateGauge from \"./charts/TemplateGauge\";\r\nimport TemplateDataCard from \"./charts/TemplateDataCard\";\r\nimport TemplateLineProgress from \"./charts/TemplateLineProgress\";\r\nimport { Typography } from \"@mui/material\";\r\n\r\ninterface WidgetContainerProps {\r\n children: React.ReactNode;\r\n widgetType: \"Line\" | \"Bar\" | \"Pie\" | \"Card\" | \"Gauge\" | \"Progress\";\r\n}\r\n\r\nexport interface WidgetProps {\r\n widgetTitle?: string;\r\n widgetType: \"Line\" | \"Bar\" | \"Pie\" | \"Card\" | \"Gauge\" | \"Progress\";\r\n data: any;\r\n valueField: string; //x-axis field in case of line/bar chart\r\n labelField: string; //y-axis field in case of line/bar chart, it can also be a comma separated string for multiple series\r\n}\r\n\r\nexport interface SingleRecordWidgetProps {\r\n widgetTitle?: string;\r\n record: object;\r\n valueField: string;\r\n labelField: string;\r\n}\r\n\r\nexport interface DashboardProps {\r\n dashboardTitle: string;\r\n dashboardWidgets: Array<WidgetProps>;\r\n}\r\n\r\nconst WidgetContainer: React.FC<WidgetContainerProps> = ({\r\n children,\r\n widgetType,\r\n}) => {\r\n return (\r\n <Grid\r\n size={{ xs: 12, sm: 6, md: 4 }}\r\n sx={{\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n padding: 1,\r\n display: \"flex\",\r\n flexDirection: widgetType != \"Card\" ? \"column\" : undefined,\r\n height: 300,\r\n }}\r\n >\r\n {children}\r\n </Grid>\r\n );\r\n};\r\n\r\nconst TemplateDashboard: React.FC<DashboardProps> = (props) => {\r\n return (\r\n <>\r\n <Typography sx={{ fontSize: 20, fontWeight: \"bold\" }}>\r\n {props.dashboardTitle}\r\n </Typography>\r\n <Grid\r\n container\r\n sx={{\r\n flexGrow: 1,\r\n width: \"100%\",\r\n overflowY: \"auto\",\r\n padding: 2,\r\n }}\r\n >\r\n {props.dashboardWidgets.map((widgetProps: any, index: any) => {\r\n if (\r\n widgetProps.widgetType === \"Card\" ||\r\n widgetProps.widgetType === \"Gauge\" ||\r\n widgetProps.widgetType === \"Progress\"\r\n ) {\r\n return (\r\n <>\r\n {widgetProps.data.map((record: any, index: any) => {\r\n const singleRecordWidgetProps: SingleRecordWidgetProps = {\r\n widgetTitle: widgetProps.widgetTitle,\r\n record,\r\n labelField: widgetProps.labelField,\r\n valueField: widgetProps.valueField,\r\n };\r\n return (\r\n <WidgetContainer\r\n key={index}\r\n widgetType={widgetProps.widgetType}\r\n >\r\n {widgetProps.widgetType === \"Card\" ? (\r\n <TemplateDataCard {...singleRecordWidgetProps} />\r\n ) : null}\r\n {widgetProps.widgetType === \"Gauge\" ? (\r\n <TemplateGauge {...singleRecordWidgetProps} />\r\n ) : null}\r\n {widgetProps.widgetType === \"Progress\" ? (\r\n <TemplateLineProgress {...singleRecordWidgetProps} />\r\n ) : null}\r\n </WidgetContainer>\r\n );\r\n })}\r\n </>\r\n );\r\n } else {\r\n return (\r\n <WidgetContainer key={index} widgetType={widgetProps.widgetType}>\r\n {widgetProps.widgetType === \"Pie\" ? (\r\n <TemplatePieChart {...widgetProps} />\r\n ) : null}\r\n {widgetProps.widgetType === \"Line\" ? (\r\n <TemplateLineChart {...widgetProps} />\r\n ) : null}\r\n {widgetProps.widgetType === \"Bar\" ? (\r\n <TemplateBarChart {...widgetProps} />\r\n ) : null}\r\n </WidgetContainer>\r\n );\r\n }\r\n })}\r\n </Grid>\r\n </>\r\n );\r\n};\r\n\r\nexport default TemplateDashboard;\r\n","import { useState } from \"react\";\r\nimport { Box, Button } from \"@mui/material\";\r\nimport { toast } from \"react-toastify\";\r\nimport { useAxios } from \"../../hooks\";\r\nimport { TransferList } from \"../templates\";\r\n\r\ntype RoleAuthoritiesFormProps = {\r\n roleId: number;\r\n availableAuthorities: Array<any>;\r\n currentRoleAuthorities: Array<any>;\r\n closeModalFn: () => void;\r\n};\r\n\r\nconst RoleAuthoritiesForm: React.FC<RoleAuthoritiesFormProps> = (props) => {\r\n const [selectedOptions, setSelectedOptions] = useState([\r\n ...props.currentRoleAuthorities,\r\n ]);\r\n const { handlePostRequest } = useAxios();\r\n const saveRoleAuthorities = async () => {\r\n await handlePostRequest({\r\n endPointURI: \"api/v1/admin/role/authorities\",\r\n showMask: true,\r\n parameters: { roleId: props.roleId },\r\n data: selectedOptions,\r\n successCallBkFn: () => {\r\n toast.success(\"Your request has been proccesed successfully\");\r\n if (props.closeModalFn) {\r\n props.closeModalFn();\r\n }\r\n },\r\n });\r\n };\r\n return (\r\n <>\r\n <TransferList\r\n displayField=\"authorityName\"\r\n options={props.availableAuthorities}\r\n valueField=\"id\"\r\n selectedOptions={selectedOptions}\r\n setSelection={setSelectedOptions}\r\n />\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"flex-end\",\r\n width: \"100%\",\r\n }}\r\n >\r\n <Button\r\n variant=\"contained\"\r\n onClick={saveRoleAuthorities}\r\n sx={{ marginRight: 1, marginLeft: 1 }}\r\n >\r\n Save\r\n </Button>\r\n <Button variant=\"contained\" color=\"error\" onClick={props.closeModalFn}>\r\n Cancel\r\n </Button>\r\n </Box>\r\n </>\r\n );\r\n};\r\n\r\nexport default RoleAuthoritiesForm;\r\n","import Home from \"../components/common/Home\";\r\nimport { ADMINISTRATION_ROUTES } from \"./administration\";\r\nimport { SystemRoute } from \"./types\";\r\n\r\nexport const SYSTEM_ROUTES: Array<SystemRoute> = [\r\n {\r\n path: \"/\",\r\n component: Home,\r\n },\r\n ...ADMINISTRATION_ROUTES,\r\n];\r\n","import { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport { Box } from \"@mui/material\";\r\n\r\nconst Home: React.FC = () => {\r\n return (\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n flex: 1,\r\n fontSize: 24,\r\n fontWeight: \"bold\",\r\n }}\r\n >\r\n <img src=\"logo.png\" style={{ margin: 5 }} />\r\n <div>Welcome to Ezzsteel Flat Product Management System</div>\r\n <div style={{ fontSize: 16 }}>\r\n Use side menu [\r\n <FontAwesomeIcon\r\n icon=\"bars\"\r\n style={{ marginLeft: 10, marginRight: 10 }}\r\n />\r\n ] to navigate to your authorized system modules\r\n </div>\r\n </Box>\r\n );\r\n};\r\n\r\nexport default Home;\r\n","import { SystemRoute } from \"../types\";\r\nimport { adminRoutes } from \"./adminRoutes\";\r\n\r\nexport const ADMINISTRATION_ROUTES: Array<SystemRoute> = [...adminRoutes];\r\n","import { SystemRoute } from \"../types\";\r\n\r\nimport AuthorityGrid from \"../../components/admin/AuthorityGrid\";\r\nimport BluePrintGrid from \"../../components/admin/BluePrintGrid\";\r\nimport BluePrintPageGrid from \"../../components/admin/BluePrintPageGrid\";\r\nimport BluePrintPointGrid from \"../../components/admin/BluePrintPointGrid\";\r\nimport DashboardGrid from \"../../components/admin/DashboardGrid\";\r\nimport DashboardWidgetGrid from \"../../components/admin/DashboardWidgetGrid\";\r\nimport DataQueryGrid from \"../../components/admin/DataQueryGrid\";\r\nimport DataQueryParameterGrid from \"../../components/admin/DataQueryParameterGrid\";\r\nimport DatasourceConnectionGrid from \"../../components/admin/DatasourceConnectionGrid\";\r\nimport EmployeeGrid from \"../../components/admin/EmployeeGrid\";\r\nimport EntityParameterGrid from \"../../components/admin/EntityParameterGrid\";\r\nimport ExcelUploaderDetailGrid from \"../../components/admin/ExcelUploaderDetailGrid\";\r\nimport ExcelUploaderHeaderGrid from \"../../components/admin/ExcelUploaderHeaderGrid\";\r\nimport LookupGrid from \"../../components/admin/LookupGrid\";\r\nimport MailAttachmentGrid from \"../../components/admin/MailAttachmentGrid\";\r\nimport MailBodyGrid from \"../../components/admin/MailBodyGrid\";\r\nimport MailNotificationQueueGrid from \"../../components/admin/MailNotificationQueueGrid\";\r\nimport MailRecipientGrid from \"../../components/admin/MailRecipientGrid\";\r\nimport MailTemplateGrid from \"../../components/admin/MailTemplateGrid\";\r\nimport NewTableGrid from \"../../components/admin/NewTableGrid\";\r\nimport NotificationGrid from \"../../components/admin/NotificationGrid\";\r\nimport NotificationQueueGrid from \"../../components/admin/NotificationQueueGrid\";\r\nimport OrganizationGrid from \"../../components/admin/OrganizationGrid\";\r\nimport OrganizationApplicationGrid from \"../../components/admin/OrganizationApplicationGrid\";\r\nimport OrganizationRankGrid from \"../../components/admin/OrganizationRankGrid\";\r\nimport OrganizationUnitGrid from \"../../components/admin/OrganizationUnitGrid\";\r\nimport OrganizationUserGrid from \"../../components/admin/OrganizationUserGrid\";\r\nimport OrganizationUserRoleGrid from \"../../components/admin/OrganizationUserRoleGrid\";\r\nimport ReportGrid from \"../../components/admin/ReportGrid\";\r\nimport ReportParameterGrid from \"../../components/admin/ReportParameterGrid\";\r\nimport RoleGrid from \"../../components/admin/RoleGrid\";\r\nimport RoleAuthorityGrid from \"../../components/admin/RoleAuthorityGrid\";\r\nimport UserAccountGrid from \"../../components/admin/UserAccountGrid\";\r\nimport UserRequestGrid from \"../../components/admin/UserRequestGrid\";\r\nimport WidgetGrid from \"../../components/admin/WidgetGrid\";\r\nimport WorkflowDocumentGrid from \"../../components/admin/WorkflowDocumentGrid\";\r\nimport WorkflowDocumentActionGrid from \"../../components/admin/WorkflowDocumentActionGrid\";\r\nimport WorkflowDocumentActionHistoryGrid from \"../../components/admin/WorkflowDocumentActionHistoryGrid\";\r\nimport WorkflowDocumentActionMailGrid from \"../../components/admin/WorkflowDocumentActionMailGrid\";\r\nimport WorkflowDocumentMailLogGrid from \"../../components/admin/WorkflowDocumentMailLogGrid\";\r\nimport WorkflowDocumentStatusGrid from \"../../components/admin/WorkflowDocumentStatusGrid\";\r\nimport AttachmentGrid from \"../../components/admin/AttachmentGrid\";\r\nexport const adminRoutes: Array<SystemRoute> = [\r\n {\r\n path: \"admin/attachments\",\r\n component: AttachmentGrid,\r\n authority: \"ATTACHMENT_VIEW\",\r\n },\r\n {\r\n path: \"admin/authorities\",\r\n component: AuthorityGrid,\r\n authority: \"AUTHORITY_VIEW\",\r\n },\r\n {\r\n path: \"admin/blueprints\",\r\n component: BluePrintGrid,\r\n authority: \"BLUE_PRINT_VIEW\",\r\n },\r\n {\r\n path: \"admin/blueprintpages\",\r\n component: BluePrintPageGrid,\r\n authority: \"BLUE_PRINT_PAGE_VIEW\",\r\n },\r\n {\r\n path: \"admin/blueprintpoints\",\r\n component: BluePrintPointGrid,\r\n authority: \"BLUE_PRINT_POINT_VIEW\",\r\n },\r\n {\r\n path: \"admin/dashboards\",\r\n component: DashboardGrid,\r\n authority: \"DASHBOARD_VIEW\",\r\n },\r\n {\r\n path: \"admin/dashboardwidgets\",\r\n component: DashboardWidgetGrid,\r\n authority: \"DASHBOARD_WIDGET_VIEW\",\r\n },\r\n {\r\n path: \"admin/dataqueries\",\r\n component: DataQueryGrid,\r\n authority: \"DATA_QUERY_VIEW\",\r\n },\r\n {\r\n path: \"admin/dataqueryparameters\",\r\n component: DataQueryParameterGrid,\r\n authority: \"DATA_QUERY_PARAMETER_VIEW\",\r\n },\r\n {\r\n path: \"admin/datasourceconnections\",\r\n component: DatasourceConnectionGrid,\r\n authority: \"DATASOURCE_CONNECTION_VIEW\",\r\n },\r\n {\r\n path: \"admin/employees\",\r\n component: EmployeeGrid,\r\n authority: \"EMPLOYEE_VIEW\",\r\n },\r\n {\r\n path: \"admin/entityparameters\",\r\n component: EntityParameterGrid,\r\n authority: \"ENTITY_PARAMETER_VIEW\",\r\n },\r\n {\r\n path: \"admin/exceluploaderdetails\",\r\n component: ExcelUploaderDetailGrid,\r\n authority: \"EXCEL_UPLOADER_DETAIL_VIEW\",\r\n },\r\n {\r\n path: \"admin/exceluploaderheaders\",\r\n component: ExcelUploaderHeaderGrid,\r\n authority: \"EXCEL_UPLOADER_HEADER_VIEW\",\r\n },\r\n {\r\n path: \"admin/lookups\",\r\n component: LookupGrid,\r\n authority: \"LOOKUP_VIEW\",\r\n },\r\n {\r\n path: \"admin/mailattachments\",\r\n component: MailAttachmentGrid,\r\n authority: \"MAIL_ATTACHMENT_VIEW\",\r\n },\r\n {\r\n path: \"admin/mailbodies\",\r\n component: MailBodyGrid,\r\n authority: \"MAIL_BODY_VIEW\",\r\n },\r\n {\r\n path: \"admin/mailnotificationqueues\",\r\n component: MailNotificationQueueGrid,\r\n authority: \"MAIL_NOTIFICATION_QUEUE_VIEW\",\r\n },\r\n {\r\n path: \"admin/mailrecipients\",\r\n component: MailRecipientGrid,\r\n authority: \"MAIL_RECIPIENT_VIEW\",\r\n },\r\n {\r\n path: \"admin/mailtemplates\",\r\n component: MailTemplateGrid,\r\n authority: \"MAIL_TEMPLATE_VIEW\",\r\n },\r\n {\r\n path: \"admin/newtables\",\r\n component: NewTableGrid,\r\n authority: \"NEW_TABLE_VIEW\",\r\n },\r\n {\r\n path: \"admin/notifications\",\r\n component: NotificationGrid,\r\n authority: \"NOTIFICATION_VIEW\",\r\n },\r\n {\r\n path: \"admin/notificationqueues\",\r\n component: NotificationQueueGrid,\r\n authority: \"NOTIFICATION_QUEUE_VIEW\",\r\n },\r\n {\r\n path: \"admin/organizations\",\r\n component: OrganizationGrid,\r\n authority: \"ORGANIZATION_VIEW\",\r\n },\r\n {\r\n path: \"admin/organizationapplications\",\r\n component: OrganizationApplicationGrid,\r\n authority: \"ORGANIZATION_APPLICATION_VIEW\",\r\n },\r\n {\r\n path: \"admin/organizationranks\",\r\n component: OrganizationRankGrid,\r\n authority: \"ORGANIZATION_RANK_VIEW\",\r\n },\r\n {\r\n path: \"admin/organizationunits\",\r\n component: OrganizationUnitGrid,\r\n authority: \"ORGANIZATION_UNIT_VIEW\",\r\n },\r\n {\r\n path: \"admin/organizationusers\",\r\n component: OrganizationUserGrid,\r\n authority: \"ORGANIZATION_USER_VIEW\",\r\n },\r\n {\r\n path: \"admin/organizationuserroles\",\r\n component: OrganizationUserRoleGrid,\r\n authority: \"ORGANIZATION_USER_ROLE_VIEW\",\r\n },\r\n {\r\n path: \"admin/reports\",\r\n component: ReportGrid,\r\n authority: \"REPORT_VIEW\",\r\n },\r\n {\r\n path: \"admin/reportparameters\",\r\n component: ReportParameterGrid,\r\n authority: \"REPORT_PARAMETER_VIEW\",\r\n },\r\n {\r\n path: \"admin/roles\",\r\n component: RoleGrid,\r\n authority: \"ROLE_VIEW\",\r\n },\r\n {\r\n path: \"admin/roleauthorities\",\r\n component: RoleAuthorityGrid,\r\n authority: \"ROLE_AUTHORITY_VIEW\",\r\n },\r\n {\r\n path: \"admin/useraccounts\",\r\n component: UserAccountGrid,\r\n authority: \"USER_ACCOUNT_VIEW\",\r\n },\r\n {\r\n path: \"admin/userrequests\",\r\n component: UserRequestGrid,\r\n authority: \"USER_REQUEST_VIEW\",\r\n },\r\n {\r\n path: \"admin/widgets\",\r\n component: WidgetGrid,\r\n authority: \"WIDGET_VIEW\",\r\n },\r\n {\r\n path: \"admin/workflowdocuments\",\r\n component: WorkflowDocumentGrid,\r\n authority: \"WORKFLOW_DOCUMENT_VIEW\",\r\n },\r\n {\r\n path: \"admin/workflowdocumentactions\",\r\n component: WorkflowDocumentActionGrid,\r\n authority: \"WORKFLOW_DOCUMENT_ACTION_VIEW\",\r\n },\r\n {\r\n path: \"admin/workflowdocumentactionhistories\",\r\n component: WorkflowDocumentActionHistoryGrid,\r\n authority: \"WORKFLOW_DOCUMENT_ACTION_HISTORY_VIEW\",\r\n },\r\n {\r\n path: \"admin/workflowdocumentactionmails\",\r\n component: WorkflowDocumentActionMailGrid,\r\n authority: \"WORKFLOW_DOCUMENT_ACTION_MAIL_VIEW\",\r\n },\r\n {\r\n path: \"admin/workflowdocumentmaillogs\",\r\n component: WorkflowDocumentMailLogGrid,\r\n authority: \"WORKFLOW_DOCUMENT_MAIL_LOG_VIEW\",\r\n },\r\n {\r\n path: \"admin/workflowdocumentstatuses\",\r\n component: WorkflowDocumentStatusGrid,\r\n authority: \"WORKFLOW_DOCUMENT_STATUS_VIEW\",\r\n },\r\n];\r\n\r\n// import { adminRoutes } from \"./adminRoutes\";\r\n// [...adminRoutes]\r\n","import { useState } from \"react\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\n\r\n\r\nconst AttachmentGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/attachment/all\",\r\n deleteById: \"api/v1/admin/attachment\",\r\n save: \"api/v1/admin/attachment\",\r\n findById: \"api/v1/admin/attachment\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ATTACHMENT_ATTACHMENT_NUMBER\",\r\n fieldName: \"attachmentNumber\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ATTACHMENT_ATTACHMENT_SIZE\",\r\n fieldName: \"attachmentSize\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ATTACHMENT_ATTACHMENT_TYPE\",\r\n fieldName: \"attachmentType\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ATTACHMENT_CATEGORY\",\r\n fieldName: \"category\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ATTACHMENT_DOC_TYPE\",\r\n fieldName: \"docType\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ATTACHMENT_FILE_NAME\",\r\n fieldName: \"fileName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ATTACHMENT_REF_KEY\",\r\n fieldName: \"refKey\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ATTACHMENT_REMARK\",\r\n fieldName: \"remark\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"ATTACHMENT_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"ATTACHMENT_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"ATTACHMENT_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default AttachmentGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst AuthorityGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n commonStoreKey: \"SystemAuthorities\",\r\n deleteById: \"api/v1/admin/authority\",\r\n save: \"api/v1/admin/authority\",\r\n findById: \"api/v1/admin/authority\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"AUTHORITY_AUTHORITY_CODE\",\r\n fieldName: \"authorityCode\",\r\n required: true,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"AUTHORITY_AUTHORITY_DESCRIPTION\",\r\n fieldName: \"authorityDescription\",\r\n required: true,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"AUTHORITY_AUTHORITY_NAME\",\r\n fieldName: \"authorityName\",\r\n required: true,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"AUTHORITY_IS_ACTIVE\",\r\n fieldName: \"isActive\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"AUTHORITY_ORGANIZATION_APPLICATION_ID\",\r\n fieldName: \"organizationApplicationId\",\r\n required: false,\r\n fieldType: \"text\",\r\n gridProps: {\r\n hidden: true,\r\n },\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\", reloadAfterSave: true }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"AUTHORITY_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"AUTHORITY_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"AUTHORITY_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default AuthorityGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst BluePrintGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/blueprint/all\",\r\n deleteById: \"api/v1/admin/blueprint\",\r\n save: \"api/v1/admin/blueprint\",\r\n findById: \"api/v1/admin/blueprint\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_BLUE_PRINT_CODE\",\r\n fieldName: \"bluePrintCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_QUERY_ID\",\r\n fieldName: \"queryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"BLUE_PRINT_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"BLUE_PRINT_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"BLUE_PRINT_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default BluePrintGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst BluePrintPageGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/blueprintpage/all\",\r\n deleteById: \"api/v1/admin/blueprintpage\",\r\n save: \"api/v1/admin/blueprintpage\",\r\n findById: \"api/v1/admin/blueprintpage\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_PAGE_BLUE_PRINT_ID\",\r\n fieldName: \"bluePrintId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_PAGE_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_PAGE_PAGE_NAME\",\r\n fieldName: \"pageName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_PAGE_PAGE_ORDER\",\r\n fieldName: \"pageOrder\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_PAGE_QUERY_ID\",\r\n fieldName: \"queryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"BLUE_PRINT_PAGE_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"BLUE_PRINT_PAGE_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"BLUE_PRINT_PAGE_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default BluePrintPageGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst BluePrintPointGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/blueprintpoint/all\",\r\n deleteById: \"api/v1/admin/blueprintpoint\",\r\n save: \"api/v1/admin/blueprintpoint\",\r\n findById: \"api/v1/admin/blueprintpoint\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_POINT_BLUE_PRINT_PAGE_ID\",\r\n fieldName: \"bluePrintPageId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_POINT_FONT_SIZE\",\r\n fieldName: \"fontSize\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_POINT_POINT_CODE\",\r\n fieldName: \"pointCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_POINT_X\",\r\n fieldName: \"x\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"BLUE_PRINT_POINT_Y\",\r\n fieldName: \"y\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"BLUE_PRINT_POINT_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"BLUE_PRINT_POINT_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"BLUE_PRINT_POINT_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default BluePrintPointGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst DashboardGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/dashboard/all\",\r\n deleteById: \"api/v1/admin/dashboard\",\r\n save: \"api/v1/admin/dashboard\",\r\n findById: \"api/v1/admin/dashboard\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DASHBOARD_DASHBOARD_CODE\",\r\n fieldName: \"dashboardCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DASHBOARD_DASHBOARD_NAME\",\r\n fieldName: \"dashboardName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DASHBOARD_DASHBOARD_TITLE\",\r\n fieldName: \"dashboardTitle\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DASHBOARD_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DASHBOARD_LOAD_WIDGETS_INDIVIDUALLY\",\r\n fieldName: \"loadWidgetsIndividually\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DASHBOARD_NUMBER_OF_COLUMNS\",\r\n fieldName: \"numberOfColumns\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"DASHBOARD_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"DASHBOARD_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"DASHBOARD_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default DashboardGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst DashboardWidgetGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/dashboardwidget/all\",\r\n deleteById: \"api/v1/admin/dashboardwidget\",\r\n save: \"api/v1/admin/dashboardwidget\",\r\n findById: \"api/v1/admin/dashboardwidget\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DASHBOARD_WIDGET_DASHBOARD_ID\",\r\n fieldName: \"dashboardId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DASHBOARD_WIDGET_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DASHBOARD_WIDGET_WIDGET_ID\",\r\n fieldName: \"widgetId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DASHBOARD_WIDGET_WIDGET_ORDER\",\r\n fieldName: \"widgetOrder\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"DASHBOARD_WIDGET_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"DASHBOARD_WIDGET_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"DASHBOARD_WIDGET_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default DashboardWidgetGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst DataQueryGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n commonStoreKey: \"SystemDataQueries\",\r\n deleteById: \"api/v1/admin/dataquery\",\r\n save: \"api/v1/admin/dataquery\",\r\n findById: \"api/v1/admin/dataquery\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATA_QUERY_DATASOURCE_CON_ID\",\r\n fieldName: \"datasourceConId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATA_QUERY_QUERY_NAME\",\r\n fieldName: \"queryName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATA_QUERY_QUERY_STR\",\r\n fieldName: \"queryStr\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATA_QUERY_USE_SYS_CON\",\r\n fieldName: \"useSysCon\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\", reloadAfterSave: true }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"DATA_QUERY_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"DATA_QUERY_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"DATA_QUERY_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default DataQueryGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst DataQueryParameterGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/dataqueryparameter/all\",\r\n deleteById: \"api/v1/admin/dataqueryparameter\",\r\n save: \"api/v1/admin/dataqueryparameter\",\r\n findById: \"api/v1/admin/dataqueryparameter\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATA_QUERY_PARAMETER_DATA_QUERY_ID\",\r\n fieldName: \"dataQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATA_QUERY_PARAMETER_DEFAULT_VALUE\",\r\n fieldName: \"defaultValue\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATA_QUERY_PARAMETER_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATA_QUERY_PARAMETER_ENTITY_PARAMETER_ID\",\r\n fieldName: \"entityParameterId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATA_QUERY_PARAMETER_HIDDEN\",\r\n fieldName: \"hidden\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATA_QUERY_PARAMETER_MANDATORY\",\r\n fieldName: \"mandatory\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"DATA_QUERY_PARAMETER_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"DATA_QUERY_PARAMETER_EDIT\" }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"DATA_QUERY_PARAMETER_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default DataQueryParameterGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst DatasourceConnectionGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n commonStoreKey: \"SystemDataSources\",\r\n deleteById: \"api/v1/admin/datasourceconnection\",\r\n save: \"api/v1/admin/datasourceconnection\",\r\n findById: \"api/v1/admin/datasourceconnection\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATASOURCE_CONNECTION_CONNECTION_NAME\",\r\n fieldName: \"connectionName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATASOURCE_CONNECTION_DATASOURCE_PASSWORD\",\r\n fieldName: \"datasourcePassword\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATASOURCE_CONNECTION_DATASOURCE_TYPE\",\r\n fieldName: \"datasourceType\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATASOURCE_CONNECTION_DATASOURCE_URL\",\r\n fieldName: \"datasourceUrl\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATASOURCE_CONNECTION_DATASOURCE_USERNAME\",\r\n fieldName: \"datasourceUsername\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"DATASOURCE_CONNECTION_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\", reloadAfterSave: true }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"DATASOURCE_CONNECTION_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"DATASOURCE_CONNECTION_EDIT\" }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"DATASOURCE_CONNECTION_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default DatasourceConnectionGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst EmployeeGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/employee/all\",\r\n deleteById: \"api/v1/admin/employee\",\r\n save: \"api/v1/admin/employee\",\r\n findById: \"api/v1/admin/employee\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EMPLOYEE_EMAIL\",\r\n fieldName: \"email\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EMPLOYEE_EMPLOYEE_NAME\",\r\n fieldName: \"employeeName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EMPLOYEE_EMPLOYEE_NUMBER\",\r\n fieldName: \"employeeNumber\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EMPLOYEE_MOBILE_NUMBER\",\r\n fieldName: \"mobileNumber\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EMPLOYEE_ORGANIZATION_RANK_ID\",\r\n fieldName: \"organizationRankId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EMPLOYEE_ORGANIZATION_UNIT_ID\",\r\n fieldName: \"organizationUnitId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EMPLOYEE_USER_ACCOUNT_ID\",\r\n fieldName: \"userAccountId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"EMPLOYEE_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"EMPLOYEE_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"EMPLOYEE_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default EmployeeGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst EntityParameterGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n commonStoreKey: \"SystemEntityParameters\",\r\n deleteById: \"api/v1/admin/entityparameter\",\r\n save: \"api/v1/admin/entityparameter\",\r\n findById: \"api/v1/admin/entityparameter\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ENTITY_PARAMETER_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ENTITY_PARAMETER_PARAMETER_CODE\",\r\n fieldName: \"parameterCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ENTITY_PARAMETER_PARAMETER_DATA_QUERY_ID\",\r\n fieldName: \"parameterDataQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ENTITY_PARAMETER_PARAMETER_DATASET\",\r\n fieldName: \"parameterDataset\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ENTITY_PARAMETER_PARAMETER_DISPLAY_FIELD\",\r\n fieldName: \"parameterDisplayField\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ENTITY_PARAMETER_PARAMETER_LABEL\",\r\n fieldName: \"parameterLabel\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ENTITY_PARAMETER_PARAMETER_TYPE\",\r\n fieldName: \"parameterType\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ENTITY_PARAMETER_PARAMETER_VALUE_FIELD\",\r\n fieldName: \"parameterValueField\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ENTITY_PARAMETER_PARAMETER_VALUE_FORMAT\",\r\n fieldName: \"parameterValueFormat\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\", reloadAfterSave: true }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"ENTITY_PARAMETER_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"ENTITY_PARAMETER_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"ENTITY_PARAMETER_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default EntityParameterGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst ExcelUploaderDetailGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/exceluploaderdetail/all\",\r\n deleteById: \"api/v1/admin/exceluploaderdetail\",\r\n save: \"api/v1/admin/exceluploaderdetail\",\r\n findById: \"api/v1/admin/exceluploaderdetail\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EXCEL_UPLOADER_DETAIL_COLUMN_INDEX\",\r\n fieldName: \"columnIndex\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EXCEL_UPLOADER_DETAIL_EXCEL_UPLOADER_HEADER_ID\",\r\n fieldName: \"excelUploaderHeaderId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EXCEL_UPLOADER_DETAIL_LOOKUP_QUERY_ID\",\r\n fieldName: \"lookupQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EXCEL_UPLOADER_DETAIL_TABLE_FIELD\",\r\n fieldName: \"tableField\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"EXCEL_UPLOADER_DETAIL_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"EXCEL_UPLOADER_DETAIL_EDIT\" }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"EXCEL_UPLOADER_DETAIL_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default ExcelUploaderDetailGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst ExcelUploaderHeaderGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/exceluploaderheader/all\",\r\n deleteById: \"api/v1/admin/exceluploaderheader\",\r\n save: \"api/v1/admin/exceluploaderheader\",\r\n findById: \"api/v1/admin/exceluploaderheader\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EXCEL_UPLOADER_HEADER_UPLOADER_CONNECTION_ID\",\r\n fieldName: \"uploaderConnectionId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EXCEL_UPLOADER_HEADER_UPLOADER_DATABASE_NAME\",\r\n fieldName: \"uploaderDatabaseName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EXCEL_UPLOADER_HEADER_UPLOADER_NAME\",\r\n fieldName: \"uploaderName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"EXCEL_UPLOADER_HEADER_UPLOADER_TABLE_NAME\",\r\n fieldName: \"uploaderTableName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"EXCEL_UPLOADER_HEADER_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"EXCEL_UPLOADER_HEADER_EDIT\" }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"EXCEL_UPLOADER_HEADER_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default ExcelUploaderHeaderGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst LookupGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/lookup/all\",\r\n deleteById: \"api/v1/admin/lookup\",\r\n save: \"api/v1/admin/lookup\",\r\n findById: \"api/v1/admin/lookup\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"LOOKUP_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"LOOKUP_LOOKUP_AR_DISPLAY\",\r\n fieldName: \"lookupArDisplay\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"LOOKUP_LOOKUP_EN_DISPLAY\",\r\n fieldName: \"lookupEnDisplay\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"LOOKUP_LOOKUP_TYPE\",\r\n fieldName: \"lookupType\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"LOOKUP_LOOKUP_VALUE\",\r\n fieldName: \"lookupValue\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"LOOKUP_ORG_CODE\",\r\n fieldName: \"orgCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"LOOKUP_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"LOOKUP_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"LOOKUP_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default LookupGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst MailAttachmentGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/mailattachment/all\",\r\n deleteById: \"api/v1/admin/mailattachment\",\r\n save: \"api/v1/admin/mailattachment\",\r\n findById: \"api/v1/admin/mailattachment\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_ATTACHMENT_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_ATTACHMENT_MAIL_TEMPLATE_ID\",\r\n fieldName: \"mailTemplateId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_ATTACHMENT_REPORT_ID\",\r\n fieldName: \"reportId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"MAIL_ATTACHMENT_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"MAIL_ATTACHMENT_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"MAIL_ATTACHMENT_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default MailAttachmentGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst MailBodyGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/mailbody/all\",\r\n deleteById: \"api/v1/admin/mailbody\",\r\n save: \"api/v1/admin/mailbody\",\r\n findById: \"api/v1/admin/mailbody\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_BODY_BODY_CONTENT\",\r\n fieldName: \"bodyContent\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_BODY_BODY_CONTENT_DATA_QUERY_ID\",\r\n fieldName: \"bodyContentDataQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_BODY_BODY_ORDER\",\r\n fieldName: \"bodyOrder\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_BODY_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_BODY_IS_MAIN\",\r\n fieldName: \"isMain\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_BODY_MAIL_TEMPLATE_ID\",\r\n fieldName: \"mailTemplateId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_BODY_PRINT_FOR_EACH_RECORD\",\r\n fieldName: \"printForEachRecord\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"MAIL_BODY_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"MAIL_BODY_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"MAIL_BODY_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default MailBodyGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst MailNotificationQueueGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/mailnotificationqueue/all\",\r\n deleteById: \"api/v1/admin/mailnotificationqueue\",\r\n save: \"api/v1/admin/mailnotificationqueue\",\r\n findById: \"api/v1/admin/mailnotificationqueue\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_NOTIFICATION_QUEUE_CUSTOM_MAIL_ATTACHED_REPORT_ID\",\r\n fieldName: \"customMailAttachedReportId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_NOTIFICATION_QUEUE_CUSTOM_MAIL_BODY\",\r\n fieldName: \"customMailBody\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_NOTIFICATION_QUEUE_CUSTOM_MAIL_SUBJECT\",\r\n fieldName: \"customMailSubject\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_NOTIFICATION_QUEUE_CUSTOM_RECIPIENTS\",\r\n fieldName: \"customRecipients\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_NOTIFICATION_QUEUE_IS_NOTIFIED\",\r\n fieldName: \"isNotified\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_NOTIFICATION_QUEUE_MAIL_PARAMETERS\",\r\n fieldName: \"mailParameters\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_NOTIFICATION_QUEUE_MAIL_TEMPLATE_ID\",\r\n fieldName: \"mailTemplateId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_NOTIFICATION_QUEUE_NOTIFICATION_MESSAGE\",\r\n fieldName: \"notificationMessage\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_NOTIFICATION_QUEUE_NOTIFICATION_TIME\",\r\n fieldName: \"notificationTime\",\r\n required: false,\r\n fieldType: \"datetime\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"MAIL_NOTIFICATION_QUEUE_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{\r\n isEnabled: true,\r\n authority: \"MAIL_NOTIFICATION_QUEUE_EDIT\",\r\n }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"MAIL_NOTIFICATION_QUEUE_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default MailNotificationQueueGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst MailRecipientGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/mailrecipient/all\",\r\n deleteById: \"api/v1/admin/mailrecipient\",\r\n save: \"api/v1/admin/mailrecipient\",\r\n findById: \"api/v1/admin/mailrecipient\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_RECIPIENT_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_RECIPIENT_MAIL_TEMPLATE_ID\",\r\n fieldName: \"mailTemplateId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_RECIPIENT_RECIPIENT_MAIL\",\r\n fieldName: \"recipientMail\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_RECIPIENT_RECIPIENT_TYPE\",\r\n fieldName: \"recipientType\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"MAIL_RECIPIENT_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"MAIL_RECIPIENT_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"MAIL_RECIPIENT_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default MailRecipientGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst MailTemplateGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/mailtemplate/all\",\r\n deleteById: \"api/v1/admin/mailtemplate\",\r\n save: \"api/v1/admin/mailtemplate\",\r\n findById: \"api/v1/admin/mailtemplate\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_TEMPLATE_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_TEMPLATE_MAIL_CC_DATA_QUERY_ID\",\r\n fieldName: \"mailCcDataQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_TEMPLATE_MAIL_SUBJECT\",\r\n fieldName: \"mailSubject\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_TEMPLATE_MAIL_TEMPLATE_CODE\",\r\n fieldName: \"mailTemplateCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_TEMPLATE_MAIL_TEMPLATE_NAME\",\r\n fieldName: \"mailTemplateName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_TEMPLATE_MAIL_TO_DATA_QUERY_ID\",\r\n fieldName: \"mailToDataQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_TEMPLATE_PERIOD_TYPE\",\r\n fieldName: \"periodType\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_TEMPLATE_PERIOD_VALUE\",\r\n fieldName: \"periodValue\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_TEMPLATE_PERIODICAL\",\r\n fieldName: \"periodical\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_TEMPLATE_START_SENDING_AT\",\r\n fieldName: \"startSendingAt\",\r\n required: false,\r\n fieldType: \"datetime\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"MAIL_TEMPLATE_SUBJECT_DATA_QUERY_ID\",\r\n fieldName: \"subjectDataQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"MAIL_TEMPLATE_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"MAIL_TEMPLATE_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"MAIL_TEMPLATE_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default MailTemplateGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst NewTableGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/newtable/all\",\r\n deleteById: \"api/v1/admin/newtable\",\r\n save: \"api/v1/admin/newtable\",\r\n findById: \"api/v1/admin/newtable\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NEW_TABLE_TEST_DATE\",\r\n fieldName: \"testDate\",\r\n required: false,\r\n fieldType: \"date\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NEW_TABLE_TEST_LONG\",\r\n fieldName: \"testLong\",\r\n required: false,\r\n fieldType: \"number\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NEW_TABLE_TEST_DECIMAL\",\r\n fieldName: \"testDecimal\",\r\n required: false,\r\n fieldType: \"number\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"NEW_TABLE_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"NEW_TABLE_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"NEW_TABLE_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default NewTableGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst NotificationGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/notification/all\",\r\n deleteById: \"api/v1/admin/notification\",\r\n save: \"api/v1/admin/notification\",\r\n findById: \"api/v1/admin/notification\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_NOTIFICATION_ACTION_KEY\",\r\n fieldName: \"notificationActionKey\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_NOTIFICATION_ACTION_PAYLOAD\",\r\n fieldName: \"notificationActionPayload\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_NOTIFICATION_CODE\",\r\n fieldName: \"notificationCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_NOTIFICATION_ICON\",\r\n fieldName: \"notificationIcon\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_NOTIFICATION_QUERY_ID\",\r\n fieldName: \"notificationQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_NOTIFICATION_TEXT\",\r\n fieldName: \"notificationText\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_USERS_TO_NOTIFY_QUERY_ID\",\r\n fieldName: \"usersToNotifyQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"NOTIFICATION_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"NOTIFICATION_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"NOTIFICATION_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default NotificationGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst NotificationQueueGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/notificationqueue/all\",\r\n deleteById: \"api/v1/admin/notificationqueue\",\r\n save: \"api/v1/admin/notificationqueue\",\r\n findById: \"api/v1/admin/notificationqueue\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_QUEUE_CUSTOM_NOTIFICATION_ACTION_KEY\",\r\n fieldName: \"customNotificationActionKey\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_QUEUE_CUSTOM_NOTIFICATION_ACTION_PAYLOAD\",\r\n fieldName: \"customNotificationActionPayload\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_QUEUE_CUSTOM_NOTIFICATION_ICON\",\r\n fieldName: \"customNotificationIcon\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_QUEUE_CUSTOM_NOTIFICATION_TEXT\",\r\n fieldName: \"customNotificationText\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_QUEUE_IS_NOTIFIED\",\r\n fieldName: \"isNotified\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_QUEUE_NOTIFICATION_CODE\",\r\n fieldName: \"notificationCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_QUEUE_NOTIFICATION_PARAMS\",\r\n fieldName: \"notificationParams\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_QUEUE_NOTIFIED_TIME\",\r\n fieldName: \"notifiedTime\",\r\n required: false,\r\n fieldType: \"datetime\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"NOTIFICATION_QUEUE_USERNAME\",\r\n fieldName: \"username\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"NOTIFICATION_QUEUE_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"NOTIFICATION_QUEUE_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"NOTIFICATION_QUEUE_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default NotificationQueueGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst OrganizationGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/organization/all\",\r\n deleteById: \"api/v1/admin/organization\",\r\n save: \"api/v1/admin/organization\",\r\n findById: \"api/v1/admin/organization\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_ORGANIZATION_CODE\",\r\n fieldName: \"organizationCode\",\r\n required: true,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_IS_ACTIVE\",\r\n fieldName: \"isActive\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_ORGANIZATION_NAME\",\r\n fieldName: \"organizationName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"organizationCode\"}\r\n gridTitle=\"ORGANIZATION_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"ORGANIZATION_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"ORGANIZATION_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default OrganizationGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst OrganizationApplicationGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/organizationapplication/all\",\r\n deleteById: \"api/v1/admin/organizationapplication\",\r\n save: \"api/v1/admin/organizationapplication\",\r\n findById: \"api/v1/admin/organizationapplication\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_APPLICATION_APPLICATION_CODE\",\r\n fieldName: \"applicationCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_APPLICATION_APPLICATION_DESCRIPTION\",\r\n fieldName: \"applicationDescription\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_APPLICATION_APPLICATION_NAME\",\r\n fieldName: \"applicationName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_APPLICATION_IS_ACTIVE\",\r\n fieldName: \"isActive\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"ORGANIZATION_APPLICATION_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{\r\n isEnabled: true,\r\n authority: \"ORGANIZATION_APPLICATION_EDIT\",\r\n }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"ORGANIZATION_APPLICATION_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default OrganizationApplicationGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst OrganizationRankGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/organizationrank/all\",\r\n deleteById: \"api/v1/admin/organizationrank\",\r\n save: \"api/v1/admin/organizationrank\",\r\n findById: \"api/v1/admin/organizationrank\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_RANK_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_RANK_ORGANIZATION_CODE\",\r\n fieldName: \"organizationCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_RANK_RANK_CODE\",\r\n fieldName: \"rankCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_RANK_RANK_NAME\",\r\n fieldName: \"rankName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_RANK_RANK_ORDER\",\r\n fieldName: \"rankOrder\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"ORGANIZATION_RANK_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"ORGANIZATION_RANK_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"ORGANIZATION_RANK_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default OrganizationRankGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst OrganizationUnitGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/organizationunit/all\",\r\n deleteById: \"api/v1/admin/organizationunit\",\r\n save: \"api/v1/admin/organizationunit\",\r\n findById: \"api/v1/admin/organizationunit\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_UNIT_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_UNIT_ORGANIZATION_CODE\",\r\n fieldName: \"organizationCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_UNIT_ORGANIZATION_UNIT_AR_NAME\",\r\n fieldName: \"organizationUnitArName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_UNIT_ORGANIZATION_UNIT_EN_NAME\",\r\n fieldName: \"organizationUnitEnName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_UNIT_ORGANIZATION_UNIT_PARENT_ID\",\r\n fieldName: \"organizationUnitParentId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"ORGANIZATION_UNIT_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"ORGANIZATION_UNIT_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"ORGANIZATION_UNIT_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default OrganizationUnitGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst OrganizationUserGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/organizationuser/all\",\r\n deleteById: \"api/v1/admin/organizationuser\",\r\n save: \"api/v1/admin/organizationuser\",\r\n findById: \"api/v1/admin/organizationuser\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_USER_IS_ACTIVE\",\r\n fieldName: \"isActive\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_USER_IS_DEFAULT\",\r\n fieldName: \"isDefault\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_USER_ORGANIZATION_CODE\",\r\n fieldName: \"organizationCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_USER_USERNAME\",\r\n fieldName: \"username\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"ORGANIZATION_USER_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"ORGANIZATION_USER_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"ORGANIZATION_USER_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default OrganizationUserGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst OrganizationUserRoleGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/organizationuserrole/all\",\r\n deleteById: \"api/v1/admin/organizationuserrole\",\r\n save: \"api/v1/admin/organizationuserrole\",\r\n findById: \"api/v1/admin/organizationuserrole\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_USER_ROLE_END_DATE\",\r\n fieldName: \"endDate\",\r\n required: false,\r\n fieldType: \"datetime\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_USER_ROLE_IS_ACTIVE\",\r\n fieldName: \"isActive\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_USER_ROLE_ORGANIZATION_CODE\",\r\n fieldName: \"organizationCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_USER_ROLE_ROLE_ID\",\r\n fieldName: \"roleId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_USER_ROLE_START_DATE\",\r\n fieldName: \"startDate\",\r\n required: false,\r\n fieldType: \"datetime\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ORGANIZATION_USER_ROLE_USERNAME\",\r\n fieldName: \"username\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"ORGANIZATION_USER_ROLE_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"ORGANIZATION_USER_ROLE_EDIT\" }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"ORGANIZATION_USER_ROLE_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default OrganizationUserRoleGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst ReportGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/report/all\",\r\n deleteById: \"api/v1/admin/report\",\r\n save: \"api/v1/admin/report\",\r\n findById: \"api/v1/admin/report\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_DATASOURCE_CON_ID\",\r\n fieldName: \"datasourceConId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_REPORT_BLUE_PRINT_ID\",\r\n fieldName: \"reportBluePrintId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_REPORT_CATEGORY\",\r\n fieldName: \"reportCategory\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_REPORT_CODE\",\r\n fieldName: \"reportCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_REPORT_EXCEL_DATA_QUERY_ID\",\r\n fieldName: \"reportExcelDataQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_REPORT_EXPORT_NAME\",\r\n fieldName: \"reportExportName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_REPORT_JASPER_NAME\",\r\n fieldName: \"reportJasperName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_REPORT_JASPER_PATH\",\r\n fieldName: \"reportJasperPath\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_REPORT_MENU_CODE\",\r\n fieldName: \"reportMenuCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_REPORT_NAME\",\r\n fieldName: \"reportName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_REPORT_TYPE\",\r\n fieldName: \"reportType\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_USE_SYS_DATASOURCE\",\r\n fieldName: \"useSysDatasource\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"REPORT_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"REPORT_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"REPORT_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default ReportGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst ReportParameterGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/reportparameter/all\",\r\n deleteById: \"api/v1/admin/reportparameter\",\r\n save: \"api/v1/admin/reportparameter\",\r\n findById: \"api/v1/admin/reportparameter\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_PARAMETER_DEFAULT_VALUE\",\r\n fieldName: \"defaultValue\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_PARAMETER_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_PARAMETER_ENTITY_PARAMETER_ID\",\r\n fieldName: \"entityParameterId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_PARAMETER_HIDDEN\",\r\n fieldName: \"hidden\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_PARAMETER_MANDATORY\",\r\n fieldName: \"mandatory\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"REPORT_PARAMETER_REPORT_ID\",\r\n fieldName: \"reportId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"REPORT_PARAMETER_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"REPORT_PARAMETER_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"REPORT_PARAMETER_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default ReportParameterGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\nimport { useAxios, useWindow } from \"../../hooks\";\r\nimport RoleAuthoritiesForm from \"./RoleAuthoritiesForm\";\r\n\r\nconst RoleGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n commonStoreKey: \"SystemRoles\",\r\n deleteById: \"api/v1/admin/role\",\r\n save: \"api/v1/admin/role\",\r\n findById: \"api/v1/admin/role\",\r\n setData: setData,\r\n });\r\n const [selectedRole, setSelectedRole] = useState<any>(null);\r\n const { handleGetRequest } = useAxios();\r\n const [selectedRoleAuthorities, setSelectedRoleAuthorities] = useState<any>(\r\n []\r\n );\r\n const [\r\n selectedRoleAvailableAuthorities,\r\n setSelectedRoleAvailableAuthorities,\r\n ] = useState<any>([]);\r\n const {\r\n Window: RoleAuthoritiesWindow,\r\n setWindowState: setRoleAuthorirtiesWindowOpen,\r\n } = useWindow({\r\n width: \"50%\",\r\n windowIcon: \"key\",\r\n windowTitle: \"Role Authorities\",\r\n });\r\n const loadRoleAuthorities = async (data: any) => {\r\n await handleGetRequest({\r\n endPointURI: \"api/v1/admin/role/authorities\",\r\n showMask: true,\r\n parameters: {\r\n roleId: data.id,\r\n },\r\n successCallBkFn: (response: any) => {\r\n setRoleAuthorirtiesWindowOpen(true);\r\n setSelectedRoleAuthorities(response.data.selectedAuthorities);\r\n setSelectedRoleAvailableAuthorities(response.data.availableAuthorities);\r\n },\r\n });\r\n };\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ROLE_ROLE_NAME\",\r\n fieldName: \"roleName\",\r\n required: true,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ROLE_DESCRIPTION\",\r\n fieldName: \"description\",\r\n required: true,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ROLE_IS_ACTIVE\",\r\n fieldName: \"isActive\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ROLE_ORGANIZATION_APPLICATION_ID\",\r\n fieldName: \"organizationApplicationId\",\r\n required: false,\r\n fieldType: \"text\",\r\n gridProps: {\r\n hidden: true,\r\n },\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <>\r\n <RoleAuthoritiesWindow>\r\n <RoleAuthoritiesForm\r\n roleId={selectedRole?.id}\r\n availableAuthorities={selectedRoleAvailableAuthorities}\r\n currentRoleAuthorities={selectedRoleAuthorities}\r\n closeModalFn={() => {\r\n setRoleAuthorirtiesWindowOpen(false);\r\n }}\r\n />\r\n </RoleAuthoritiesWindow>\r\n <TemplateGrid\r\n rowActions={[\r\n {\r\n icon: \"key\",\r\n label: \"authorities\",\r\n actionFn: async (data) => {\r\n setSelectedRole(data);\r\n loadRoleAuthorities(data);\r\n },\r\n },\r\n ]}\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\", reloadAfterSave: true }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"ROLE_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"ROLE_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"ROLE_DELETE\" }}\r\n />\r\n </>\r\n );\r\n};\r\n\r\nexport default RoleGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst RoleAuthorityGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/roleauthority/all\",\r\n deleteById: \"api/v1/admin/roleauthority\",\r\n save: \"api/v1/admin/roleauthority\",\r\n findById: \"api/v1/admin/roleauthority\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ROLE_AUTHORITY_AUTHORITY_ID\",\r\n fieldName: \"authorityId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ROLE_AUTHORITY_IS_ACTIVE\",\r\n fieldName: \"isActive\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"ROLE_AUTHORITY_ROLE_ID\",\r\n fieldName: \"roleId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"ROLE_AUTHORITY_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"ROLE_AUTHORITY_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"ROLE_AUTHORITY_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default RoleAuthorityGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst UserAccountGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/useraccount/all\",\r\n deleteById: \"api/v1/admin/useraccount\",\r\n save: \"api/v1/admin/useraccount\",\r\n findById: \"api/v1/admin/useraccount\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_ACCOUNT_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_ACCOUNT_PASSWORD\",\r\n fieldName: \"password\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_ACCOUNT_USERNAME\",\r\n fieldName: \"username\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"USER_ACCOUNT_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"USER_ACCOUNT_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"USER_ACCOUNT_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default UserAccountGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst UserRequestGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/userrequest/all\",\r\n deleteById: \"api/v1/admin/userrequest\",\r\n save: \"api/v1/admin/userrequest\",\r\n findById: \"api/v1/admin/userrequest\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_REQUEST_IS_NOTIFIED\",\r\n fieldName: \"isNotified\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_REQUEST_MAILS_TO_NOTIFY\",\r\n fieldName: \"mailsToNotify\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_REQUEST_NOTIFICATION_MESSAGE\",\r\n fieldName: \"notificationMessage\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_REQUEST_NOTIFICATION_TIME\",\r\n fieldName: \"notificationTime\",\r\n required: false,\r\n fieldType: \"datetime\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_REQUEST_NOTIFICATION_TYPE\",\r\n fieldName: \"notificationType\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_REQUEST_NOTIFY_USER\",\r\n fieldName: \"notifyUser\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_REQUEST_REPORT_CODE\",\r\n fieldName: \"reportCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_REQUEST_REPORT_PARAMETERS\",\r\n fieldName: \"reportParameters\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_REQUEST_REQUEST_TYPE\",\r\n fieldName: \"requestType\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_REQUEST_STATUS\",\r\n fieldName: \"status\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"USER_REQUEST_STATUS_MESSAGE\",\r\n fieldName: \"statusMessage\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"USER_REQUEST_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"USER_REQUEST_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"USER_REQUEST_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default UserRequestGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst WidgetGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/widget/all\",\r\n deleteById: \"api/v1/admin/widget\",\r\n save: \"api/v1/admin/widget\",\r\n findById: \"api/v1/admin/widget\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_DATA_QUERY_ID\",\r\n fieldName: \"dataQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_HEIGHT\",\r\n fieldName: \"height\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_HORIZONTAL_AXIS_FIELD\",\r\n fieldName: \"horizontalAxisField\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_HORIZONTAL_AXIS_LABEL\",\r\n fieldName: \"horizontalAxisLabel\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_ICON\",\r\n fieldName: \"icon\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_SERIES_KEYS\",\r\n fieldName: \"seriesKeys\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_TITLE\",\r\n fieldName: \"title\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_VERTICAL_AXIS_FIELD\",\r\n fieldName: \"verticalAxisField\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_VERTICAL_AXIS_LABEL\",\r\n fieldName: \"verticalAxisLabel\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_WIDGET_DESCRIPTION\",\r\n fieldName: \"widgetDescription\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_WIDGET_NAME\",\r\n fieldName: \"widgetName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_WIDGET_TYPE\",\r\n fieldName: \"widgetType\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WIDGET_WIDTH\",\r\n fieldName: \"width\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"WIDGET_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"WIDGET_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"WIDGET_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default WidgetGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst WorkflowDocumentGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/workflowdocument/all\",\r\n deleteById: \"api/v1/admin/workflowdocument\",\r\n save: \"api/v1/admin/workflowdocument\",\r\n findById: \"api/v1/admin/workflowdocument\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_APP_NOTIFICATION_ICON\",\r\n fieldName: \"appNotificationIcon\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_APP_NOTIFICATION_STYLE\",\r\n fieldName: \"appNotificationStyle\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_APP_VIEW_ROUTE\",\r\n fieldName: \"appViewRoute\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_DOCUMENT_CODE\",\r\n fieldName: \"documentCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_DOCUMENT_CON_ID\",\r\n fieldName: \"documentConId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_DOCUMENT_DATABASE_NAME\",\r\n fieldName: \"documentDatabaseName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_DOCUMENT_DATABASE_TABLE\",\r\n fieldName: \"documentDatabaseTable\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_DOCUMENT_ID_FIELD\",\r\n fieldName: \"documentIdField\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_DOCUMENT_NAME\",\r\n fieldName: \"documentName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_DOCUMENT_NUMBER_FIELD\",\r\n fieldName: \"documentNumberField\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_DOCUMENT_REPORT_ID\",\r\n fieldName: \"documentReportId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_DOCUMENT_STATUS_FIELD\",\r\n fieldName: \"documentStatusField\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_MAIL_APPROVAL_ALLOWED\",\r\n fieldName: \"mailApprovalAllowed\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ORG_CODE\",\r\n fieldName: \"orgCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_USE_SYSTEM_CON\",\r\n fieldName: \"useSystemCon\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"WORKFLOW_DOCUMENT_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{ isEnabled: true, authority: \"WORKFLOW_DOCUMENT_EDIT\" }}\r\n deleteAction={{ isEnabled: true, authority: \"WORKFLOW_DOCUMENT_DELETE\" }}\r\n />\r\n );\r\n};\r\n\r\nexport default WorkflowDocumentGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst WorkflowDocumentActionGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/workflowdocumentaction/all\",\r\n deleteById: \"api/v1/admin/workflowdocumentaction\",\r\n save: \"api/v1/admin/workflowdocumentaction\",\r\n findById: \"api/v1/admin/workflowdocumentaction\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_DOCUMENT_ACTION_CODE\",\r\n fieldName: \"documentActionCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_DOCUMENT_ACTION_NAME\",\r\n fieldName: \"documentActionName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_NEXT_DOCUMENT_STATUS_ID\",\r\n fieldName: \"nextDocumentStatusId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_POST_ACTION_ENDPOINT\",\r\n fieldName: \"postActionEndpoint\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_PRE_ACTION_ENDPOINT\",\r\n fieldName: \"preActionEndpoint\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_REQUIRE_COMMENT\",\r\n fieldName: \"requireComment\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_WORKFLOW_DOCUMENT_ID\",\r\n fieldName: \"workflowDocumentId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"WORKFLOW_DOCUMENT_ACTION_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{\r\n isEnabled: true,\r\n authority: \"WORKFLOW_DOCUMENT_ACTION_EDIT\",\r\n }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"WORKFLOW_DOCUMENT_ACTION_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default WorkflowDocumentActionGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst WorkflowDocumentActionHistoryGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/workflowdocumentactionhistory/all\",\r\n deleteById: \"api/v1/admin/workflowdocumentactionhistory\",\r\n save: \"api/v1/admin/workflowdocumentactionhistory\",\r\n findById: \"api/v1/admin/workflowdocumentactionhistory\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_HISTORY_ACTION_BY\",\r\n fieldName: \"actionBy\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_HISTORY_ACTION_COMMENT\",\r\n fieldName: \"actionComment\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_HISTORY_ACTION_METHOD\",\r\n fieldName: \"actionMethod\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_HISTORY_ACTION_TIME\",\r\n fieldName: \"actionTime\",\r\n required: false,\r\n fieldType: \"datetime\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_HISTORY_DOCUMENT_ACTION_ID\",\r\n fieldName: \"documentActionId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_HISTORY_DOCUMENT_REF_ID\",\r\n fieldName: \"documentRefId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_HISTORY_WORKFLOW_DOCUMENT_ID\",\r\n fieldName: \"workflowDocumentId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"WORKFLOW_DOCUMENT_ACTION_HISTORY_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{\r\n isEnabled: true,\r\n authority: \"WORKFLOW_DOCUMENT_ACTION_HISTORY_EDIT\",\r\n }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"WORKFLOW_DOCUMENT_ACTION_HISTORY_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default WorkflowDocumentActionHistoryGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst WorkflowDocumentActionMailGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/workflowdocumentactionmail/all\",\r\n deleteById: \"api/v1/admin/workflowdocumentactionmail\",\r\n save: \"api/v1/admin/workflowdocumentactionmail\",\r\n findById: \"api/v1/admin/workflowdocumentactionmail\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_MAIL_DOCUMENT_ACTION_ID\",\r\n fieldName: \"documentActionId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_MAIL_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_ACTION_MAIL_MAIL_TEMPLATE_ID\",\r\n fieldName: \"mailTemplateId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"WORKFLOW_DOCUMENT_ACTION_MAIL_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{\r\n isEnabled: true,\r\n authority: \"WORKFLOW_DOCUMENT_ACTION_MAIL_EDIT\",\r\n }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"WORKFLOW_DOCUMENT_ACTION_MAIL_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default WorkflowDocumentActionMailGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst WorkflowDocumentMailLogGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/workflowdocumentmaillog/all\",\r\n deleteById: \"api/v1/admin/workflowdocumentmaillog\",\r\n save: \"api/v1/admin/workflowdocumentmaillog\",\r\n findById: \"api/v1/admin/workflowdocumentmaillog\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_MAIL_LOG_GRAPH_API_MSG_ID\",\r\n fieldName: \"graphApiMsgId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_MAIL_LOG_IS_PROCESSED\",\r\n fieldName: \"isProcessed\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_MAIL_LOG_MAIL_ACTION_CODE\",\r\n fieldName: \"mailActionCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_MAIL_LOG_MAIL_BODY_CONTENT\",\r\n fieldName: \"mailBodyContent\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_MAIL_LOG_MAIL_FROM\",\r\n fieldName: \"mailFrom\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_MAIL_LOG_MAIL_SUBJECT\",\r\n fieldName: \"mailSubject\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_MAIL_LOG_PROCESS_MESSAGE\",\r\n fieldName: \"processMessage\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_MAIL_LOG_PROCESS_TIME\",\r\n fieldName: \"processTime\",\r\n required: false,\r\n fieldType: \"datetime\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_MAIL_LOG_REF_DOC_ID\",\r\n fieldName: \"refDocId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_MAIL_LOG_WORKFLOW_DOCUMENT_ID\",\r\n fieldName: \"workflowDocumentId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"WORKFLOW_DOCUMENT_MAIL_LOG_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{\r\n isEnabled: true,\r\n authority: \"WORKFLOW_DOCUMENT_MAIL_LOG_EDIT\",\r\n }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"WORKFLOW_DOCUMENT_MAIL_LOG_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default WorkflowDocumentMailLogGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../../hooks/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\r\n\r\nconst WorkflowDocumentStatusGrid: React.FC = () => {\r\n const [data, setData] = useState([]);\r\n const apiActions = useApiActions({\r\n findAll: \"api/v1/admin/workflowdocumentstatus/all\",\r\n deleteById: \"api/v1/admin/workflowdocumentstatus\",\r\n save: \"api/v1/admin/workflowdocumentstatus\",\r\n findById: \"api/v1/admin/workflowdocumentstatus\",\r\n setData: setData,\r\n });\r\n\r\n const formElements: Array<FormElementProps> = [\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_STATUS_DOCUMENT_STATUS_CODE\",\r\n fieldName: \"documentStatusCode\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_STATUS_DOCUMENT_STATUS_NAME\",\r\n fieldName: \"documentStatusName\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_STATUS_DOCUMENT_STATUS_ORDER\",\r\n fieldName: \"documentStatusOrder\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_STATUS_ENABLED\",\r\n fieldName: \"enabled\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_STATUS_IS_ZERO_STATE\",\r\n fieldName: \"isZeroState\",\r\n required: false,\r\n fieldType: \"checkbox\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_STATUS_NEXT_ACTION_TAKERS_QUERY_ID\",\r\n fieldName: \"nextActionTakersQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_STATUS_NEXT_ACTIONS_QUERY_ID\",\r\n fieldName: \"nextActionsQueryId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n {\r\n type: \"field\",\r\n mode: \"props\",\r\n props: {\r\n fieldLabel: \"WORKFLOW_DOCUMENT_STATUS_WORKFLOW_DOCUMENT_ID\",\r\n fieldName: \"workflowDocumentId\",\r\n required: false,\r\n fieldType: \"text\",\r\n },\r\n },\r\n ];\r\n\r\n return (\r\n <TemplateGrid\r\n apiActions={apiActions}\r\n data={data}\r\n setData={setData}\r\n editMode={{ editMode: \"row\" }}\r\n formElements={formElements}\r\n keyColumnName={\"id\"}\r\n gridTitle=\"WORKFLOW_DOCUMENT_STATUS_PLURAL\"\r\n girdIcon=\"table-cells\"\r\n editAction={{\r\n isEnabled: true,\r\n authority: \"WORKFLOW_DOCUMENT_STATUS_EDIT\",\r\n }}\r\n deleteAction={{\r\n isEnabled: true,\r\n authority: \"WORKFLOW_DOCUMENT_STATUS_DELETE\",\r\n }}\r\n />\r\n );\r\n};\r\n\r\nexport default WorkflowDocumentStatusGrid;\r\n","import { Box } from \"@mui/material\";\r\nimport { useSelector } from \"react-redux\";\r\nimport { CacheProvider } from \"@emotion/react\";\r\nimport { Route, Routes } from \"react-router-dom\";\r\nimport { RootState } from \"../redux/store\";\r\nimport { cacheLtr, cacheRtl } from \"../components/common/LayoutHandlers\";\r\nimport { SYSTEM_ROUTES } from \"../routes\";\r\nimport { SystemRoute } from \"../routes/types\";\r\n\r\nconst MainContent: React.FC = () => {\r\n const AppLayoutState = useSelector((state: RootState) => state.AppLayout);\r\n const AppInfo = useSelector((state: RootState) => state.AppInfo.value);\r\n const businessRoutes = useSelector(\r\n (state: RootState) => state.AppInfo.value.businessRoutes\r\n );\r\n return (\r\n <CacheProvider\r\n value={AppLayoutState.appDirection === \"ltr\" ? cacheLtr : cacheRtl}\r\n >\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n // alignItems: \"center\",\r\n justifyContent: \"flex-start\",\r\n flex: 1,\r\n overflow: \"hidden\",\r\n padding: 3,\r\n }}\r\n >\r\n <Routes>\r\n {AppInfo.enableAdministrationModule\r\n ? SYSTEM_ROUTES.map((route: SystemRoute, index) => {\r\n return (\r\n <Route\r\n key={\"adm\" + index}\r\n path={route.path}\r\n Component={route.component}\r\n />\r\n );\r\n })\r\n : null}\r\n {businessRoutes.map((route: SystemRoute, index) => {\r\n return (\r\n <Route\r\n key={\"bs\" + index}\r\n path={route.path}\r\n Component={route.component}\r\n />\r\n );\r\n })}\r\n </Routes>\r\n </Box>\r\n </CacheProvider>\r\n );\r\n};\r\n\r\nexport default MainContent;\r\n","import { styled } from \"@mui/material/styles\";\r\nimport { grey } from \"@mui/material/colors\";\r\nimport SwipeableDrawer from \"@mui/material/SwipeableDrawer\";\r\nimport { useDispatch, useSelector } from \"react-redux\";\r\nimport { Box, Typography } from \"@mui/material\";\r\nimport { RootState } from \"../redux/store\";\r\nimport { AppLayoutActions } from \"../redux/features/common/AppLayoutSlice\";\r\nimport NavigationTree from \"./NavigationTree\";\r\n\r\nconst drawerBleeding = 56;\r\n\r\ninterface Props {\r\n /**\r\n * Injected by the documentation to work in an iframe.\r\n * You won't need it on your project.\r\n */\r\n window?: () => Window;\r\n}\r\n\r\nconst Puller = styled(\"div\")(({ theme }) => ({\r\n width: 30,\r\n height: 6,\r\n margin: 10,\r\n backgroundColor: grey[300],\r\n borderRadius: 3,\r\n // position: \"absolute\",\r\n top: 8,\r\n // left: \"calc(50% - 15px)\",\r\n ...theme.applyStyles(\"dark\", {\r\n backgroundColor: grey[900],\r\n }),\r\n}));\r\n\r\nexport default function MobileDrawer(props: Props) {\r\n const { window } = props;\r\n const AppLayout = useSelector((state: RootState) => state.AppLayout);\r\n const AppInfo = useSelector((state: RootState) => state.AppInfo.value);\r\n const dispatch = useDispatch();\r\n const toggleDrawer = (newState: boolean) => {\r\n dispatch(AppLayoutActions.setSideBarState(newState));\r\n };\r\n // This is used only for the example\r\n const container =\r\n window !== undefined ? () => window().document.body : undefined;\r\n\r\n return (\r\n <SwipeableDrawer\r\n container={container}\r\n anchor=\"bottom\"\r\n open={AppLayout.sideBarOpened}\r\n onClose={() => {\r\n toggleDrawer(false);\r\n }}\r\n onOpen={() => {\r\n toggleDrawer(true);\r\n }}\r\n swipeAreaWidth={drawerBleeding}\r\n disableSwipeToOpen={false}\r\n ModalProps={{\r\n keepMounted: true,\r\n }}\r\n >\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n alignItems: \"center\",\r\n height: \"100%\",\r\n overflow: \"hidden\",\r\n }}\r\n >\r\n <Puller />\r\n <Box\r\n sx={{\r\n flexGrow: 1,\r\n display: \"flex\",\r\n justifyContent: \"center\",\r\n width: \"99%\",\r\n overflowY: \"auto\",\r\n }}\r\n >\r\n <NavigationTree />\r\n </Box>\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"space-around\",\r\n marginTop: 1,\r\n width: \"100%\",\r\n }}\r\n >\r\n <Typography sx={{ fontSize: 12 }} color=\"textDisabled\">\r\n {AppInfo.appName}\r\n </Typography>\r\n <Typography sx={{ fontSize: 12 }} color=\"textDisabled\">\r\n V.{AppInfo.appVersion}\r\n </Typography>\r\n </Box>\r\n </Box>\r\n </SwipeableDrawer>\r\n );\r\n}\r\n","import { useSelector } from \"react-redux\";\r\nimport { RootState } from \"../../redux/store\";\r\nimport { Backdrop, CircularProgress } from \"@mui/material\";\r\n\r\nconst LoadingMask: React.FC = () => {\r\n const loadingMask = useSelector(\r\n (state: RootState) => state.loadingMask.value\r\n );\r\n return (\r\n <Backdrop\r\n sx={{ color: \"#fff\", zIndex: (theme) => theme.zIndex.drawer + 1 }}\r\n open={loadingMask.isOpened}\r\n >\r\n <CircularProgress color=\"inherit\" />\r\n </Backdrop>\r\n );\r\n};\r\n\r\nexport default LoadingMask;\r\n","import {\r\n Box,\r\n Button,\r\n CircularProgress,\r\n createTheme,\r\n Paper,\r\n TextField,\r\n Typography,\r\n} from \"@mui/material\";\r\nimport { useDispatch, useSelector } from \"react-redux\";\r\nimport { ThemeProvider } from \"@emotion/react\";\r\nimport { useEffect, useState } from \"react\";\r\nimport axios from \"axios\";\r\nimport { toast } from \"react-toastify\";\r\nimport { RootState } from \"../../redux/store\";\r\nimport { UserSessionActions } from \"../../redux/features/common/UserSessionSlice\";\r\nimport { DARK_THEME_INITIAL_MAIN_COLOR, DARK_THEME_INITIAL_SECANDARY_COLOR } from \"../../util\";\r\n\r\nconst Login: React.FC = () => {\r\n const appInfo = useSelector((state: RootState) => state.AppInfo.value);\r\n const [username, setUsername] = useState(\"\");\r\n const [password, setPassword] = useState(\"\");\r\n const [isLoginInProcess, setIsLoginInProcess] = useState(false);\r\n const UserSessionState = useSelector(\r\n (state: RootState) => state.UserSession.value\r\n );\r\n const dispatch = useDispatch();\r\n const handleLogin = async () => {\r\n if (username == null || username == \"\") {\r\n toast.error(\"username is required to proceed\");\r\n return;\r\n }\r\n if (password == null || password == \"\") {\r\n toast.error(\"password is required to proceed\");\r\n return;\r\n }\r\n setIsLoginInProcess(true);\r\n let response: any = null;\r\n try {\r\n response = await axios.post(\r\n `${appInfo.apiBaseUrl}/api/auth/login`,\r\n {\r\n username,\r\n password,\r\n },\r\n {\r\n withCredentials: true,\r\n }\r\n );\r\n if (response.data != null && response.data !== \"\") {\r\n setIsLoginInProcess(false);\r\n const UserSession = {\r\n isAuthenticated: true,\r\n authorities: response.data.authorities,\r\n userProfile: response.data,\r\n };\r\n dispatch(UserSessionActions.setAuthenticated(UserSession));\r\n }\r\n } catch (e: any) {\r\n setIsLoginInProcess(false);\r\n toast.error(\r\n e?.response?.data ||\r\n \"failed to authenticate, contact your administrator\"\r\n );\r\n }\r\n };\r\n const userSession = useSelector(\r\n (state: RootState) => state.UserSession.value\r\n );\r\n const loginTheme = createTheme({\r\n components: {\r\n MuiCssBaseline: {\r\n styleOverrides: `\r\n /* Custom Scrollbar */\r\n * {\r\n scrollbar-width: thin;\r\n scrollbar-color: ${\r\n appInfo.appTheme?.dark?.primaryColor ||\r\n DARK_THEME_INITIAL_MAIN_COLOR\r\n } #121212;\r\n }\r\n \r\n /* Webkit Browsers */\r\n *::-webkit-scrollbar {\r\n width: 12px;\r\n height: 10px;\r\n } \r\n `,\r\n },\r\n },\r\n palette: {\r\n mode: \"dark\",\r\n primary: {\r\n main:\r\n appInfo.appTheme?.dark?.primaryColor || DARK_THEME_INITIAL_MAIN_COLOR,\r\n },\r\n secondary: {\r\n main:\r\n appInfo.appTheme?.dark?.secondaryColor ||\r\n DARK_THEME_INITIAL_SECANDARY_COLOR,\r\n },\r\n },\r\n });\r\n const checkUserSession = async () => {\r\n if (appInfo?.apiBaseUrl) {\r\n if (userSession.isAuthenticated == null) {\r\n try {\r\n let response = await axios.get(\r\n `${appInfo.apiBaseUrl}/api/auth/userInfo`,\r\n {\r\n withCredentials: true,\r\n }\r\n );\r\n if (response != null && response.data != null) {\r\n const UserSession = {\r\n isAuthenticated: true,\r\n authorities: response.data.authorities,\r\n userProfile: response.data,\r\n };\r\n dispatch(UserSessionActions.setAuthenticated(UserSession));\r\n } else {\r\n dispatch(UserSessionActions.setUnAuthenticated());\r\n }\r\n } catch (error) {\r\n dispatch(UserSessionActions.setUnAuthenticated());\r\n }\r\n }\r\n }\r\n };\r\n useEffect(() => {\r\n checkUserSession();\r\n }, [appInfo]);\r\n return (\r\n <ThemeProvider theme={loginTheme}>\r\n <Paper\r\n sx={{\r\n display: \"flex\",\r\n height: \"100vh\",\r\n width: \"100%\",\r\n borderRadius: 0,\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n }}\r\n >\r\n {UserSessionState.isAuthenticated == false ? (\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n }}\r\n >\r\n <img src={appInfo?.appLogo} width={150} height={150} />\r\n <Typography sx={{ m: 1 }} variant=\"h4\" color=\"textSecondary\">\r\n {appInfo?.appName}\r\n </Typography>\r\n <Typography\r\n sx={{\r\n paddingRight: 1,\r\n width: \"100%\",\r\n textAlign: \"right\",\r\n fontSize: 10,\r\n }}\r\n variant=\"caption\"\r\n color=\"textSecondary\"\r\n >\r\n V.{appInfo.appVersion}\r\n </Typography>\r\n <TextField\r\n label=\"username\"\r\n sx={{ width: 300, m: 1 }}\r\n value={username}\r\n onChange={(event) => {\r\n setUsername(event.target.value);\r\n }}\r\n onKeyDown={(event) => {\r\n if (event.key === \"Enter\") {\r\n handleLogin();\r\n }\r\n }}\r\n />\r\n <TextField\r\n label=\"password\"\r\n sx={{ width: 300, m: 1 }}\r\n value={password}\r\n type=\"password\"\r\n onChange={(event) => {\r\n setPassword(event.target.value);\r\n }}\r\n onKeyDown={(event) => {\r\n if (event.key === \"Enter\") {\r\n handleLogin();\r\n }\r\n }}\r\n />\r\n <Button\r\n loading={isLoginInProcess}\r\n onClick={handleLogin}\r\n variant=\"contained\"\r\n color=\"primary\"\r\n sx={{ m: 1 }}\r\n >\r\n login\r\n </Button>\r\n </Box>\r\n ) : (\r\n <>\r\n <CircularProgress sx={{ marginRight: 1 }} />\r\n <div>You will be redirected shortly ... please wait</div>\r\n </>\r\n )}\r\n </Paper>\r\n </ThemeProvider>\r\n );\r\n};\r\n\r\nexport default Login;\r\n","import { styled, useTheme } from \"@mui/material/styles\";\r\nimport CssBaseline from \"@mui/material/CssBaseline\";\r\nimport { useDispatch, useSelector } from \"react-redux\";\r\nimport TopBar from \"./TopBar\";\r\nimport { DrawerHeader } from \"./DrawerHeader\";\r\nimport SideBar from \"./SideBar\";\r\nimport MainContent from \"./MainContent\";\r\nimport { BrowserRouter } from \"react-router-dom\";\r\nimport MobileDrawer from \"./MobileDrawer\";\r\nimport { ToastContainer } from \"react-toastify\";\r\nimport { useEffect, useState } from \"react\";\r\nimport useLoadingMask from \"../hooks/useLoadingMask\";\r\nimport { useIsMobile } from \"../hooks/UseMobile\";\r\nimport useSession from \"../hooks/UseSession\";\r\nimport useAxios from \"../hooks/useAxios\";\r\nimport { DRAWER_WIDTH } from \"../redux/features/common/AppLayoutSlice\";\r\nimport { UserSessionProps } from \"../redux/features/common/UserSessionSlice\";\r\nimport LoadingMask from \"../components/common/LoadingMask\";\r\nimport Login from \"../components/common/Login\";\r\nimport { setStoreData } from \"../redux/features/common/CommonStoreSlice\";\r\n\r\nconst Main = styled(\"main\", {\r\n shouldForwardProp: (prop) => prop !== \"open\",\r\n})<{\r\n open?: boolean;\r\n}>(({ theme: any, open }) => {\r\n const AppLayout = useSelector((state: any) => state.AppLayout);\r\n const dispatch = useDispatch();\r\n const { show, hide } = useLoadingMask();\r\n const commonStores = useSelector((state: any) => state.commonStores);\r\n const [isAutoLoadLoaded, setAutoLoadLoaded] = useState<boolean>(false);\r\n const theme = useTheme();\r\n const isMobile = useIsMobile();\r\n const { isUserAuthorized } = useSession();\r\n\r\n // loadCommonStores\r\n const { handleGetRequest } = useAxios();\r\n const loadCommonStores = async () => {\r\n debugger;\r\n if (!isAutoLoadLoaded) { \r\n setAutoLoadLoaded(true);\r\n show(\"Loading ... please wait\");\r\n const stores = commonStores.stores;\r\n const storeKeys = commonStores.storeKeys;\r\n for (let storeKey of storeKeys) {\r\n if (\r\n (stores[storeKey]?.authority === undefined ||\r\n stores[storeKey]?.authority === null ||\r\n isUserAuthorized(stores[storeKey]?.authority)) &&\r\n stores[storeKey]?.url != \"\" &&\r\n stores[storeKey].autoLoad === true\r\n ) {\r\n await handleGetRequest({\r\n endPointURI: stores[storeKey].url,\r\n showMask: false,\r\n successCallBkFn: (response) => {\r\n dispatch(setStoreData({ storeKey, data: response.data }));\r\n },\r\n failureCallBkFn: () => {\r\n dispatch(setStoreData({ storeKey, data: [] }));\r\n },\r\n });\r\n }\r\n }\r\n hide();\r\n }\r\n };\r\n\r\n useEffect(() => {\r\n if (commonStores.storeKeys) {\r\n loadCommonStores();\r\n }\r\n }, [commonStores.storeKeys]);\r\n\r\n return {\r\n display: \"flex\",\r\n flexDirection: \"column\",\r\n overflow: \"hidden\",\r\n flexGrow: 1,\r\n width: !isMobile && open ? `calc(100% - ${DRAWER_WIDTH}px)` : \"100%\",\r\n direction: AppLayout.appDirection,\r\n justifyContent: \"flex-start\",\r\n transition:\r\n open === true\r\n ? theme.transitions.create([\"margin\", \"width\"], {\r\n easing: theme.transitions.easing.easeOut,\r\n duration: theme.transitions.duration.enteringScreen,\r\n })\r\n : theme.transitions.create([\"margin\", \"width\"], {\r\n easing: theme.transitions.easing.sharp,\r\n duration: theme.transitions.duration.leavingScreen,\r\n }),\r\n marginLeft:\r\n !isMobile && AppLayout.appDirection === \"ltr\" && open === true\r\n ? DRAWER_WIDTH + \"px\"\r\n : 0,\r\n marginRight:\r\n !isMobile && AppLayout.appDirection === \"rtl\" && open === true\r\n ? DRAWER_WIDTH + \"px\"\r\n : 0,\r\n };\r\n});\r\n\r\nexport default function Layout() {\r\n const AppLayoutState = useSelector((state: any) => state.AppLayout);\r\n const isMobile = useIsMobile();\r\n const UserSession: UserSessionProps = useSelector(\r\n (state: any) => state.UserSession\r\n );\r\n return (\r\n <BrowserRouter>\r\n <ToastContainer draggable={true} position=\"bottom-center\" />\r\n <LoadingMask />\r\n {UserSession.value.isAuthenticated === true ? (\r\n <Main open={AppLayoutState.sideBarOpened}>\r\n <CssBaseline />\r\n <TopBar />\r\n {!isMobile ? <SideBar /> : null}\r\n {isMobile ? <MobileDrawer /> : null}\r\n <DrawerHeader />\r\n <MainContent />\r\n </Main>\r\n ) : (\r\n <Login />\r\n )}\r\n </BrowserRouter>\r\n );\r\n}\r\n","import { createSlice, Reducer } from \"@reduxjs/toolkit\";\r\nimport { SystemRoute } from \"../../../routes/types\";\r\nimport { ExtendedTreeItemProps } from \"../../../navigationItems\";\r\nimport { StoreMetaData } from \"./CommonStoreSlice\";\r\n\r\nexport type AppInfo = {\r\n documentTitle: string | null;\r\n apiBaseUrl: string | null;\r\n appName: string | null;\r\n appVersion: string | null;\r\n appLogo: any | null;\r\n businessRoutes: Array<SystemRoute>;\r\n businessNavigationItems: Array<ExtendedTreeItemProps>;\r\n businessReduxReducers: { [key: string]: Reducer<any> };\r\n businessCommonStoresMetaData: { [key: string]: StoreMetaData };\r\n muiPremiumKey: string;\r\n enableAdministrationModule: boolean;\r\n appTheme?: {\r\n light: { primaryColor: string; secondaryColor: string };\r\n dark: { primaryColor: string; secondaryColor: string };\r\n };\r\n};\r\n\r\nexport type AppInfoProp = {\r\n value: AppInfo;\r\n};\r\n\r\nconst initialState: AppInfoProp = {\r\n value: {\r\n documentTitle: null,\r\n apiBaseUrl: null,\r\n appName: null,\r\n appVersion: null,\r\n appLogo: null,\r\n muiPremiumKey: null,\r\n enableAdministrationModule: false,\r\n businessRoutes: [],\r\n businessNavigationItems: [],\r\n businessReduxReducers: {},\r\n businessCommonStoresMetaData: {},\r\n appTheme: {\r\n light: { primaryColor: \"#37505C\", secondaryColor: \"#ff6d00\" },\r\n dark: { primaryColor: \"#ea690e\", secondaryColor: \"#74776B\" },\r\n },\r\n },\r\n};\r\n\r\nconst AppInfoSlice = createSlice({\r\n name: \"AppInfo\",\r\n initialState: initialState,\r\n reducers: {\r\n setAppInfo: (state, action) => {\r\n state.value = action.payload;\r\n },\r\n },\r\n});\r\n\r\nexport const AppInfoActions = AppInfoSlice.actions;\r\nexport default AppInfoSlice.reducer;\r\n","import { CommonStoresInterface } from \"../common/CommonStoreSlice\";\r\n\r\nexport const ADMINISTRATION_STORES: CommonStoresInterface = {\r\n SystemDataSourceType: {\r\n autoLoad: false,\r\n data: [{ value: \"Mysql\" }, { value: \"Oracle\" }, { value: \"DB2\" }],\r\n url: \"\",\r\n },\r\n SystemParameterTypes: {\r\n autoLoad: false,\r\n url: \"\",\r\n data: [\r\n { value: \"datetime\" },\r\n { value: \"date\" },\r\n { value: \"text\" },\r\n { value: \"number\" },\r\n { value: \"droplist\" },\r\n ],\r\n },\r\n SystemReportTypes: {\r\n autoLoad: false,\r\n url: \"\",\r\n data: [{ value: \"Excel\" }, { value: \"Jasper\" }, { value: \"Blueprint\" }],\r\n },\r\n SystemWidgetTypes: {\r\n autoLoad: false,\r\n url: \"\",\r\n data: [\r\n { name: \"LineChart\" },\r\n { name: \"ColumnChart\" },\r\n { name: \"PieChart\" },\r\n { name: \"Card\" },\r\n { name: \"CircularProgress\" },\r\n { name: \"LinearProgress\" },\r\n ],\r\n },\r\n SystemMailRecipientTypes: {\r\n autoLoad: false,\r\n url: \"\",\r\n data: [{ name: \"To\" }, { name: \"CC\" }],\r\n },\r\n SystemDataSources: {\r\n autoLoad: true,\r\n data: [],\r\n authority: \"DEVELOPMENT_ADMIN\",\r\n url: \"api/v1/admin/datasourceconnection/all\",\r\n },\r\n SystemDataQueries: {\r\n autoLoad: true,\r\n data: [],\r\n authority: \"DEVELOPMENT_ADMIN\",\r\n url: \"api/v1/admin/dataquery/all\",\r\n },\r\n SystemEntityParameters: {\r\n autoLoad: true,\r\n data: [],\r\n authority: \"DEVELOPMENT_ADMIN\",\r\n url: \"api/v1/admin/entityparameter/all\",\r\n },\r\n SystemAuthorities: {\r\n autoLoad: true,\r\n data: [],\r\n authority: \"DEVELOPMENT_ADMIN\",\r\n url: \"api/v1/admin/authority/all\",\r\n },\r\n SystemRoles: {\r\n autoLoad: true,\r\n data: [],\r\n authority: \"DEVELOPMENT_ADMIN\",\r\n url: \"api/v1/admin/role/all\",\r\n },\r\n};\r\n","import { useDispatch, useSelector } from \"react-redux\";\r\nimport { createTheme, ThemeOptions } from \"@mui/material\";\r\nimport { ThemeProvider } from \"@emotion/react\";\r\nimport React, { useEffect } from \"react\";\r\nimport Layout from \"../layout/Layout\";\r\nimport { AppInfo, AppInfoActions } from \"../redux/features/common/AppInfoSlice\";\r\nimport { LicenseInfo } from \"@mui/x-license\";\r\nimport {\r\n DARK_THEME_INITIAL_MAIN_COLOR,\r\n DARK_THEME_INITIAL_SECANDARY_COLOR,\r\n LIGHT_THEME_INITIAL_MAIN_COLOR,\r\n LIGHT_THEME_INITIAL_SECANDARY_COLOR,\r\n} from \"../util\";\r\nimport { setStoresMetaData } from \"../redux/features/common/CommonStoreSlice\";\r\nimport { ADMINISTRATION_STORES } from \"../redux/features/administration/AdministrationStoresMetaData\";\r\n\r\nconst App: React.FC<AppInfo> = (props: AppInfo) => {\r\n const dispatch = useDispatch();\r\n LicenseInfo.setLicenseKey(props.muiPremiumKey);\r\n const LightThemeOptions: ThemeOptions = {\r\n components: {\r\n MuiCssBaseline: {\r\n styleOverrides: `\r\n /* Custom Scrollbar */\r\n * {\r\n scrollbar-width: thin;\r\n scrollbar-color: ${\r\n props.appTheme?.light?.primaryColor ||\r\n LIGHT_THEME_INITIAL_MAIN_COLOR\r\n } #ffffff;\r\n }\r\n \r\n /* Webkit Browsers */\r\n *::-webkit-scrollbar {\r\n width: 12px;\r\n height: 10px;\r\n } \r\n `,\r\n },\r\n },\r\n palette: {\r\n mode: \"light\",\r\n primary: {\r\n main:\r\n props.appTheme?.light?.primaryColor || LIGHT_THEME_INITIAL_MAIN_COLOR,\r\n },\r\n secondary: {\r\n main:\r\n props.appTheme?.light?.secondaryColor ||\r\n LIGHT_THEME_INITIAL_SECANDARY_COLOR,\r\n },\r\n background: {\r\n default: \"#f5f5f5\",\r\n paper: \"#f5f5f5\",\r\n },\r\n },\r\n };\r\n const DarkThemeOptions: ThemeOptions = {\r\n components: {\r\n MuiCssBaseline: {\r\n styleOverrides: `\r\n /* Custom Scrollbar */\r\n * {\r\n scrollbar-width: thin;\r\n scrollbar-color: ${\r\n props.appTheme?.dark?.primaryColor || DARK_THEME_INITIAL_MAIN_COLOR\r\n } #121212;\r\n }\r\n \r\n /* Webkit Browsers */\r\n *::-webkit-scrollbar {\r\n width: 12px;\r\n height: 10px;\r\n } \r\n `,\r\n },\r\n },\r\n palette: {\r\n mode: \"dark\",\r\n primary: {\r\n main:\r\n props.appTheme?.dark?.primaryColor || DARK_THEME_INITIAL_MAIN_COLOR,\r\n },\r\n secondary: {\r\n main:\r\n props.appTheme?.dark?.secondaryColor ||\r\n DARK_THEME_INITIAL_SECANDARY_COLOR,\r\n },\r\n },\r\n };\r\n\r\n let commonStores = {};\r\n if (props.enableAdministrationModule) {\r\n commonStores = { ...ADMINISTRATION_STORES };\r\n }\r\n if (props.businessCommonStoresMetaData) {\r\n commonStores = {\r\n ...commonStores,\r\n ...props.businessCommonStoresMetaData,\r\n };\r\n } \r\n dispatch(setStoresMetaData(commonStores));\r\n const AppLayoutState = useSelector((state: any) => state.AppLayout);\r\n let themeOptions = { ...LightThemeOptions };\r\n if (AppLayoutState.themeMode === \"dark\") {\r\n themeOptions = { ...DarkThemeOptions };\r\n }\r\n const theme = createTheme({\r\n direction: AppLayoutState.appDirection,\r\n ...themeOptions,\r\n });\r\n useEffect(() => {\r\n document.title = props.documentTitle;\r\n dispatch(AppInfoActions.setAppInfo(props));\r\n }, []);\r\n return (\r\n <ThemeProvider theme={theme}>\r\n <Layout />\r\n </ThemeProvider>\r\n );\r\n};\r\n\r\nexport default App;\r\n","import { Provider } from \"react-redux\";\r\nimport { library } from \"@fortawesome/fontawesome-svg-core\";\r\nimport { fab } from \"@fortawesome/free-brands-svg-icons\";\r\nimport { far } from \"@fortawesome/free-regular-svg-icons\";\r\nimport { fas } from \"@fortawesome/free-solid-svg-icons\";\r\nimport \"../styles/index.css\";\r\nimport \"react-toastify/dist/ReactToastify.css\";\r\nimport App from \"./App\";\r\nimport { AppInfo } from \"../redux/features/common/AppInfoSlice\";\r\nimport AppLayoutReducer from \"../redux/features/common/AppLayoutSlice\";\r\nimport UserSessionReducer from \"../redux/features/common/UserSessionSlice\";\r\nimport LoadingMaskReducer from \"../redux/features/common/LoadingMaskSlice\";\r\nimport CommonStoreReducer from \"../redux/features/common/CommonStoreSlice\";\r\nimport AppInfoReducer from \"../redux/features/common/AppInfoSlice\";\r\nimport { configureStore } from \"@reduxjs/toolkit\";\r\n\r\nlibrary.add(fab);\r\nlibrary.add(far);\r\nlibrary.add(fas);\r\n\r\nexport const BaseApp: React.FC<AppInfo> = (props) => {\r\n const systemReducers = {\r\n AppLayout: AppLayoutReducer,\r\n UserSession: UserSessionReducer,\r\n loadingMask: LoadingMaskReducer,\r\n commonStores: CommonStoreReducer,\r\n AppInfo: AppInfoReducer,\r\n ...props.businessReduxReducers,\r\n };\r\n const store = configureStore({\r\n reducer: systemReducers,\r\n });\r\n // let csInitialState: CommonStoresInterface = {};\r\n // if (props.enableAdministrationModule) {\r\n // for (let adminStoreKey of Object.keys(ADMINISTRATION_STORES)) {\r\n // csInitialState[adminStoreKey] = ADMINISTRATION_STORES[adminStoreKey];\r\n // addCommonStore(adminStoreKey, ADMINISTRATION_STORES[adminStoreKey]);\r\n // }\r\n // }\r\n // if (props?.businessCommonStoresMetaData) {\r\n // for (let businessStoreKey of Object.keys(\r\n // props.businessCommonStoresMetaData\r\n // )) {\r\n // csInitialState[businessStoreKey] =\r\n // props.businessCommonStoresMetaData[businessStoreKey];\r\n // addCommonStore(\r\n // businessStoreKey,\r\n // props.businessCommonStoresMetaData[businessStoreKey]\r\n // );\r\n // }\r\n // }\r\n\r\n return (\r\n <Provider store={store}>\r\n <App {...props} />\r\n </Provider>\r\n );\r\n};\r\n"],"names":["css","ref","insertAt","document","head","getElementsByTagName","style","createElement","type","firstChild","insertBefore","appendChild","styleSheet","cssText","createTextNode","useIsMobile","breakpoint","isMobile","setIsMobile","useState","window","innerWidth","useEffect","handleResize","addEventListener","removeEventListener","DRAWER_WIDTH","AppLayoutSlice","createSlice","name","sideBarOpened","themeMode","localStorage","getItem","appDirection","reducers","toggleSideBarState","state","setSideBarState","action","payload","setThemeMode","setAppDirection","AppLayoutActions","actions","AppLayoutReducer","reducer","loadingMaskSlice","value","isOpened","message","showLoadingMask","hideLoadingMask","LoadingMaskReducer","useLoadingMask","dispatch","useDispatch","show","hide","useAxios","mask","apiBaseUrl","useSelector","AppInfo","axiosInstance","axios","create","baseURL","timeout","withCredentials","defaults","interceptors","response","use","error","status","toast","autoClose","data","handleGetRequest","async","props","endPointURI","parameters","undefined","showMask","loadingMessage","get","params","successCallBkFn","failureCallBkFn","handlePostRequest","post","handleDeleteRequest","delete","HandleDownloadHTTPPostPDF","responseType","UserSessionSlice","isAuthenticated","authorities","userProfile","setAuthenticated","setUnAuthenticated","UserSessionActions","UserSessionReducer","resources","en","translation","common","ar","i18n","initReactI18next","init","lng","fallbackLng","AppBar","styled","MuiAppBar","shouldForwardProp","prop","theme","AppLayout","transition","transitions","easing","sharp","duration","leavingScreen","variants","open","width","marginLeft","marginRight","easeOut","enteringScreen","TopBar","UserSession","_jsx","position","children","_jsxs","Toolbar","IconButton","color","onClick","edge","sx","mr","ml","display","FontAwesomeIcon","icon","Avatar","src","appLogo","Typography","variant","noWrap","component","flex","appName","setItem","prefix","iconName","nextLanguage","language","changeLanguage","username","console","log","rotation","DrawerHeader","alignItems","mixins","toolbar","justifyContent","r","e","t","f","n","Array","isArray","o","length","clsx","arguments","useSession","isUserAuthorized","authorityCode","grantedAuthority","authority","findNavigationItemById","id","nodes","node","found","NavigationItems","label","actionPayload","path","DotIcon","Box","height","borderRadius","bgcolor","verticalAlign","zIndex","mx","StyledTreeItemRoot","TreeItem2Root","palette","grey","treeItemClasses","groupTransition","spacing","applyStyles","CustomTreeItemContent","TreeItem2Content","flexDirection","marginBottom","marginTop","padding","paddingRight","primary","dark","main","content","left","top","backgroundColor","alpha","contrastText","AnimatedCollapse","animated","Collapse","TransitionComponent","useSpring","to","opacity","in","transform","StyledTreeItemLabelText","fontWeight","CustomLabel","expandable","other","useTranslation","appLayoutState","TreeItem2Label","fontSize","isExpandable","reactChildren","some","Boolean","CustomTreeItem","React","forwardRef","itemId","disabled","getRootProps","getContentProps","getIconContainerProps","getCheckboxProps","getLabelProps","getGroupTransitionProps","getDragAndDropOverlayProps","publicAPI","useTreeItem2","rootRef","item","TreeItem2Provider","className","expanded","selected","focused","TreeItem2IconContainer","TreeItem2Icon","TreeItem2Checkbox","TreeItem2DragAndDropOverlay","NavigationTree","navigate","useNavigate","filterData","filter","map","mergedNavigationItems","enableAdministrationModule","push","businessNavigationItems","authoriedNavigationItems","RichTreeView","items","onItemClick","event","navigationItem","flexGrow","maxWidth","direction","maxHeight","overflowY","overflowX","slots","SideBar","useTheme","Drawer","flexShrink","boxSizing","anchor","textAlign","appVersion","Divider","cacheRtl","createCache","key","stylisPlugins","prefixer","rtlPlugin","cacheLtr","useConfirmationWindow","setOpen","ConfirmationWindow","Dialog","DialogTitle","title","DialogContent","DialogContentText","body","DialogActions","Button","onConfirmationCallBk","autoFocus","TemplateGridMultiRecordAction","rowAction","session","confirmationMessage","actionFn","recordsToProcessActionOn","recordIdsToProcessActionOn","reloadData","isActionAllowed","_Fragment","preActionValidation","record","isConfirmationRequired","formActionProps","actionButtonVariant","size","actionButtonColor","DATE_FORMAT","DATE_TIME_FORMAT","LIGHT_THEME_INITIAL_MAIN_COLOR","LIGHT_THEME_INITIAL_SECANDARY_COLOR","DARK_THEME_INITIAL_MAIN_COLOR","DARK_THEME_INITIAL_SECANDARY_COLOR","Datefield","LocalizationProvider","dateAdapter","AdapterMoment","DatePicker","moment","format","onChange","momentValue","v","isValid","onChangeCallBack","slotProps","textField","InputLabelProps","shrink","required","errorMessage","helperText","DatetimeField","DateTimePicker","ComboBox","AppLayoutState","Autocomplete","option","options","valueField","getValue","newValue","clearOnBlur","handleHomeEndKeys","getOptionLabel","displayField","renderOption","props1","popper","Popper","renderInput","TextField","CheckBox","FormControlLabel","control","Checkbox","checked","checkedValue","target","unCheckedValue","generateDateTimeColumn","colDef","renderEditCell","api","setEditCellValue","field","valueParser","row","column","valueFormatter","generateComboColumn","valueGetter","renderCell","find","selectedRecord","generateCheckBoxColumn","getElementFields","element","fields","mode","elements","childElement","getAllFields","constructValidationSchema","validationSchemaObj","fieldName","fieldType","z","number","required_error","invalid_type_error","optional","nullable","string","min","StyledQuickFilter","QuickFilter","StyledToolbarButton","ToolbarButton","ownerState","gridArea","pointerEvents","StyledTextField","TemplateGridTopBar","isCreationAuthorized","templateProps","editAction","gridSelection","rowSelectionModel","keyColumnName","sRecords","sRecordIds","ids","selectedId","x","selectedRecords","selectedRecordIds","getGridSelection","Set","editMode","handleCreateNewRecord","rowActions","gridActionProps","multiRecord","apiActions","gridLoadParametersValues","tBar","Tooltip","ColumnsPanelTrigger","render","GridViewColumnIcon","FilterPanelTrigger","Badge","badgeContent","filterCount","GridFilterListIcon","gridStateKey","clearGridState","orientation","flexItem","ExportExcel","MenuItem","QuickFilterTrigger","triggerProps","enterDelay","QuickFilterControl","controlProps","inputRef","placeholder","input","startAdornment","InputAdornment","endAdornment","QuickFilterClear","hasDigitsOnly","str","test","isNumber","isNaN","isNumeric","trim","Number","capitalizeFirstLetter","charAt","toUpperCase","slice","TemplateGridRecordAction","iconStyle","getActionIconStyleForRecord","isActionVisibleForRecord","isActionDisabledForRecord","GridActionsCellItem","showInMenu","formatMuiErrorMessage","code","args","url","URL","forEach","arg","searchParams","append","process","env","NODE_ENV","reactIsModule","exports","b","Symbol","for","c","d","g","h","k","l","m","p","q","w","y","a","u","$$typeof","A","reactIs_production_min","AsyncMode","ConcurrentMode","ContextConsumer","Element","ForwardRef","Fragment","Lazy","Portal","Profiler","StrictMode","Suspense","isAsyncMode","isConcurrentMode","isContextConsumer","isContextProvider","isElement","isForwardRef","isFragment","isLazy","isMemo","isProfiler","isStrictMode","isSuspense","isValidElementType","typeOf","require$$0","hasSymbol","REACT_ELEMENT_TYPE","REACT_PORTAL_TYPE","REACT_FRAGMENT_TYPE","REACT_STRICT_MODE_TYPE","REACT_PROFILER_TYPE","REACT_PROVIDER_TYPE","REACT_CONTEXT_TYPE","REACT_ASYNC_MODE_TYPE","REACT_CONCURRENT_MODE_TYPE","REACT_FORWARD_REF_TYPE","REACT_SUSPENSE_TYPE","REACT_SUSPENSE_LIST_TYPE","REACT_MEMO_TYPE","REACT_LAZY_TYPE","REACT_BLOCK_TYPE","REACT_FUNDAMENTAL_TYPE","REACT_RESPONDER_TYPE","REACT_SCOPE_TYPE","object","$$typeofType","ContextProvider","Memo","hasWarnedAboutDeprecatedIsAsyncMode","reactIs_development","isPortal","getOwnPropertySymbols","Object","hasOwnProperty","prototype","propIsEnumerable","propertyIsEnumerable","objectAssign","assign","test1","String","getOwnPropertyNames","test2","i","fromCharCode","join","test3","split","letter","keys","err","shouldUseNative","source","from","symbols","val","TypeError","toObject","s","call","ReactPropTypesSecret_1","has","Function","bind","printWarning","ReactPropTypesSecret","loggedTypeFailures","require$$1","text","Error","checkPropTypes","typeSpecs","values","location","componentName","getStack","typeSpecName","ex","stack","resetWarningCache","checkPropTypes_1","ReactIs","require$$2","require$$3","require$$4","emptyFunctionThatReturnsNull","factoryWithTypeCheckers","isValidElement","throwOnDirectAccess","ITERATOR_SYMBOL","iterator","ANONYMOUS","ReactPropTypes","array","createPrimitiveTypeChecker","bigint","bool","func","symbol","any","createChainableTypeChecker","arrayOf","typeChecker","propName","propFullName","PropTypeError","propValue","getPropType","elementType","instanceOf","expectedClass","expectedClassName","constructor","isNode","objectOf","propType","oneOf","expectedValues","is","valuesString","JSON","stringify","getPreciseType","oneOfType","arrayOfTypeCheckers","checker","getPostfixForTypeWarning","expectedTypes","checkerResult","expectedType","shape","shapeTypes","invalidValidatorError","exact","allKeys","this","validate","manualPropTypeCallCache","manualPropTypeWarningCount","checkType","isRequired","secret","cacheKey","chainedCheckType","every","iteratorFn","maybeIterable","getIteratorFn","step","entries","next","done","entry","RegExp","isSymbol","Date","PropTypes","emptyFunction","emptyFunctionWithReset","factoryWithThrowingShims","shim","getShim","propTypesModule","REACT_CONSUMER_TYPE","REACT_VIEW_TRANSITION_TYPE","REACT_CLIENT_REFERENCE","reactIs_production","SuspenseList","isSuspenseList","getModuleId","isPlainObject","getPrototypeOf","toStringTag","deepClone","output","deepmerge","clone","createBreakpoints","breakpoints","xs","sm","md","lg","xl","unit","sortedValues","breakpointsAsArray","sort","breakpoint1","breakpoint2","reduce","acc","obj","sortBreakpointsValues","up","down","between","start","end","endIndex","indexOf","only","not","keyIndex","replace","responsivePropType","merge","defaultBreakpoints","defaultContainerQueries","containerQueries","containerName","result","handleBreakpoints","styleFromPropValue","themeBreakpoints","index","breakpointKeys","startsWith","match","containerKey","shorthand","matches","_formatErrorMessage","containerQuery","getContainerQuery","includes","cssKey","capitalize","getPath","checkVars","vars","getStyleValue","themeMapping","propValueFinal","userValue","cssProperty","themeKey","fn","propTypes","filterProps","properties","directions","aliases","marginX","marginY","paddingX","paddingY","getCssProperties","cache","memoize","property","dir","marginKeys","paddingKeys","spacingKeys","createUnaryUnit","defaultValue","themeSpacing","abs","Math","isInteger","transformed","createUnarySpacing","transformer","resolveCssProperty","cssProperties","getStyleFromPropValue","margin","compose","styles","handlers","concat","borderTransform","createBorderStyle","border","borderTop","borderRight","borderBottom","borderLeft","borderColor","borderTopColor","borderRightColor","borderBottomColor","borderLeftColor","outline","outlineColor","gap","columnGap","rowGap","paletteTransform","sizingTransform","breakpointsValues","minWidth","minHeight","defaultSxConfig","pt","pr","pb","pl","px","py","paddingTop","paddingBottom","paddingLeft","paddingInline","paddingInlineStart","paddingInlineEnd","paddingBlock","paddingBlockStart","paddingBlockEnd","mt","mb","my","marginInline","marginInlineStart","marginInlineEnd","marginBlock","marginBlockStart","marginBlockEnd","displayPrint","overflow","textOverflow","visibility","whiteSpace","flexBasis","flexWrap","alignContent","order","alignSelf","justifyItems","justifySelf","gridColumn","gridRow","gridAutoFlow","gridAutoColumns","gridAutoRows","gridTemplateColumns","gridTemplateRows","gridTemplateAreas","right","bottom","boxShadow","font","fontFamily","fontStyle","letterSpacing","textTransform","lineHeight","typography","styleFunctionSx","getThemeValue","config","unstable_sxConfig","traverse","sxInput","sxObject","emptyBreakpoints","breakpointsInput","breakpointsInOrder","createEmptyBreakpointObject","breakpointsKeys","styleKey","maybeFn","objects","union","objectsHaveSameKeys","sorted","regex","sortContainerQueries","breakpointOutput","removeUnusedBreakpoints","unstable_createStyleFunctionSx","colorSchemes","getColorSchemeSelector","selector","defaultTheme","contextTheme","useContext","ThemeContext","systemDefaultTheme","paletteInput","spacingInput","shapeInput","mui","argsInput","argument","createSpacing","muiTheme","components","themeInput","toContainerQuery","mediaQuery","attachCq","cssContainerQueries","unstable_sx","createTheme","extendSxProp","inSx","systemProps","otherProps","splitProps","finalSx","defaultGenerator","ClassNameGenerator","generate","configure","generator","reset","createClassNameGenerator","globalStateClasses","active","completed","focusVisible","readOnly","themeId","defaultClassName","generateClassName","BoxRoot","tag","stylesFactory","emStyled","inProps","useThemeWithoutDefault","as","createBox","globalStatePrefix","slot","globalStateClass","generateUtilityClass","generateUtilityClasses","root","TemplateTextField","inputLabel","FormElementField","fieldInfo","formManager","formActions","formValues","hidden","hiddenFields","Grid2","formProps","fieldSize","fullWidth","disabledFields","fieldLabel","setValue","onValueChangeCallBack","formState","errors","toString","dateFormat","optionDisplayField","optionValueField","FormAction","setConfirmationWindowState","FormElementGroup","container","TemplateForm","setHiddenFields","setDisabledFields","formSchema","useForm","resolver","zodResolver","watch","pathParameters","useParams","formRouteRecordIdParamName","setFieldValue","fieldValue","hideField","oldValues","showField","disableField","enableField","idToLoad","recordIdToEdit","retrievedRecord","loadRecordById","loadRecord","formElement","enabled","saveButtonSpecs","startIcon","handleSubmit","preSaveValidation","savedRecord","saveRecord","formSavedSuccessfullyCallBk","formCloseCallBk","cancelButtonSpecs","useWindow","windowState","setWindowState","Window","windowProps","Modal","drawer","onClose","onCloseCallBack","windowIcon","windowTitle","Paper","currentNewRecordIndex","loadGridState","saved","parse","saveGridState","statePart","current","PIN_FIXED_COLUMNS","TemplateGrid","formElements","savedState","useMemo","gridProps","initialVisibilityState","columnVisibilityModel","existingFields","themeDirection","setColumnVisibilityModel","columnOrder","setColumnOrder","columnWidths","setColumnWidths","gridRowGroupingModel","setGridRowGroupingModel","columnGroupingModel","newLeft","pinnedColumns","newRight","setPinnedColumns","recordToDelete","setRecordToDelete","recordToEdit","setRecordToEdit","rowModesModel","setRowModesModel","setRowSelectionModel","setData","validationSchema","generatedColumns","isDefaultEditable","columns","tableField","muiProps","editable","headerName","headerAlign","align","searchable","constructGridColumnsFromFields","isEditAllowed","isDeleteAllowed","deleteAction","setConfirmationWindowOpened","isNew","deleteRecordById","postActionCallBack","oldData","formModalHeight","formModalWidth","formModalMinHeight","formModalMinWidth","formModalIcon","formModalTitle","specs","modalHeight","modalWidth","modalMinHeight","modalMinWidth","modalIcon","modalTitle","FormWindow","setFormWindowState","actionColumn","isEnabled","getActions","disableDefaultAction","isInEditMode","GridRowModes","Edit","View","handleSaveRowClick","ignoreModifications","newData","handleCancelRowEditClick","isEditActionVisibleForRecord","isActionEditDisabledForRecord","formRoute","handleEditRecord","isDeleteActionVisibleForRecord","isDeleteActionDisabledForRecord","structuredColumns","autoLoad","adjustedColumns","baseCols","col","fieldToCol","Map","formComponent","editAuthorityKey","hideInfoBar","hideBackButton","girdIcon","gridTitle","gridLoadParameters","setGridLoadParametersValues","Accordion","defaultExpanded","AccordionSummary","expandIcon","GridExpandMoreIcon","AccordionDetails","DataGridPremium","newRecord","oldRows","oldModel","removeItem","getRowId","showToolbar","rows","checkboxSelection","onRowModesModelChange","newModel","rowGroupingColumnMode","processRowUpdate","ZodError","validateRecord","requestObject","reloadAfterSave","onRowSelectionModelChange","gridSelectionModel","onColumnVisibilityModelChange","model","onColumnOrderChange","targetIndex","prevOrder","currentOrder","fromIndex","splice","onColumnWidthChange","updatedWidths","rowGroupingModel","onRowGroupingModelChange","handleRowGroupChange","onPinnedColumnsChange","newPinedColumns","commonStoreSlice","initialState","stores","storeKeys","isAutoLoadLoaded","setStoresMetaData","setStoreData","storeKey","setAutoLoadLoaded","CommonStoreReducer","useApiActions","apiActionsProps","CommonStores","commonStores","commonStoreKey","findAll","recordId","findById","findByIdParamName","save","deleteById","deleteByIdParamName","intersection","TransferList","selectedOptions","setSelection","setChecked","setLeft","setRight","leftFilterValue","setLeftFilterValue","rightFilterValue","setRightFilterValue","leftChecked","rightChecked","handleToggle","currentIndex","newChecked","numberOfChecked","handleToggleAll","customList","unfilteredItems","side","toLocaleLowerCase","Card","CardHeader","avatar","indeterminate","inputProps","subheader","List","dense","role","ListItemButton","cursor","ListItemIcon","tabIndex","disableRipple","ListItemText","oldState","newState","TemplatePieChart","chartData","labelField","PieChart","series","TemplateBarChart","BarChart","dataset","xAxis","dataKey","scaleType","TemplateLineChart","LineChart","TemplateGauge","widgetTitle","Gauge","TemplateDataCard","LinearProgressWithLabel","LinearProgress","round","TemplateLineProgress","WidgetContainer","widgetType","Grid","TemplateDashboard","dashboardTitle","dashboardWidgets","widgetProps","singleRecordWidgetProps","RoleAuthoritiesForm","setSelectedOptions","currentRoleAuthorities","availableAuthorities","roleId","success","closeModalFn","SYSTEM_ROUTES","selectedRole","setSelectedRole","selectedRoleAuthorities","setSelectedRoleAuthorities","selectedRoleAvailableAuthorities","setSelectedRoleAvailableAuthorities","RoleAuthoritiesWindow","setRoleAuthorirtiesWindowOpen","selectedAuthorities","loadRoleAuthorities","MainContent","businessRoutes","CacheProvider","Routes","route","Route","Component","Puller","MobileDrawer","toggleDrawer","SwipeableDrawer","onOpen","swipeAreaWidth","disableSwipeToOpen","ModalProps","keepMounted","LoadingMask","loadingMask","Backdrop","CircularProgress","Login","appInfo","setUsername","password","setPassword","isLoginInProcess","setIsLoginInProcess","UserSessionState","handleLogin","userSession","loginTheme","MuiCssBaseline","styleOverrides","appTheme","primaryColor","secondary","secondaryColor","checkUserSession","ThemeProvider","onKeyDown","loading","Main","loadCommonStores","Layout","BrowserRouter","ToastContainer","draggable","CssBaseline","AppInfoSlice","documentTitle","muiPremiumKey","businessReduxReducers","businessCommonStoresMetaData","light","setAppInfo","AppInfoActions","AppInfoReducer","ADMINISTRATION_STORES","SystemDataSourceType","SystemParameterTypes","SystemReportTypes","SystemWidgetTypes","SystemMailRecipientTypes","SystemDataSources","SystemDataQueries","SystemEntityParameters","SystemAuthorities","SystemRoles","App","LicenseInfo","setLicenseKey","LightThemeOptions","background","default","paper","DarkThemeOptions","themeOptions","library","add","fab","far","fas","BaseApp","systemReducers","store","configureStore","Provider"],"mappings":"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","x_google_ignoreList":[0,13,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77]}