@asaleh37/ui-base 1.1.8 → 1.1.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.d.ts +1 -0
- package/dist/index.js +3 -3
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +3 -3
- package/dist/index.mjs.map +1 -1
- package/package.json +113 -113
- package/rollup.config-1748377725725.cjs +16 -16
- package/src/components/App.tsx +2 -0
- package/src/components/BaseApp.tsx +0 -5
- package/src/redux/features/common/AppInfoSlice.ts +2 -0
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../src/redux/features/common/AppLayoutSlice.ts","../src/redux/features/common/UserSessionSlice.ts","../src/redux/features/common/LoadingMaskSlice.ts","../src/redux/features/administration/AdministrationStoresMetaData.ts","../src/redux/features/common/CommonStoreSlice.ts","../src/redux/features/common/AppInfoSlice.ts","../src/redux/store.ts","../node_modules/style-inject/dist/style-inject.es.js","../src/theme/LightThemeOptions.ts","../src/theme/DarkThemeOptions.ts","../src/hooks/UseMobile.tsx","../src/hooks/useLoadingMask.tsx","../src/hooks/useAxios.tsx","../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/components/templates/DataEntryTemplates/useApiActions.ts","../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/components/App.tsx","../src/components/BaseApp.tsx","../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"],"sourcesContent":["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 } 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 { 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 { 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 { createSlice, PayloadAction } from \"@reduxjs/toolkit\";\r\nimport { ADMINISTRATION_STORES } from \"../administration/AdministrationStoresMetaData\";\r\n\r\nexport interface CommonStoresInterface {\r\n [key: string]: StoreMetaData;\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 ...ADMINISTRATION_STORES,\r\n};\r\n\r\nconst commonStoreSlice = createSlice({\r\n name: \"loadingMask\",\r\n initialState: commonStoresInitialState,\r\n reducers: {\r\n setStoreData(state, action: PayloadAction<setStoreDataProps>) {\r\n state[action.payload.storeKey].data = action.payload.data;\r\n },\r\n },\r\n});\r\n\r\nexport const { setStoreData } = commonStoreSlice.actions;\r\nexport default commonStoreSlice.reducer;\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};\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 businessRoutes: [],\r\n businessNavigationItems: [],\r\n businessReduxReducers: {},\r\n businessCommonStoresMetaData: {},\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 { configureStore, Reducer } from \"@reduxjs/toolkit\";\r\nimport AppLayoutReducer from \"./features/common/AppLayoutSlice\";\r\nimport UserSessionReducer from \"./features/common/UserSessionSlice\";\r\nimport LoadingMaskReducer from \"./features/common/LoadingMaskSlice\";\r\nimport CommonStoreReducer from \"./features/common/CommonStoreSlice\";\r\nimport AppInfoReducer from \"./features/common/AppInfoSlice\";\r\n\r\nconst reducers = {\r\n AppLayout: AppLayoutReducer,\r\n UserSession: UserSessionReducer,\r\n loadingMask: LoadingMaskReducer,\r\n commonStores: CommonStoreReducer,\r\n AppInfo: AppInfoReducer,\r\n};\r\n\r\nexport function addReducer(key: string, reducer: Reducer<any>) {\r\n if (!reducers[key]) {\r\n reducers[key] = reducer;\r\n }\r\n}\r\n\r\nexport const store = configureStore({\r\n reducer: reducers,\r\n});\r\n\r\n// Infer the `RootState` and `AppDispatch` types from the store itself\r\nexport type RootState = ReturnType<typeof store.getState>;\r\nexport type AppDispatch = typeof store.dispatch;\r\n","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 { ThemeOptions } from \"@mui/material\";\r\n\r\nexport 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: #37505C #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: \"#37505C\",\r\n },\r\n secondary: {\r\n main: \"#ff6d00\",\r\n },\r\n background: {\r\n default: \"#f5f5f5\",\r\n paper: \"#f5f5f5\",\r\n },\r\n },\r\n};\r\n","import { ThemeOptions } from \"@mui/material\";\r\n\r\nexport 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: #ea690e #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: \"#ea690e\",\r\n },\r\n secondary: {\r\n main: \"#74776B\",\r\n },\r\n },\r\n};\r\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 { 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 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 businessNavigationItems = useSelector(\r\n (state: RootState) => state.AppInfo.value.businessNavigationItems\r\n );\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 ...NavigationItems,\r\n ...businessNavigationItems,\r\n ];\r\n\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(itemId, NavigationItems);\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\";","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 { useDispatch, useSelector } from \"react-redux\";\r\nimport { RootState } from \"../../../redux/store\";\r\nimport useSession from \"../../../hooks/UseSession\";\r\nimport useAxios from \"../../../hooks/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: RootState) => state.commonStores);\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 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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\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\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 <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=\"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\nexport default RoleGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 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 {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 {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 { DarkThemeOptions } from \"../../theme/DarkThemeOptions\";\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(DarkThemeOptions);\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 } from \"react\";\r\nimport { RootState } from \"../redux/store\";\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: RootState) => state.AppLayout);\r\n const dispatch = useDispatch();\r\n const { show, hide } = useLoadingMask();\r\n const CommonStores = useSelector((state: RootState) => state.commonStores);\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 show(\"Loading ... please wait\");\r\n let storeKeys = Object.keys(CommonStores);\r\n for (let storeKey of storeKeys) {\r\n if (\r\n (CommonStores[storeKey]?.authority === undefined ||\r\n CommonStores[storeKey]?.authority === null ||\r\n isUserAuthorized(CommonStores[storeKey]?.authority)) &&\r\n CommonStores[storeKey]?.url != \"\" &&\r\n CommonStores[storeKey].autoLoad === true\r\n ) {\r\n await handleGetRequest({\r\n endPointURI: CommonStores[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 useEffect(() => {\r\n loadCommonStores();\r\n }, []);\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: RootState) => state.AppLayout);\r\n const isMobile = useIsMobile();\r\n const UserSession: UserSessionProps = useSelector(\r\n (state: RootState) => 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 { useDispatch, useSelector } from \"react-redux\";\r\nimport { createTheme } from \"@mui/material\";\r\nimport { ThemeProvider } from \"@emotion/react\";\r\nimport React, { useEffect } from \"react\";\r\nimport { RootState } from \"../redux/store\";\r\nimport { LightThemeOptions } from \"../theme/LightThemeOptions\";\r\nimport { DarkThemeOptions } from \"../theme/DarkThemeOptions\";\r\nimport Layout from \"../layout/Layout\";\r\nimport { AppInfo, AppInfoActions } from \"../redux/features/common/AppInfoSlice\";\r\n\r\nconst App: React.FC<AppInfo> = (props: AppInfo) => {\r\n const dispatch = useDispatch();\r\n const AppLayoutState = useSelector((state: RootState) => 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 { addReducer, store } from \"../redux/store\";\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 { LicenseInfo } from \"@mui/x-license\";\r\n\r\nLicenseInfo.setLicenseKey(\r\n \"c2bd611fa642666253500ab9c8e4f78fTz0xMTE4MjEsRT0xNzc2OTg4Nzk5MDAwLFM9cHJlbWl1bSxMTT1zdWJzY3JpcHRpb24sUFY9aW5pdGlhbCxLVj0y\"\r\n);\r\nimport \"react-toastify/dist/ReactToastify.css\";\r\nimport App from \"./App\";\r\nimport { AppInfo } from \"../redux/features/common/AppInfoSlice\";\r\nimport { commonStoresInitialState } from \"../redux/features/common/CommonStoreSlice\";\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 if (props?.businessCommonStoresMetaData) {\r\n for (let businessStoreKey of Object.keys(\r\n props.businessCommonStoresMetaData\r\n )) {\r\n commonStoresInitialState[businessStoreKey] =\r\n props.businessCommonStoresMetaData[businessStoreKey];\r\n }\r\n }\r\n if (props?.businessReduxReducers) {\r\n for (let businessReducerKey of Object.keys(props.businessReduxReducers)) {\r\n addReducer(\r\n businessReducerKey,\r\n props.businessReduxReducers[businessReducerKey]\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","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 } 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 <ListItem\r\n key={value[valueField]}\r\n role=\"listitem\"\r\n component=\"button\"\r\n onClick={handleToggle(value)}\r\n >\r\n <ListItemIcon>\r\n <Checkbox\r\n checked={checked.indexOf(value) !== -1}\r\n tabIndex={-1}\r\n disableRipple\r\n inputProps={{\r\n \"aria-labelledby\": labelId,\r\n }}\r\n />\r\n </ListItemIcon>\r\n <ListItemText\r\n id={value[valueField]}\r\n primary={value[displayField]}\r\n />\r\n </ListItem>\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 >\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 <\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"],"names":["DRAWER_WIDTH","AppLayoutSlice","createSlice","name","sideBarOpened","themeMode","localStorage","getItem","appDirection","reducers","toggleSideBarState","state","setSideBarState","action","payload","setThemeMode","setAppDirection","AppLayoutActions","actions","AppLayoutReducer","reducer","UserSessionSlice","value","isAuthenticated","authorities","userProfile","setAuthenticated","setUnAuthenticated","UserSessionActions","UserSessionReducer","loadingMaskSlice","isOpened","message","showLoadingMask","hideLoadingMask","LoadingMaskReducer","commonStoresInitialState","SystemDataSourceType","autoLoad","data","url","SystemParameterTypes","SystemReportTypes","SystemWidgetTypes","SystemMailRecipientTypes","SystemDataSources","authority","SystemDataQueries","SystemEntityParameters","SystemAuthorities","SystemRoles","commonStoreSlice","initialState","setStoreData","storeKey","CommonStoreReducer","AppInfoSlice","documentTitle","apiBaseUrl","appName","appVersion","appLogo","businessRoutes","businessNavigationItems","businessReduxReducers","businessCommonStoresMetaData","setAppInfo","AppInfoActions","AppLayout","UserSession","loadingMask","commonStores","AppInfo","store","configureStore","css","ref","insertAt","document","head","getElementsByTagName","style","createElement","type","firstChild","insertBefore","appendChild","styleSheet","cssText","createTextNode","LightThemeOptions","components","MuiCssBaseline","styleOverrides","palette","mode","primary","main","secondary","background","default","paper","DarkThemeOptions","useIsMobile","breakpoint","isMobile","setIsMobile","useState","window","innerWidth","useEffect","handleResize","addEventListener","removeEventListener","useLoadingMask","dispatch","useDispatch","show","hide","useAxios","mask","useSelector","axiosInstance","axios","create","baseURL","timeout","withCredentials","defaults","interceptors","response","use","error","status","toast","autoClose","handleGetRequest","async","props","endPointURI","parameters","undefined","showMask","loadingMessage","get","params","successCallBkFn","failureCallBkFn","handlePostRequest","post","handleDeleteRequest","delete","HandleDownloadHTTPPostPDF","responseType","resources","en","translation","common","ar","i18n","initReactI18next","init","lng","fallbackLng","AppBar","styled","MuiAppBar","shouldForwardProp","prop","theme","transition","transitions","easing","sharp","duration","leavingScreen","variants","open","width","marginLeft","marginRight","easeOut","enteringScreen","TopBar","_jsx","position","children","_jsxs","Toolbar","IconButton","color","onClick","edge","sx","mr","ml","display","FontAwesomeIcon","icon","Avatar","src","Typography","variant","noWrap","component","flex","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","findNavigationItemById","id","nodes","node","found","NavigationItems","label","actionPayload","path","DotIcon","Box","height","borderRadius","bgcolor","verticalAlign","zIndex","mx","StyledTreeItemRoot","TreeItem2Root","grey","treeItemClasses","groupTransition","spacing","applyStyles","CustomTreeItemContent","TreeItem2Content","flexDirection","marginBottom","marginTop","padding","paddingRight","dark","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","authoriedNavigationItems","RichTreeView","items","onItemClick","event","navigationItem","flexGrow","maxWidth","direction","maxHeight","overflowY","overflowX","slots","SideBar","useTheme","Drawer","flexShrink","boxSizing","anchor","textAlign","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","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","push","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","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","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","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","useApiActions","apiActionsProps","CommonStores","commonStoreKey","storeKeys","findAll","recordId","findById","findByIdParamName","save","deleteById","deleteByIdParamName","SYSTEM_ROUTES","MainContent","CacheProvider","Routes","route","Route","Component","Puller","MobileDrawer","toggleDrawer","newState","SwipeableDrawer","onOpen","swipeAreaWidth","disableSwipeToOpen","ModalProps","keepMounted","LoadingMask","Backdrop","CircularProgress","Login","appInfo","setUsername","password","setPassword","isLoginInProcess","setIsLoginInProcess","UserSessionState","handleLogin","userSession","loginTheme","checkUserSession","ThemeProvider","onKeyDown","loading","Main","loadCommonStores","Layout","BrowserRouter","ToastContainer","draggable","CssBaseline","App","themeOptions","LicenseInfo","setLicenseKey","library","add","fab","far","fas","BaseApp","businessStoreKey","businessReducerKey","Provider","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","labelId","ListItem","ListItemIcon","tabIndex","disableRipple","ListItemText","oldState","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"],"mappings":"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","x_google_ignoreList":[7,19,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,78,79,80,81,82,83]}
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../src/redux/features/common/AppLayoutSlice.ts","../src/redux/features/common/UserSessionSlice.ts","../src/redux/features/common/LoadingMaskSlice.ts","../src/redux/features/administration/AdministrationStoresMetaData.ts","../src/redux/features/common/CommonStoreSlice.ts","../src/redux/features/common/AppInfoSlice.ts","../src/redux/store.ts","../node_modules/style-inject/dist/style-inject.es.js","../src/theme/LightThemeOptions.ts","../src/theme/DarkThemeOptions.ts","../src/hooks/UseMobile.tsx","../src/hooks/useLoadingMask.tsx","../src/hooks/useAxios.tsx","../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/components/templates/DataEntryTemplates/useApiActions.ts","../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/components/App.tsx","../src/components/BaseApp.tsx","../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"],"sourcesContent":["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 } 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 { 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 { 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 { createSlice, PayloadAction } from \"@reduxjs/toolkit\";\r\nimport { ADMINISTRATION_STORES } from \"../administration/AdministrationStoresMetaData\";\r\n\r\nexport interface CommonStoresInterface {\r\n [key: string]: StoreMetaData;\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 ...ADMINISTRATION_STORES,\r\n};\r\n\r\nconst commonStoreSlice = createSlice({\r\n name: \"loadingMask\",\r\n initialState: commonStoresInitialState,\r\n reducers: {\r\n setStoreData(state, action: PayloadAction<setStoreDataProps>) {\r\n state[action.payload.storeKey].data = action.payload.data;\r\n },\r\n },\r\n});\r\n\r\nexport const { setStoreData } = commonStoreSlice.actions;\r\nexport default commonStoreSlice.reducer;\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};\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 businessRoutes: [],\r\n businessNavigationItems: [],\r\n businessReduxReducers: {},\r\n businessCommonStoresMetaData: {},\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 { configureStore, Reducer } from \"@reduxjs/toolkit\";\r\nimport AppLayoutReducer from \"./features/common/AppLayoutSlice\";\r\nimport UserSessionReducer from \"./features/common/UserSessionSlice\";\r\nimport LoadingMaskReducer from \"./features/common/LoadingMaskSlice\";\r\nimport CommonStoreReducer from \"./features/common/CommonStoreSlice\";\r\nimport AppInfoReducer from \"./features/common/AppInfoSlice\";\r\n\r\nconst reducers = {\r\n AppLayout: AppLayoutReducer,\r\n UserSession: UserSessionReducer,\r\n loadingMask: LoadingMaskReducer,\r\n commonStores: CommonStoreReducer,\r\n AppInfo: AppInfoReducer,\r\n};\r\n\r\nexport function addReducer(key: string, reducer: Reducer<any>) {\r\n if (!reducers[key]) {\r\n reducers[key] = reducer;\r\n }\r\n}\r\n\r\nexport const store = configureStore({\r\n reducer: reducers,\r\n});\r\n\r\n// Infer the `RootState` and `AppDispatch` types from the store itself\r\nexport type RootState = ReturnType<typeof store.getState>;\r\nexport type AppDispatch = typeof store.dispatch;\r\n","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 { ThemeOptions } from \"@mui/material\";\r\n\r\nexport 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: #37505C #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: \"#37505C\",\r\n },\r\n secondary: {\r\n main: \"#ff6d00\",\r\n },\r\n background: {\r\n default: \"#f5f5f5\",\r\n paper: \"#f5f5f5\",\r\n },\r\n },\r\n};\r\n","import { ThemeOptions } from \"@mui/material\";\r\n\r\nexport 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: #ea690e #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: \"#ea690e\",\r\n },\r\n secondary: {\r\n main: \"#74776B\",\r\n },\r\n },\r\n};\r\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 { 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 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 businessNavigationItems = useSelector(\r\n (state: RootState) => state.AppInfo.value.businessNavigationItems\r\n );\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 ...NavigationItems,\r\n ...businessNavigationItems,\r\n ];\r\n\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(itemId, NavigationItems);\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\";","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 { useDispatch, useSelector } from \"react-redux\";\r\nimport { RootState } from \"../../../redux/store\";\r\nimport useSession from \"../../../hooks/UseSession\";\r\nimport useAxios from \"../../../hooks/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: RootState) => state.commonStores);\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 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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/useApiActions\";\r\nimport { FormElementProps } from \"../templates/DataEntryTemplates/DataEntryTypes\";\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\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 <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=\"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\nexport default RoleGrid;\r\n","import { useState } from \"react\";\r\nimport TemplateGrid from \"../templates/DataEntryTemplates/TemplateDataGrid/TemplateGrid\";\r\nimport useApiActions from \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 \"../templates/DataEntryTemplates/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 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 {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 {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 { DarkThemeOptions } from \"../../theme/DarkThemeOptions\";\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(DarkThemeOptions);\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 } from \"react\";\r\nimport { RootState } from \"../redux/store\";\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: RootState) => state.AppLayout);\r\n const dispatch = useDispatch();\r\n const { show, hide } = useLoadingMask();\r\n const CommonStores = useSelector((state: RootState) => state.commonStores);\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 show(\"Loading ... please wait\");\r\n let storeKeys = Object.keys(CommonStores);\r\n for (let storeKey of storeKeys) {\r\n if (\r\n (CommonStores[storeKey]?.authority === undefined ||\r\n CommonStores[storeKey]?.authority === null ||\r\n isUserAuthorized(CommonStores[storeKey]?.authority)) &&\r\n CommonStores[storeKey]?.url != \"\" &&\r\n CommonStores[storeKey].autoLoad === true\r\n ) {\r\n await handleGetRequest({\r\n endPointURI: CommonStores[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 useEffect(() => {\r\n loadCommonStores();\r\n }, []);\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: RootState) => state.AppLayout);\r\n const isMobile = useIsMobile();\r\n const UserSession: UserSessionProps = useSelector(\r\n (state: RootState) => 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 { useDispatch, useSelector } from \"react-redux\";\r\nimport { createTheme } from \"@mui/material\";\r\nimport { ThemeProvider } from \"@emotion/react\";\r\nimport React, { useEffect } from \"react\";\r\nimport { RootState } from \"../redux/store\";\r\nimport { LightThemeOptions } from \"../theme/LightThemeOptions\";\r\nimport { DarkThemeOptions } from \"../theme/DarkThemeOptions\";\r\nimport Layout from \"../layout/Layout\";\r\nimport { AppInfo, AppInfoActions } from \"../redux/features/common/AppInfoSlice\";\r\nimport { LicenseInfo } from \"@mui/x-license\";\r\n\r\nconst App: React.FC<AppInfo> = (props: AppInfo) => {\r\n LicenseInfo.setLicenseKey(props.muiPremiumKey);\r\n const dispatch = useDispatch();\r\n const AppLayoutState = useSelector((state: RootState) => 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 { addReducer, store } from \"../redux/store\";\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 { commonStoresInitialState } from \"../redux/features/common/CommonStoreSlice\";\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 if (props?.businessCommonStoresMetaData) {\r\n for (let businessStoreKey of Object.keys(\r\n props.businessCommonStoresMetaData\r\n )) {\r\n commonStoresInitialState[businessStoreKey] =\r\n props.businessCommonStoresMetaData[businessStoreKey];\r\n }\r\n }\r\n if (props?.businessReduxReducers) {\r\n for (let businessReducerKey of Object.keys(props.businessReduxReducers)) {\r\n addReducer(\r\n businessReducerKey,\r\n props.businessReduxReducers[businessReducerKey]\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","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 } 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 <ListItem\r\n key={value[valueField]}\r\n role=\"listitem\"\r\n component=\"button\"\r\n onClick={handleToggle(value)}\r\n >\r\n <ListItemIcon>\r\n <Checkbox\r\n checked={checked.indexOf(value) !== -1}\r\n tabIndex={-1}\r\n disableRipple\r\n inputProps={{\r\n \"aria-labelledby\": labelId,\r\n }}\r\n />\r\n </ListItemIcon>\r\n <ListItemText\r\n id={value[valueField]}\r\n primary={value[displayField]}\r\n />\r\n </ListItem>\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 >\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 <\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"],"names":["DRAWER_WIDTH","AppLayoutSlice","createSlice","name","sideBarOpened","themeMode","localStorage","getItem","appDirection","reducers","toggleSideBarState","state","setSideBarState","action","payload","setThemeMode","setAppDirection","AppLayoutActions","actions","AppLayoutReducer","reducer","UserSessionSlice","value","isAuthenticated","authorities","userProfile","setAuthenticated","setUnAuthenticated","UserSessionActions","UserSessionReducer","loadingMaskSlice","isOpened","message","showLoadingMask","hideLoadingMask","LoadingMaskReducer","commonStoresInitialState","SystemDataSourceType","autoLoad","data","url","SystemParameterTypes","SystemReportTypes","SystemWidgetTypes","SystemMailRecipientTypes","SystemDataSources","authority","SystemDataQueries","SystemEntityParameters","SystemAuthorities","SystemRoles","commonStoreSlice","initialState","setStoreData","storeKey","CommonStoreReducer","AppInfoSlice","documentTitle","apiBaseUrl","appName","appVersion","appLogo","muiPremiumKey","businessRoutes","businessNavigationItems","businessReduxReducers","businessCommonStoresMetaData","setAppInfo","AppInfoActions","AppLayout","UserSession","loadingMask","commonStores","AppInfo","store","configureStore","css","ref","insertAt","document","head","getElementsByTagName","style","createElement","type","firstChild","insertBefore","appendChild","styleSheet","cssText","createTextNode","LightThemeOptions","components","MuiCssBaseline","styleOverrides","palette","mode","primary","main","secondary","background","default","paper","DarkThemeOptions","useIsMobile","breakpoint","isMobile","setIsMobile","useState","window","innerWidth","useEffect","handleResize","addEventListener","removeEventListener","useLoadingMask","dispatch","useDispatch","show","hide","useAxios","mask","useSelector","axiosInstance","axios","create","baseURL","timeout","withCredentials","defaults","interceptors","response","use","error","status","toast","autoClose","handleGetRequest","async","props","endPointURI","parameters","undefined","showMask","loadingMessage","get","params","successCallBkFn","failureCallBkFn","handlePostRequest","post","handleDeleteRequest","delete","HandleDownloadHTTPPostPDF","responseType","resources","en","translation","common","ar","i18n","initReactI18next","init","lng","fallbackLng","AppBar","styled","MuiAppBar","shouldForwardProp","prop","theme","transition","transitions","easing","sharp","duration","leavingScreen","variants","open","width","marginLeft","marginRight","easeOut","enteringScreen","TopBar","_jsx","position","children","_jsxs","Toolbar","IconButton","color","onClick","edge","sx","mr","ml","display","FontAwesomeIcon","icon","Avatar","src","Typography","variant","noWrap","component","flex","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","findNavigationItemById","id","nodes","node","found","NavigationItems","label","actionPayload","path","DotIcon","Box","height","borderRadius","bgcolor","verticalAlign","zIndex","mx","StyledTreeItemRoot","TreeItem2Root","grey","treeItemClasses","groupTransition","spacing","applyStyles","CustomTreeItemContent","TreeItem2Content","flexDirection","marginBottom","marginTop","padding","paddingRight","dark","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","authoriedNavigationItems","RichTreeView","items","onItemClick","event","navigationItem","flexGrow","maxWidth","direction","maxHeight","overflowY","overflowX","slots","SideBar","useTheme","Drawer","flexShrink","boxSizing","anchor","textAlign","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","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","push","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","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","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","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","useApiActions","apiActionsProps","CommonStores","commonStoreKey","storeKeys","findAll","recordId","findById","findByIdParamName","save","deleteById","deleteByIdParamName","SYSTEM_ROUTES","MainContent","CacheProvider","Routes","route","Route","Component","Puller","MobileDrawer","toggleDrawer","newState","SwipeableDrawer","onOpen","swipeAreaWidth","disableSwipeToOpen","ModalProps","keepMounted","LoadingMask","Backdrop","CircularProgress","Login","appInfo","setUsername","password","setPassword","isLoginInProcess","setIsLoginInProcess","UserSessionState","handleLogin","userSession","loginTheme","checkUserSession","ThemeProvider","onKeyDown","loading","Main","loadCommonStores","Layout","BrowserRouter","ToastContainer","draggable","CssBaseline","App","LicenseInfo","setLicenseKey","themeOptions","library","add","fab","far","fas","BaseApp","businessStoreKey","businessReducerKey","Provider","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","labelId","ListItem","ListItemIcon","tabIndex","disableRipple","ListItemText","oldState","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"],"mappings":"2mIAEO,MAAMA,GAAe,IActBC,GAAiBC,EAAY,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,QCD9B,MAQMC,GAAmBnB,EAAY,CACnCC,KAAM,2BAT+B,CACrCmB,MAAO,CACLC,gBAAiB,KACjBC,YAAa,GACbC,YAAa,OAOfhB,SAAU,CACRiB,iBAAkB,CAACf,EAAOE,KACxBF,EAAMW,MAAQT,EAAOC,SAEvBa,mBAAqBhB,IACnBA,EAAMW,MAAQ,CACZC,iBAAiB,EACjBC,YAAa,GACbC,YAAa,UAMRG,GAAqBP,GAAiBH,QACnD,IAAeW,GAAAR,GAAiBD,QCvDhC,MAIMU,GAAmB5B,EAAY,CACnCC,KAAM,2BALoC,CAC1CmB,MAAO,CAAES,UAAU,EAAOC,QAAS,OAMnCvB,SAAU,CACRwB,gBAAiB,CACftB,EACAE,KAEAF,EAAMW,MAAMS,UAAW,EACvBpB,EAAMW,MAAMU,QAAUnB,EAAOC,SAE/BoB,gBAAkBvB,IAChBA,EAAMW,MAAMS,UAAW,EACvBpB,EAAMW,MAAMU,QAAU,UAKfC,gBAAEA,GAAeC,gBAAEA,IAAoBJ,GAAiBZ,QACrE,IAAeiB,GAAAL,GAAiBV,QC3BzB,MCiBMgB,GAAkD,CDhB7DC,qBAAsB,CACpBC,UAAU,EACVC,KAAM,CAAC,CAAEjB,MAAO,SAAW,CAAEA,MAAO,UAAY,CAAEA,MAAO,QACzDkB,IAAK,IAEPC,qBAAsB,CACpBH,UAAU,EACVE,IAAK,GACLD,KAAM,CACJ,CAAEjB,MAAO,YACT,CAAEA,MAAO,QACT,CAAEA,MAAO,QACT,CAAEA,MAAO,UACT,CAAEA,MAAO,cAGboB,kBAAmB,CACjBJ,UAAU,EACVE,IAAK,GACLD,KAAM,CAAC,CAAEjB,MAAO,SAAW,CAAEA,MAAO,UAAY,CAAEA,MAAO,eAE3DqB,kBAAmB,CACjBL,UAAU,EACVE,IAAK,GACLD,KAAM,CACJ,CAAEpC,KAAM,aACR,CAAEA,KAAM,eACR,CAAEA,KAAM,YACR,CAAEA,KAAM,QACR,CAAEA,KAAM,oBACR,CAAEA,KAAM,oBAGZyC,yBAA0B,CACxBN,UAAU,EACVE,IAAK,GACLD,KAAM,CAAC,CAAEpC,KAAM,MAAQ,CAAEA,KAAM,QAEjC0C,kBAAmB,CACjBP,UAAU,EACVC,KAAM,GACNO,UAAW,oBACXN,IAAK,yCAEPO,kBAAmB,CACjBT,UAAU,EACVC,KAAM,GACNO,UAAW,oBACXN,IAAK,8BAEPQ,uBAAwB,CACtBV,UAAU,EACVC,KAAM,GACNO,UAAW,oBACXN,IAAK,oCAEPS,kBAAmB,CACjBX,UAAU,EACVC,KAAM,GACNO,UAAW,oBACXN,IAAK,8BAEPU,YAAa,CACXZ,UAAU,EACVC,KAAM,GACNO,UAAW,oBACXN,IAAK,0BC9CHW,GAAmBjD,EAAY,CACnCC,KAAM,cACNiD,aAAchB,GACd3B,SAAU,CACR,YAAA4C,CAAa1C,EAAOE,GAClBF,EAAME,EAAOC,QAAQwC,UAAUf,KAAO1B,EAAOC,QAAQyB,IACtD,MAIQc,aAAEA,IAAiBF,GAAiBjC,QACjD,IAAeqC,GAAAJ,GAAiB/B,QCZhC,MAeMoC,GAAetD,EAAY,CAC/BC,KAAM,UACNiD,aAjBgC,CAChC9B,MAAO,CACLmC,cAAe,KACfC,WAAY,KACZC,QAAS,KACTC,WAAY,KACZC,QAAS,KACTC,cAAe,KACfC,eAAgB,GAChBC,wBAAyB,GACzBC,sBAAuB,CAAE,EACzBC,6BAA8B,CAAE,IAOlCzD,SAAU,CACR0D,WAAY,CAACxD,EAAOE,KAClBF,EAAMW,MAAQT,EAAOC,YAKdsD,GAAiBZ,GAAatC,QCxC3C,MAAMT,GAAW,CACf4D,UAAWlD,GACXmD,YAAazC,GACb0C,YAAapC,GACbqC,aAAcjB,GACdkB,QDoCajB,GAAapC,SC3BrB,MAAMsD,GAAQC,EAAe,CAClCvD,QAASX,MCtBX,SAAqBmE,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,kTCvBO,MAAMe,GAAkC,CAC7CC,WAAY,CACVC,eAAgB,CACdC,eAAgB,8PAepBC,QAAS,CACPC,KAAM,QACNC,QAAS,CACPC,KAAM,WAERC,UAAW,CACTD,KAAM,WAERE,WAAY,CACVC,QAAS,UACTC,MAAO,aC5BAC,GAAiC,CAC5CX,WAAY,CACVC,eAAgB,CACdC,eAAgB,8PAepBC,QAAS,CACPC,KAAM,OACNC,QAAS,CACPC,KAAM,WAERC,UAAW,CACTD,KAAM,aCxBCM,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,GCPHS,GAAiB,KACrB,MAAMC,EAAWC,IAOjB,MAAO,CAAEC,KANKtF,IACZoF,EAASnF,GAAgBD,KAKZuF,KAHF,KACXH,EAASlF,SCMPsF,GAAW,KACf,MAAMC,EAAON,KACPzD,EAAagE,GAChB/G,GAAqBA,EAAM8D,QAAQnD,MAAMoC,aAEtCiE,EAAgBC,GAAMC,OAAO,CACjCC,QAASpE,EACTqE,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,SAAS5F,MAE3BgG,GAAMF,MACJ,6DAGG,WAgMX,MAAO,CACLI,iBA9LuBC,MACvBC,EAAoB,CAAEC,YAAa,GAAIC,WAAY,CAAA,WAG9BC,IAAnBH,EAAMI,UACY,MAAlBJ,EAAMI,WACa,IAAnBJ,EAAMI,UAENtB,EAAKH,KAAKqB,EAAMK,gBAElB,MAAMb,QAAsBR,EAAcsB,IAAIN,EAAMC,YAAa,CAC/DM,OAAQ,IAAKP,EAAME,YACnBb,iBAAiB,IAUnB,YANqBc,IAAnBH,EAAMI,UACY,MAAlBJ,EAAMI,WACa,IAAnBJ,EAAMI,UAENtB,EAAKF,OAEU,UAAbY,QAE0BW,IAA1BH,EAAMQ,iBACmB,MAAzBR,EAAMQ,iBAENR,EAAMQ,gBAAgBhB,GAEjBA,SAGqBW,IAA1BH,EAAMS,iBACmB,MAAzBT,EAAMS,iBAENT,EAAMS,gBAAgBjB,GAEjB,UA0JTkB,kBApFwBX,MACxBC,EAAoB,CAAEC,YAAa,GAAIC,WAAY,CAAE,EAAEtG,KAAM,CAAA,WAGxCuG,IAAnBH,EAAMI,UACY,MAAlBJ,EAAMI,WACa,IAAnBJ,EAAMI,UAENtB,EAAKH,KAAKqB,EAAMK,gBAElB,IAAIb,QAAsBR,EAAc2B,KACtCX,EAAMC,YACND,EAAMpG,KACN,CACE2G,OAAQP,EAAME,aAUlB,YANqBC,IAAnBH,EAAMI,UACY,MAAlBJ,EAAMI,WACa,IAAnBJ,EAAMI,UAENtB,EAAKF,OAEU,UAAbY,QAE0BW,IAA1BH,EAAMQ,iBACmB,MAAzBR,EAAMQ,iBAENR,EAAMQ,gBAAgBhB,GAEjBA,SAGqBW,IAA1BH,EAAMS,iBACmB,MAAzBT,EAAMS,iBAENT,EAAMS,gBAAgBjB,GAEjB,UA8CToB,oBA3C0Bb,MAC1BC,EAAoB,CAAEC,YAAa,GAAIC,WAAY,CAAA,WAG9BC,IAAnBH,EAAMI,UACY,MAAlBJ,EAAMI,WACa,IAAnBJ,EAAMI,UAENtB,EAAKH,KAAKqB,EAAMK,gBAElB,IAAIb,QAAsBR,EAAc6B,OAAOb,EAAMC,YAAa,CAChEM,OAAQ,IACHP,EAAME,cAUb,YANqBC,IAAnBH,EAAMI,UACY,MAAlBJ,EAAMI,WACa,IAAnBJ,EAAMI,UAENtB,EAAKF,OAEU,UAAbY,QAE0BW,IAA1BH,EAAMQ,iBACmB,MAAzBR,EAAMQ,iBAENR,EAAMQ,gBAAgBhB,GAEjBA,SAGqBW,IAA1BH,EAAMS,iBACmB,MAAzBT,EAAMS,iBAENT,EAAMS,gBAAgBjB,GAEjB,UAOTsB,0BAxJgCf,MAChCC,EAAoB,CAAEC,YAAa,GAAIC,WAAY,CAAE,EAAEtG,KAAM,CAAA,WAGxCuG,IAAnBH,EAAMI,UACY,MAAlBJ,EAAMI,WACa,IAAnBJ,EAAMI,UAENtB,EAAKH,KAAKqB,EAAMK,gBAElB,MAAMb,QAAsBR,EAAc2B,KACxCX,EAAMC,YACND,EAAMpG,KACN,CACEmH,aAAc,SAUlB,YANqBZ,IAAnBH,EAAMI,UACY,MAAlBJ,EAAMI,WACa,IAAnBJ,EAAMI,UAENtB,EAAKF,OAEU,UAAbY,QAE0BW,IAA1BH,EAAMQ,iBACmB,MAAzBR,EAAMQ,iBAENR,EAAMQ,gBAAgBhB,GAEjBA,SAGqBW,IAA1BH,EAAMS,iBACmB,MAAzBT,EAAMS,iBAENT,EAAMS,gBAAgBjB,GAEjB,ytECvJN,MCCDwB,GAAY,CAChBC,GAAI,CAAEC,YDFqB,IACxBC,w1gBCEHC,GAAI,CAAEF,YCFoB,IACvBC,gugBCDLE,GAAK5B,IAAI6B,IAAkBC,KAAK,CAC9BP,UAAWA,GACXQ,IAAK7J,aAAaC,QAAQ,aAAe,KACzC6J,YAAa,OAGR,MCUDC,GAASC,EAAOC,GAAW,CAC/BC,kBAAoBC,GAAkB,SAATA,GADhBH,EAEC,EAAGI,YACjB,MAAMrG,EAAYqD,GAAa/G,GAAqBA,EAAM0D,YACpDqC,EAAWF,KACjB,MAAO,CACLmE,WAAYD,EAAME,YAAY/C,OAAO,CAAC,SAAU,SAAU,CACxDgD,OAAQH,EAAME,YAAYC,OAAOC,MACjCC,SAAUL,EAAME,YAAYG,SAASC,gBAEvCC,SAAU,CACR,CACEtC,MAAO,EAAGuC,UAAWA,EACrBhG,MAAO,CACLiG,MAAQzE,OAA8CoC,EAAnC,qBACnBsC,WACG1E,GAAuC,QAA3BrC,EAAU7D,kBAEnBsI,EADA,QAENuC,YACG3E,GAAuC,QAA3BrC,EAAU7D,kBAEnBsI,EADA,QAEN6B,WAAYD,EAAME,YAAY/C,OAAO,CAAC,SAAU,SAAU,CACxDgD,OAAQH,EAAME,YAAYC,OAAOS,QACjCP,SAAUL,EAAME,YAAYG,SAASQ,wBAQ3CC,GAAmB,KACvB,MAAM/G,EAAUiD,GAAa/G,GAAqBA,EAAM8D,QAAQnD,QAC1D+C,EAAYqD,GAAa/G,GAAqBA,EAAM0D,YACpDC,EAAcoD,GAAa/G,GAAqBA,EAAM2D,eACtDmE,iBAAEA,GAAqBjB,KACvBd,EAAWF,KACXY,EAAWC,IAYjB,OACEoE,EAACpB,GAAM,CAACqB,SAAS,QAAQR,KAAM7G,EAAUjE,cAAauL,SACpDC,EAACC,GAAO,CAAAF,SAAA,CACNF,EAACK,GACCC,MAAM,UAAS,aACJ,cACXC,QATc,KACpB5E,EAASnG,GAAiBP,uBASpBuL,KAAK,QACLC,GAAI,CACF,CACEC,GAA+B,QAA3B9H,EAAU7D,aAAyB,OAAIsI,EAC3CsD,GAA+B,QAA3B/H,EAAU7D,aAAyB,OAAIsI,GAE7CzE,EAAUjE,eAAiB,CAAEiM,QAAS,SACvCV,SAEDF,EAACa,GAAgB,CAAAC,KAAK,WAExBd,EAACe,EAAM,CAACC,IAAKhI,EAAQZ,QAASqI,GAAI,CAAEb,YAAa,EAAGD,WAAY,KAChEK,EAACiB,EAAU,CAACC,QAAQ,KAAKC,UAAOC,UAAU,MAAMX,GAAI,CAAEY,KAAM,GAAGnB,SAC5DjF,EAAW,GAAKjC,EAAQd,UAE3B8H,EAACK,EACC,CAAAC,MAAM,UACNC,QAAS,KACP5E,EACEnG,GAAiBF,aACS,UAAxBsD,EAAUhE,UAAwB,OAAS,UAG/CC,aAAayM,QACX,YACwB,UAAxB1I,EAAUhE,UAAwB,OAAS,UAE9CsL,SAEwB,UAAxBtH,EAAUhE,UACToL,EAACa,GAAgB,CAAAC,KAAK,SAEtBd,EAACa,GAAe,CAACC,KAAM,CAAES,OAAQ,MAAOC,SAAU,WAGtDxB,EAACK,EAAU,CACTC,MAAM,UACNC,QAAS,KACP,IAAIkB,EAAiC,OAAlBlD,GAAKmD,SAAoB,KAAO,KD1GjC,IAAChD,IC2GJ+C,ED1GzBlD,GAAKoD,eAAejD,GACpB7J,aAAayM,QAAQ,WAAY5C,GC0GvB/C,EACEnG,GAAiBD,gBACE,OAAjBkM,EAAwB,MAAQ,kBAKtCzB,EAACa,GAAgB,CAAAC,KAAK,eAExBd,EAACe,EAAM,CAAA,GACPf,EAAK,MAAA,CAAAvG,MAAO,CAAEkG,WAAY,EAAGC,YAAa,GAAGM,SAC1CjF,EAAW,GAAKpC,EAAYhD,OAAOG,aAAa4L,WAEnD5B,EAACK,EAAW,CAAAC,MAAM,UAAUC,QAvEbtD,UACnB,UACQD,EAAiB,CAAEG,YAAa,oBACtC,MAAOP,GACPiF,QAAQC,IAAI,eAAgBlF,GAE9BjB,EAASxF,GAAmBD,uBAkEtBgK,SAAAF,EAACa,GACC,CAAAkB,SAAqC,QAA3BnJ,EAAU7D,aAAyB,SAAMsI,EACnDyD,KAAK,qCCnIJkB,GAAenD,EAAO,MAAPA,EAAc,EAAGI,YAAa,CACxD2B,QAAS,OACTqB,WAAY,YAGThD,EAAMiD,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,MAAMnK,EAAcoD,GAAa/G,GAAqBA,EAAM2D,cAiB5D,MAAO,CAAEA,cAAaoK,iBAhBIC,IACxB,GAAIrK,GAAahD,OAAOE,YAItB,IAAK,IAAIoN,KAAoBtK,EAAYhD,MAAME,YAC7C,GACkC,sBAAhCoN,GAAkB9L,WAClB8L,GAAkB9L,YAAc6L,EAEhC,OAAO,EAIb,OAAO,KCHEE,GAAyB,CACpCC,EACAC,KAEA,IAAK,MAAMC,KAAQD,EAAO,CACxB,GAAIC,EAAKF,KAAOA,EAAI,OAAOE,EAC3B,GAAIA,EAAKrD,SAAU,CACjB,MAAMsD,EAAQJ,GAAuBC,EAAIE,EAAKrD,UAC9C,GAAIsD,EAAO,OAAOA,KAMXC,GAA6D,IC3BI,CCA5E,CACEJ,GAAI,QACJK,MAAO,wBACPrM,UAAW,oBACXyJ,KAAM,OACNZ,SAAU,CACR,CACEmD,GAAI,yBACJK,MAAO,oBACP5C,KAAM,OACNZ,SAAU,CACR,CACEmD,GAAI,sCACJK,MAAO,sBACP5C,KAAM,QACN1L,OAAQ,aACRuO,cAAe,CAAEC,KAAM,wBAEzB,CACEP,GAAI,iDACJK,MAAO,kCACP5C,KAAM,kBACN1L,OAAQ,aACRuO,cAAe,CAAEC,KAAM,qCAI7B,CACEP,GAAI,iBACJK,MAAO,0BACP5C,KAAM,SACNZ,SAAU,CACR,CACEmD,GAAI,2BACJK,MAAO,mBACP5C,KAAM,MACN1L,OAAQ,aACRuO,cAAe,CAAEC,KAAM,sBAEzB,CACEP,GAAI,aACJK,MAAO,cACP5C,KAAM,MACN1L,OAAQ,aACRuO,cAAe,CAAEC,KAAM,gBAEzB,CACEP,GAAI,0BACJK,MAAO,kBACP5C,KAAM,OACN1L,OAAQ,aACRuO,cAAe,CAAEC,KAAM,sBAI7B,CACEP,GAAI,iBACJK,MAAO,oBACP5C,KAAM,OACNZ,SAAU,CACR,CACEmD,GAAI,sCACJK,MAAO,+BACP5C,KAAM,OACN1L,OAAQ,aACRuO,cAAe,CAAEC,KAAM,gCAEzB,CACEP,GAAI,iCACJK,MAAO,0BACP5C,KAAM,IACN1L,OAAQ,aACRuO,cAAe,CAAEC,KAAM,2BAEzB,CACEP,GAAI,2BACJK,MAAO,oBACP5C,KAAM,YACN1L,OAAQ,aACRuO,cAAe,CAAEC,KAAM,sBAEzB,CACEP,GAAI,qCACJK,MAAO,+BACP5C,KAAM,aACN1L,OAAQ,aACRuO,cAAe,CAAEC,KAAM,+BAEzB,CACEP,GAAI,wBACJK,MAAO,gBACP5C,KAAM,OACN1L,OAAQ,aACRuO,cAAe,CAAEC,KAAM,kBAEzB,CACEP,GAAI,kCACJK,MAAO,2BACP5C,KAAM,gBACN1L,OAAQ,aACRuO,cAAe,CAAEC,KAAM,4BAEzB,CACEP,GAAI,2BACJK,MAAO,oBACP5C,KAAM,cACN1L,OAAQ,aACRuO,cAAe,CAAEC,KAAM,qBAEzB,CACEP,GAAI,wBACJK,MAAO,gBACP5C,KAAM,YACN1L,OAAQ,aACRuO,cAAe,CAAEC,KAAM,kBAEzB,CACEP,GAAI,2BACJK,MAAO,mBACP5C,KAAM,uBACN1L,OAAQ,aACRuO,cAAe,CAAEC,KAAM,qBAEzB,CACEP,GAAI,8BACJK,MAAO,uBACP5C,KAAM,WACN1L,OAAQ,aACRuO,cAAe,CAAEC,KAAM,wBAEzB,CACEP,GAAI,8BACJK,MAAO,sBACP5C,KAAM,OACN1L,OAAQ,aACRuO,cAAe,CAAEC,KAAM,0BAI7B,CACEP,GAAI,iBACJK,MAAO,oBACP5C,KAAM,KACNZ,SAAU,CACR,CACEmD,GAAI,gCACJK,MAAO,oCACP5C,KAAM,iBACN1L,OAAQ,aACRuO,cAAe,CAAEC,KAAM,mCAEzB,CACEP,GAAI,8BACJK,MAAO,iCACP5C,KAAM,qBACN1L,OAAQ,aACRuO,cAAe,CAAEC,KAAM,iCAEzB,CACEP,GAAI,0BACJK,MAAO,4BACP5C,KAAM,OACN1L,OAAQ,aACRuO,cAAe,CAAEC,KAAM,+BAK7B,CACEP,GAAI,eACJK,MAAO,gBACP5C,KAAM,aACN1L,OAAQ,aACRuO,cAAe,CAAEC,KAAM,sBC9I/B,SAASC,KACP,OACE7D,EAAC8D,GAAG,CACFrD,GAAI,CACFf,MAAO,EACPqE,OAAQ,EACRC,aAAc,MACdC,QAAS,eACTrD,QAAS,eACTsD,cAAe,SACfC,OAAQ,EACRC,GAAI,IAIZ,CAQA,MAAMC,GAAqBxF,EAAOyF,GAAPzF,EAAsB,EAAGI,YAAa,CAC/DqB,MAAOrB,EAAM3E,QAAQiK,KAAK,KAC1BtE,SAAU,WACV,CAAC,MAAMuE,GAAgBC,mBAAoB,CACzC9E,WAAYV,EAAMyF,QAAQ,SAEzBzF,EAAM0F,YAAY,QAAS,CAC5BrE,MAAOrB,EAAM3E,QAAQiK,KAAK,WAIxBK,GAAwB/F,EAAOgG,GAAPhG,EAAyB,EAAGI,YAAa,CACrE6F,cAAe,cACfd,aAAc/E,EAAMyF,QAAQ,IAC5BK,aAAc9F,EAAMyF,QAAQ,IAC5BM,UAAW/F,EAAMyF,QAAQ,IACzBO,QAAShG,EAAMyF,QAAQ,IACvBQ,aAAcjG,EAAMyF,QAAQ,GAC5B,kBAAqB,CACnB,2EACE,CACEpE,MAAOrB,EAAM3E,QAAQE,QAAQ2K,QAC1BlG,EAAM0F,YAAY,QAAS,CAC5BrE,MAAOrB,EAAM3E,QAAQE,QAAQC,QAGnC,YAAa,CACX2K,QAAS,KACTxE,QAAS,QACTX,SAAU,WACVoF,KAAM,OACNC,IAAK,OACLvB,OAAQ,oBACRrE,MAAO,QACP6F,gBAAiBtG,EAAM3E,QAAQiK,KAAK,QACjCtF,EAAM0F,YAAY,QAAS,CAC5BY,gBAAiBtG,EAAM3E,QAAQiK,KAAK,SAI1C,UAAW,CACTgB,gBAAiBC,EAAMvG,EAAM3E,QAAQE,QAAQC,KAAM,IACnD6F,MAAO,WACJrB,EAAM0F,YAAY,QAAS,CAC5BrE,MAAOrB,EAAM3E,QAAQE,QAAQC,QAGjC,4DAA+D,CAC7D8K,gBAAiBtG,EAAM3E,QAAQE,QAAQ2K,KACvC7E,MAAOrB,EAAM3E,QAAQE,QAAQiL,gBAC1BxG,EAAM0F,YAAY,QAAS,CAC5BY,gBAAiBtG,EAAM3E,QAAQE,QAAQC,YAKvCiL,GAAmBC,GAASC,IAElC,SAASC,GAAoB3I,GAC3B,MAAMzD,EAAQqM,GAAU,CACtBC,GAAI,CACFC,QAAS9I,EAAM+I,GAAK,EAAI,EACxBC,UAAW,iBAAiBhJ,EAAM+I,GAAK,EAAI,aAI/C,OAAOjG,EAAC0F,GAAiB,CAAAjM,MAAOA,KAAWyD,GAC7C,CAEA,MAAMiJ,GAA0BtH,EAAOoC,GAAPpC,CAAmB,CACjDyB,MAAO,UACP8F,WAAY,MASd,SAASC,IAAYvF,KACnBA,EAAIwF,WACJA,EAAUpG,SACVA,KACGqG,IAEH,MAAMhE,EAAEA,GAAMiE,KACRC,EAAiBxK,GAAa/G,GAAqBA,EAAM0D,YAC/D,OACEuH,EAACuG,OACKH,EACJ9F,GAAI,CACFG,QAAS,OACTqB,WAAY,SACZgD,QAAS,GACV/E,SAAA,CAEDF,EAACa,GACC,CAAApH,MAAO,CACLmG,YAA6C,QAAhC6G,EAAe1R,aAAyB,OAAIsI,EACzDsC,WAA4C,QAAhC8G,EAAe1R,aAAyB,OAAIsI,EACxDsJ,SAAU,UAEZ7F,KAAMA,IAERd,EAACmG,GAAwB,CAAAjF,QAAQ,QAAQT,GAAI,CAAEkG,SAAU,IAAIzG,SAC1DqC,EAAErC,KAEJoG,GAActG,EAAC6D,GAAU,MAGhC,CAEA,MAAM+C,GAAgBC,GAChBnE,MAAMC,QAAQkE,GACTA,EAAchE,OAAS,GAAKgE,EAAcC,KAAKF,IAEjDG,QAAQF,GAOXG,GAAiBC,EAAMC,YAAW,SACtChK,EACA9D,GAEA,MAAMiK,GAAEA,EAAE8D,OAAEA,EAAMzD,MAAEA,EAAK0D,SAAEA,EAAQlH,SAAEA,KAAaqG,GAAUrJ,GACtDmK,aACJA,EAAYC,gBACZA,EAAeC,sBACfA,EAAqBC,iBACrBA,EAAgBC,cAChBA,EAAaC,wBACbA,EAAuBC,2BACvBA,EAA0B9K,OAC1BA,EAAM+K,UACNA,GACEC,GAAa,CAAExE,KAAI8D,SAAQjH,WAAUwD,QAAO0D,WAAUU,QAAS1O,IAC7D2O,EAAOH,EAAU9S,QAAQqS,GACzBb,EAAaM,GAAa1G,GAChC,OACEF,EAACgI,GAAiB,CAACb,OAAQA,WACzBhH,EAACkE,OAAuBgD,EAAad,GAAMrG,SAAA,CACzCC,EAACyE,GAAqB,IAChB0C,EAAgB,CAClBW,UAAWnF,GAAK,UAAW,CACzB,eAAgBjG,EAAOqL,SACvB,eAAgBrL,EAAOsL,SACvB,cAAetL,EAAOuL,QACtB,eAAgBvL,EAAOuK,aAEzBlH,SAAA,CAEFF,EAACqI,GAA2B,IAAAd,IAAuBrH,SACjDF,EAACsI,GAAc,CAAAzL,OAAQA,MAEzBmD,EAACuI,GAAiB,IAAKf,MACvBxH,EAACqG,GACK,IAAAoB,EAAc,CAChB3G,KAAMiH,GAAMjH,MAAQ,OACpBwF,WAAYA,GAAczJ,EAAOqL,aAGrClI,EAACwI,OAAgCb,SAElCzH,GAAYF,EAAC6F,GAAwB,IAAA6B,UAI9C,IAEc,SAAUe,KACtB,MAAMC,EAAWC,KACXlC,EAAiBxK,GAAa/G,GAAqBA,EAAM0D,YACzDL,EAA0B0D,GAC7B/G,GAAqBA,EAAM8D,QAAQnD,MAAM0C,0BAE3BqD,IACjB,MAAMX,EAAWF,MACXkI,iBAAEA,GAAqBD,KACvB4F,EAAc9R,GACXA,EACJ+R,QACEd,QACoB1K,IAAnB0K,EAAK1Q,WACa,MAAlB0Q,EAAK1Q,WACL4L,EAAiB8E,EAAK1Q,aAEzByR,KAAKf,IACAA,EAAK7H,WACP6H,EAAK7H,SAAW0I,EAAWb,EAAK7H,WAE3B6H,KAIPgB,EAAwB,IACzBtF,MACAlL,GAGCyQ,EAA2BJ,EAAWG,GAE5C,OACE/I,EAACiJ,GAAY,CACXC,MAAOF,EACPG,YAAa,CAACC,EAAOjC,KACnB,MAAMkC,EAAiBjG,GAAuB+D,EAAQ1D,IAEzB,eAA3B4F,GAAgBjU,QACiB,MAAjCiU,GAAgB1F,oBACatG,IAA5BgM,EAAenJ,UACc,OAA5BmJ,EAAenJ,UACmB,GAAlCmJ,EAAenJ,SAAS2C,QAE1B6F,EAASW,GAAgB1F,eAAeC,MAAQ,KAIpDnD,GAAI,CACFsD,OAAQ,cACRuF,SAAU,EACVC,SAAUhV,GACViV,UAAW/C,EAAe1R,aAC1B0U,UAAWxO,EAAW,SAAMoC,EAC5BqM,UAAW,OACXC,UAAW,QAEbC,MAAO,CAAE7B,KAAMf,KAGrB,CCrRA,MAAM6C,GAAoB,KACxB,MAAM7Q,EAAUiD,GAAa/G,GAAqBA,EAAM8D,QAAQnD,QAC1DoJ,EAAQ6K,IACRlR,EAAYqD,GAAa/G,GAAqBA,EAAM0D,YACpD+C,EAAWC,IAIjB,OACEuE,EAAC4J,GAAM,CACLtJ,GAAI,CACFf,MAAOnL,GACPyV,WAAY,EACZ,qBAAsB,CACpBtK,MAAOnL,GACP0V,UAAW,eAGf/I,QAAQ,aACRgJ,OAAmC,QAA3BtR,EAAU7D,aAAyB,OAAS,QACpD0K,KAAM7G,EAAUjE,cAEhBuL,SAAA,CAAAC,EAAC6B,GACC,CAAA9B,SAAA,CAAAC,EAAC2D,EAAI,CAAArD,GAAI,CAAEf,MAAO,QAAQQ,SAAA,CACxBF,EAACiB,EAAU,CACTX,MAAM,UACNG,GAAI,CACFf,MAAO,OACPyK,UAAW,SACXxD,SAAU,GACVP,WAAY,QACblG,SAAA,mBAIHC,EAAC2D,EAAG,CACFrD,GAAI,CACFG,QAAS,OACTqB,WAAY,SACZG,eAAgB,eAChB4C,UAAW,GACZ9E,SAAA,CAEDF,EAACiB,EAAU,CAACR,GAAI,CAAEkG,SAAU,IAAMrG,MAAM,eAAcJ,SACnDlH,EAAQd,UAEXiI,EAACc,EAAW,CAAAR,GAAI,CAAEkG,SAAU,IAAMrG,MAAM,eACnCJ,SAAA,CAAA,KAAAlH,EAAQb,oBAIjB6H,EAACK,GAAU,CAACE,QA9CI,KACpB5E,EAASnG,GAAiBP,uBA8CnBiL,SAAoB,QAApBjB,EAAMuK,UACLxJ,EAACa,GAAgB,CAAAC,KAAK,eAEtBd,EAACa,GAAgB,CAAAC,KAAK,qBAI5Bd,EAACoK,OACDpK,EAACyI,GAAiB,CAAA,OCtEX4B,GAAWC,GAAY,CAClCC,IAAK,SACLC,cAAe,CAACC,GAAUC,MAGfC,GAAWL,GAAY,CAClCC,IAAK,QCOMK,GAAyB1N,IACpC,MAAOuC,EAAMoL,GAAW1P,GAAkB,IACpCoH,EAAEA,GAAMiE,KAiCd,MAAO,CAAEsE,mBAhC4B,IAEjC3K,EAAC4K,EAAM,CAACtL,KAAMA,YACZO,EAACgL,YAAa9N,EAAM+N,QACpBjL,EAACkL,EAAa,CAAAhL,SACZF,EAACmL,EAAiB,CAAAjL,SAAEhD,EAAMkO,SAE5BjL,EAACkL,EAAa,CAAAnL,SAAA,CACZF,EAACsL,EAAM,CACLpK,QAAQ,YACRZ,MAAM,UACNC,QAAS,KACPsK,GAAQ,IACT3K,SAEAqC,EAAE,cAELvC,EAACsL,EAAM,CACLpK,QAAQ,YACRZ,MAAM,QACNC,QAAS,KACPrD,EAAMqO,uBACNV,GAAQ,IAEVW,WAAS,EAAAtL,SAERqC,EAAE,qBAMgB9C,OAAMoL,YC5C/BY,GACJC,IAEA,MAAMnJ,EAAEA,GAAMiE,KACRmF,EAAU3I,MACV8H,mBAAEA,EAAkBD,QAAEA,GAAYD,GAAsB,CAC5DQ,KAAM7I,EAAEmJ,GAAWE,qBAAuB,uBAC1CX,MAAO1I,EAAE,gBACTgJ,qBAAsBtO,gBACdyO,GAAWG,SACfH,EAAUI,yBACVJ,EAAUK,6BAERL,GAAWM,YACbN,EAAUM,gBAIhB,IAAIC,GAAkB,EAKtB,GAJIP,EAAUrU,YACZ4U,EAAkBN,EAAQ1I,iBAAiByI,EAAUrU,YAGnD4U,EACF,OACE9L,EAAA+L,EAAA,CAAAhM,SAAA,CACEF,EAAC8K,EAAqB,CAAA,GACtB3K,EAACmL,EACC,CAAA/K,QAAStD,UACP,GACEyO,GAAWI,0BACXJ,GAAWI,yBAAyBjJ,OAAS,EAC7C,CACA,GAAI6I,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,mBAIdlP,GAAMF,MAAM2F,EAAE,0CAGlBrB,QACEwK,GAAWhI,MACP,WACAgI,GAAWY,iBAAiBC,oBAC5Bb,EAAUY,gBAAgBC,oBAC1B,OAENC,KAAK,QACLlM,MAAOoL,GAAWY,iBAAiBG,mBAAqB,UAASvM,SAAA,CAEhEwL,GAAW5K,KACVd,EAACa,GACC,CAAApH,MAAO,CAAEmG,YAAa,EAAGD,WAAY,GACrCmB,KAAM4K,EAAU5K,OAGlBd,EAAKkM,EAAA,CAAA,GAENR,GAAWhI,MAAQnB,EAAEmJ,EAAUhI,OAAS1D,EAAAkM,EAAA,WCjFtCQ,GAAc,aACdC,GAAmB,sBCiB1BC,GAAuC1P,IAC3C,MAAMqF,EAAEA,GAAMiE,KACd,OACExG,EAAC6M,GAAoB,CAACC,YAAaC,GAAa7M,SAC9CF,EAACgN,GACC,CAAAnX,MACiB,MAAfqH,EAAMrH,YAAiCwH,IAAhBH,EAAMrH,OAAuC,KAAhBqH,EAAMrH,MACtDoX,GAAO/P,EAAMrH,MAAOqH,GAAOgQ,QAAUR,IACrC,KAENjM,GAAIvD,EAAMuD,GACViD,MAAOnB,EAAErF,EAAMwG,OACfwJ,OAAQhQ,GAAOgQ,QAAUR,GACzBtF,SAAUlK,EAAMkK,SAChB+F,SAAWC,IACT,IAAIC,EAAI,KACW,MAAfD,GAAuBA,EAAYE,YACrCD,EAAID,EAAYF,OAAOhQ,GAAOgQ,QAAUR,UAGbrP,IAA3BH,EAAMqQ,kBACoB,MAA1BrQ,EAAMqQ,kBAENrQ,EAAMqQ,iBAAiBF,IAG3BG,UAAW,CACTC,UAAW,CACTC,gBAAiB,CAAEC,QAAQ,GAC3BzM,QAAS,WACT0M,SAAU1Q,EAAM0Q,SAChBhR,WACyBS,IAAvBH,EAAM2Q,cAAoD,MAAtB3Q,EAAM2Q,aAC5CC,gBACyBzQ,IAAvBH,EAAM2Q,cAAoD,MAAtB3Q,EAAM2Q,aACxC7N,EAAAkM,EAAA,CAAAhM,SAAGqC,EAAErF,EAAM2Q,gBAEX7N,eCrCV+N,GAA+C7Q,IACnD,MAAMqF,EAAEA,GAAMiE,KACd,OACExG,EAAC6M,GAAoB,CAACC,YAAaC,GAAa7M,SAC9CF,EAACgO,GACC,CAAAnY,MACiB,MAAfqH,EAAMrH,YAAiCwH,IAAhBH,EAAMrH,OAAuC,KAAhBqH,EAAMrH,MACtDoX,GAAO/P,EAAMrH,MAAOqH,GAAOgQ,QAAUP,IACrC,KAENjJ,MAAOnB,EAAErF,EAAMwG,OACfjD,GAAIvD,EAAMuD,GACVyM,OAAQhQ,GAAOgQ,QAAUP,GACzBvF,SAAUlK,EAAMkK,SAChB+F,SAAWC,IACT,IAAIC,EAAI,KACW,MAAfD,GAAuBA,EAAYE,YACrCD,EAAID,EAAYF,OAAOhQ,GAAOgQ,QAAUP,UAGbtP,IAA3BH,EAAMqQ,kBACoB,MAA1BrQ,EAAMqQ,kBAENrQ,EAAMqQ,iBAAiBF,IAG3BG,UAAW,CACTC,UAAW,CACTvM,QAAS,WACT0M,SAAU1Q,EAAM0Q,SAChBhR,WACyBS,IAAvBH,EAAM2Q,cAAoD,MAAtB3Q,EAAM2Q,aAC5CC,gBACyBzQ,IAAvBH,EAAM2Q,cAAoD,MAAtB3Q,EAAM2Q,aACxC7N,EAAAkM,EAAA,CAAAhM,SAAGqC,EAAErF,EAAM2Q,gBAEX7N,eCpCViO,GAAqC/Q,IACzC,MAAMgR,EAAiBjS,GAAa/G,GAAqBA,EAAM0D,aACzD2J,EAAEA,GAAMiE,KASd,OACExG,EAACmO,EACC,CAAA1N,GAAIvD,EAAMuD,GACV5K,MAXa,CAACwX,IAChB,IAAK,IAAIe,KAAUlR,EAAMmR,QACvB,GAAID,EAAOlR,EAAMoR,aAAejB,EAC9B,OAAOe,EAGX,OAAO,MAKEG,CAASrR,EAAMrH,OACtBwY,QAASnR,EAAMmR,QACfjH,SAAUlK,EAAMkK,SAChB+F,SAAU,CAAC/D,EAAOoF,KAChB,QAC6BnR,IAA3BH,EAAMqQ,kBACoB,MAA1BrQ,EAAMqQ,iBAEN,GAAgB,MAAZiB,EAAkB,CACpB,IAAInB,EAAImB,EAAStR,EAAMoR,YACvBpR,EAAMqQ,iBAAiBF,EAAGmB,QAE1BtR,EAAMqQ,iBAAiB,KAAM,OAInCkB,aAAW,EACXC,mBAAiB,EACjBC,eAAiBP,GACE,MAAVA,EAAiB7L,EAAE6L,EAAOlR,EAAM0R,eAAiB,GAE1DC,aAAc,CAACC,EAAQV,IAEnBpO,EAAQ,KAAA,IAAA8O,EACL5O,SAAU,MAAVkO,EAAiB7L,EAAE6L,EAAOlR,EAAM0R,eAAiB,KAIxDhF,MAAO,CACLmF,OAAS7R,GACP8C,EAACgP,EACK,IAAA9R,EACJzD,MAAO,IAAKyD,EAAMzD,MAAO+P,UAAW0E,EAAenZ,iBAIzDka,YAAcxR,GAEVuC,EAACkP,EAAS,IACJzR,EACJmQ,SAAU1Q,EAAM0Q,WAAY,EAC5B1M,QAAQ,WACRwM,gBAAiB,CAAEC,QAAQ,GAC3BjK,MAAOnB,EAAErF,EAAMwG,OACf9G,MACwB,MAAtBM,EAAM2Q,mBAA+CxQ,IAAvBH,EAAM2Q,aAItCC,WACwB,MAAtB5Q,EAAM2Q,mBAA+CxQ,IAAvBH,EAAM2Q,aAChCtL,EAAErF,EAAM2Q,cACR,QCtEZsB,GAAqCjS,IACzC,MAAMqF,EAAEA,GAAMiE,KACd,OACExG,EAACoP,EACC,CAAA3O,GAAIvD,EAAMuD,GACV2G,SAAUlK,EAAMkK,WAAY,EAC5BwG,SAAU1Q,EAAM0Q,WAAY,EAC5ByB,QACErP,EAACsP,EACC,CAAAC,QACErS,GAAOsS,cAAgBtS,EAAMrH,OACb,SAAhBqH,EAAMrH,OACS,KAAfqH,EAAMrH,MAIRsX,SAAW7K,SAEoBjF,IAA3BH,EAAMqQ,kBACoB,MAA1BrQ,EAAMqQ,mBAEFjL,EAAEmN,OAAOF,aAEclS,IAAvBH,EAAMsS,cACgB,MAAtBtS,EAAMsS,aAENtS,EAAMqQ,iBAAiBrQ,EAAMsS,cAE7BtS,EAAMqQ,iBAAiB,aAIElQ,IAAzBH,EAAMwS,gBACkB,MAAxBxS,EAAMwS,eAENxS,EAAMqQ,iBAAiBrQ,EAAMwS,gBAE7BxS,EAAMqQ,iBAAiB,aAOnC7J,MAAOnB,EAAErF,EAAMwG,UCfRiM,GAA+BC,IACP,IAC9BA,EACHjW,KAAM,SACNkW,eAAiBpS,GAEbuC,EAAC+N,GACC,CAAAtN,GAAI,CAAEf,MAAO,QACbgE,MAAM,GACN7N,MAAO4H,EAAO5H,MACd0X,iBAAmBF,IACjB5P,EAAOqS,IAAIC,iBAAiB,CAC1B1M,GAAI5F,EAAO4F,GACX2M,MAAOvS,EAAOuS,MACdna,MAAOwX,OAMjB4C,YAAa,CAACpa,EAAYqa,EAAUC,KAClC,IAAI9C,EAAI,KAIR,OAHc,OAAVxX,IACFwX,EAAIJ,GAAOpX,GAAOqX,OAAOP,KAEpBU,GAET+C,eAAgB,CAACva,EAAYqa,EAAUC,IAC9BD,EAAIC,EAAOH,SAWXK,GAEcT,IACU,IAC9BA,EACHjW,KAAM,SACN2W,YAAcza,GACRA,EACKA,EAAQ,GAEVA,EAET0a,WAAanT,IACX,IAAIgP,EAAS,KACb,IACEA,EAAShP,EAAWwS,OAAOvB,QAAQmC,MAChCzI,GAAcA,EAAK3K,EAAWwS,OAAOtB,aAAelR,EAAWvH,QAElE,MAAOyM,GAAG,CACZ,OACEtC,EAAA,MAAA,CAAAE,SACa,MAAVkM,EACGA,EAAOhP,EAAWwS,OAAOhB,cACzBxR,EAAWvH,SAKrBga,eAAiBpS,GAEbuC,EAACiO,GACK,IAAAxQ,EACJgD,GAAI,CAAEf,MAAO,QACb2O,QAASuB,EAAOvB,QAChBC,WAAYsB,EAAOtB,WACnBM,aAAcgB,EAAOhB,aACrBrB,iBAAkB,CAACF,EAAQoD,KACf,OAANpD,GACF5P,EAAOqS,IAAIC,iBAAiB,CAC1B1M,GAAI5F,EAAO4F,GACX2M,MAAOvS,EAAOuS,MACdna,MAAO,OAGX4H,EAAOqS,IAAIC,iBAAiB,CAC1B1M,GAAI5F,EAAO4F,GACX2M,MAAOvS,EAAOuS,MACdna,MAAOwX,EAAI,UAeZqD,GAEcd,IAClB,IACFA,EACHjW,KAAM,SACN2W,YAAcza,GACC,MAATA,GAA0BwH,MAATxH,EACZ,KAEAA,EAAQ,GAGnB0a,WAAanT,IACX,MAAMvH,EAAQuH,GAAYvH,MAC1B,OACEA,IAAU+Z,EAAOJ,cACP,SAAV3Z,GACU,IAAVA,IACU,IAAVA,EAEOmK,EAACa,GAAe,CAACC,KAAK,QAAQR,MAAM,UAEpCN,EAACa,GAAe,CAACC,KAAK,QAAQR,MAAM,SAG/CuP,eAAiBpS,GAEbuC,EAACmP,GACK,IAAA1R,EACJ+R,aAAcI,GAAQJ,cAAgB,OACtCE,eAAgBE,GAAQF,gBAAkB,QAC1CnC,iBAAmBF,IACjB5P,EAAOqS,IAAIC,iBAAiB,CAC1B1M,GAAI5F,EAAO4F,GACX2M,MAAOvS,EAAOuS,MACdna,MAAOwX,EAAI,UCrKZsD,GAEmBC,IAC9B,MAAMC,EAAkC,GACxC,GAAqB,UAAjBD,EAAQjX,MAAqC,UAAjBiX,EAAQrW,MAAoBqW,GAAS1T,MACnE2T,EAAOC,KAAKF,EAAQ1T,YACf,GACY,UAAjB0T,EAAQjX,MACRiX,GAAS1T,OACT0T,GAAS1T,OAAO6T,SAEhB,IAAK,MAAMC,KAAgBJ,EAAQ1T,MAAM6T,SACvCF,EAAOC,QAAQH,GAAiBK,IAGpC,OAAOH,GAGII,GAEmBF,IAC9B,MAAMF,EAAkC,GACxC,IAAK,MAAMD,KAAWG,EACpBF,EAAOC,QAAQH,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,CAAErb,QAAS,2BAClBsb,IAAI,EAAG,0BAEuBP,GAAEM,SAASF,WAAWC,WAK/D,OAAOR,GC/HHW,GAAoBjT,EAAOkT,GAAPlT,CAAoB,CAC5C+B,QAAS,OACTqB,WAAY,WAGR+P,GAAsBnT,EAAOoT,GAAPpT,EAC1B,EAAGI,QAAOiT,iBAAkB,CAC1BC,SAAU,QACVzS,MAAO,cACPqE,OAAQ,cACRI,OAAQ,EACR6B,QAASkM,EAAWhK,SAAW,EAAI,EACnCkK,cAAeF,EAAWhK,SAAW,OAAS,OAC9ChJ,WAAYD,EAAME,YAAY/C,OAAO,CAAC,gBAIpCiW,GAAkBxT,EAAOqQ,EAAPrQ,EAErB,EAAGI,QAAOiT,iBAAkB,CAC7BC,SAAU,QACVxI,UAAW,OACXjK,MAAOwS,EAAWhK,SAAW,IAAM,uBACnClC,QAASkM,EAAWhK,SAAW,EAAI,EACnChJ,WAAYD,EAAME,YAAY/C,OAAO,CAAC,QAAS,gBAG3CkW,GACJpV,IAEA,MAAMqF,EAAEA,GAAMiE,KACRmF,EAAU3I,KACVuP,GAAuBrV,GAAOsV,eAAeC,YAAYpb,WAC3DsU,EAAQ1I,iBAAiB/F,EAAMsV,cAAcC,WAAWpb,WAGtDqb,EDuGa,EACnBC,EACA7b,EACA8b,KAEA,MAAMC,EAAW,GACXC,EAAa,GACnB,GAC6B,YAA3BH,EAAkBhZ,MACa,IAA/BgZ,EAAkBI,IAAIvG,KAEtB,IAAK,MAAMJ,KAAUtV,EACnB+b,EAAS/B,KAAK1E,GACd0G,EAAWhC,KAAK1E,EAAOwG,SAGzB,GAAID,GAAmBI,IACrB,IAAK,MAAMC,KAAcL,EAAkBI,IAAK,CAC9C,MAAM3G,EAAStV,EAAK0Z,MAAMyC,GAAMA,EAAEL,KAAmBI,IACrDH,EAAS/B,KAAK1E,GACd0G,EAAWhC,KAAKkC,GAItB,MAAO,CAAEE,gBAAiBL,EAAUM,kBAAmBL,IC/HjCM,CACpBlW,GAAOsV,eAAeG,mBAAqB,CACzCI,IAAK,IAAIM,IACT1Z,KAAM,WAERuD,GAAOsV,eAAe1b,MAAQ,GAC9BoG,GAAOsV,eAAeI,eAAiB,MAEzC,OACEzS,EAACC,GAAO,CAAAF,SAAA,CAENqS,GAC4C,QAA5CrV,GAAOsV,eAAec,UAAUA,SAC9BnT,EAACmL,EAAO,CAAA/K,QAASrD,GAAOqW,sBAAqBrT,SAAA,CAC3CF,EAACa,IACCC,KAAK,MACLrH,MAAO,CAAEmG,YAAa,EAAGD,WAAY,KAEtC4C,EAAE,oBAGLvC,QAED9C,GAAOsV,eAAegB,WACrBtW,EAAMsV,cAAcgB,WAAW1K,KAAK4C,IACU,IAA5CA,GAAW+H,iBAAiBC,YAC1B1T,EAACyL,GACK,IAAAC,EACJM,WAAY/O,UACVC,EAAMsV,cAAcmB,WAAW3H,WAC7B9O,GAAOsV,eAAeoB,2BAG1B7H,2BAA4B2G,EAAcS,kBAC1CrH,yBAA0B4G,EAAcQ,kBAG1ClT,EAAKkM,EAAA,MAITlM,EAAKkM,EAAA,CAAA,GAEPlM,EAAC8D,EAAI,CAAArD,GAAI,CAAEY,KAAM,EAAG+C,GAAI,IAAKlE,SAAGhD,GAAOsV,eAAeqB,OAEtD7T,EAAC8T,EAAQ,CAAA7I,MAAM,UAAS/K,SACtBF,EAAC+T,GAAmB,CAACC,OAAQhU,EAACiS,GAAa,CAAA,YACzCjS,EAACiU,IAAmBtN,SAAS,cAIjC3G,EAAC8T,EAAQ,CAAA7I,MAAM,UAAS/K,SACtBF,EAACkU,GAAkB,CACjBF,OAAQ,CAAC9W,EAAOhI,IACd8K,EAACiS,GAAa,IAAK/U,EAAOoD,MAAM,UAASJ,SACvCF,EAACmU,EAAK,CACJC,aAAclf,EAAMmf,YACpB/T,MAAM,UACNY,QAAQ,MAAKhB,SAEbF,EAACsU,GAAkB,CAAC3N,SAAS,kBAOtCzJ,GAAOsV,eAAe+B,aACrBvU,EAAC8T,EAAO,CAAC7I,MAAO1I,EAAE,oBAChBrC,SAAAF,EAACK,EAAW,CAAAE,QAASrD,GAAOsX,eAC1BtU,SAAAF,EAACa,GAAgB,CAAAC,KAAK,eAI1Bd,EAAAkM,EAAA,CAAA,GAGFlM,EAACoK,EACC,CAAAqK,YAAY,WACZvT,QAAQ,SACRwT,YACAjU,GAAI,CAAE2D,GAAI,MAGZpE,EAAC8T,EAAQ,CAAA7I,MAAO1I,EAAE,+BAChBvC,EAAC2U,IAAYX,OAAQhU,EAAC4U,EAAQ,CAAA,GAC5B1U,SAAAF,EAACa,GAAgB,CAAAC,KAAK,aAAaR,MAAM,cAI7CH,EAAC2R,GACC,CAAA5R,SAAA,CAAAF,EAAC6U,GACC,CAAAb,OAAQ,CAACc,EAAc5f,IACrB8K,EAAC8T,GAAQ7I,MAAO1I,EAAE,oBAAqBwS,WAAY,EAAC7U,SAClDF,EAACgS,OACK8C,EACJ5C,WAAY,CAAEhK,SAAUhT,EAAMgT,UAC9B5H,MAAM,UAAS,gBACApL,EAAMgT,SAErBhI,SAAAF,EAACa,GAAgB,CAAAC,KAAK,iBAK9Bd,EAACgV,GACC,CAAAhB,OAAQ,EAAG5a,SAAQ6b,GAAgB/f,IACjC8K,EAACqS,GAAe,IACV4C,EACJ/C,WAAY,CAAEhK,SAAUhT,EAAMgT,UAC9BgN,SAAU9b,EAAG,aACF,SACX+b,YAAa,GAAG5S,EAAE,yBAClBiK,KAAK,QACLgB,UAAW,CACT4H,MAAO,CACLC,eACErV,EAACsV,EAAc,CAACrV,SAAS,QACvBC,SAAAF,EAACa,GAAgB,CAAAC,KAAK,aAG1ByU,aAAcrgB,EAAMW,MAClBmK,EAACsV,EAAc,CAACrV,SAAS,eACvBD,EAACwV,IACChV,KAAK,MACLgM,KAAK,qBACM,eAActM,SAGzBF,EAACa,GAAe,CAACC,KAAK,cAGxB,QACDmU,EAAazH,WAAW4H,UAE1BH,EAAazH,kBAO1BxN,EAACK,EACC,CAAAE,QAAS,KACPrD,EAAMsV,cAAcmB,WAAW3H,WAC7B9O,GAAOsV,eAAeoB,2BAEzB1T,SAEDF,EAACa,GAAgB,CAAAC,KAAK,kBC7NxB,SAAU2U,GAAcC,GAC5B,MAAO,QAAQC,KAAKD,EACtB,CAEM,SAAUE,GAAS/f,GACvB,MAAwB,iBAAVA,IAAuBggB,MAAMhgB,EAC7C,CAEM,SAAUigB,GAAUjgB,GACxB,MACmB,iBAAVA,GAAuC,KAAjBA,EAAMkgB,SAAkBF,MAAMG,OAAOngB,GAEtE,CAEM,SAAUogB,GAAsBP,GACpC,OAAKA,EACEA,EAAIQ,OAAO,GAAGC,cAAgBT,EAAIU,MAAM,GAD9B,EAEnB,CCTA,MAAMC,GACJ3K,IAEA,MAAMnJ,EAAEA,GAAMiE,KACRmF,EAAU3I,MACV8H,mBAAEA,EAAkBD,QAAEA,GAAYD,GAAsB,CAC5DQ,KAAM7I,EAAEmJ,GAAWE,qBAAuB,uBAC1CX,MAAO1I,EAAE,gBACTgJ,qBAAsBtO,gBACdyO,GAAWG,SAASH,EAAUU,SAChCV,GAAWM,YACbN,EAAUM,gBAIhB,IAAIC,GAAkB,EAClBP,EAAUrU,YACZ4U,EAAkBN,EAAQ1I,iBAAiByI,EAAUrU,YAEvD,IAAIif,EAAiB,CAAE,EACnB5K,GAAW6K,8BACbD,EAAY5K,EAAU6K,4BAA4B7K,EAAUU,SAE9D,IAAIoK,GAA2B,EAC3B9K,GAAW8K,2BACbA,EAA2B9K,GAAW8K,yBACpC9K,EAAUU,SAGd,IAAIqK,GAA4B,EAMhC,GALI/K,GAAW+K,4BACbA,EAA4B/K,EAAU+K,0BACpC/K,EAAUU,SAGVH,GAAmBuK,EACrB,OACErW,eACEH,EAAC8K,MACD9K,EAAC0W,GACC,CAAAtP,SAAUqP,EACV3V,KACEd,EAAC8T,EAAQ,CAAA7I,MAAOS,GAAWhI,MAAQnB,EAAEmJ,EAAUhI,OAAS,YACtD1D,EAACa,IACCC,KAAM4K,EAAU5K,KAChBrH,MAAO,IACF6c,EACHhW,MAAOmW,EACH,OACoBpZ,MAApBiZ,GAAWhW,MACXgW,EAAUhW,WACVjD,OAKZsZ,WAAYjL,GAAW+H,iBAAiBkD,aAAc,EACtDjT,MAAO,GACPuE,UAAU,cACV3H,MAAM,UACNC,QAAStD,UACP,IAAKwZ,EAA2B,CAC9B,GAAI/K,GAAWS,sBACRT,EAAUS,oBAAoBT,EAAUU,QAC3C,QAGsC,IAAtCV,GAAWW,uBACbxB,GAAQ,UAEFa,EAAUG,SAASH,EAAUU,QAC/BV,GAAWM,YACbN,EAAUM,sBCtEb,SAAS4K,GAAsBC,KAASC,GACrD,MAAM/f,EAAM,IAAIggB,IAAI,0CAA0CF,KAE9D,OADAC,EAAKE,SAAQC,GAAOlgB,EAAImgB,aAAaC,OAAO,SAAUF,KAC/C,uBAAuBJ,YAAe9f,yBAC/C;;;;;;;;kCCZ6B,eAAzBqgB,QAAQC,IAAIC,SACdC,GAAAC,wCCMW,IAAIC,EAAE,mBAAoBC,QAAQA,OAAOC,IAAIC,EAAEH,EAAEC,OAAOC,IAAI,iBAAiB,MAAME,EAAEJ,EAAEC,OAAOC,IAAI,gBAAgB,MAAMrV,EAAEmV,EAAEC,OAAOC,IAAI,kBAAkB,MAAMnV,EAAEiV,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,MAAMlV,EAAEgV,EAAEC,OAAOC,IAAI,qBAAqB,MAAMQ,EAAEV,EAAEC,OAAOC,IAAI,kBAAkB,MAAMS,EAAEX,EACpfC,OAAOC,IAAI,uBAAuB,MAAMtV,EAAEoV,EAAEC,OAAOC,IAAI,cAAc,MAAMpV,EAAEkV,EAAEC,OAAOC,IAAI,cAAc,MAAMtK,EAAEoK,EAAEC,OAAOC,IAAI,eAAe,MAAMU,EAAEZ,EAAEC,OAAOC,IAAI,qBAAqB,MAAM1E,EAAEwE,EAAEC,OAAOC,IAAI,mBAAmB,MAAMW,EAAEb,EAAEC,OAAOC,IAAI,eAAe,MAClQ,SAASrG,EAAEiH,GAAG,GAAG,iBAAkBA,GAAG,OAAOA,EAAE,CAAC,IAAIC,EAAED,EAAEE,SAAS,OAAOD,GAAG,KAAKZ,EAAE,OAAOW,EAAEA,EAAE5e,MAAQ,KAAKse,EAAE,KAAKC,EAAE,KAAK5V,EAAE,KAAKwV,EAAE,KAAKtV,EAAE,KAAK2V,EAAE,OAAOI,EAAE,QAAQ,OAAOA,EAAEA,GAAGA,EAAEE,UAAY,KAAKT,EAAE,KAAKvV,EAAE,KAAKF,EAAE,KAAKF,EAAE,KAAK0V,EAAE,OAAOQ,EAAE,QAAQ,OAAOC,GAAG,KAAKX,EAAE,OAAOW,EAAE,CAAC,CAAC,SAASE,EAAEH,GAAG,OAAOjH,EAAEiH,KAAKL,CAAC,QAACS,GAAiBC,UAACX,EAAEU,GAAAE,eAAuBX,EAAES,GAAuBG,gBAACd,EAAEW,mBAAwBZ,EAAEY,GAAAI,QAAgBnB,EAAEe,GAAkBK,WAACvW,EAAEkW,GAAAM,SAAiB3W,EAAEqW,GAAYO,KAAC3W,EAAEoW,QAAatW,EAAEsW,GAAAQ,OAAetB,EAChfc,GAAAS,SAAiBtB,EAAEa,GAAAU,WAAmB7W,EAAEmW,GAAAW,SAAiBnB,EAAEQ,GAAAY,YAAoB,SAAShB,GAAG,OAAOG,EAAEH,IAAIjH,EAAEiH,KAAKN,CAAC,EAAEU,GAAwBa,iBAACd,EAAEC,GAAyBc,kBAAC,SAASlB,GAAG,OAAOjH,EAAEiH,KAAKP,CAAC,EAAEW,GAAyBe,kBAAC,SAASnB,GAAG,OAAOjH,EAAEiH,KAAKR,CAAC,EAAEY,GAAiBgB,UAAC,SAASpB,GAAG,MAAM,iBAAkBA,GAAG,OAAOA,GAAGA,EAAEE,WAAWb,CAAC,EAAEe,GAAoBiB,aAAC,SAASrB,GAAG,OAAOjH,EAAEiH,KAAK9V,CAAC,EAAEkW,GAAkBkB,WAAC,SAAStB,GAAG,OAAOjH,EAAEiH,KAAKjW,CAAC,EAAEqW,GAAcmB,OAAC,SAASvB,GAAG,OAAOjH,EAAEiH,KAAKhW,CAAC,EAC1doW,GAAAoB,OAAe,SAASxB,GAAG,OAAOjH,EAAEiH,KAAKlW,CAAC,EAAEsW,YAAiB,SAASJ,GAAG,OAAOjH,EAAEiH,KAAKV,CAAC,EAAEc,GAAkBqB,WAAC,SAASzB,GAAG,OAAOjH,EAAEiH,KAAKT,CAAC,EAAEa,GAAAsB,aAAqB,SAAS1B,GAAG,OAAOjH,EAAEiH,KAAK/V,CAAC,EAAEmW,GAAkBuB,WAAC,SAAS3B,GAAG,OAAOjH,EAAEiH,KAAKJ,CAAC,EAChNQ,GAAAwB,mBAAC,SAAS5B,GAAG,MAAM,iBAAkBA,GAAG,mBAAoBA,GAAGA,IAAIjW,GAAGiW,IAAIL,GAAGK,IAAIT,GAAGS,IAAI/V,GAAG+V,IAAIJ,GAAGI,IAAIH,GAAG,iBAAkBG,GAAG,OAAOA,IAAIA,EAAEE,WAAWlW,GAAGgW,EAAEE,WAAWpW,GAAGkW,EAAEE,WAAWV,GAAGQ,EAAEE,WAAWT,GAAGO,EAAEE,WAAWhW,GAAG8V,EAAEE,WAAWJ,GAAGE,EAAEE,WAAWxF,GAAGsF,EAAEE,WAAWH,GAAGC,EAAEE,WAAWpL,EAAE,EAAEsL,GAAcyB,OAAC9I,KDXhT+I,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,IAAI5gB,EAAO8hB,EAAO9hB,KAElB,OAAQA,GACN,KAAKmhB,EACL,KAAKC,EACL,KAAKN,EACL,KAAKE,EACL,KAAKD,EACL,KAAKO,EACH,OAAOthB,EAET,QACE,IAAI+hB,EAAe/hB,GAAQA,EAAK8e,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,EAEtCha,QAAc,KAAE,kLAIb2X,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,SAA4BxgB,GAC1B,MAAuB,iBAATA,GAAqC,mBAATA,GAC1CA,IAAS8gB,GAAuB9gB,IAASohB,GAA8BphB,IAASghB,GAAuBhhB,IAAS+gB,GAA0B/gB,IAASshB,GAAuBthB,IAASuhB,GAA4C,iBAATvhB,GAA8B,OAATA,IAAkBA,EAAK8e,WAAa2C,GAAmBzhB,EAAK8e,WAAa0C,GAAmBxhB,EAAK8e,WAAamC,GAAuBjhB,EAAK8e,WAAaoC,GAAsBlhB,EAAK8e,WAAauC,GAA0BrhB,EAAK8e,WAAa6C,GAA0B3hB,EAAK8e,WAAa8C,GAAwB5hB,EAAK8e,WAAa+C,GAAoB7hB,EAAK8e,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,GAAO7T,KAAI,SAAUrG,GAC5D,OAAOka,EAAMla,EAChB,IACaqa,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,SAAU9M,EAAQ4N,GAKtE,IAJA,IAAIC,EAEAC,EADAxX,EAtDL,SAAkByX,GACjB,GAAIA,QACH,MAAM,IAAIC,UAAU,yDAGrB,OAAOxB,OAAOuB,EACf,CAgDUE,CAASjO,GAGTkO,EAAI,EAAGA,EAAI5a,UAAUF,OAAQ8a,IAAK,CAG1C,IAAK,IAAIpT,KAFT+S,EAAOrB,OAAOlZ,UAAU4a,IAGnBzB,EAAe0B,KAAKN,EAAM/S,KAC7BxE,EAAGwE,GAAO+S,EAAK/S,IAIjB,GAAIyR,EAAuB,CAC1BuB,EAAUvB,EAAsBsB,GAChC,IAAK,IAAIV,EAAI,EAAGA,EAAIW,EAAQ1a,OAAQ+Z,IAC/BR,EAAiBwB,KAAKN,EAAMC,EAAQX,MACvC7W,EAAGwX,EAAQX,IAAMU,EAAKC,EAAQX,IAGnC,CACA,CAEC,OAAO7W,CACP,+CC9ED8X,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,IAAI9nB,EAAU,YAAc8nB,EACL,oBAAZxc,SACTA,QAAQjF,MAAMrG,GAEhB,IAIE,MAAM,IAAI+nB,MAAM/nB,EACjB,CAAC,MAAO0c,GAAG,CACb,CACH,CAaA,SAASsL,EAAeC,EAAWC,EAAQC,EAAUC,EAAeC,GAClE,GAA6B,eAAzBxH,QAAQC,IAAIC,SACd,IAAK,IAAIuH,KAAgBL,EACvB,GAAIV,EAAIU,EAAWK,GAAe,CAChC,IAAIjiB,EAIJ,IAGE,GAAuC,mBAA5B4hB,EAAUK,GAA8B,CACjD,IAAI1B,EAAMmB,OACPK,GAAiB,eAAiB,KAAOD,EAAW,UAAYG,EAAjE,oGACwFL,EAAUK,GADlG,mGAKF,MADA1B,EAAIzoB,KAAO,sBACLyoB,CAClB,CACUvgB,EAAQ4hB,EAAUK,GAAcJ,EAAQI,EAAcF,EAAeD,EAAU,KAAMR,EACtF,CAAC,MAAOY,GACPliB,EAAQkiB,CAClB,CAWQ,IAVIliB,GAAWA,aAAiB0hB,OAC9BL,GACGU,GAAiB,eAAiB,2BACnCD,EAAW,KAAOG,EADlB,kGAEqEjiB,EAFrE,kKAQAA,aAAiB0hB,SAAW1hB,EAAMrG,WAAW4nB,GAAqB,CAGpEA,EAAmBvhB,EAAMrG,UAAW,EAEpC,IAAIwoB,EAAQH,EAAWA,IAAa,GAEpCX,EACE,UAAYS,EAAW,UAAY9hB,EAAMrG,SAAoB,MAATwoB,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,IAAI9nB,EAAU,YAAc8nB,EACL,oBAAZxc,SACTA,QAAQjF,MAAMrG,GAEhB,IAIE,MAAM,IAAI+nB,MAAM/nB,EACjB,CAAC,MAAO0c,GAAG,CACb,GAOHsM,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,YACjCxO,OAAQwO,EAA2B,UACnCtE,OAAQsE,EAA2B,UACnCnO,OAAQmO,EAA2B,UACnCI,OAAQJ,EAA2B,UAEnCK,IA6HOC,EAA2Bf,GA5HlCgB,QA+HF,SAAkCC,GAkBhC,OAAOF,GAjBP,SAAkBnjB,EAAOsjB,EAAU7B,EAAeD,EAAU+B,GAC1D,GAA2B,mBAAhBF,EACT,OAAO,IAAIG,EAAc,aAAeD,EAAe,mBAAqB9B,EAAgB,mDAE9F,IAAIgC,EAAYzjB,EAAMsjB,GACtB,IAAK9d,MAAMC,QAAQge,GAEjB,OAAO,IAAID,EAAc,WAAahC,EAAW,KAAO+B,EAA/B,cADVG,EAAYD,GAC6E,kBAAoBhC,EAAgB,yBAE9I,IAAK,IAAI/B,EAAI,EAAGA,EAAI+D,EAAU9d,OAAQ+Z,IAAK,CACzC,IAAIhgB,EAAQ2jB,EAAYI,EAAW/D,EAAG+B,EAAeD,EAAU+B,EAAe,IAAM7D,EAAI,IAAKsB,GAC7F,GAAIthB,aAAiB0hB,MACnB,OAAO1hB,CAEjB,CACM,OAAO,IACb,GAEA,EAjJIgU,QA4JOyP,GARP,SAAkBnjB,EAAOsjB,EAAU7B,EAAeD,EAAU+B,GAC1D,IAAIE,EAAYzjB,EAAMsjB,GACtB,OAAKhB,EAAemB,GAIb,KAFE,IAAID,EAAc,WAAahC,EAAW,KAAO+B,EAA/B,cADVG,EAAYD,GAC6E,kBAAoBhC,EAAgB,qCAGpJ,IA1JIkC,YAuKOR,GARP,SAAkBnjB,EAAOsjB,EAAU7B,EAAeD,EAAU+B,GAC1D,IAAIE,EAAYzjB,EAAMsjB,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,SAAkBnjB,EAAOsjB,EAAU7B,EAAeD,EAAU+B,GAC1D,KAAMvjB,EAAMsjB,aAAqBO,GAAgB,CAC/C,IAAIC,EAAoBD,EAAcrsB,MAAQkrB,EAE9C,OAAO,IAAIc,EAAc,WAAahC,EAAW,KAAO+B,EAA/B,iBAuSTE,EAxSmBzjB,EAAMsjB,IAyS9BS,aAAgBN,EAAUM,YAAYvsB,KAG9CisB,EAAUM,YAAYvsB,KAFpBkrB,GAzS0G,mBAAoBjB,EAA1G,4BAA+JqC,EAAoB,KACpN,CAsSE,IAAsBL,EArSlB,OAAO,IACb,GAEA,EAlLIpd,KAwRO8c,GANP,SAAkBnjB,EAAOsjB,EAAU7B,EAAeD,EAAU+B,GAC1D,OAAKS,EAAOhkB,EAAMsjB,IAGX,KAFE,IAAIE,EAAc,WAAahC,EAAW,KAAO+B,EAA/B,kBAAwE9B,EAAgB,2BAGzH,IAtRIwC,SAsNF,SAAmCZ,GAoBjC,OAAOF,GAnBP,SAAkBnjB,EAAOsjB,EAAU7B,EAAeD,EAAU+B,GAC1D,GAA2B,mBAAhBF,EACT,OAAO,IAAIG,EAAc,aAAeD,EAAe,mBAAqB9B,EAAgB,oDAE9F,IAAIgC,EAAYzjB,EAAMsjB,GAClBY,EAAWR,EAAYD,GAC3B,GAAiB,WAAbS,EACF,OAAO,IAAIV,EAAc,WAAahC,EAAW,KAAO+B,EAA/B,cAAoEW,EAAW,kBAAoBzC,EAAgB,0BAE9I,IAAK,IAAIpU,KAAOoW,EACd,GAAI7C,EAAI6C,EAAWpW,GAAM,CACvB,IAAI3N,EAAQ2jB,EAAYI,EAAWpW,EAAKoU,EAAeD,EAAU+B,EAAe,IAAMlW,EAAK2T,GAC3F,GAAIthB,aAAiB0hB,MACnB,OAAO1hB,CAEnB,CAEM,OAAO,IACb,GAEA,EA1OIykB,MAkLF,SAA+BC,GAC7B,IAAK5e,MAAMC,QAAQ2e,GAWjB,MAV6B,eAAzBlK,QAAQC,IAAIC,UAEZ2G,EADElb,UAAUF,OAAS,EAEnB,+DAAiEE,UAAUF,OAA3E,uFAIW,0DAGVyc,EAoBT,OAAOe,GAjBP,SAAkBnjB,EAAOsjB,EAAU7B,EAAeD,EAAU+B,GAE1D,IADA,IAAIE,EAAYzjB,EAAMsjB,GACb5D,EAAI,EAAGA,EAAI0E,EAAeze,OAAQ+Z,IACzC,GAAI2E,EAAGZ,EAAWW,EAAe1E,IAC/B,OAAO,KAIX,IAAI4E,EAAeC,KAAKC,UAAUJ,GAAgB,SAAkB/W,EAAK1U,GAEvE,MAAa,WADF8rB,EAAe9rB,GAEjB4mB,OAAO5mB,GAETA,CACf,IACM,OAAO,IAAI6qB,EAAc,WAAahC,EAAW,KAAO+B,EAAe,eAAiBhE,OAAOkE,GAAtE,kBAA6GhC,EAAgB,sBAAwB6C,EAAe,IACnM,GAEA,EAlNII,UA2OF,SAAgCC,GAC9B,IAAKnf,MAAMC,QAAQkf,GAEjB,MADyB,eAAzBzK,QAAQC,IAAIC,UAA4B2G,EAAa,0EAC9CqB,EAGT,IAAK,IAAI1C,EAAI,EAAGA,EAAIiF,EAAoBhf,OAAQ+Z,IAAK,CACnD,IAAIkF,EAAUD,EAAoBjF,GAClC,GAAuB,mBAAZkF,EAKT,OAJA7D,EACE,8FACc8D,EAAyBD,GAAW,aAAelF,EAAI,KAEhE0C,CAEf,CAiBI,OAAOe,GAfP,SAAkBnjB,EAAOsjB,EAAU7B,EAAeD,EAAU+B,GAE1D,IADA,IAAIuB,EAAgB,GACXpF,EAAI,EAAGA,EAAIiF,EAAoBhf,OAAQ+Z,IAAK,CACnD,IACIqF,GAAgBH,EADND,EAAoBjF,IACN1f,EAAOsjB,EAAU7B,EAAeD,EAAU+B,EAAcvC,GACpF,GAAqB,MAAjB+D,EACF,OAAO,KAELA,EAAcnrB,MAAQgnB,EAAImE,EAAcnrB,KAAM,iBAChDkrB,EAAclR,KAAKmR,EAAcnrB,KAAKorB,aAEhD,CAEM,OAAO,IAAIxB,EAAc,WAAahC,EAAW,KAAO+B,EAA/B,kBAAwE9B,EAAgB,KADrFqD,EAAcnf,OAAS,EAAK,2BAA6Bmf,EAAclF,KAAK,MAAQ,IAAK,IACyB,IACpJ,GAEA,EA3QIqF,MA8RF,SAAgCC,GAmB9B,OAAO/B,GAlBP,SAAkBnjB,EAAOsjB,EAAU7B,EAAeD,EAAU+B,GAC1D,IAAIE,EAAYzjB,EAAMsjB,GAClBY,EAAWR,EAAYD,GAC3B,GAAiB,WAAbS,EACF,OAAO,IAAIV,EAAc,WAAahC,EAAW,KAAO+B,EAAe,cAAgBW,EAA9D,kBAAmGzC,EAAgB,yBAE9I,IAAK,IAAIpU,KAAO6X,EAAY,CAC1B,IAAIN,EAAUM,EAAW7X,GACzB,GAAuB,mBAAZuX,EACT,OAAOO,EAAsB1D,EAAeD,EAAU+B,EAAclW,EAAKoX,EAAeG,IAE1F,IAAIllB,EAAQklB,EAAQnB,EAAWpW,EAAKoU,EAAeD,EAAU+B,EAAe,IAAMlW,EAAK2T,GACvF,GAAIthB,EACF,OAAOA,CAEjB,CACM,OAAO,IACb,GAEA,EAjTI0lB,MAmTF,SAAsCF,GA6BpC,OAAO/B,GA5BP,SAAkBnjB,EAAOsjB,EAAU7B,EAAeD,EAAU+B,GAC1D,IAAIE,EAAYzjB,EAAMsjB,GAClBY,EAAWR,EAAYD,GAC3B,GAAiB,WAAbS,EACF,OAAO,IAAIV,EAAc,WAAahC,EAAW,KAAO+B,EAAe,cAAgBW,EAA9D,kBAAmGzC,EAAgB,yBAG9I,IAAI4D,EAAUhG,EAAO,CAAA,EAAIrf,EAAMsjB,GAAW4B,GAC1C,IAAK,IAAI7X,KAAOgY,EAAS,CACvB,IAAIT,EAAUM,EAAW7X,GACzB,GAAIuT,EAAIsE,EAAY7X,IAA2B,mBAAZuX,EACjC,OAAOO,EAAsB1D,EAAeD,EAAU+B,EAAclW,EAAKoX,EAAeG,IAE1F,IAAKA,EACH,OAAO,IAAIpB,EACT,WAAahC,EAAW,KAAO+B,EAAe,UAAYlW,EAAM,kBAAoBoU,EAApF,mBACmB8C,KAAKC,UAAUxkB,EAAMsjB,GAAW,KAAM,MACzD,iBAAmBiB,KAAKC,UAAUzF,OAAOiB,KAAKkF,GAAa,KAAM,OAGrE,IAAIxlB,EAAQklB,EAAQnB,EAAWpW,EAAKoU,EAAeD,EAAU+B,EAAe,IAAMlW,EAAK2T,GACvF,GAAIthB,EACF,OAAOA,CAEjB,CACM,OAAO,IACb,GAGA,GAzUE,SAAS2kB,EAAGtO,EAAGqF,GAEb,OAAIrF,IAAMqF,EAGK,IAANrF,GAAW,EAAIA,GAAM,EAAIqF,EAGzBrF,GAAMA,GAAKqF,GAAMA,CAE9B,CAUE,SAASoI,EAAcnqB,EAASO,GAC9B0rB,KAAKjsB,QAAUA,EACfisB,KAAK1rB,KAAOA,GAAwB,iBAATA,EAAoBA,EAAM,CAAE,EACvD0rB,KAAKzD,MAAQ,EACjB,CAIE,SAASsB,EAA2BoC,GAClC,GAA6B,eAAzBrL,QAAQC,IAAIC,SACd,IAAIoL,EAA0B,CAAE,EAC5BC,EAA6B,EAEnC,SAASC,EAAUC,EAAY3lB,EAAOsjB,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,EAAIzoB,KAAO,sBACLyoB,CAChB,CAAe,GAA6B,eAAzB/F,QAAQC,IAAIC,UAAgD,oBAAZzV,QAAyB,CAElF,IAAIkhB,EAAWpE,EAAgB,IAAM6B,GAElCkC,EAAwBK,IAEzBJ,EAA6B,IAE7B1E,EACE,2EACuBwC,EAAe,cAAgB9B,EADtD,wNAMF+D,EAAwBK,IAAY,EACpCJ,IAEZ,CACA,CACM,OAAuB,MAAnBzlB,EAAMsjB,GACJqC,EACsB,OAApB3lB,EAAMsjB,GACD,IAAIE,EAAc,OAAShC,EAAW,KAAO+B,EAA3B,+BAAiF9B,EAAgB,+BAErH,IAAI+B,EAAc,OAAShC,EAAW,KAAO+B,EAA3B,+BAAiF9B,EAAgB,oCAErH,KAEA8D,EAASvlB,EAAOsjB,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,SAAkBnjB,EAAOsjB,EAAU7B,EAAeD,EAAU+B,EAAcqC,GACxE,IAAInC,EAAYzjB,EAAMsjB,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,EAAclW,EAAK5Q,GACzE,OAAO,IAAI+mB,GACR/B,GAAiB,eAAiB,KAAOD,EAAW,UAAY+B,EAAe,IAAMlW,EAAtF,6FACiF5Q,EAAO,KAE9F,CAwDE,SAASunB,EAAOP,GACd,cAAeA,GACb,IAAK,SACL,IAAK,SACL,IAAK,YACH,OAAO,EACT,IAAK,UACH,OAAQA,EACV,IAAK,SACH,GAAIje,MAAMC,QAAQge,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,EAAKxtB,OACf,OAAO,OAKX,OAASwtB,EAAO1D,EAAS4D,QAAQC,MAAM,CACrC,IAAIC,EAAQJ,EAAKxtB,MACjB,GAAI4tB,IACGvC,EAAOuC,EAAM,IAChB,OAAO,CAGzB,CAMQ,OAAO,EACT,QACE,OAAO,EAEf,CA2BE,SAAS7C,EAAYD,GACnB,IAAIS,SAAkBT,EACtB,OAAIje,MAAMC,QAAQge,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,EAAyBlsB,GAChC,IAAI8D,EAAOgoB,EAAe9rB,GAC1B,OAAQ8D,GACN,IAAK,QACL,IAAK,SACH,MAAO,MAAQA,EACjB,IAAK,UACL,IAAK,OACL,IAAK,SACH,MAAO,KAAOA,EAChB,QACE,OAAOA,EAEf,CAcE,OAxbA+mB,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,EAAK/mB,EAAOsjB,EAAU7B,EAAeD,EAAU+B,EAAcqC,GACpE,GAAIA,IAAW5E,EAAf,CAIA,IAAIf,EAAM,IAAImB,MACZ,mLAKF,MADAnB,EAAIzoB,KAAO,sBACLyoB,CAPV,EAUE,SAAS+G,IACP,OAAOD,CAEX,CAJEA,EAAKpB,WAAaoB,EAMlB,IAAIpE,EAAiB,CACnBC,MAAOmE,EACPjE,OAAQiE,EACRhE,KAAMgE,EACN/D,KAAM+D,EACN1S,OAAQ0S,EACRxI,OAAQwI,EACRrS,OAAQqS,EACR9D,OAAQ8D,EAER7D,IAAK6D,EACL3D,QAAS4D,EACTtT,QAASqT,EACTpD,YAAaoD,EACbnD,WAAYoD,EACZ3gB,KAAM0gB,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,EAAO9hB,MACxB,KAAK8gB,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,SAAUxgB,GACrC,MAAO,iBAAoBA,GACzB,mBAAsBA,GACtBA,IAAS8gB,GACT9gB,IAASghB,GACThhB,IAAS+gB,GACT/gB,IAASshB,GACTthB,IAASuhB,GACR,iBAAoBvhB,GACnB,OAASA,IACRA,EAAK8e,WAAa2C,GACjBzhB,EAAK8e,WAAa0C,GAClBxhB,EAAK8e,WAAaoC,GAClBlhB,EAAK8e,WAAa2L,GAClBzqB,EAAK8e,WAAauC,GAClBrhB,EAAK8e,WAAa6L,QAClB,IAAW3qB,EAAK+qB,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,EAAO9hB,MACxB,KAAK8gB,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,SAAUxgB,GACrC,MAAO,iBAAoBA,GACzB,mBAAsBA,GACtBA,IAAS8gB,GACT9gB,IAASghB,GACThhB,IAAS+gB,GACT/gB,IAASshB,GACTthB,IAASuhB,GACR,iBAAoBvhB,GACnB,OAASA,IACRA,EAAK8e,WAAa2C,GACjBzhB,EAAK8e,WAAa0C,GAClBxhB,EAAK8e,WAAaoC,GAClBlhB,EAAK8e,WAAa2L,GAClBzqB,EAAK8e,WAAauC,GAClBrhB,EAAK8e,WAAa6L,QAClB,IAAW3qB,EAAK+qB,YAGvB,EACD5I,GAAA1B,OAAiBA,CAClB,CAxHD,sCCV2B,eAAzBhD,QAAQC,IAAIC,SACdC,GAAAC,QAAwD6C,KAExD9C,GAAAC,QAAyD4G,6BCDpD,SAASuG,GAAc5c,GAC5B,GAAoB,iBAATA,GAA8B,OAATA,EAC9B,OAAO,EAET,MAAMoU,EAAYF,OAAO2I,eAAe7c,GACxC,QAAsB,OAAdoU,GAAsBA,IAAcF,OAAOE,WAAkD,OAArCF,OAAO2I,eAAezI,IAA0BzE,OAAOmN,eAAe9c,GAAW2P,OAAOiI,YAAY5X,EACtK,CACA,SAAS+c,GAAUzH,GACjB,GAAiBpW,EAAMuY,eAAenC,IAAWlD,GAAAA,mBAAmBkD,KAAYsH,GAActH,GAC5F,OAAOA,EAET,MAAM0H,EAAS,CAAE,EAIjB,OAHA9I,OAAOiB,KAAKG,GAAQrG,SAAQzM,IAC1Bwa,EAAOxa,GAAOua,GAAUzH,EAAO9S,OAE1Bwa,CACT,CAoBe,SAASC,GAAUvV,EAAQ4N,EAAQhP,EAAU,CAC1D4W,OAAO,IAEP,MAAMF,EAAS1W,EAAQ4W,MAAQ,IAC1BxV,GACDA,EAiBJ,OAhBIkV,GAAclV,IAAWkV,GAActH,IACzCpB,OAAOiB,KAAKG,GAAQrG,SAAQzM,IACTtD,EAAMuY,eAAenC,EAAO9S,KAAS4P,sBAAmBkD,EAAO9S,IAC9Ewa,EAAOxa,GAAO8S,EAAO9S,GACZoa,GAActH,EAAO9S,KAEhC0R,OAAOE,UAAUD,eAAe0B,KAAKnO,EAAQlF,IAAQoa,GAAclV,EAAOlF,IAExEwa,EAAOxa,GAAOya,GAAUvV,EAAOlF,GAAM8S,EAAO9S,GAAM8D,GACzCA,EAAQ4W,MACjBF,EAAOxa,GAAOoa,GAActH,EAAO9S,IAAQua,GAAUzH,EAAO9S,IAAQ8S,EAAO9S,GAE3Ewa,EAAOxa,GAAO8S,EAAO9S,MAIpBwa,CACT,CC5Ce,SAASG,GAAkBC,GACxC,MAAM1G,OAGJA,EAAS,CACP2G,GAAI,EAEJC,GAAI,IAEJC,GAAI,IAEJC,GAAI,KAEJC,GAAI,MACLC,KACDA,EAAO,KAAIpC,KACXA,EAAO,KACJ9c,GACD4e,EACEO,EAnCsBjH,KAC5B,MAAMkH,EAAqB1J,OAAOiB,KAAKuB,GAAQ3V,KAAIyB,IAAQ,CACzDA,MACAiT,IAAKiB,EAAOlU,QACP,GAGP,OADAob,EAAmBC,MAAK,CAACC,EAAaC,IAAgBD,EAAYrI,IAAMsI,EAAYtI,MAC7EmI,EAAmBI,QAAO,CAACC,EAAKC,KAC9B,IACFD,EACH,CAACC,EAAI1b,KAAM0b,EAAIzI,OAEhB,KAuBkB0I,CAAsBzH,GACrCvB,EAAOjB,OAAOiB,KAAKwI,GACzB,SAASS,EAAG5b,GAEV,MAAO,qBAD8B,iBAAhBkU,EAAOlU,GAAoBkU,EAAOlU,GAAOA,IAC1Bkb,IACxC,CACE,SAASW,EAAK7b,GAEZ,MAAO,sBAD8B,iBAAhBkU,EAAOlU,GAAoBkU,EAAOlU,GAAOA,GAC1B8Y,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,SAAcnc,GACZ,OAAI2S,EAAKuJ,QAAQlc,GAAO,EAAI2S,EAAKra,OACxBwjB,EAAQ9b,EAAK2S,EAAKA,EAAKuJ,QAAQlc,GAAO,IAExC4b,EAAG5b,EACd,EAmBIoc,IAlBF,SAAapc,GAEX,MAAMqc,EAAW1J,EAAKuJ,QAAQlc,GAC9B,OAAiB,IAAbqc,EACKT,EAAGjJ,EAAK,IAEb0J,IAAa1J,EAAKra,OAAS,EACtBujB,EAAKlJ,EAAK0J,IAEZP,EAAQ9b,EAAK2S,EAAKA,EAAKuJ,QAAQlc,GAAO,IAAIsc,QAAQ,SAAU,qBACvE,EASIpB,UACGlf,EAEP,CChFA,MAAM4b,GAAQ,CACZne,aAAc,GCAV8iB,GAA8C,eAAzB1P,QAAQC,IAAIC,SAA4BuM,GAAUjC,UAAU,CAACiC,GAAUtS,OAAQsS,GAAUjS,OAAQiS,GAAUpI,OAAQoI,GAAU/D,QAAU,CAAE,ECApK,SAASiH,GAAMf,EAAKje,GAClB,OAAKA,EAGEid,GAAUgB,EAAKje,EAAM,CAC1Bkd,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,GAAI5b,GAAO,qBAAqBkU,GAAOlU,SAEnC0c,GAA0B,CAC9BC,iBAAkBC,IAAkB,CAClChB,GAAI5b,IACF,IAAI6c,EAAwB,iBAAR7c,EAAmBA,EAAMkU,GAAOlU,IAAQA,EAI5D,MAHsB,iBAAX6c,IACTA,EAAS,GAAGA,OAEPD,EAAgB,cAAcA,gBAA4BC,KAAY,yBAAyBA,SAIrG,SAASC,GAAkBnqB,EAAOyjB,EAAW2G,GAClD,MAAMroB,EAAQ/B,EAAM+B,OAAS,CAAE,EAC/B,GAAIyD,MAAMC,QAAQge,GAAY,CAC5B,MAAM4G,EAAmBtoB,EAAMkmB,aAAe6B,GAC9C,OAAOrG,EAAUoF,QAAO,CAACC,EAAKje,EAAMyf,KAClCxB,EAAIuB,EAAiBpB,GAAGoB,EAAiBrK,KAAKsK,KAAWF,EAAmB3G,EAAU6G,IAC/ExB,IACN,GACP,CACE,GAAyB,iBAAdrF,EAAwB,CACjC,MAAM4G,EAAmBtoB,EAAMkmB,aAAe6B,GAC9C,OAAO/K,OAAOiB,KAAKyD,GAAWoF,QAAO,CAACC,EAAKhrB,KACzC,GCpBwBysB,EDoBNF,EAAiBrK,KCnBtB,OAD2BrnB,EDoBCmF,ICnBrBnF,EAAM6xB,WAAW,OAASD,EAAe3gB,MAAKyD,GAAO1U,EAAM6xB,WAAW,IAAInd,QAAa1U,EAAM8xB,MAAM,SDmBjE,CACpD,MAAMC,EClBP,SAA2B3oB,EAAO4oB,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,EACpCjyB,EAAQmgB,OAAOH,OAAOmS,GAAkBA,GAAkB,GAAKA,EACrE,OAAO/oB,EAAMioB,iBAAiBC,GAAehB,GAAGtwB,EAClD,CDO6BoyB,CAAkBhpB,EAAMioB,iBAAmBjoB,EAAQgoB,GAAyBjsB,GAC7F4sB,IACF5B,EAAI4B,GAAgBN,EAAmB3G,EAAU3lB,GAAaA,GAExE,MAEW,GAAIihB,OAAOiB,KAAKqK,EAAiB9I,QAAUA,IAAQyJ,SAASltB,GAAa,CAE5EgrB,EADiBuB,EAAiBpB,GAAGnrB,IACrBssB,EAAmB3G,EAAU3lB,GAAaA,EAClE,KAAa,CACL,MAAMmtB,EAASntB,EACfgrB,EAAImC,GAAUxH,EAAUwH,EAChC,CCjCO,IAAuBV,EAAgB5xB,EDkCxC,OAAOmwB,IACN,GACP,CAEE,OADesB,EAAmB3G,EAEpC,CE7De,SAASyH,GAAWxW,GACjC,GAAsB,iBAAXA,EACT,MAAM,IAAI0M,MAA+B,eAAzBlH,QAAQC,IAAIC,SAA4B,uDAAyDyQ,GAAoB,IAEvI,OAAOnW,EAAOsE,OAAO,GAAGC,cAAgBvE,EAAOwE,MAAM,EACvD,CCPO,SAASiS,GAAQpC,EAAKriB,EAAM0kB,GAAY,GAC7C,IAAK1kB,GAAwB,iBAATA,EAClB,OAAO,KAIT,GAAIqiB,GAAOA,EAAIsC,MAAQD,EAAW,CAChC,MAAM9K,EAAM,QAAQ5Z,IAAOoZ,MAAM,KAAK+I,QAAO,CAACC,EAAKje,IAASie,GAAOA,EAAIje,GAAQie,EAAIje,GAAQ,MAAMke,GACjG,GAAW,MAAPzI,EACF,OAAOA,CAEb,CACE,OAAO5Z,EAAKoZ,MAAM,KAAK+I,QAAO,CAACC,EAAKje,IAC9Bie,GAAoB,MAAbA,EAAIje,GACNie,EAAIje,GAEN,MACNke,EACL,CACO,SAASuC,GAAcC,EAAcviB,EAAWwiB,EAAgBC,EAAYD,GACjF,IAAI7yB,EAWJ,OATEA,EAD0B,mBAAjB4yB,EACDA,EAAaC,GACZhmB,MAAMC,QAAQ8lB,GACfA,EAAaC,IAAmBC,EAEhCN,GAAQI,EAAcC,IAAmBC,EAE/CziB,IACFrQ,EAAQqQ,EAAUrQ,EAAO8yB,EAAWF,IAE/B5yB,CACT,CACA,SAAS4D,GAAM4U,GACb,MAAMrP,KACJA,EAAI4pB,YACJA,EAAcva,EAAQrP,KAAI6pB,SAC1BA,EAAQ3iB,UACRA,GACEmI,EAIEya,EAAK5rB,IACT,GAAmB,MAAfA,EAAM8B,GACR,OAAO,KAET,MAAM2hB,EAAYzjB,EAAM8B,GAElBypB,EAAeJ,GADPnrB,EAAM+B,MACgB4pB,IAAa,CAAE,EAcnD,OAAOxB,GAAkBnqB,EAAOyjB,GAbL+H,IACzB,IAAI7yB,EAAQ2yB,GAAcC,EAAcviB,EAAWwiB,GAKnD,OAJIA,IAAmB7yB,GAAmC,iBAAnB6yB,IAErC7yB,EAAQ2yB,GAAcC,EAAcviB,EAAW,GAAGlH,IAA0B,YAAnB0pB,EAA+B,GAAKN,GAAWM,KAAmBA,KAEzG,IAAhBE,EACK/yB,EAEF,CACL+yB,CAACA,GAAc/yB,OASrB,OAJAizB,EAAGC,UAAqC,eAAzB3R,QAAQC,IAAIC,SAA4B,CACrDtY,CAACA,GAAO8nB,IACN,CAAE,EACNgC,EAAGE,YAAc,CAAChqB,GACX8pB,CACT,CCpEA,MAAMG,GAAa,CACjB/Q,EAAG,SACHC,EAAG,WAEC+Q,GAAa,CACjB3mB,EAAG,MACHF,EAAG,QACHoV,EAAG,SACHQ,EAAG,OACHhF,EAAG,CAAC,OAAQ,SACZqF,EAAG,CAAC,MAAO,WAEP6Q,GAAU,CACdC,QAAS,KACTC,QAAS,KACTC,SAAU,KACVC,SAAU,MAMNC,GC3BS,SAAiBV,GAC9B,MAAMW,EAAQ,CAAE,EAChB,OAAOxS,SACc5Z,IAAfosB,EAAMxS,KACRwS,EAAMxS,GAAO6R,EAAG7R,IAEXwS,EAAMxS,GAEjB,CDmByByS,EAAQ1qB,IAE/B,GAAIA,EAAK6D,OAAS,EAAG,CACnB,IAAIsmB,GAAQnqB,GAGV,MAAO,CAACA,GAFRA,EAAOmqB,GAAQnqB,EAIrB,CACE,MAAOuZ,EAAGd,GAAKzY,EAAKge,MAAM,IACpB2M,EAAWV,GAAW1Q,GACtB/O,EAAY0f,GAAWzR,IAAM,GACnC,OAAO/U,MAAMC,QAAQ6G,GAAaA,EAAUV,KAAI8gB,GAAOD,EAAWC,IAAO,CAACD,EAAWngB,MAE1EqgB,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,GAAgB/qB,EAAO4pB,EAAUoB,EAAczJ,GAC7D,MAAM0J,EAAe7B,GAAQppB,EAAO4pB,GAAU,IAASoB,EACvD,MAA4B,iBAAjBC,GAAqD,iBAAjBA,EACtC1M,GACc,iBAARA,EACFA,GAEoB,eAAzBpG,QAAQC,IAAIC,UACK,iBAARkG,GACT3b,QAAQjF,MAAM,iBAAiB4jB,8CAAqDhD,MAG5D,iBAAjB0M,EACLA,EAAaxC,WAAW,SAAmB,IAARlK,EAC9B,EAEL0M,EAAaxC,WAAW,SAAmB,IAARlK,EAC9B0M,EAEF,QAAQ1M,OAAS0M,KAEnBA,EAAe1M,GAGtB9a,MAAMC,QAAQunB,GACT1M,IACL,GAAmB,iBAARA,EACT,OAAOA,EAET,MAAM2M,EAAMC,KAAKD,IAAI3M,GACQ,eAAzBpG,QAAQC,IAAIC,WACTtB,OAAOqU,UAAUF,GAEXA,EAAMD,EAAarnB,OAAS,GACrChB,QAAQjF,MAAM,CAAC,4BAA4ButB,gBAAmB,6BAA6B1I,KAAKC,UAAUwI,MAAkB,GAAGC,OAASD,EAAarnB,OAAS,0CAA0Cia,KAAK,OAF7Mjb,QAAQjF,MAAM,CAAC,oBAAoBisB,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,UACdzV,QAAQjF,MAAM,CAAC,oBAAoBisB,cAAqBqB,iBAA6B,kDAAkDpN,KAAK,OAEvI,OACT,CACO,SAASyN,GAAmBtrB,GACjC,OAAO+qB,GAAgB/qB,EAAO,UAAW,EAAG,UAC9C,CACO,SAASsP,GAASic,EAAa7J,GACpC,MAAyB,iBAAdA,GAAuC,MAAbA,EAC5BA,EAEF6J,EAAY7J,EACrB,CAOA,SAAS8J,GAAmBvtB,EAAOggB,EAAMle,EAAMwrB,GAG7C,IAAKtN,EAAKgL,SAASlpB,GACjB,OAAO,KAET,MACMsoB,EAbD,SAA+BoD,EAAeF,GACnD,OAAO7J,GAAa+J,EAAc3E,QAAO,CAACC,EAAK4C,KAC7C5C,EAAI4C,GAAera,GAASic,EAAa7J,GAClCqF,IACN,GACL,CAQ6B2E,CADLnB,GAAiBxqB,GACyBwrB,GAEhE,OAAOnD,GAAkBnqB,EADPA,EAAM8B,GACmBsoB,EAC7C,CACA,SAAS7tB,GAAMyD,EAAOggB,GACpB,MAAMsN,EAAcD,GAAmBrtB,EAAM+B,OAC7C,OAAOgd,OAAOiB,KAAKhgB,GAAO4L,KAAI9J,GAAQyrB,GAAmBvtB,EAAOggB,EAAMle,EAAMwrB,KAAczE,OAAOgB,GAAO,GAC1G,CACO,SAAS6D,GAAO1tB,GACrB,OAAOzD,GAAMyD,EAAO2sB,GACtB,CAMO,SAAS5kB,GAAQ/H,GACtB,OAAOzD,GAAMyD,EAAO4sB,GACtB,CE7IA,SAASe,MAAWC,GAClB,MAAMC,EAAWD,EAAO/E,QAAO,CAACC,EAAKvsB,KACnCA,EAAMuvB,YAAYhS,SAAQhY,IACxBgnB,EAAIhnB,GAAQvF,KAEPusB,IACN,IAIG8C,EAAK5rB,GACF+e,OAAOiB,KAAKhgB,GAAO6oB,QAAO,CAACC,EAAKhnB,IACjC+rB,EAAS/rB,GACJ+nB,GAAMf,EAAK+E,EAAS/rB,GAAM9B,IAE5B8oB,GACN,IAIL,OAFA8C,EAAGC,UAAqC,eAAzB3R,QAAQC,IAAIC,SAA4BwT,EAAO/E,QAAO,CAACC,EAAKvsB,IAAUwiB,OAAOM,OAAOyJ,EAAKvsB,EAAMsvB,YAAY,CAAE,GAAI,CAAE,EAClID,EAAGE,YAAc8B,EAAO/E,QAAO,CAACC,EAAKvsB,IAAUusB,EAAIgF,OAAOvxB,EAAMuvB,cAAc,IACvEF,CACT,CCjBO,SAASmC,GAAgBp1B,GAC9B,MAAqB,iBAAVA,EACFA,EAEF,GAAGA,WACZ,CACA,SAASq1B,GAAkBlsB,EAAMkH,GAC/B,OAAOzM,GAAM,CACXuF,OACA6pB,SAAU,UACV3iB,aAEJ,CHsHA0kB,GAAO7B,UAAqC,eAAzB3R,QAAQC,IAAIC,SAA4BuS,GAAW9D,QAAO,CAACE,EAAK1b,KACjF0b,EAAI1b,GAAOuc,GACJb,IACN,CAAA,GAAM,CAAE,EACX2E,GAAO5B,YAAca,GAIrB5kB,GAAQ8jB,UAAqC,eAAzB3R,QAAQC,IAAIC,SAA4BwS,GAAY/D,QAAO,CAACE,EAAK1b,KACnF0b,EAAI1b,GAAOuc,GACJb,IACN,CAAA,GAAM,CAAE,EACXhhB,GAAQ+jB,YAAcc,GAIuB,eAAzB1S,QAAQC,IAAIC,UAA4ByS,GAAYhE,QAAO,CAACE,EAAK1b,KACnF0b,EAAI1b,GAAOuc,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,gBAIjClnB,GAAe9G,IAC1B,QAA2BG,IAAvBH,EAAM8G,cAAqD,OAAvB9G,EAAM8G,aAAuB,CACnE,MAAMwmB,EAAcR,GAAgB9sB,EAAM+B,MAAO,qBAAsB,EAAG,gBACpEqoB,EAAqB3G,IAAc,CACvC3c,aAAcuK,GAASic,EAAa7J,KAEtC,OAAO0G,GAAkBnqB,EAAOA,EAAM8G,aAAcsjB,EACxD,CACE,OAAO,MAETtjB,GAAa+kB,UAAqC,eAAzB3R,QAAQC,IAAIC,SAA4B,CAC/DtT,aAAc8iB,IACZ,CAAE,EACN9iB,GAAaglB,YAAc,CAAC,gBACZ6B,GAAQM,GAAQC,GAAWC,GAAaC,GAAcC,GAAYC,GAAaC,GAAgBC,GAAkBC,GAAmBC,GAAiB5nB,GAAc6nB,GAASC,ICvCrL,MAAMC,GAAM7uB,IACjB,QAAkBG,IAAdH,EAAM6uB,KAAmC,OAAd7uB,EAAM6uB,IAAc,CACjD,MAAMvB,EAAcR,GAAgB9sB,EAAM+B,MAAO,UAAW,EAAG,OACzDqoB,EAAqB3G,IAAc,CACvCoL,IAAKxd,GAASic,EAAa7J,KAE7B,OAAO0G,GAAkBnqB,EAAOA,EAAM6uB,IAAKzE,EAC/C,CACE,OAAO,MAETyE,GAAIhD,UAAqC,eAAzB3R,QAAQC,IAAIC,SAA4B,CACtDyU,IAAKjF,IACH,CAAE,EACNiF,GAAI/C,YAAc,CAAC,OAIZ,MAAMgD,GAAY9uB,IACvB,QAAwBG,IAApBH,EAAM8uB,WAA+C,OAApB9uB,EAAM8uB,UAAoB,CAC7D,MAAMxB,EAAcR,GAAgB9sB,EAAM+B,MAAO,UAAW,EAAG,aACzDqoB,EAAqB3G,IAAc,CACvCqL,UAAWzd,GAASic,EAAa7J,KAEnC,OAAO0G,GAAkBnqB,EAAOA,EAAM8uB,UAAW1E,EACrD,CACE,OAAO,MAET0E,GAAUjD,UAAqC,eAAzB3R,QAAQC,IAAIC,SAA4B,CAC5D0U,UAAWlF,IACT,CAAE,EACNkF,GAAUhD,YAAc,CAAC,aAIlB,MAAMiD,GAAS/uB,IACpB,QAAqBG,IAAjBH,EAAM+uB,QAAyC,OAAjB/uB,EAAM+uB,OAAiB,CACvD,MAAMzB,EAAcR,GAAgB9sB,EAAM+B,MAAO,UAAW,EAAG,UACzDqoB,EAAqB3G,IAAc,CACvCsL,OAAQ1d,GAASic,EAAa7J,KAEhC,OAAO0G,GAAkBnqB,EAAOA,EAAM+uB,OAAQ3E,EAClD,CACE,OAAO,MAET2E,GAAOlD,UAAqC,eAAzB3R,QAAQC,IAAIC,SAA4B,CACzD2U,OAAQnF,IACN,CAAE,EACNmF,GAAOjD,YAAc,CAAC,UCrDf,SAASkD,GAAiBr2B,EAAO8yB,GACtC,MAAkB,SAAdA,EACKA,EAEF9yB,CACT,CD4Eag1B,GAAQkB,GAAKC,GAAWC,GA3BXxyB,GAAM,CAC9BuF,KAAM,eAEevF,GAAM,CAC3BuF,KAAM,YAEoBvF,GAAM,CAChCuF,KAAM,iBAEuBvF,GAAM,CACnCuF,KAAM,oBAEoBvF,GAAM,CAChCuF,KAAM,iBAE2BvF,GAAM,CACvCuF,KAAM,wBAEwBvF,GAAM,CACpCuF,KAAM,qBAEyBvF,GAAM,CACrCuF,KAAM,sBAEgBvF,GAAM,CAC5BuF,KAAM,cE9ED,SAASmtB,GAAgBt2B,GAC9B,OAAOA,GAAS,GAAe,IAAVA,EAAyB,IAARA,EAAH,IAAoBA,CACzD,CDmBgBg1B,GAhBKpxB,GAAM,CACzBuF,KAAM,QACN6pB,SAAU,UACV3iB,UAAWgmB,KAEUzyB,GAAM,CAC3BuF,KAAM,UACN4pB,YAAa,kBACbC,SAAU,UACV3iB,UAAWgmB,KAEkBzyB,GAAM,CACnCuF,KAAM,kBACN6pB,SAAU,UACV3iB,UAAWgmB,MChBN,MAAMxsB,GAAQjG,GAAM,CACzBuF,KAAM,QACNkH,UAAWimB,KAEA5iB,GAAWrM,IACtB,QAAuBG,IAAnBH,EAAMqM,UAA6C,OAAnBrM,EAAMqM,SAAmB,CAC3D,MAAM+d,EAAqB3G,IACzB,MAAM3lB,EAAakC,EAAM+B,OAAOkmB,aAAa1G,SAASkC,IAAcyL,GAAkBzL,GACtF,OAAK3lB,EAKkC,OAAnCkC,EAAM+B,OAAOkmB,aAAaM,KACrB,CACLlc,SAAU,GAAGvO,IAAakC,EAAM+B,MAAMkmB,YAAYM,QAG/C,CACLlc,SAAUvO,GAVH,CACLuO,SAAU4iB,GAAgBxL,KAYhC,OAAO0G,GAAkBnqB,EAAOA,EAAMqM,SAAU+d,EACpD,CACE,OAAO,MAET/d,GAASyf,YAAc,CAAC,YACjB,MAAMqD,GAAW5yB,GAAM,CAC5BuF,KAAM,WACNkH,UAAWimB,KAEApoB,GAAStK,GAAM,CAC1BuF,KAAM,SACNkH,UAAWimB,KAEA1iB,GAAYhQ,GAAM,CAC7BuF,KAAM,YACNkH,UAAWimB,KAEAG,GAAY7yB,GAAM,CAC7BuF,KAAM,YACNkH,UAAWimB,KAEY1yB,GAAM,CAC7BuF,KAAM,OACN4pB,YAAa,QACb1iB,UAAWimB,KAEa1yB,GAAM,CAC9BuF,KAAM,OACN4pB,YAAa,SACb1iB,UAAWimB,KAKEtB,GAAQnrB,GAAO6J,GAAU8iB,GAAUtoB,GAAQ0F,GAAW6iB,GAH5C7yB,GAAM,CAC7BuF,KAAM,eCvDR,MAAMutB,GAAkB,CAEtBpB,OAAQ,CACNtC,SAAU,UACV3iB,UAAW+kB,IAEbG,UAAW,CACTvC,SAAU,UACV3iB,UAAW+kB,IAEbI,YAAa,CACXxC,SAAU,UACV3iB,UAAW+kB,IAEbK,aAAc,CACZzC,SAAU,UACV3iB,UAAW+kB,IAEbM,WAAY,CACV1C,SAAU,UACV3iB,UAAW+kB,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,UACV3iB,UAAW+kB,IAEba,aAAc,CACZjD,SAAU,WAEZ7kB,aAAc,CACZ6kB,SAAU,qBACVpvB,MAAOuK,IAGT1D,MAAO,CACLuoB,SAAU,UACV3iB,UAAWgmB,IAEbjoB,QAAS,CACP4kB,SAAU,UACVD,YAAa,kBACb1iB,UAAWgmB,IAEb3mB,gBAAiB,CACfsjB,SAAU,UACV3iB,UAAWgmB,IAGb/T,EAAG,CACD1e,MAAOwL,IAETunB,GAAI,CACF/yB,MAAOwL,IAETwnB,GAAI,CACFhzB,MAAOwL,IAETynB,GAAI,CACFjzB,MAAOwL,IAET0nB,GAAI,CACFlzB,MAAOwL,IAET2nB,GAAI,CACFnzB,MAAOwL,IAET4nB,GAAI,CACFpzB,MAAOwL,IAETA,QAAS,CACPxL,MAAOwL,IAET6nB,WAAY,CACVrzB,MAAOwL,IAETC,aAAc,CACZzL,MAAOwL,IAET8nB,cAAe,CACbtzB,MAAOwL,IAET+nB,YAAa,CACXvzB,MAAOwL,IAETqkB,SAAU,CACR7vB,MAAOwL,IAETskB,SAAU,CACR9vB,MAAOwL,IAETgoB,cAAe,CACbxzB,MAAOwL,IAETioB,mBAAoB,CAClBzzB,MAAOwL,IAETkoB,iBAAkB,CAChB1zB,MAAOwL,IAETmoB,aAAc,CACZ3zB,MAAOwL,IAETooB,kBAAmB,CACjB5zB,MAAOwL,IAETqoB,gBAAiB,CACf7zB,MAAOwL,IAETiT,EAAG,CACDze,MAAOmxB,IAET2C,GAAI,CACF9zB,MAAOmxB,IAETlqB,GAAI,CACFjH,MAAOmxB,IAET4C,GAAI,CACF/zB,MAAOmxB,IAETjqB,GAAI,CACFlH,MAAOmxB,IAETxmB,GAAI,CACF3K,MAAOmxB,IAET6C,GAAI,CACFh0B,MAAOmxB,IAETA,OAAQ,CACNnxB,MAAOmxB,IAET5lB,UAAW,CACTvL,MAAOmxB,IAEThrB,YAAa,CACXnG,MAAOmxB,IAET7lB,aAAc,CACZtL,MAAOmxB,IAETjrB,WAAY,CACVlG,MAAOmxB,IAETxB,QAAS,CACP3vB,MAAOmxB,IAETvB,QAAS,CACP5vB,MAAOmxB,IAET8C,aAAc,CACZj0B,MAAOmxB,IAET+C,kBAAmB,CACjBl0B,MAAOmxB,IAETgD,gBAAiB,CACfn0B,MAAOmxB,IAETiD,YAAa,CACXp0B,MAAOmxB,IAETkD,iBAAkB,CAChBr0B,MAAOmxB,IAETmD,eAAgB,CACdt0B,MAAOmxB,IAGToD,aAAc,CACZpF,aAAa,EACb1iB,UAAWrQ,IAAU,CACnB,eAAgB,CACd+K,QAAS/K,MAIf+K,QAAS,CAAE,EACXqtB,SAAU,CAAE,EACZC,aAAc,CAAE,EAChBC,WAAY,CAAE,EACdC,WAAY,CAAE,EAEdC,UAAW,CAAE,EACbvpB,cAAe,CAAE,EACjBwpB,SAAU,CAAE,EACZlsB,eAAgB,CAAE,EAClBH,WAAY,CAAE,EACdssB,aAAc,CAAE,EAChBC,MAAO,CAAE,EACTntB,KAAM,CAAE,EACRiI,SAAU,CAAE,EACZU,WAAY,CAAE,EACdykB,UAAW,CAAE,EACbC,aAAc,CAAE,EAChBC,YAAa,CAAE,EAEf5C,IAAK,CACHtyB,MAAOsyB,IAETE,OAAQ,CACNxyB,MAAOwyB,IAETD,UAAW,CACTvyB,MAAOuyB,IAET4C,WAAY,CAAE,EACdC,QAAS,CAAE,EACXC,aAAc,CAAE,EAChBC,gBAAiB,CAAE,EACnBC,aAAc,CAAE,EAChBC,oBAAqB,CAAE,EACvBC,iBAAkB,CAAE,EACpBC,kBAAmB,CAAE,EACrBhd,SAAU,CAAE,EAEZlS,SAAU,CAAE,EACZkE,OAAQ,CACN0kB,SAAU,UAEZvjB,IAAK,CAAE,EACP8pB,MAAO,CAAE,EACTC,OAAQ,CAAE,EACVhqB,KAAM,CAAE,EAERiqB,UAAW,CACTzG,SAAU,WAGZnpB,MAAO,CACLwG,UAAWimB,IAEb5iB,SAAU,CACR9P,MAAO8P,IAET8iB,SAAU,CACRnmB,UAAWimB,IAEbpoB,OAAQ,CACNmC,UAAWimB,IAEb1iB,UAAW,CACTvD,UAAWimB,IAEbG,UAAW,CACTpmB,UAAWimB,IAEbliB,UAAW,CAAE,EAEbslB,KAAM,CACJ1G,SAAU,QAEZ2G,WAAY,CACV3G,SAAU,cAEZliB,SAAU,CACRkiB,SAAU,cAEZ4G,UAAW,CACT5G,SAAU,cAEZziB,WAAY,CACVyiB,SAAU,cAEZ6G,cAAe,CAAE,EACjBC,cAAe,CAAE,EACjBC,WAAY,CAAE,EACdzlB,UAAW,CAAE,EACb0lB,WAAY,CACVjH,aAAa,EACbC,SAAU,eCtKd,MAAMiH,GA5GC,WACL,SAASC,EAAc/wB,EAAMwe,EAAKve,EAAO+wB,GACvC,MAAM9yB,EAAQ,CACZ8B,CAACA,GAAOwe,EACRve,SAEIoP,EAAU2hB,EAAOhxB,GACvB,IAAKqP,EACH,MAAO,CACLrP,CAACA,GAAOwe,GAGZ,MAAMoL,YACJA,EAAc5pB,EAAI6pB,SAClBA,EAAQ3iB,UACRA,EAASzM,MACTA,GACE4U,EACJ,GAAW,MAAPmP,EACF,OAAO,KAIT,GAAiB,eAAbqL,GAAqC,YAARrL,EAC/B,MAAO,CACLxe,CAACA,GAAOwe,GAGZ,MAAMiL,EAAeJ,GAAQppB,EAAO4pB,IAAa,CAAE,EACnD,GAAIpvB,EACF,OAAOA,EAAMyD,GAef,OAAOmqB,GAAkBnqB,EAAOsgB,GAbLkL,IACzB,IAAI7yB,EAAQ0Y,GAASka,EAAcviB,EAAWwiB,GAK9C,OAJIA,IAAmB7yB,GAAmC,iBAAnB6yB,IAErC7yB,EAAQ0Y,GAASka,EAAcviB,EAAW,GAAGlH,IAA0B,YAAnB0pB,EAA+B,GAAKN,GAAWM,KAAmBA,KAEpG,IAAhBE,EACK/yB,EAEF,CACL+yB,CAACA,GAAc/yB,KAIvB,CA4DE,OA3DA,SAASi6B,EAAgB5yB,GACvB,MAAMuD,GACJA,EAAExB,MACFA,EAAQ,CAAA,GACN/B,GAAS,CAAE,EACf,IAAKuD,EACH,OAAO,KAET,MAAMuvB,EAAS/wB,EAAMgxB,mBAAqB1D,GAO1C,SAAS2D,EAASC,GAChB,IAAIC,EAAWD,EACf,GAAuB,mBAAZA,EACTC,EAAWD,EAAQlxB,QACd,GAAuB,iBAAZkxB,EAEhB,OAAOA,EAET,IAAKC,EACH,OAAO,KAET,MAAMC,EZQL,SAAqCC,EAAmB,IAC7D,MAAMC,EAAqBD,EAAiBpT,MAAM6I,QAAO,CAACC,EAAKzb,KAE7Dyb,EAD2BsK,EAAiBnK,GAAG5b,IACrB,CAAE,EACrByb,IACN,IACH,OAAOuK,GAAsB,CAAE,CACjC,CYf+BC,CAA4BvxB,EAAMkmB,aACrDsL,EAAkBxU,OAAOiB,KAAKmT,GACpC,IAAIl3B,EAAMk3B,EA2BV,OA1BApU,OAAOiB,KAAKkT,GAAUpZ,SAAQ0Z,IAC5B,MAAM76B,GAlFI86B,EAkFaP,EAASM,GAlFbzZ,EAkFwBhY,EAjFvB,mBAAZ0xB,EAAyBA,EAAQ1Z,GAAO0Z,GADxD,IAAkBA,EAAS1Z,EAmFnB,GAAIphB,QACF,GAAqB,iBAAVA,EACT,GAAIm6B,EAAOU,GACTv3B,EAAM4tB,GAAM5tB,EAAK42B,EAAcW,EAAU76B,EAAOoJ,EAAO+wB,QAClD,CACL,MAAM5D,EAAoB/E,GAAkB,CAC1CpoB,SACCpJ,GAAOod,IAAM,CACdyd,CAACA,GAAWzd,OAhG5B,YAAgC2d,GAC9B,MAAMrO,EAAUqO,EAAQ7K,QAAO,CAAC7I,EAAMzB,IAAWyB,EAAK8N,OAAO/O,OAAOiB,KAAKzB,KAAU,IAC7EoV,EAAQ,IAAIxd,IAAIkP,GACtB,OAAOqO,EAAQ3N,OAAMxH,GAAUoV,EAAMrkB,OAASyP,OAAOiB,KAAKzB,GAAQ5Y,QACpE,CA8FkBiuB,CAAoB1E,EAAmBv2B,GAMzCsD,EAAM4tB,GAAM5tB,EAAKizB,GALjBjzB,EAAIu3B,GAAYZ,EAAgB,CAC9BrvB,GAAI5K,EACJoJ,SAKlB,MAEY9F,EAAM4tB,GAAM5tB,EAAK42B,EAAcW,EAAU76B,EAAOoJ,EAAO+wB,OX3G5D,SAA8B/wB,EAAO9F,GAC1C,IAAK8F,EAAMioB,iBACT,OAAO/tB,EAET,MAAM43B,EAAS9U,OAAOiB,KAAK/jB,GAAK0P,QAAO0B,GAAOA,EAAImd,WAAW,gBAAe9B,MAAK,CAACrN,EAAGd,KACnF,MAAMuZ,EAAQ,yBACd,QAASzY,EAAEoP,MAAMqJ,KAAS,IAAM,KAAOvZ,EAAEkQ,MAAMqJ,KAAS,IAAM,MAEhE,OAAKD,EAAOluB,OAGLkuB,EAAOhL,QAAO,CAACC,EAAKzb,KACzB,MAAM1U,EAAQsD,EAAIoR,GAGlB,cAFOyb,EAAIzb,GACXyb,EAAIzb,GAAO1U,EACJmwB,IACN,IACE7sB,IARIA,CAUX,CW4Fa83B,CAAqBhyB,EZb3B,SAAiCwoB,EAAgBhuB,GACtD,OAAOguB,EAAe1B,QAAO,CAACC,EAAKzb,KACjC,MAAM2mB,EAAmBlL,EAAIzb,GAK7B,QAJ4B2mB,GAA6D,IAAzCjV,OAAOiB,KAAKgU,GAAkBruB,gBAErEmjB,EAAIzb,GAENyb,IACNvsB,EACL,CYIyC03B,CAAwBV,EAAiBt3B,GAClF,CACI,OAAOuJ,MAAMC,QAAQlC,GAAMA,EAAGqI,IAAIonB,GAAYA,EAASzvB,EAC3D,CAEA,CACwB2wB,GC9DT,SAASzsB,GAAY4F,EAAKugB,GAEvC,MAAM7rB,EAAQujB,KACd,GAAIvjB,EAAMspB,KAAM,CACd,IAAKtpB,EAAMoyB,eAAe9mB,IAAgD,mBAAjCtL,EAAMqyB,uBAC7C,MAAO,CAAE,EAGX,IAAIC,EAAWtyB,EAAMqyB,uBAAuB/mB,GAC5C,MAAiB,MAAbgnB,EACKzG,IAELyG,EAASrJ,SAAS,UAAYqJ,EAASrJ,SAAS,QAElDqJ,EAAW,WAAWA,EAAS1K,QAAQ,QAAS,UAE3C,CACL0K,CAACA,GAAWzG,GAElB,CACE,OAAI7rB,EAAM3E,QAAQC,OAASgQ,EAClBugB,EAEF,CAAE,CACX,CC/EA,SAAShhB,GAAS0nB,EAAe,MAC/B,MAAMC,EAAexqB,EAAMyqB,WAAWC,GACtC,OAAQF,IALaxL,EAKiBwL,EAJH,IAA5BxV,OAAOiB,KAAK+I,GAAKpjB,QAI6C4uB,EAAfD,EALxD,IAAuBvL,CAMvB,CFmHA6J,GAAgB9G,YAAc,CAAC,MGzHxB,MAAM4I,GCIb,SAAqBvjB,EAAU,MAAOyI,GACpC,MACEqO,YAAamL,EAAmB,CAAE,EAClCh2B,QAASu3B,EAAe,CAAE,EAC1BntB,QAASotB,EACT3P,MAAO4P,EAAa,CAAE,KACnBxrB,GACD8H,EACE8W,EAAcD,GAAkBoL,GAChC5rB,ECZO,SAAuBotB,EAAe,EAIrD5rB,EAAYqkB,GAAmB,CAC7B7lB,QAASotB,KAGT,GAAIA,EAAaE,IACf,OAAOF,EAET,MAAMptB,EAAU,IAAIutB,KACW,eAAzB7a,QAAQC,IAAIC,WACR2a,EAAUpvB,QAAU,GACxBhB,QAAQjF,MAAM,mEAAmEq1B,EAAUpvB,YAG7D,IAArBovB,EAAUpvB,OAAe,CAAC,GAAKovB,GAChCnpB,KAAIopB,IACd,MAAMnN,EAAS7e,EAAUgsB,GACzB,MAAyB,iBAAXnN,EAAsB,GAAGA,MAAaA,KACnDjI,KAAK,MAGV,OADApY,EAAQstB,KAAM,EACPttB,CACT,CDbkBytB,CAAcL,GAC9B,IAAIM,EAAWpN,GAAU,CACvBG,cACA3b,UAAW,MACXrP,WAAY,CAAE,EAEdG,QAAS,CACPC,KAAM,WACHs3B,GAELntB,UACAyd,MAAO,IACFA,MACA4P,IAEJxrB,GAcH,OAbA6rB,EfSa,SAA6BC,GAC1C,MAAMC,EAAmB,CAACC,EAAY79B,IAAS69B,EAAW1L,QAAQ,SAAUnyB,EAAO,cAAcA,IAAS,cAC1G,SAAS89B,EAASjvB,EAAM7O,GACtB6O,EAAK4iB,GAAK,IAAIrP,IAASwb,EAAiBD,EAAWlN,YAAYgB,MAAMrP,GAAOpiB,GAC5E6O,EAAK6iB,KAAO,IAAItP,IAASwb,EAAiBD,EAAWlN,YAAYiB,QAAQtP,GAAOpiB,GAChF6O,EAAK8iB,QAAU,IAAIvP,IAASwb,EAAiBD,EAAWlN,YAAYkB,WAAWvP,GAAOpiB,GACtF6O,EAAKmjB,KAAO,IAAI5P,IAASwb,EAAiBD,EAAWlN,YAAYuB,QAAQ5P,GAAOpiB,GAChF6O,EAAKojB,IAAM,IAAI7P,KACb,MAAMsQ,EAASkL,EAAiBD,EAAWlN,YAAYwB,OAAO7P,GAAOpiB,GACrE,OAAI0yB,EAAOc,SAAS,eAEXd,EAAOP,QAAQ,eAAgB,IAAIA,QAAQ,aAAc,UAAUA,QAAQ,aAAc,UAAUA,QAAQ,MAAO,MAEpHO,EAEb,CACE,MAAM7jB,EAAO,CAAE,EACT2jB,EAAmBxyB,IACvB89B,EAASjvB,EAAM7O,GACR6O,GAGT,OADAivB,EAAStL,GACF,IACFmL,EACHnL,mBAEJ,CenCauL,CAAoBL,GAC/BA,EAASztB,YAAcA,GACvBytB,EAAWtb,EAAKiP,QAAO,CAACC,EAAKkM,IAAalN,GAAUgB,EAAKkM,IAAWE,GACpEA,EAASnC,kBAAoB,IACxB1D,MACAhmB,GAAO0pB,mBAEZmC,EAASM,YAAc,SAAYx1B,GACjC,OAAO4yB,GAAgB,CACrBrvB,GAAIvD,EACJ+B,MAAOujB,MAEV,EACM4P,CACT,CD3CkCO,GGanB,SAASC,GAAa11B,GACnC,MACEuD,GAAIoyB,KACDtsB,GACDrJ,GACE41B,YACJA,EAAWC,WACXA,GAtBe71B,KACjB,MAAMkqB,EAAS,CACb0L,YAAa,CAAE,EACfC,WAAY,CAAA,GAER/C,EAAS9yB,GAAO+B,OAAOgxB,mBAAqB1D,GAQlD,OAPAtQ,OAAOiB,KAAKhgB,GAAO8Z,SAAQhY,IACrBgxB,EAAOhxB,GACTooB,EAAO0L,YAAY9zB,GAAQ9B,EAAM8B,GAEjCooB,EAAO2L,WAAW/zB,GAAQ9B,EAAM8B,MAG7BooB,GAUH4L,CAAWzsB,GACf,IAAI0sB,EAoBJ,OAlBEA,EADEvwB,MAAMC,QAAQkwB,GACN,CAACC,KAAgBD,GACF,mBAATA,EACN,IAAI/b,KACZ,MAAMsQ,EAASyL,KAAQ/b,GACvB,OAAK6N,GAAcyC,GAGZ,IACF0L,KACA1L,GAJI0L,GAQD,IACLA,KACAD,GAGA,IACFE,EACHtyB,GAAIwyB,EAER,CClDA,MAAMC,GAAmBvU,GAAiBA,EAepCwU,GAd2B,MAC/B,IAAIC,EAAWF,GACf,MAAO,CACL,SAAAG,CAAUC,GACRF,EAAWE,CACZ,EACDF,SAASzU,GACAyU,EAASzU,GAElB,KAAA4U,GACEH,EAAWF,EACjB,IAG2BM,GCdpB,MAAMC,GAAqB,CAChCC,OAAQ,SACRnkB,QAAS,UACTokB,UAAW,YACXvsB,SAAU,WACVxK,MAAO,QACPsL,SAAU,WACVE,QAAS,UACTwrB,aAAc,eACdn0B,KAAM,OACNo0B,SAAU,WACVjmB,SAAU,WACVzF,SAAU,YCZZ,MCKMrE,GCES,SAAmBuK,EAAU,IAC1C,MAAMylB,QACJA,EAAOtC,aACPA,EAAYuC,iBACZA,EAAmB,cAAaC,kBAChCA,GACE3lB,EACE4lB;;;;;;;;ACHO,SAAgBC,EAAK7lB,GAClC,MAAM8lB,EAAgBC,GAASF,EAAK7lB,GACpC,MAA6B,eAAzB+I,QAAQC,IAAIC,SACP,IAAIwT,KACT,MAAM1pB,EAAsC,IAAI8yB,KAMhD,OALsB,IAAlBpJ,EAAOjoB,OACThB,QAAQjF,MAAM,CAAC,uCAAuCwE,uCAAgD,gFAAgF0b,KAAK,OAClLgO,EAAOhkB,MAAKrN,QAAmB4D,IAAV5D,KAC9BoI,QAAQjF,MAAM,mBAAmBwE,wDAE5B+yB,KAAiBrJ,IAGrBqJ,CACT,CDXkBt1B,CAAO,MAAO,CAC5BE,kBAAmBC,GAAiB,UAATA,GAA6B,OAATA,GAA0B,OAATA,GADlDH,CAEbixB,IACGhsB,EAAmBmD,EAAMC,YAAW,SAAamtB,EAASj7B,GAC9D,MAAM6F,ERdV,SAAkBuyB,EAAeI,IAC/B,OAAO0C,GAAuB9C,EAChC,CQYkB1nB,CAAS0nB,IACjBvpB,UACJA,EAAS7G,UACTA,EAAY,SACTmF,GACDqsB,GAAayB,GACjB,OAAoBr0B,EAAKi0B,EAAS,CAChCM,GAAInzB,EACJhI,IAAKA,EACL6O,UAAWnF,GAAKmF,EAAW+rB,EAAoBA,EAAkBD,GAAoBA,GACrF90B,MAAO60B,GAAU70B,EAAM60B,IAAoB70B,KACxCsH,GAET,IACE,OAAOzC,CACT,CD5BY0wB,CAAU,CACpBT,iBGNa,SAAgCpV,EAAe/U,EAAO6qB,EAAoB,OACvF,MAAMrN,EAAS,CAAE,EAIjB,OAHAxd,EAAMoN,SAAQ0d,IACZtN,EAAOsN,GLWI,SAA8B/V,EAAe+V,EAAMD,EAAoB,OACpF,MAAME,EAAmBlB,GAAmBiB,GAC5C,OAAOC,EAAmB,GAAGF,KAAqBE,IAAqB,GAAGxB,GAAmBC,SAASzU,MAAkB+V,GAC1H,CKdmBE,CAAqBjW,EAAe+V,EAAMD,MAEpDrN,CACT,CJNmByN,CAAuB,SAAU,CAAC,SCMtBC,KAC7Bd,kBAAmBb,GAAmBC,WAEf,eAAzBhc,QAAQC,IAAIC,WAA4BxT,GAAIilB,UAAmC,CAQ7E7oB,SAAU2jB,GAAUtgB,KAKpBnC,UAAWyiB,GAAUhD,YAIrBpgB,GAAIojB,GAAUjC,UAAU,CAACiC,GAAUvD,QAAQuD,GAAUjC,UAAU,CAACiC,GAAU3D,KAAM2D,GAAUpI,OAAQoI,GAAU5D,QAAS4D,GAAU3D,KAAM2D,GAAUpI,WIzBjJ,MAAMsZ,GACJ73B,GAEO8C,EAACkP,EAAS,IAAKhS,EAAOsQ,UAAW,CAAEwnB,WAAY,CAAErnB,QAAQ,MCK5DsnB,GACJrkB,IAEA,GAAIA,GAASskB,UAAW,CACtB,MAAMh4B,EAAQ0T,EAAQskB,UAChBC,EAAcvkB,GAASukB,aAAe,KACtCC,EAAcxkB,GAASwkB,aAAe,KACtCC,EAAazkB,GAASykB,YAAc,KACpCjkB,EAAiBR,GAASskB,WAAW9jB,WAAa,KAClDC,EAAYT,GAASskB,WAAW7jB,WAAa,KACnD,OAAMnU,GAASi4B,GAAeE,GAAcjkB,GAAaC,OAG/BhU,IAAlBH,GAAOo4B,QAAyBp4B,GAAOo4B,QAC5C1kB,EAAQ2kB,aAAarN,SAAS9W,GAkK/BpR,EAAAkM,EAAA,CAAA,GAjKAlM,EAACw1B,GACChpB,KACEtP,GAAOu4B,WAAWC,WAAa,CAC7BnQ,GAAI,GACJD,GAAI,GACJD,GAAI,IAGR5kB,GAAI,CACFwE,QAAS,EACTvF,MAAO,QACRQ,SAEc,SAAdmR,GAAsC,WAAdA,EACvBrR,EAAC+0B,IACCY,WAAS,EACTh8B,KAAM0X,EACNjK,YACElK,GAAOkK,WAAYwJ,EAAQglB,eAAe1N,SAAS9W,IAIrDkkB,OAAQp4B,GAAOo4B,SAAU,EACzB5xB,MAAOxG,GAAO24B,WACdhgC,MAAOw/B,EAAWjkB,GAClBjE,SAAW/D,IACT,IAAIoF,EAAW,KACW,IAAtBpF,EAAMqG,OAAO5Z,QAEb2Y,EADgB,WAAd6C,GAA0ByE,GAAU1M,EAAMqG,OAAO5Z,OACxCmgB,OAAO5M,EAAMqG,OAAO5Z,OAEpBuT,EAAMqG,OAAO5Z,OAG5Bs/B,EAAYW,SAAS1kB,EAAW5C,GAC5BtR,GAAOu4B,WAAWM,uBACpB74B,GAAOu4B,WAAWM,sBAChBvnB,EACA2mB,EACAC,IAIN30B,GAAIvD,GAAOu4B,WAAWh8B,MACtBmD,MAAkDS,MAA3C83B,EAAYa,UAAUC,OAAO7kB,GACpCtD,WAAYqnB,GAAaa,WAAWC,OAClC7kB,IACC7a,SAAS2/B,aAES,SAArBh5B,GAAOmU,UACTrR,EAAC4M,GACC,CAAAM,OAAQhQ,GAAOi5B,YAAczpB,GAC7BjM,GAAIvD,GAAOu4B,WAAWh8B,OAAS,CAAEiG,MAAO,QACxC0H,YACElK,GAAOkK,WAAYwJ,EAAQglB,eAAe1N,SAAS9W,IAIrD1N,MAAOxG,GAAO24B,WACdtoB,iBAAmBF,IACjB8nB,EAAYW,SAAS1kB,EAAW/D,GAC5BnQ,GAAOu4B,WAAWM,uBACpB74B,GAAOu4B,WAAWM,sBAChB1oB,EACA8nB,EACAC,IAINv/B,MAAOw/B,EAAWjkB,GAClBxU,MAAkDS,MAA3C83B,EAAYa,UAAUC,OAAO7kB,GACpCvD,aAAcsnB,GAAaa,WAAWC,OACpC7kB,IACC7a,SAAS2/B,aAES,aAArBh5B,GAAOmU,UACTrR,EAAC+N,IACCb,OAAQhQ,GAAOi5B,YAAcxpB,GAC7BlM,GAAIvD,GAAOu4B,WAAWh8B,OAAS,CAAEiG,MAAO,QACxC0H,YACElK,GAAOkK,WAAYwJ,EAAQglB,eAAe1N,SAAS9W,IAIrD1N,MAAOxG,GAAO24B,WACdtoB,iBAAmBF,IACjB8nB,EAAYW,SAAS1kB,EAAW/D,GAC5BnQ,GAAOu4B,WAAWM,uBACpB74B,GAAOu4B,WAAWM,sBAChB1oB,EACA8nB,EACAC,IAINv/B,MAAOw/B,EAAWjkB,GAClBxU,MAAkDS,MAA3C83B,EAAYa,UAAUC,OAAO7kB,GACpCvD,aAAcsnB,GAAaa,WAAWC,OACpC7kB,IACC7a,SAAS2/B,aAES,aAArBh5B,GAAOmU,UACTrR,EAACmP,GAAQ,CACPzL,MAAOxG,GAAO24B,WACdtoB,iBAAmBF,IACjB8nB,EAAYW,SAAS1kB,EAAW/D,GAC5BnQ,GAAOu4B,WAAWM,uBACpB74B,GAAOu4B,WAAWM,sBAChB1oB,EACA8nB,EACAC,IAINv/B,MAAOw/B,EAAWjkB,GAClB5B,aAActS,GAAOsS,cAAgB,OACrCE,eAAgBxS,GAAOwS,gBAAkB,QACzCtI,YACElK,GAAOkK,WAAYwJ,EAAQglB,eAAe1N,SAAS9W,IAIrD3Q,GAAIvD,GAAOu4B,WAAWh8B,QAED,aAArByD,GAAOmU,UACTrR,EAACiO,GACC,CAAAxN,GAAIvD,GAAOu4B,WAAWh8B,OAAS,CAAEiG,MAAO,QACxCgE,MAAOxG,GAAO24B,WACdzuB,YACElK,GAAOkK,WAAYwJ,EAAQglB,eAAe1N,SAAS9W,IAIrD7D,iBAAkB,CAACF,EAAQoD,KACzB,IAAIjC,EAAW,KACXnB,IACFmB,EAAWnB,EAAI,IAEjB8nB,EAAYW,SAAS1kB,EAAW5C,GAC5BtR,GAAOu4B,WAAWM,uBACpB74B,GAAOu4B,WAAWM,sBAChBvnB,EACA2mB,EACAC,EACA3kB,IAINpC,QAASnR,GAAOmR,SAAW,GAC3BO,aAAc1R,GAAOk5B,oBAAsB,GAC3C9nB,WAAYpR,GAAOm5B,kBAAoB,GACvCxgC,MAAOw/B,EAAWjkB,GAClBvD,aAAcsnB,GAAaa,WAAWC,OACpC7kB,IACC7a,SAAS2/B,aAGdl2B,EAAAkM,EAAA,CAAAhM,SAAA,yBAjKGF,QAwKT,OAAOA,SCvLLs2B,GAAsClhC,IAC1C,MAAMuW,EAAU3I,MACV8H,mBAAEA,EAAoBD,QAAS0rB,GACnC3rB,GAAsB,CACpBQ,KAAMhW,GAAQwW,qBAAuB,GACrCX,MAAO,eACPM,qBAAsB,KACpBnW,GAAQyW,SAASzW,GAAQgX,WAG/B,OACEhX,SAAQiC,WAERsU,EAAQ1I,iBAAiB7N,EAAOiC,WAG9B8I,EAAA+L,EAAA,CAAAhM,SAAA,CACEF,EAAC8K,EAAqB,IACtB3K,EAACmL,EACC,CAAApK,QAAS9L,GAAQkX,iBAAiBC,oBAClCjM,MAAOlL,GAAQkX,iBAAiBG,kBAChClM,QAAS,KACP,GAAInL,GAAQyW,SAAU,CACpB,GAAIzW,GAAQ+W,sBACL/W,EAAO+W,oBAAoB/W,EAAOgX,QACrC,QAGmC,IAAnChX,GAAQiX,uBACVkqB,GAA2B,GAE3BnhC,GAAQyW,SAASzW,EAAOgX,UAG7BlM,SAAA,CAEA9K,GAAQ0L,KACPd,EAACa,IACCC,KAAM1L,EAAO0L,KACbrH,MAAO,CAAEmG,YAAa,EAAGD,WAAY,KAGvCK,QAEFA,kBAAM5K,GAAQsO,cAKb1D,SC7CLw2B,GACJt5B,GAGE8C,cACEG,EAACq1B,GAAMiB,WAAS,EAACh2B,GAAIvD,GAAOzD,MAAOwI,WAAW,aAC3C/B,SAAA,CAAAhD,GAAOwG,MACN1D,EAACw1B,EACC,CAAAhpB,KAAM,GACN/L,GAAI,CAAEwE,QAAS,EAAGmB,WAAY,OAAQxF,QAAS,QAE9CV,SAAAhD,GAAO4D,KACNX,EAAA+L,EAAA,CAAAhM,SAAA,CACEF,EAACa,GAAe,CACdC,KAAM5D,EAAM4D,KACZrH,MAAO,CAAEmG,YAAa,EAAGD,WAAY,KAEvCK,EAAM,MAAA,CAAAE,SAAAhD,EAAMwG,WAGd1D,EAAAkM,EAAA,CAAAhM,SAAGhD,EAAMwG,UAIb1D,QAED9C,GAAO6T,SACJ7T,EAAM6T,SAASjI,KAAK8H,GACG,UAAjBA,EAAQjX,KAERqG,EAACw2B,GACK,IAAA5lB,EAAQ1T,MACZi4B,YAAaj4B,EAAMi4B,YACnBE,WAAYn4B,EAAMm4B,WAClBD,YAAal4B,EAAMk4B,YACnBG,aAAcr4B,EAAMq4B,aACpBK,eAAgB14B,EAAM04B,iBAGA,UAAjBhlB,EAAQjX,MAAqC,UAAjBiX,EAAQrW,KAE3CyF,EAACi1B,IACCC,UAAWtkB,EAAQ1T,MACnBi4B,YAAaj4B,EAAMi4B,YACnBE,WAAYn4B,EAAMm4B,WAClBD,YAAal4B,EAAMk4B,YACnBG,aAAcr4B,EAAMq4B,aACpBK,eAAgB14B,EAAM04B,iBAGA,UAAjBhlB,EAAQjX,MAAqC,SAAjBiX,EAAQrW,KAE3CyF,EAACw1B,EAAK,CACJhpB,KACEoE,GAAS1T,OAAOu4B,WAAWC,WAAa,CACtCnQ,GAAI,EACJD,GAAI,EACJD,GAAI,IAGR5kB,GAAI,CAAEwE,QAAS,EAAGvF,MAAO,QAEzBQ,SAAAF,EAAC4Q,EAAQrN,KACP,CAAA4xB,YAAaj4B,EAAMi4B,YACnBE,WAAYn4B,EAAMm4B,WAClBD,YAAal4B,EAAMk4B,qBAfpB,IAqBT,KAEHl4B,GAAOzH,QACNuK,EAACw1B,EAAK,CAAChpB,KAAM,CAAE6Y,GAAI,IAAM5kB,GAAI,CAAEwE,QAAS,GAAG/E,SACxChD,EAAMzH,QAAQqT,KAAK1T,GACX4K,EAACs2B,GAAU,IAAKlhC,EAAQgX,OAAQlP,EAAMm4B,iBAIjDr1B,EAAAkM,EAAA,CAAA,QCvEJwqB,GACJx5B,IAEA,MAAM2T,EAASI,GAAa/T,EAAM6T,WAC3BwkB,EAAcoB,GAAmBx7B,EAAmB,KACpDy6B,EAAgBgB,GAAqBz7B,EAAmB,IACzD07B,EAAavlB,GAAEmK,OAAOvK,GAA0BL,IAEhDskB,EAAc2B,GAAkB,CACpCC,SAAUC,GAAYH,KAElBxB,EAAaF,EAAY8B,QACzBC,EAAiBC,KACjBC,EAAkCl6B,GAAOk6B,2BAwCzChC,EAAc,CAClBiC,cAAe,CAACjmB,EAAmBkmB,KACjCnC,EAAYW,SAAS1kB,EAAWkmB,IAElCC,UAAYnmB,IACVulB,GAAiBa,GACG,IAAIA,EAAWpmB,MAIrCqmB,UAAYrmB,IACVulB,GAAiBa,GACGA,EAAU3uB,QAAQoK,GAAMA,IAAM7B,OAIpDsmB,aAAetmB,IACbwlB,GAAmBY,GACC,IAAIA,EAAWpmB,MAIrCumB,YAAcvmB,IACZwlB,GAAmBY,GACCA,EAAU3uB,QAAQoK,GAAMA,IAAM7B,QAUtD,OAJA9V,GAAU,KApES2B,WACjB,IAAI26B,EAAW,KASf,GARI16B,GAAO26B,eACTD,EAAW16B,EAAM26B,eAEjBT,GACAF,EAAeE,KAEfQ,EAAWV,EAAeE,IAExBQ,EAAU,CACZ,MAAME,QAA6B56B,EAAMyW,WAAWokB,eAClDH,GAEEE,GACF3C,EAAY5B,MAAM,IAAKuE,MAsD3BE,KACC,CAAC96B,GAAO26B,iBAGT13B,EACE+L,EAAA,CAAAhM,SAAA,CAAAF,EAAC8D,GAAG,CACFrD,GAAI,CACFG,QAAS,OACTS,KAAM,EACN3B,MAAO,OACPqE,OAAQ,cACRe,cAAe,SACf7C,WAAY,SACZgsB,SAAU,QAGZ/tB,SAAAF,EAACw1B,EAAM,CAAA/0B,GAAI,CAAEf,MAAO,QAAU+2B,WAC3B,EAAAv2B,SAAAhD,EAAM6T,SAASjI,KAAKmvB,GACM,UAArBA,EAAYt+B,KAEZqG,EAACw2B,GAAgB,IACXyB,EAAY/6B,MAChBi4B,YAAaA,EACbE,WAAYA,EACZD,YAAaA,EACbG,aAAcA,EACdK,eAAgBA,IAIC,UAArBqC,EAAYt+B,MACS,UAArBs+B,EAAY19B,KAGVyF,EAACi1B,GAAgB,CACfC,UAAW+C,EAAY/6B,MACvBi4B,YAAaA,EACbE,WAAYA,EACZD,YAAaA,EACbG,aAAcA,EACdK,eAAgBA,IAIC,UAArBqC,EAAYt+B,MACS,SAArBs+B,EAAY19B,KAGVyF,EAACw1B,EAAK,CACJhpB,KACEyrB,GAAa/6B,OAAOu4B,WAAWC,WAAa,CAC1CnQ,GAAI,EACJD,GAAI,EACJF,GAAI,IAGR3kB,GAAI,CAAEwE,QAAS,EAAGvF,MAAO,QAEzBQ,SAAAF,EAACi4B,EAAY10B,KAAI,CACf4xB,YAAaA,EACbE,WAAYA,WAjBb,QA0Bbl1B,EAAC2D,GAAG,CACFrD,GAAI,CACFG,QAAS,OACTlB,MAAO,OACPuC,WAAY,SACZG,eAAgB,cACjBlC,SAAA,CAEAhD,GAAOzH,QACNyH,EAAMzH,QAAQqT,KAAK1T,IACwB,IAArCA,GAAQkX,iBAAiB4rB,QACpBl4B,EAACs2B,GAAe,IAAAlhC,EAAQgX,OAAQipB,IAEhCr1B,UAIXA,EAAKkM,EAAA,CAAA,GAEPlM,EAAA,MAAA,CAAKvG,MAAO,CAAE4H,KAAM,KACpBrB,EAACsL,EAAM,CACLpK,QACEhE,GAAOi7B,iBAAiB5rB,oBACpBrP,EAAMi7B,gBAAgB5rB,oBACtB,YAEN9L,GAAI,CAAEyX,EAAG,GACTkgB,UACEl7B,GAAOi7B,iBAAiBr3B,KACtBd,EAACa,GAAe,CAACC,KAAM5D,EAAMi7B,gBAAgBr3B,OAC3C,KAENR,MACEpD,GAAOi7B,iBAAiB1rB,kBACpBvP,EAAMi7B,gBAAgB1rB,kBACtB,UAENlM,QAAS40B,EAAYkD,cAClB5Z,IACC5c,QAAQC,IAAI,cAAe2c,GA7JpBxhB,OAAOmP,IACxB,KAAIlP,GAAOo7B,mBAAsBp7B,EAAMo7B,kBAAkBlsB,KAGrDA,EAAQ,CACV,MAAMmsB,QAAyBr7B,EAAMyW,WAAW6kB,WAAWpsB,GACvDmsB,IACFpD,EAAY5B,MAAM,IAAKgF,IACnBr7B,GAAOu7B,6BACTv7B,EAAMu7B,4BAA4BF,GAEhCr7B,GAAOw7B,iBACTx7B,EAAMw7B,qBAkJFF,CAAW/Z,MAEZwX,IACCn5B,GAAMF,MACJ,wEAEFiF,QAAQC,IAAI,wBAAyBm0B,eAIxC/4B,GAAOi7B,iBAAiBz0B,OAAS,SAEpC1D,EAACsL,GACCpK,QACEhE,GAAOy7B,mBAAmBpsB,oBACtBrP,EAAMy7B,kBAAkBpsB,oBACxB,YAEN6rB,UACEl7B,GAAOy7B,mBAAmB73B,KACxBd,EAACa,GAAgB,CAAAC,KAAM5D,EAAMy7B,kBAAkB73B,OAC7C,KAENR,MACEpD,GAAOy7B,mBAAmBlsB,kBACtBvP,EAAMy7B,kBAAkBlsB,kBACxB,QAENhM,GAAI,CAAEyX,EAAG,GACT3X,QAAS,KACHrD,GAAOw7B,iBACTx7B,EAAMw7B,kBAERvD,EAAY5B,MAAM,KAGnBrzB,SAAAhD,GAAOy7B,mBAAmBj1B,OAAS,kBC9NjCk1B,GAAa17B,IACxB,MAAO27B,EAAaC,GAAkB39B,GAAS,GA6E/C,MAAO,CAAE09B,cAAaC,iBAAgBC,OA3ECC,GAEnCh5B,EAACi5B,EAAK,CACJx5B,KAAMo5B,EACNp4B,GAAI,CAAE0D,OAASlF,GAAUA,EAAMkF,OAAO+0B,QACtCC,QAAS,MACFN,GAAe37B,GAAOk8B,iBACzBl8B,EAAMk8B,mBAIVl5B,SAAAC,EAAC2D,EAAG,CACFrD,GAAI,CACFR,SAAU,WACVqF,IAAK,MACLD,KAAM,MACNoE,UAAW,MACXvD,UAAW,wBACXnC,OAAQ7G,GAAO6G,QAAU,MACzBrE,MAAOxC,GAAOwC,OAAS,MACvB2sB,SAAUnvB,EAAMmvB,UAAY,IAC5BC,UAAWpvB,EAAMovB,WAAa,IAC9B2B,SAAU,SACVhqB,QAAS,uBACTrD,QAAS,OACTkE,cAAe,SACf7C,WAAY,SACZG,eAAgB,cACjBlC,SAAA,CAEDF,EAACpB,EAAO,CAAAqB,SAAS,SAAQC,SACvBC,EAACC,GAAQc,QAAQ,QAAOhB,SAAA,CACtBF,EAACa,GAAe,CACdC,KAAM5D,GAAOm8B,YAAc,kBAC3B5/B,MAAO,CAAEmG,YAAa,KAExBI,EAACiB,EAAW,CAAAC,QAAQ,KAAKZ,MAAM,UAAUc,UAAU,MAChDlB,SAAAhD,GAAOo8B,aAAe,WAEzBt5B,EAAA,MAAA,CAAKvG,MAAO,CAAE6P,SAAU,KACxBtJ,EAACK,EAAU,CACTE,QAAS,KACPu4B,GAAe,GAEYz7B,MAAzBH,EAAMk8B,iBACmB,MAAzBl8B,EAAMk8B,iBAENl8B,EAAMk8B,mBAGV94B,MAAM,qBAENN,EAACa,IAAgBC,KAAK,wBAI5Bd,EAACu5B,EAAK,CACJ94B,GAAI,CAEFG,QAAS,OACTkE,cAAe,SACf7C,WAAY,SACZvC,MAAO,OACPqE,OAAQ,OACRkB,QAAS,EAETgpB,SAAU,UACX/tB,SAEA84B,GAAa94B,kBCnD1B,IAAIs5B,IAA0B,EAU9B,MAAMC,GAAiBllB,IACrB,IACE,MAAMmlB,EAAQ7kC,aAAaC,QAAQyf,GACnC,OAAOmlB,EAAQjY,KAAKkY,MAAMD,GAAS,CAAE,EACrC,MAAOp3B,GAEP,OADAT,QAAQjF,MAAM,4BAA6B0F,GACpC,CAAE,IAIPs3B,GAAgB,CAACrlB,EAAsBslB,KAC3C,MAAMC,EAAUL,GAAcllB,GAC9B1f,aAAayM,QACXiT,EACAkN,KAAKC,UAAU,IAAKoY,KAAYD,MAI9BE,GAAoB,CAAC,YAAa,WAElCC,GAA6C98B,IACjD,MAAMqF,EAAEA,GAAMiE,KACRqK,EAASI,GAAa/T,EAAM+8B,cAC5B1E,EAAe,GACf2E,EAAajzB,EAAMkzB,SACvB,IAAOj9B,GAAOqX,aAAeklB,GAAcv8B,EAAMqX,cAAgB,CAAE,GACnE,IAEF,IAAK,MAAMvE,KAASa,GACe,IAA7Bb,GAAOoqB,WAAW9E,QACpBC,EAAazkB,KAAKd,EAAMoB,WAG5B,IAAIipB,EAAoD,CAAE,EAC1D,GAAIH,GAAYI,sBAAuB,CACrCD,EAAyBH,EAAWI,sBACpC,MAAMC,EAAiBte,OAAOiB,KAAKmd,GACnC,IAAK,MAAMrqB,KAASulB,EACbgF,EAAerS,SAASlY,KAC3BqqB,EAAuBrqB,IAAS,QAIpC,IAAK,MAAMA,KAASulB,EAClB8E,EAAuBrqB,IAAS,EAIpC,MAAMwqB,EAAiBv+B,GACpB/G,GAAqBA,EAAM0D,UAAU7D,gBAgBjCulC,EAAuBG,GAC5BxzB,EAAM9L,SAAoCk/B,IACrCK,EAAaC,GAAkB1zB,EAAM9L,SAC1C++B,EAAWQ,aAAe,KAErBE,EAAcC,GAAmB5zB,EAAM9L,SAE3C++B,EAAWU,cAAgB,KACvBE,EAAsBC,GAC3B5/B,EAA+B++B,EAAWc,qBAAuB,IACnE,IAAIC,EAAUf,GAAYgB,eAAe71B,MAAQ,GACjD41B,EAAUA,EAAQpyB,QACfuD,IAAiB2tB,GAAkB7R,SAAS9b,KAE/C,IAAI+uB,EAAWjB,GAAYgB,eAAe9L,OAAS,IAAM,GACzD+L,EAAWA,EAAStyB,QACjBuD,IAAiB2tB,GAAkB7R,SAAS9b,KAG/C,MAAO8uB,EAAeE,GAAoBjgC,EAAiC,CACzEkK,KAAM,IAAwB,QAAnBm1B,EAA2BT,GAAoB,MAAQkB,GAClE7L,MAAO,IACkB,QAAnBoL,EAA2BT,GAAoB,MAChDoB,KAIDxvB,EAAU3I,KACV0F,EAAWC,MACV0yB,EAAgBC,GAAqBngC,EAAc,OACnDogC,EAAcC,GAAmBrgC,EAAc,OAC/CsgC,EAAeC,GAAoBvgC,EAA4B,CAAA,IAE/DwX,EAAmBgpB,GACxBxgC,EAAgC,CAAE4X,IAAK,IAAIM,IAAO1Z,KAAM,YAC1D,IAAIiZ,EAAwB,KACxB1V,GAAO0V,gBACTA,EAAgB1V,GAAO0V,eAEzB,MAAMgpB,EAAU1+B,EAAM0+B,QAChBC,EAAmBvqB,GAAEmK,OAAOvK,GAA0BL,IACtDirB,EvDpHyB,EAACjrB,EAAQkrB,EAAmBx5B,KAC3D,MAAMy5B,EAAqC,GAC3C,IAAK,MAAMC,KAAcprB,EACvB,GAC4B,SAA1BorB,GAAY5qB,WACc,WAA1B4qB,GAAY5qB,UACZ,CACA,MAAMlB,EAA6B,IAC9B8rB,GAAY7B,WAAW8B,SAC1BC,SACEF,GAAY7B,WAAW8B,UAAUC,UAAYJ,EAC/CpiC,KAA+B,UAAzBsiC,GAAY5qB,UAAwB,SAAW,SACrDrB,MAAOisB,GAAY7qB,UACnBgrB,WAAY75B,EAAE05B,GAAYpG,YAAcoG,GAAY7qB,WACpDirB,YAAa,SACbC,MAAO,SACPhH,OAAQ2G,GAAY3G,OACpBiH,WAAYN,GAAY7B,WAAWmC,WACnCl7B,KAAM,EACNgrB,SAAU,KAEZ2P,EAAQlrB,KAAKX,QACR,GAA8B,SAA1B8rB,GAAY5qB,UAAsB,CAC3C,MAAMlB,GD7D4BP,EC6DoB,IACjDqsB,GAAY7B,WAAW8B,SAC1BC,SACEF,GAAY7B,WAAW8B,UAAUC,UAAYJ,EAC/C/rB,MAAOisB,GAAY7qB,UACnBgrB,WAAY75B,EAAE05B,GAAYpG,YAAcoG,GAAY7qB,WACpDirB,YAAa,SACbC,MAAO,SACPhH,OAAQ2G,GAAY3G,OACpBiH,WAAYN,GAAY7B,WAAWmC,WACnCl7B,KAAM,EACNgrB,SAAU,KDvEmB,IAC9Bzc,EACHjW,KAAM,SACNkW,eAAiBpS,GAEbuC,EAAC4M,GACC,CAAAnM,GAAI,CAAEf,MAAO,QACbgE,MAAM,GACN7N,MAAO4H,EAAO5H,MACd0X,iBAAmBF,IACjB5P,EAAOqS,IAAIC,iBAAiB,CAC1B1M,GAAI5F,EAAO4F,GACX2M,MAAOvS,EAAOuS,MACdna,MAAOwX,OAMjB4C,YAAa,CAACpa,EAAYqa,EAAUC,KAClC,IAAI9C,EAAI,KAIR,OAHc,OAAVxX,IACFwX,EAAIJ,GAAOpX,GAAOqX,OAAOR,KAEpBW,GAET+C,eAAgB,CAACva,EAAYqa,EAAUC,IAC9BD,EAAIC,EAAOH,SC8ClBgsB,EAAQlrB,KAAKX,QACR,GAA8B,aAA1B8rB,GAAY5qB,UAA0B,CAC/C,MAAMlB,EAA6BR,GAAuB,IACrDssB,GAAY7B,WAAW8B,SAC1BC,SACEF,GAAY7B,WAAW8B,UAAUC,UAAYJ,EAC/C/rB,MAAOisB,GAAY7qB,UACnBgrB,WAAY75B,EAAE05B,GAAYpG,YAAcoG,GAAY7qB,WACpDirB,YAAa,SACbC,MAAO,SACPhH,OAAQ2G,GAAY3G,OACpBiH,WAAYN,GAAY7B,WAAWmC,WACnCl7B,KAAM,EACNgrB,SAAU,MAEZ2P,EAAQlrB,KAAKX,QACR,GAA8B,aAA1B8rB,GAAY5qB,UAA0B,CAC/C,MAAMlB,EAASO,GAAuB,IACjCurB,GAAY7B,WAAW8B,SAC1BC,SACEF,GAAY7B,WAAW8B,UAAUC,UAAYJ,EAC/C/rB,MAAOisB,GAAY7qB,UACnBgrB,WAAY75B,EAAE05B,GAAYpG,YAAcoG,GAAY7qB,WACpDirB,YAAa,SACbC,MAAO,SACPhH,OAAQ2G,GAAY3G,OACpBiH,WAAYN,GAAY7B,WAAWmC,WACnC/sB,aAAcysB,GAAYzsB,aAC1BE,eAAgBusB,GAAYvsB,eAC5BhQ,MAAO,MAETs8B,EAAQlrB,KAAKX,QACR,GAA8B,aAA1B8rB,GAAY5qB,UAA0B,CAC/C,MAAMlB,EAA6BE,GAAoB,IAClD4rB,GAAY7B,WAAW8B,SAC1BC,SACEF,GAAY7B,WAAW8B,UAAUC,UAAYJ,EAC/C/rB,MAAOisB,GAAY7qB,UACnBgrB,WAAY75B,EAAE05B,GAAYpG,YAAcoG,GAAY7qB,WACpDirB,YAAa,SACbC,MAAO,SACPhH,OAAQ2G,GAAY3G,OACpBiH,WAAYN,GAAY7B,WAAWmC,WACnCjuB,WAAY2tB,GAAY5F,kBAAoB,QAC5CznB,aAAcqtB,GAAY7F,oBAAsB,UAChD/nB,QAAS4tB,GAAY5tB,SAAW,GAChChN,KAAM,EACNgrB,SAAU,MAEZ2P,EAAQlrB,KAAKX,GD3HoB,IAACP,EC8HtC,OAAOosB,GuD4BkBQ,CACvB3rB,EAC8B,QAA9B3T,GAAOoW,UAAUA,WAAsB,EACvC/Q,GAEF,IAAIk6B,GAAgB,EAChBv/B,GAAOuV,YAAYpb,YACrBolC,EAAgB9wB,EAAQ1I,iBAAiB/F,EAAMuV,WAAWpb,YAE5D,IAAIqlC,GAAkB,EAClBx/B,GAAOy/B,cAActlC,YACvBqlC,EAAkB/wB,EAAQ1I,iBAAiB/F,EAAMy/B,aAAatlC,YAGhE,MAmDMyT,mBAAEA,EAAoBD,QAAS+xB,GACnChyB,GAAsB,CACpBK,MAAO,eACPG,KAAM,gDACNG,qBA1BuBtO,UACzB,IAAImqB,GAAS,EACPiU,IAA4C,IAA1BA,GAAgBwB,QACtCzV,QAAelqB,EAAMyW,WAAWmpB,iBAC9BzB,EAAezoB,KAGfwU,IACElqB,GAAOy/B,cAAcI,0BACjB7/B,EAAMy/B,aAAaI,mBAAmB1B,GAG9CO,GAASoB,GACSA,EAAQn0B,QACrBuD,GACCA,EAAOwG,IAAkByoB,EAAezoB,WAclD,IAAIqqB,EACAC,EACAC,GACAC,GACAC,GACAC,GAE8B,UAA9BpgC,GAAOoW,UAAUA,WACnB2pB,EAAkB//B,GAAOoW,UAAUiqB,OAAOC,aAAe,cACzDN,EAAiBhgC,GAAOoW,UAAUiqB,OAAOE,YAAc,MACvDN,GAAqBjgC,GAAOoW,UAAUiqB,OAAOG,eAC7CN,GAAoBlgC,GAAOoW,UAAUiqB,OAAOI,cAC5CN,GAAgBngC,GAAOoW,UAAUiqB,OAAOK,WAAa,SACrDN,GAAiBpgC,GAAOoW,UAAUiqB,OAAOM,YAAc,eAGzD,MAAQ9E,OAAQ+E,GAAYhF,eAAgBiF,IAAuBnF,GAAU,CAC3E70B,OAAQk5B,EACR3Q,UAAW6Q,GACX9Q,SAAU+Q,GACVhE,gBAAiB,KACfl8B,EAAMyW,WAAW3H,WAAW9O,GAAO0W,2BAErClU,MAAOw9B,EACP7D,WAAYgE,GACZ/D,YAAagE,KAgTTU,GAAmC,CACvCrkC,KAAM,UACNqW,MAAO,UACPosB,WAAY,GACZC,YAAa,SACb38B,OACGxC,GAAOsW,WAAuC,GAA1BtW,EAAMsW,WAAW3Q,OAAc,IACnD3F,GAAOuV,YAAcvV,GAAOuV,YAAYwrB,UAAY,GAAK,IACzD/gC,GAAOy/B,cAAgBz/B,GAAOy/B,cAAcsB,UAAY,GAAK,GAChEC,WA/J8BzgC,IAC9B,MAAM2O,EAAc3O,EAAOyS,IACrBza,EAA+D,GACrE,GAAiC,QAA7ByH,GAAOoW,UAAUA,gBAEejW,IAAhCH,GAAOihC,uBACNjhC,EAAMihC,sBACP,CACA,MAAMC,EACJ3C,EAAcrvB,EAAOwG,KAAiBrY,OAAS8jC,GAAaC,KAC9D,GAAgC,QAA5BphC,EAAMoW,SAASA,UAAsB8qB,EACnC3B,IACFhnC,EAAQqb,KACN9Q,EAAC0W,GACC,CAAA5V,KAAMd,EAACa,GAAe,CAACC,KAAK,SAC5B4C,MAAOnB,EAAE,kBACThC,QAAS,KAvGI,CAAC6L,IAC1B,MAAM/I,EAAK+I,EAAOwG,GAClB8oB,EAAiB,IACZD,EACHp4B,CAACA,GAAK,CAAE9I,KAAM8jC,GAAaE,SAoGfC,CAAmBpyB,OAIzB3W,EAAQqb,KACN9Q,EAAC0W,GACC,CAAA5V,KAAMd,EAACa,GAAe,CAACC,KAAK,WAC5B4C,MAAOnB,EAAE,oBACThC,QAAS,KA9CU,CAAC6L,IAChC,MAAM/I,EAAK+I,EAAOwG,GACdvP,GAAMuS,GAASvS,IAAOA,EAAK,GAC7Bq4B,EAAiB,IACZD,EACHp4B,CAACA,GAAK,CAAE9I,KAAM8jC,GAAaE,KAAME,qBAAqB,KAExD7C,GAASoB,IACP,MAAM0B,EAAU1B,EAAQn0B,QACrBuD,GAAgBA,EAAOwG,IAAkBvP,IAE5C,OAAOq7B,MAGThD,EAAiB,IACZD,EACHp4B,CAACA,GAAK,CAAE9I,KAAM8jC,GAAaE,KAAME,qBAAqB,MA+B5CE,CAAyBvyB,IAE3B9L,MAAM,kBAIP,CACL,GAAIpD,GAAOuV,aAA+C,IAAjCvV,GAAOuV,YAAYwrB,UAAoB,CAC9D,IAAIW,GAA+B,EAC/B1hC,GAAOuV,YAAY+D,2BACrBooB,EACE1hC,GAAOuV,YAAY+D,yBAAyBpK,IAEhD,IAAIyyB,GAAgC,EAChC3hC,GAAOuV,YAAYgE,4BACrBooB,EACE3hC,GAAOuV,YAAYgE,0BAA0BrK,IAE7CqwB,GAAiBmC,GACnBnpC,EAAQqb,KACN9Q,EAAC0W,GAAmB,CAClBtP,SAAUy3B,EACV/9B,KACEd,EAAC8T,EAAO,CAAC7I,MAAO1I,EAAE,kBAChBrC,SAAAF,EAACa,GAAe,CACdC,KAAM,OACNrH,MAAO,CACL6G,MAAOu+B,EACH,YACAxhC,OAKZsZ,WACEzZ,GAAOuV,YAAYgB,iBAAiBkD,aAAc,EAEpDjT,MAAOnB,EAAE,kBACT0F,UAAU,cACV3H,MAAM,UACNC,QAAS,KACHk8B,IAAkBoC,GA9Lf5hC,OAAOmP,IAC9B,GAAIA,EAEF,GADAovB,EAAgBpvB,GACgB,SAA5BlP,EAAMoW,SAASA,SACjB5K,EAASxL,EAAMoW,SAASiqB,MAAMuB,UAAY,IAAM1yB,EAAOwG,SAClD,GAAgC,UAA5B1V,EAAMoW,SAASA,SACxByqB,IAAmB,QACd,GAAkC,QAA9B7gC,GAAOoW,UAAUA,SAAoB,CAC9C,MAAMjQ,EAAK+I,EAAOwG,GAClB8oB,EAAiB,IACZD,EACHp4B,CAACA,GAAK,CAAE9I,KAAM8jC,GAAaC,UAoLfS,CAAiB3yB,OAO7B,GAAIlP,GAAOy/B,eAAmD,IAAnCz/B,GAAOy/B,cAAcsB,UAAoB,CAClE,IAAIe,GAAiC,EACjC9hC,GAAOy/B,cAAcnmB,2BACvBwoB,EACE9hC,GAAOy/B,cAAcnmB,yBAAyBpK,IAElD,IAAI6yB,GAAkC,EAClC/hC,GAAOy/B,cAAclmB,4BACvBwoB,EACE/hC,GAAOy/B,cAAclmB,0BAA0BrK,IAE/CswB,GAAmBsC,GACrBvpC,EAAQqb,KACN9Q,EAAC0W,GAAmB,CAClBtP,SAAU63B,EACVn+B,KACEd,EAAC8T,EAAO,CAAC7I,MAAO1I,EAAE,oBAChBrC,SAAAF,EAACa,GAAe,CACdC,KAAM,QACNrH,MAAO,CACL6G,MAAO2+B,EACH,YACA5hC,OAKZsZ,WACEzZ,GAAOy/B,cAAclpB,iBAAiBkD,aAAc,EAEtDjT,MAAOnB,EAAE,oBACT0F,UAAU,cACV3H,MAAM,UACNC,QAAS,KACP,GAAIm8B,IAAoBuC,EAAiC,CACvD,GAAI/hC,GAAOy/B,cAAcxwB,sBAClBjP,EAAMy/B,aAAaxwB,oBAAoBC,GAC1C,OAGJkvB,EAAkBlvB,GAClBwwB,GAA4B,UAU9C,GAAI1/B,GAAOsW,WACT,IAAK,MAAM9H,KAAaxO,EAAMsW,WAGxB9H,GAAW+H,iBAAiBC,cACgB,IAA5ChI,GAAW+H,iBAAiBC,aAG9Bje,EAAQqb,KACN9Q,EAACqW,OACK3K,EACJU,OAAQA,EACRJ,WAAY/O,UACVC,EAAMyW,WAAW3H,WAAW9O,GAAO0W,8BAQ/C,OAAOne,IAeT,IAAIypC,GAA+C,SAEjB7hC,IAAhCH,GAAOihC,uBACNjhC,EAAMihC,sBACNjhC,GAAOsW,YAActW,GAAOsW,WAAW3Q,OAAS,IAEjDq8B,GAAkBpuB,KAAKktB,IAGzBkB,GAAoB,IAAIA,MAAsBpD,GAI9CxgC,GAAU,UACgB+B,IAApBH,GAAOrG,WAA6C,IAAnBqG,EAAMrG,UACzCqG,EAAMyW,WAAW3H,WAAW9O,GAAO0W,4BAEpC,IAEH,MAiDMurB,GAA6Cl4B,EAAMkzB,SAAQ,KAC/D,MAAMiF,EAAWF,GAAkBp2B,KAAKu2B,IAAS,IAC5CA,EACH3/B,MAAOk7B,EAAayE,EAAIrvB,QAAUqvB,EAAI3/B,UAIxC,GAAIg7B,EAAY73B,OAAQ,CACtB,MAAMy8B,EAAa,IAAIC,IAAIH,EAASt2B,KAAKu2B,GAAQ,CAACA,EAAIrvB,MAAOqvB,MAC7D,OAAO3E,EAAY5xB,KAAKkH,GAAUsvB,EAAW9hC,IAAIwS,KAASnH,OAAO9B,SAGnE,OAAOq4B,IACN,CAAC1E,EAAaE,EAAcsE,KAC/B,OACE/+B,EACE+L,EAAA,CAAAhM,SAAA,CAAAF,EAAC8K,EAAkB,CAAA,GACY,UAA9B5N,GAAOoW,UAAUA,SAChBtT,EAAC89B,GACE,CAAA59B,SAAAhD,GAAOoW,UAAUiqB,OAAOiC,cACvBx/B,EAAC9C,EAAMoW,SAASiqB,MAAMiC,cAAa,CACjC3H,eACE0D,EAAeA,EAAa3oB,QAAiBvV,EAE/Cq7B,gBAAiB,KACfqF,IAAmB,GACnB7gC,EAAMyW,WAAW3H,WAAW9O,GAAO0W,6BAIvC5T,EAAC02B,GAAY,CACXmB,eACE0D,EAAeA,EAAa3oB,QAAiBvV,EAE/Cq7B,gBAAiB,KACfqF,IAAmB,GACnB7gC,EAAMyW,WAAW3H,WAAW9O,GAAO0W,2BAErC7C,SAAU7T,EAAM+8B,aAChBtmB,WAAYzW,EAAMyW,WAClB8rB,iBAAkBviC,GAAOuV,YAAYpb,UACrCohC,4BACEv7B,GAAOuV,YAAYsqB,mBAErBzE,kBAAmBp7B,GAAOuV,YAAYtG,oBACtC1W,QAASyH,GAAOsW,eAKtBxT,EAAKkM,EAAA,CAAA,QAEiB7O,IAAvBH,GAAOwiC,aAA8BxiC,GAAOwiC,YAqC3C1/B,EAAKkM,EAAA,CAAA,GApCL/L,EAAC2D,EAAG,CAACrD,GAAI,CAAEG,QAAS,uBACSvD,IAA1BH,GAAOyiC,gBAAiCziC,GAAOyiC,eAS9C3/B,EAAKkM,EAAA,CAAA,GARLlM,EAACK,EACC,CAAAE,QAAS,KACPmI,EAAS,KAAM,CAAEme,SAAS,KAC3B3mB,SAEDF,EAACa,GAAe,CAACC,KAAK,iBAK1BX,EAAC2D,EACC,CAAArD,GAAI,CACFY,KAAM,EACNT,QAAS,OACTqB,WAAY,SACZG,eAAgB,UAGjBlC,SAAA,CAAAhD,GAAO0iC,SACN5/B,EAACa,GAAe,CACdC,KAAM5D,EAAM0iC,SACZnmC,MAAO,CAAEmG,YAAa,EAAGD,WAAY,KAGvCK,EAAAkM,EAAA,CAAA,GAEFlM,EAACiB,EAAW,CAAAC,QAAQ,KAAIhB,SACrBhD,GAAO2iC,UACJ5pB,GAAsB1T,EAAErF,GAAO2iC,YAC/B,WAQX3iC,GAAO4iC,oBACR5iC,GAAO0W,0BACP1W,GAAO6iC,4BACL5/B,EAAC6/B,EAAU,CAAAC,iBACT,EAAA//B,SAAA,CAAAF,EAACkgC,EAAiB,CAAAC,WAAYngC,EAACogC,GAAkB,CAAA,YAC/CjgC,EAAC2D,EACC,CAAArD,GAAI,CACFG,QAAS,OACTqB,WAAY,SACZG,eAAgB,UACjBlC,SAAA,CAEDF,EAACa,GAAe,CACdpH,MAAO,CAAEkG,WAAY,EAAGC,YAAa,GACrCkB,KAAK,WAEPd,EAACiB,GAAWG,UAAU,OAA2BlB,SAAA,iBAGrDF,EAACqgC,EAAgB,CAAAngC,SACfF,EAAC8D,EAAG,CAAA5D,SACFF,EAAC02B,GAAY,CACXyB,gBAAiB,CACfz0B,MAAOnB,EAAE,oBACTzB,KAAM,SACNyL,oBAAqB,WACrBE,kBAAmB,WAErBksB,kBAAmB,CACjBj1B,MAAOnB,EAAE,mBACTzB,KAAM,SACNyL,oBAAqB,WACrBE,kBAAmB,SAErBkH,WAAY,CACVmpB,iBAAkB7/B,UACT,EAETu7B,WAAYv7B,MAAOQ,IACHJ,MAAVI,EACFP,EAAM6iC,4BAA4BtiC,GAElCP,EAAM6iC,4BAA4B,IAEpC7iC,EAAMyW,WAAW3H,WAAWvO,IAE9BuO,WAAY/O,YACZ86B,eAAgB96B,aAElB8T,SAAU7T,EAAM4iC,4BAMxB9/B,EAAKkM,EAAA,CAAA,GAGPlM,EAACsgC,GAAe,IACVpjC,GAAOg/B,SACXtyB,MAAO,CAAEzH,QAASmQ,IAClB9E,UAAW,CACTrL,QAAS,CACPqQ,cAAe,IACVtV,EACHyV,kBAAmBA,EACnB7b,KAAMoG,GAAOpG,MAEfyc,sBA7hBoB,KAC5B,GAAkC,SAA9BrW,GAAOoW,UAAUA,SACnB5K,EAASxL,EAAMoW,SAASiqB,MAAMuB,gBACzB,GAAkC,UAA9B5hC,GAAOoW,UAAUA,SAC1ByqB,IAAmB,QACd,GAAkC,QAA9B7gC,GAAOoW,UAAUA,SAAoB,CAC9CkmB,IAAgD,EAChD,MAAM+G,EAAiB,CAAE,EACzBA,EAAU3tB,GAAiB4mB,GAC3B+G,EAAU1D,OAAQ,EAClB,IAAK,MAAMjO,KAAckN,EAED,WAApBlN,GAAYj1B,MACZi1B,GAAY5e,OAAS4C,GAEjBgc,GAAY5e,QACduwB,EAAU3R,EAAW5e,OAAS,MAIpC4rB,GAAS4E,GAAiB,CAACD,KAAcC,KACzC9E,GAAkB+E,IAAmB,IAChCA,EACHjH,CAACA,IAAwB,CAAEj/B,KAAM8jC,GAAaC,YAugB1C9pB,eAxrBa,KACjBtX,GAAOqX,cACT1f,aAAa6rC,WAAWxjC,EAAMqX,cAEhCkmB,EAAyB,CAAA,GACzBE,EAAe,IACfE,EAAgB,CAAA,GAChBE,EAAwB,IACxBK,EAAiB,CACf/1B,KAAM,IAAwB,QAAnBm1B,EAA2BT,GAAoB,IAC1D3K,MAAO,IAAwB,QAAnBoL,EAA2BT,GAAoB,SAirBzD4G,SAAWv0B,GACFA,EAAOwG,GAEhBguB,aAAa,EACbC,KAAM3jC,GAAOpG,KACbklC,QAASmD,GACT2B,qBACAxtB,SAAS,MACTmoB,cAC6B,OAA3Bv+B,EAAMoW,SAASA,SAAoBmoB,OAAgBp+B,EAErD0jC,sBAC6B,OAA3B7jC,EAAMoW,SAASA,SAnoBY0tB,IACjCtF,EAAiBsF,SAooBP3jC,EAEN4jC,sBAAsB,WACtBC,iBA1emBjkC,MAAOmP,IAC9B,GAAgC,QAA5BlP,EAAMoW,SAASA,SAAoB,CACrC,IAAIilB,EAAmB,KACvB,MAAM1qB,EA9Ba,CAACzB,IACtB,IACEyvB,EAAiBlC,MAAMvtB,GACvB,MAAO+Q,GACPtb,QAAQC,IAAI,qBAAsBqb,GAClC,IAAItP,EAAoB,KAUxB,OAREA,EADEsP,aAAe7L,GAAE6vB,SACJhkB,EAAI8Y,OAChBntB,KACElM,GAAU,mBAAqBA,EAAMgH,KAAO,OAAShH,EAAMrG,UAE7DumB,KAAK,KAEO,sBAEVjP,IAecuzB,CAAeh1B,GACpC,GAAIyB,EAAc,CAChB,MAAMooB,EAASpoB,EAAamP,MAAM,KAWlC,MAVAlgB,GAAMF,MACJoD,EAAA,MAAA,CAAKvG,MAAO,CAAA,EAAEyG,SACX+1B,EAAOntB,KAAKlM,GACXuD,EAAA+L,EAAA,CAAAhM,SAAA,CACEF,EAAM,MAAA,CAAAE,SAAAtD,IACNoD,EAACoK,EAAO,CAAA,WAKV,IAAIkU,MAAMzQ,GAElB,GAAI3Q,GAAOuV,YAAYtG,sBAChBjP,EAAMuV,WAAWtG,oBAAoBC,GACxC,MAAM,IAAIkS,MAAM,8CAGpB,MAAM+iB,EAAqB,IAAKj1B,GAShC,GAPEA,EAAOwG,IACPgD,GAASxJ,EAAOwG,KAChBoD,OAAO5J,EAAOwG,IAAkB,IAEhCyuB,EAAczuB,GAAiB,MAEjC2lB,QAAoBr7B,EAAMyW,WAAW6kB,WAAW6I,GAC7B,MAAf9I,EACF,MAAM,IAAIja,MACR,8DAoBJ,OAjBIphB,GAAOuV,YAAYsqB,0BACf7/B,EAAMuV,WAAWsqB,mBAAmB3wB,IAEtB,IAAlBA,GAAQywB,OACVjB,GAASoB,IACP,MAAM0B,EAAU1B,EAAQn0B,QACrBoK,GAAWA,EAAEL,KAAmBxG,EAAOwG,KAE1C,MAAO,CAAC2lB,KAAgBmG,OAIW,IAArCxhC,GAAOoW,UAAUguB,iBACjBpkC,GAAOyW,YAAY3H,YAEnB9O,GAAOyW,YAAY3H,WAAW9O,GAAO0W,0BAEhC2kB,IAqbL5lB,kBAAmBA,EACnB4uB,0BAjPsBC,IAC1B7F,EAAqB6F,IAiPjBlH,sBAAuBA,EACvBmH,8BA1OgCC,IACpCjH,EAAyBiH,GACrBxkC,GAAOqX,cACTqlB,GAAc18B,EAAMqX,aAAc,CAAE+lB,sBAAuBoH,KAwOzDC,oBAnOJlkC,IAEA,MAAM0S,OAAEA,EAAMyxB,YAAEA,GAAgBnkC,EAChCk9B,GAAgBkH,IACd,MAAMC,EAAeD,EAAUh/B,OAC3B,IAAIg/B,GACJ3C,GAAkBp2B,KAAKu2B,GAAQA,EAAIrvB,QACjC+xB,EAAYD,EAAarb,QAAQtW,EAAOH,OAC9C,OAAoB,IAAhB+xB,IAEJD,EAAaE,OAAOD,EAAW,GAC/BD,EAAaE,OAAOJ,EAAa,EAAGzxB,EAAOH,OAEvC9S,GAAOqX,cACTqlB,GAAc18B,EAAMqX,aAAc,CAAEmmB,YAAaoH,KANtBA,MA4N3BG,oBAvMJxkC,IAEA,MAAMykC,EAAgB,IACjBtH,EACH,CAACn9B,EAAOmS,OAAOI,OAAQvS,EAAOiC,OAEhCm7B,EAAgBqH,GACZhlC,GAAOqX,cACTqlB,GAAc18B,EAAMqX,aAAc,CAAEqmB,aAAcsH,KAgMhDC,iBAAkBrH,EAClBsH,yBAA2BV,IAjNJ,CAACA,IAC5B3G,EAAwB2G,GACpBxkC,GAAOqX,cACTqlB,GAAc18B,EAAMqX,aAAc,CAAEymB,oBAAqB0G,KA+MrDW,CAAqBX,IAEvBxG,cAAeA,EACfoH,sBAhpB6BtB,IACjC,IAAI/F,EAAU+F,GAAU37B,MAAQ,GAChC41B,EAAUA,EAAQpyB,QACfuD,IAAiB2tB,GAAkB7R,SAAS9b,KAE/C,IAAI+uB,EAAW6F,GAAU5R,OAAS,GAClC+L,EAAWA,EAAStyB,QACjBuD,IAAiB2tB,GAAkB7R,SAAS9b,KAE/C,MAAMm2B,EAA0C,CAC9Cl9B,KAAM,IACmB,QAAnBm1B,EAA2BT,GAAoB,MAChDkB,GAEL7L,MAAO,IACkB,QAAnBoL,EAA2BT,GAAoB,MAChDoB,IAGPC,EAAiBmH,GACbrlC,GAAOqX,cACTqlB,GAAc18B,EAAMqX,aAAc,CAAE2mB,cAAeqH,WClLnDC,GACJC,IAEA,MAAMC,EAAezmC,GAAa/G,GAAqBA,EAAM6D,eACvD4C,EAAWC,IACX+P,EAAU3I,MACVhG,iBAAEA,EAAgBY,kBAAEA,EAAiBE,oBAAEA,GAC3C/B,KA0FF,MAAO,CAAEiQ,WAzFU/O,MAAOQ,IACxB,GAAIglC,GAAiBE,eAAgB,CACnC,MAAMC,EAAY3mB,OAAOiB,KAAKwlB,GAC9B,IAAK,MAAM7qC,KAAY+qC,EACrB,GAAI/qC,IAAa4qC,EAAgBE,sBAEUtlC,IAAtCqlC,EAAa7qC,IAAWR,WACe,OAAtCqrC,EAAa7qC,IAAWR,WACxBsU,EAAQ1I,iBAAiBy/B,EAAa7qC,IAAWR,aACpB,IAA/BqrC,EAAa7qC,IAAWd,IACxB,OACMiG,EAAiB,CACrBG,YAAaulC,EAAa7qC,GAAUd,IACpCuG,UAAU,EACVI,gBAAkBhB,IAChBf,EAAS/D,GAAa,CAAEC,WAAUf,KAAM4F,EAAS5F,QACjD2rC,EAAgB7G,QAAQl/B,EAAS5F,OAEnC6G,gBAAiB,KACfhC,EAAS/D,GAAa,CAAEC,WAAUf,KAAM,MACxC2rC,EAAgB7G,QAAQ,OAG5B,YAIG6G,GAAiBI,eACpB7lC,EAAiB,CACrBG,YAAaslC,EAAgBI,QAC7BvlC,UAAU,EACVF,WAAYK,GAAU,CAAE,EACxBC,gBAAkBhB,IAChB+lC,EAAgB7G,QAAQl/B,EAAS5F,UAwDpBihC,eArCE96B,MAAO6lC,IAC5B,IAAI12B,EAAc,KAClB,GAAIq2B,GAAiBM,SAAU,CAC7B,MAAM3lC,EAAkB,CAAE,EAE1BA,EADyBqlC,GAAiBO,mBAAqB,MAChCF,QACzB9lC,EAAiB,CACrBG,YAAaslC,EAAgBM,SAC7BzlC,UAAU,EACVF,aACAM,gBAAkBhB,IAChB0P,EAAS1P,EAAS5F,QAIxB,OAAOsV,GAsB4BosB,WAnDlBv7B,MAAOmP,IACxB,IAAImsB,EAAc,KAWlB,OAVIkK,GAAiBQ,YACbrlC,EAAkB,CACtBT,YAAaslC,EAAgBQ,KAC7BnsC,KAAMsV,EACN9O,UAAU,EACVI,gBAAkBhB,IAChB67B,EAAc77B,EAAS5F,QAItByhC,GAuCwCuE,iBApBxB7/B,MAAO6lC,IAC9B,IAAI1b,GAAS,EACb,GAAIqb,GAAiBS,WAAY,CAC/B,MAAM9lC,EAAkB,CAAE,EAE1BA,EADyBqlC,GAAiBU,qBAAuB,MAClCL,QACzBhlC,EAAoB,CACxBX,YAAaslC,EAAgBS,WAC7B5lC,UAAU,EACVF,aACAM,gBAAiB,KACf0pB,GAAS,GAEXzpB,gBAAiB,KACfypB,GAAS,KAIf,OAAOA,KCnHEgc,GAAoC,CAC/C,CACEx/B,KAAM,IACNxC,UCJmB,IAEnBjB,EAAC2D,EAAG,CACFrD,GAAI,CACFG,QAAS,OACTkE,cAAe,SACf7C,WAAY,SACZG,eAAgB,SAChBf,KAAM,EACNsF,SAAU,GACVP,WAAY,QAGdlG,SAAA,CAAAF,EAAA,MAAA,CAAKgB,IAAI,WAAWvH,MAAO,CAAEmxB,OAAQ,KACrC5qB,EAA6D,MAAA,CAAAE,SAAA,uDAC7DC,SAAK1G,MAAO,CAAEkN,SAAU,IAEtBzG,SAAA,CAAA,kBAAAF,EAACa,GACC,CAAAC,KAAK,OACLrH,MAAO,CAAEkG,WAAY,GAAIC,YAAa,MACtC,4DCpB+C,ICyCV,CAC7C,CACEgE,KAAM,oBACNxC,UCzC6B,KAC/B,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,8BACTK,WAAY,0BACZD,KAAM,0BACNF,SAAU,0BACVnH,QAASA,IAsFX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aAzF0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,+BACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,6BACZzkB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,6BACZzkB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,sBACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,sBACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,uBACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,qBACZzkB,UAAW,SACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,oBACZzkB,UAAW,SACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,oBACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,mBAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,wBD9D9CA,UAAW,mBAEb,CACEuM,KAAM,oBACNxC,UE/C4B,KAC9B,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BG,eAAgB,oBAChBO,WAAY,yBACZD,KAAM,yBACNF,SAAU,yBACVnH,QAASA,IA2DX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,MAAOguB,iBAAiB,GAC9CrH,aA9D0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2BACZzkB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,kCACZzkB,UAAW,uBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2BACZzkB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,sBACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,wCACZzkB,UAAW,4BACXxD,UAAU,EACVyD,UAAW,OACX+oB,UAAW,CACT9E,QAAQ,MAaZ1iB,cAAe,KACfitB,UAAU,mBACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,kBAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,uBF7B9CA,UAAW,kBAEb,CACEuM,KAAM,mBACNxC,UGpD4B,KAC9B,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,6BACTK,WAAY,yBACZD,KAAM,yBACNF,SAAU,yBACVnH,QAASA,IA0BX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aA7B0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,6BACZzkB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,sBACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,oBACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,mBAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,wBHS9CA,UAAW,mBAEb,CACEuM,KAAM,uBACNxC,UIzDgC,KAClC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,iCACTK,WAAY,6BACZD,KAAM,6BACNF,SAAU,6BACVnH,QAASA,IAwDX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aA3D0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,gCACZzkB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,0BACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,4BACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,6BACZzkB,UAAW,YACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2BACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,yBACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,wBAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,6BJhB9CA,UAAW,wBAEb,CACEuM,KAAM,wBACNxC,UK9DiC,KACnC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,kCACTK,WAAY,8BACZD,KAAM,8BACNF,SAAU,8BACVnH,QAASA,IAwDX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aA3D0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,sCACZzkB,UAAW,kBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,6BACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,8BACZzkB,UAAW,YACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,qBACZzkB,UAAW,IACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,qBACZzkB,UAAW,IACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,0BACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,yBAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,8BLX9CA,UAAW,yBAEb,CACEuM,KAAM,mBACNxC,UMnE4B,KAC9B,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,6BACTK,WAAY,yBACZD,KAAM,yBACNF,SAAU,yBACVnH,QAASA,IAkEX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aArE0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2BACZzkB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2BACZzkB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,4BACZzkB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,oBACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,sCACZzkB,UAAW,0BACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,8BACZzkB,UAAW,kBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,mBACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,kBAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,uBNhB9CA,UAAW,kBAEb,CACEuM,KAAM,yBACNxC,UOxEkC,KACpC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,mCACTK,WAAY,+BACZD,KAAM,+BACNF,SAAU,+BACVnH,QAASA,IA8CX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aAjD0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,gCACZzkB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2BACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,6BACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,gCACZzkB,UAAW,cACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,0BACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,yBAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,8BPS9CA,UAAW,yBAEb,CACEuM,KAAM,oBACNxC,UQ7E4B,KAC9B,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BG,eAAgB,oBAChBO,WAAY,yBACZD,KAAM,yBACNF,SAAU,yBACVnH,QAASA,IA8CX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,MAAOguB,iBAAiB,GAC9CrH,aAjD0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,+BACZzkB,UAAW,kBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,wBACZzkB,UAAW,YACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,uBACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,yBACZzkB,UAAW,YACXxD,UAAU,EACVyD,UAAW,cAYbuB,cAAe,KACfitB,UAAU,oBACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,mBAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,wBRc9CA,UAAW,mBAEb,CACEuM,KAAM,4BACNxC,USlFqC,KACvC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,sCACTK,WAAY,kCACZD,KAAM,kCACNF,SAAU,kCACVnH,QAASA,IAkEX,OACE57B,EAACg6B,GACC,CAAArmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aArE0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,qCACZzkB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,qCACZzkB,UAAW,eACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,+BACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2CACZzkB,UAAW,oBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,8BACZzkB,UAAW,SACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iCACZzkB,UAAW,YACXxD,UAAU,EACVyD,UAAW,cAYbuB,cAAe,KACfitB,UAAU,8BACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,6BAC1CslC,aAAc,CACZsB,WAAW,EACX5mC,UAAW,kCTHfA,UAAW,6BAEb,CACEuM,KAAM,8BACNxC,UUvFuC,KACzC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BG,eAAgB,oBAChBO,WAAY,oCACZD,KAAM,oCACNF,SAAU,oCACVnH,QAASA,IAkEX,OACE57B,EAACg6B,GACC,CAAArmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,MAAOguB,iBAAiB,GAC9CrH,aArE0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,wCACZzkB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,4CACZzkB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,wCACZzkB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,uCACZzkB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,4CACZzkB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,gCACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,cAYbuB,cAAe,KACfitB,UAAU,+BACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,8BAC1CslC,aAAc,CACZsB,WAAW,EACX5mC,UAAW,mCVEfA,UAAW,8BAEb,CACEuM,KAAM,kBACNxC,UW5F2B,KAC7B,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,4BACTK,WAAY,wBACZD,KAAM,wBACNF,SAAU,wBACVnH,QAASA,IA4EX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aA/E0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iBACZzkB,UAAW,QACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,yBACZzkB,UAAW,eACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2BACZzkB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,yBACZzkB,UAAW,eACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,gCACZzkB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,gCACZzkB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2BACZzkB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,kBACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,iBAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,sBXD9CA,UAAW,iBAEb,CACEuM,KAAM,yBACNxC,UYjGkC,KACpC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BG,eAAgB,yBAChBO,WAAY,+BACZD,KAAM,+BACNF,SAAU,+BACVnH,QAASA,IAgGX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,MAAOguB,iBAAiB,GAC9CrH,aAnG0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2BACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,kCACZzkB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2CACZzkB,UAAW,uBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,qCACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2CACZzkB,UAAW,wBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,mCACZzkB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,kCACZzkB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,yCACZzkB,UAAW,sBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,0CACZzkB,UAAW,uBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,0BACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,yBAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,8BZhB9CA,UAAW,yBAEb,CACEuM,KAAM,6BACNxC,UatGsC,KACxC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,uCACTK,WAAY,mCACZD,KAAM,mCACNF,SAAU,mCACVnH,QAASA,IA8CX,OACE57B,EAACg6B,GACC,CAAArmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aAjD0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,qCACZzkB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iDACZzkB,UAAW,wBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,wCACZzkB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,oCACZzkB,UAAW,aACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,+BACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,8BAC1CslC,aAAc,CACZsB,WAAW,EACX5mC,UAAW,mCbqCfA,UAAW,8BAEb,CACEuM,KAAM,6BACNxC,Uc3GsC,KACxC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,uCACTK,WAAY,mCACZD,KAAM,mCACNF,SAAU,mCACVnH,QAASA,IA8CX,OACE57B,EAACg6B,GACC,CAAArmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aAjD0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,+CACZzkB,UAAW,uBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,+CACZzkB,UAAW,uBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,sCACZzkB,UAAW,eACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,4CACZzkB,UAAW,oBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,+BACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,8BAC1CslC,aAAc,CACZsB,WAAW,EACX5mC,UAAW,mCd0CfA,UAAW,8BAEb,CACEuM,KAAM,gBACNxC,UehHyB,KAC3B,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,0BACTK,WAAY,sBACZD,KAAM,sBACNF,SAAU,sBACVnH,QAASA,IAkEX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aArE0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iBACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2BACZzkB,UAAW,kBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2BACZzkB,UAAW,kBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,qBACZzkB,UAAW,aACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,sBACZzkB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,kBACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,gBACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,eAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,oBf6B9CA,UAAW,eAEb,CACEuM,KAAM,wBACNxC,UgBrHiC,KACnC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,kCACTK,WAAY,8BACZD,KAAM,8BACNF,SAAU,8BACVnH,QAASA,IAoCX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aAvC0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,0BACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,mCACZzkB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,4BACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,yBACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,wBAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,6BhBgE9CA,UAAW,wBAEb,CACEuM,KAAM,mBACNxC,UiB1H2B,KAC7B,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,4BACTK,WAAY,wBACZD,KAAM,wBACNF,SAAU,wBACVnH,QAASA,IA4EX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aA/E0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,yBACZzkB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,uCACZzkB,UAAW,yBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,uBACZzkB,UAAW,YACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,oBACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,oBACZzkB,UAAW,SACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,6BACZzkB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,kCACZzkB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,cAYbuB,cAAe,KACfitB,UAAU,mBACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,kBAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,uBjB6B9CA,UAAW,kBAEb,CACEuM,KAAM,+BACNxC,UkB/HwC,KAC1C,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,yCACTK,WAAY,qCACZD,KAAM,qCACNF,SAAU,qCACVnH,QAASA,IAgGX,OACE57B,EAACg6B,IACCrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aAnG0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,yDACZzkB,UAAW,6BACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2CACZzkB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,8CACZzkB,UAAW,oBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,4CACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,sCACZzkB,UAAW,aACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,0CACZzkB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2CACZzkB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,+CACZzkB,UAAW,sBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,4CACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,cAYbuB,cAAe,KACfitB,UAAU,iCACVD,SAAS,cACTntB,WAAY,CACVwrB,WAAW,EACX5mC,UAAW,gCAEbslC,aAAc,CACZsB,WAAW,EACX5mC,UAAW,qClBSfA,UAAW,gCAEb,CACEuM,KAAM,uBACNxC,UmBpIgC,KAClC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,iCACTK,WAAY,6BACZD,KAAM,6BACNF,SAAU,6BACVnH,QAASA,IA8CX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aAjD0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,yBACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,kCACZzkB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,gCACZzkB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,gCACZzkB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,wBACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,uBAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,4BnBqE9CA,UAAW,uBAEb,CACEuM,KAAM,sBACNxC,UoBzI+B,KACjC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,gCACTK,WAAY,4BACZD,KAAM,4BACNF,SAAU,4BACVnH,QAASA,IAoHX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aAvH0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,wBACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,sCACZzkB,UAAW,oBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,6BACZzkB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,mCACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,mCACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,sCACZzkB,UAAW,oBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,4BACZzkB,UAAW,aACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,6BACZzkB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2BACZzkB,UAAW,aACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iCACZzkB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,sCACZzkB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,uBACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,sBAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,2BpBI9CA,UAAW,sBAEb,CACEuM,KAAM,kBACNxC,UqB9I2B,KAC7B,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,4BACTK,WAAY,wBACZD,KAAM,wBACNF,SAAU,wBACVnH,QAASA,IAoCX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aAvC0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,sBACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,sBACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,WAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,yBACZzkB,UAAW,cACXxD,UAAU,EACVyD,UAAW,YAYbuB,cAAe,KACfitB,UAAU,mBACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,kBAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,uBrByF9CA,UAAW,kBAEb,CACEuM,KAAM,sBACNxC,UsBnJ+B,KACjC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,gCACTK,WAAY,4BACZD,KAAM,4BACNF,SAAU,4BACVnH,QAASA,IAsFX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aAzF0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,uBACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,uCACZzkB,UAAW,wBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2CACZzkB,UAAW,4BACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iCACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iCACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,qCACZzkB,UAAW,sBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iCACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,wCACZzkB,UAAW,uBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,sBACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,qBAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,0BtB4C9CA,UAAW,qBAEb,CACEuM,KAAM,2BACNxC,UuBxJoC,KACtC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,qCACTK,WAAY,iCACZD,KAAM,iCACNF,SAAU,iCACVnH,QAASA,IAgGX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aAnG0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,oDACZzkB,UAAW,8BACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,wDACZzkB,UAAW,kCACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,8CACZzkB,UAAW,yBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,8CACZzkB,UAAW,yBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iCACZzkB,UAAW,aACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,uCACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,yCACZzkB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,mCACZzkB,UAAW,eACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,8BACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,4BACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,2BAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,gCvBuC9CA,UAAW,2BAEb,CACEuM,KAAM,sBACNxC,UwB7J+B,KACjC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,gCACTK,WAAY,4BACZD,KAAM,4BACNF,SAAU,4BACVnH,QAASA,IAoCX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aAvC0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iCACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,yBACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iCACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,mBACfitB,UAAU,sBACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,qBAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,0BxBwG9CA,UAAW,qBAEb,CACEuM,KAAM,iCACNxC,UyBlK0C,KAC5C,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,2CACTK,WAAY,uCACZD,KAAM,uCACNF,SAAU,uCACVnH,QAASA,IA8CX,OACE57B,EAACg6B,IACCrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aAjD0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,4CACZzkB,UAAW,kBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,mDACZzkB,UAAW,yBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,4CACZzkB,UAAW,kBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,qCACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,cAYbuB,cAAe,KACfitB,UAAU,kCACVD,SAAS,cACTntB,WAAY,CACVwrB,WAAW,EACX5mC,UAAW,iCAEbslC,aAAc,CACZsB,WAAW,EACX5mC,UAAW,sCzB8FfA,UAAW,iCAEb,CACEuM,KAAM,0BACNxC,U0BvKmC,KACrC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,oCACTK,WAAY,gCACZD,KAAM,gCACNF,SAAU,gCACVnH,QAASA,IAwDX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aA3D0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,4BACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,sCACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,8BACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,8BACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,+BACZzkB,UAAW,YACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,2BACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,0BAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,+B1B8F9CA,UAAW,0BAEb,CACEuM,KAAM,0BACNxC,U2B5KmC,KACrC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,oCACTK,WAAY,gCACZD,KAAM,gCACNF,SAAU,gCACVnH,QAASA,IAwDX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aA3D0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,4BACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,sCACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,8CACZzkB,UAAW,yBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,8CACZzkB,UAAW,yBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,gDACZzkB,UAAW,2BACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,2BACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,0BAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,+B3BmG9CA,UAAW,0BAEb,CACEuM,KAAM,0BACNxC,U4BjLmC,KACrC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,oCACTK,WAAY,gCACZD,KAAM,gCACNF,SAAU,gCACVnH,QAASA,IA8CX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aAjD0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,8BACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,+BACZzkB,UAAW,YACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,sCACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,6BACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,2BACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,0BAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,+B5BkH9CA,UAAW,0BAEb,CACEuM,KAAM,8BACNxC,U6BtLuC,KACzC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,wCACTK,WAAY,oCACZD,KAAM,oCACNF,SAAU,oCACVnH,QAASA,IAkEX,OACE57B,EAACg6B,GACC,CAAArmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aArE0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,kCACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,mCACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2CACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iCACZzkB,UAAW,SACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,oCACZzkB,UAAW,YACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,kCACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,gCACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,+BAC1CslC,aAAc,CACZsB,WAAW,EACX5mC,UAAW,oC7BiGfA,UAAW,+BAEb,CACEuM,KAAM,gBACNxC,U8B3LyB,KAC3B,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,0BACTK,WAAY,sBACZD,KAAM,sBACNF,SAAU,sBACVnH,QAASA,IA8HX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aAjI0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2BACZzkB,UAAW,kBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,8BACZzkB,UAAW,oBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,yBACZzkB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,qBACZzkB,UAAW,aACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,oCACZzkB,UAAW,yBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,4BACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,4BACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,4BACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,0BACZzkB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,qBACZzkB,UAAW,aACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,qBACZzkB,UAAW,aACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,4BACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,cAYbuB,cAAe,KACfitB,UAAU,gBACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,eAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,oB9B4C9CA,UAAW,eAEb,CACEuM,KAAM,yBACNxC,U+BhMkC,KACpC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,mCACTK,WAAY,+BACZD,KAAM,+BACNF,SAAU,+BACVnH,QAASA,IAkEX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aArE0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iCACZzkB,UAAW,eACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2BACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,uCACZzkB,UAAW,oBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,0BACZzkB,UAAW,SACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,6BACZzkB,UAAW,YACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,6BACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,0BACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,yBAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,8B/B6G9CA,UAAW,yBAEb,CACEuM,KAAM,cACNxC,UgCrMuB,KACzB,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BG,eAAgB,cAChBO,WAAY,oBACZD,KAAM,oBACNF,SAAU,oBACVnH,QAASA,IAiDX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,MAAOguB,iBAAiB,GAC9CrH,aApD0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iBACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,mBACZzkB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iBACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,mCACZzkB,UAAW,4BACXxD,UAAU,EACVyD,UAAW,OACX+oB,UAAW,CACT9E,QAAQ,MAaZ1iB,cAAe,KACfitB,UAAU,cACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,aAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,kBhCmI9CA,UAAW,aAEb,CACEuM,KAAM,wBACNxC,UiC1MgC,KAClC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,iCACTK,WAAY,6BACZD,KAAM,6BACNF,SAAU,6BACVnH,QAASA,IAoCX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aAvC0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,8BACZzkB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2BACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,yBACZzkB,UAAW,SACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,wBACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,uBAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,4BjCqJ9CA,UAAW,uBAEb,CACEuM,KAAM,qBACNxC,UkC/M8B,KAChC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,+BACTK,WAAY,2BACZD,KAAM,2BACNF,SAAU,2BACVnH,QAASA,IAoCX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aAvC0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,uBACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,wBACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,wBACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,sBACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,qBAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,0BlC0J9CA,UAAW,qBAEb,CACEuM,KAAM,qBACNxC,UmCpN8B,KAChC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,+BACTK,WAAY,2BACZD,KAAM,2BACNF,SAAU,2BACVnH,QAASA,IAoHX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aAvH0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2BACZzkB,UAAW,aACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,+BACZzkB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,oCACZzkB,UAAW,sBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iCACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iCACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2BACZzkB,UAAW,aACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2BACZzkB,UAAW,aACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iCACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,4BACZzkB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,sBACZzkB,UAAW,SACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,8BACZzkB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,sBACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,qBAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,0BnC+E9CA,UAAW,qBAEb,CACEuM,KAAM,gBACNxC,UoCzNyB,KAC3B,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,0BACTK,WAAY,sBACZD,KAAM,sBACNF,SAAU,sBACVnH,QAASA,IAkJX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aArJ0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,uBACZzkB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iBACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,gBACZzkB,UAAW,SACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,+BACZzkB,UAAW,sBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,+BACZzkB,UAAW,sBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,cACZzkB,UAAW,OACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,qBACZzkB,UAAW,aACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,eACZzkB,UAAW,QACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,6BACZzkB,UAAW,oBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,6BACZzkB,UAAW,oBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,4BACZzkB,UAAW,oBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,qBACZzkB,UAAW,aACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,qBACZzkB,UAAW,aACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,eACZzkB,UAAW,QACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,gBACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,eAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,oBpCsD9CA,UAAW,eAEb,CACEuM,KAAM,0BACNxC,UqC9NmC,KACrC,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,oCACTK,WAAY,gCACZD,KAAM,gCACNF,SAAU,gCACVnH,QAASA,IA4JX,OACE57B,EAACg6B,GAAY,CACXrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aA/J0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,0CACZzkB,UAAW,sBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2CACZzkB,UAAW,uBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,mCACZzkB,UAAW,eACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,kCACZzkB,UAAW,eACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,oCACZzkB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2CACZzkB,UAAW,uBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,4CACZzkB,UAAW,wBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,sCACZzkB,UAAW,kBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,kCACZzkB,UAAW,eACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,0CACZzkB,UAAW,sBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,uCACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,0CACZzkB,UAAW,sBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,0CACZzkB,UAAW,sBACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,6BACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,mCACZzkB,UAAW,eACXxD,UAAU,EACVyD,UAAW,cAYbuB,cAAe,KACfitB,UAAU,2BACVD,SAAS,cACTntB,WAAY,CAAEwrB,WAAW,EAAM5mC,UAAW,0BAC1CslC,aAAc,CAAEsB,WAAW,EAAM5mC,UAAW,+BrCiD9CA,UAAW,0BAEb,CACEuM,KAAM,gCACNxC,UsCnOyC,KAC3C,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,0CACTK,WAAY,sCACZD,KAAM,sCACNF,SAAU,sCACVnH,QAASA,IA4EX,OACE57B,EAACg6B,IACCrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aA/E0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,gDACZzkB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,gDACZzkB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,mDACZzkB,UAAW,uBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,gDACZzkB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,+CACZzkB,UAAW,oBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,2CACZzkB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,gDACZzkB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,kCACVD,SAAS,cACTntB,WAAY,CACVwrB,WAAW,EACX5mC,UAAW,iCAEbslC,aAAc,CACZsB,WAAW,EACX5mC,UAAW,sCtCiIfA,UAAW,iCAEb,CACEuM,KAAM,wCACNxC,UuCxOgD,KAClD,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,iDACTK,WAAY,6CACZD,KAAM,6CACNF,SAAU,6CACVnH,QAASA,IA4EX,OACE57B,EAACg6B,IACCrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aA/E0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,6CACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,kDACZzkB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iDACZzkB,UAAW,eACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,+CACZzkB,UAAW,aACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,sDACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,mDACZzkB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,wDACZzkB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,0CACVD,SAAS,cACTntB,WAAY,CACVwrB,WAAW,EACX5mC,UAAW,yCAEbslC,aAAc,CACZsB,WAAW,EACX5mC,UAAW,8CvCsIfA,UAAW,yCAEb,CACEuM,KAAM,oCACNxC,UwC7O6C,KAC/C,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,8CACTK,WAAY,0CACZD,KAAM,0CACNF,SAAU,0CACVnH,QAASA,IAoCX,OACE57B,EAACg6B,IACCrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aAvC0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,mDACZzkB,UAAW,mBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,wCACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iDACZzkB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,uCACVD,SAAS,cACTntB,WAAY,CACVwrB,WAAW,EACX5mC,UAAW,sCAEbslC,aAAc,CACZsB,WAAW,EACX5mC,UAAW,2CxCmLfA,UAAW,sCAEb,CACEuM,KAAM,iCACNxC,UyClP0C,KAC5C,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,2CACTK,WAAY,uCACZD,KAAM,uCACNF,SAAU,uCACVnH,QAASA,IA0GX,OACE57B,EAACg6B,IACCrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aA7G0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,8CACZzkB,UAAW,gBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,0CACZzkB,UAAW,cACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,8CACZzkB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,+CACZzkB,UAAW,kBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,uCACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,0CACZzkB,UAAW,cACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,6CACZzkB,UAAW,iBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,0CACZzkB,UAAW,cACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,wCACZzkB,UAAW,WACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,kDACZzkB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,oCACVD,SAAS,cACTntB,WAAY,CACVwrB,WAAW,EACX5mC,UAAW,mCAEbslC,aAAc,CACZsB,WAAW,EACX5mC,UAAW,wCzCkHfA,UAAW,mCAEb,CACEuM,KAAM,iCACNxC,U0CvPyC,KAC3C,MAAOtK,EAAM8kC,GAAWzgC,EAAS,IAC3BwY,EAAa6uB,GAAc,CAC/BK,QAAS,0CACTK,WAAY,sCACZD,KAAM,sCACNF,SAAU,sCACVnH,QAASA,IAsFX,OACE57B,EAACg6B,IACCrmB,WAAYA,EACZ7c,KAAMA,EACN8kC,QAASA,EACTtoB,SAAU,CAAEA,SAAU,OACtB2mB,aAzF0C,CAC5C,CACEtgC,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,gDACZzkB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,gDACZzkB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iDACZzkB,UAAW,sBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,mCACZzkB,UAAW,UACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,yCACZzkB,UAAW,cACXxD,UAAU,EACVyD,UAAW,aAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,uDACZzkB,UAAW,0BACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,iDACZzkB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,SAGf,CACE1X,KAAM,QACNY,KAAM,QACN2C,MAAO,CACL24B,WAAY,gDACZzkB,UAAW,qBACXxD,UAAU,EACVyD,UAAW,UAYbuB,cAAe,KACfitB,UAAU,kCACVD,SAAS,cACTntB,WAAY,CACVwrB,WAAW,EACX5mC,UAAW,iCAEbslC,aAAc,CACZsB,WAAW,EACX5mC,UAAW,sC1C2IfA,UAAW,oC2CpPTgsC,GAAwB,KAC5B,MAAMn1B,EAAiBjS,GAAa/G,GAAqBA,EAAM0D,YACzDN,EAAiB2D,GACpB/G,GAAqBA,EAAM8D,QAAQnD,MAAMyC,iBAE5C,OACE0H,EAACsjC,EACC,CAAAztC,MAAuC,QAAhCqY,EAAenZ,aAAyB4V,GAAWN,YAE1DrK,EAAC8D,EACC,CAAArD,GAAI,CACFG,QAAS,OACTkE,cAAe,SAEf1C,eAAgB,aAChBf,KAAM,EACN4sB,SAAU,SACVhpB,QAAS,GACV/E,SAEDC,EAACojC,GACE,CAAArjC,SAAA,CAAAkjC,GAAct6B,KAAI,CAAC06B,EAAoBhc,IAEpCxnB,EAACyjC,GAAK,CAEJ7/B,KAAM4/B,EAAM5/B,KACZ8/B,UAAWF,EAAMpiC,WAFZ,MAAQomB,KAMlBlvB,EAAewQ,KAAI,CAAC06B,EAAoBhc,IAErCxnB,EAACyjC,GAAK,CAEJ7/B,KAAM4/B,EAAM5/B,KACZ8/B,UAAWF,EAAMpiC,WAFZ,KAAOomB,aCvBtBmc,GAAS9kC,EAAO,MAAPA,EAAc,EAAGI,YAAa,CAC3CS,MAAO,GACPqE,OAAQ,EACR6mB,OAAQ,GACRrlB,gBAAiBhB,GAAK,KACtBP,aAAc,EAEdsB,IAAK,KAEFrG,EAAM0F,YAAY,OAAQ,CAC3BY,gBAAiBhB,GAAK,WAIF,SAAAq/B,GAAa1mC,GACnC,MAAM9B,OAAEA,GAAW8B,EACbtE,EAAYqD,GAAa/G,GAAqBA,EAAM0D,YACpDI,EAAUiD,GAAa/G,GAAqBA,EAAM8D,QAAQnD,QAC1D8F,EAAWC,IACXioC,EAAgBC,IACpBnoC,EAASnG,GAAiBL,gBAAgB2uC,KAM5C,OACE9jC,EAAC+jC,GAAe,CACdtN,eAJSp5B,IAAXjC,EAAuB,IAAMA,IAAS9B,SAAS8R,UAAO/N,EAKpD6M,OAAO,SACPzK,KAAM7G,EAAUjE,cAChBwkC,QAAS,KACP0K,GAAa,IAEfG,OAAQ,KACNH,GAAa,IAEfI,eA/CiB,GAgDjBC,oBAAoB,EACpBC,WAAY,CACVC,aAAa,GACdlkC,SAEDC,EAAC2D,EACC,CAAArD,GAAI,CACFG,QAAS,OACTkE,cAAe,SACf7C,WAAY,SACZ8B,OAAQ,OACRkqB,SAAU,UAGZ/tB,SAAA,CAAAF,EAAC2jC,GAAS,CAAA,GACV3jC,EAAC8D,EAAG,CACFrD,GAAI,CACF6I,SAAU,EACV1I,QAAS,OACTwB,eAAgB,SAChB1C,MAAO,MACPgK,UAAW,QAGbxJ,SAAAF,EAACyI,GAAiB,CAAA,KAEpBtI,EAAC2D,EACC,CAAArD,GAAI,CACFG,QAAS,OACTqB,WAAY,SACZG,eAAgB,eAChB4C,UAAW,EACXtF,MAAO,QACRQ,SAAA,CAEDF,EAACiB,EAAU,CAACR,GAAI,CAAEkG,SAAU,IAAMrG,MAAM,eAAcJ,SACnDlH,EAAQd,UAEXiI,EAACc,EAAW,CAAAR,GAAI,CAAEkG,SAAU,IAAMrG,MAAM,eACnCJ,SAAA,CAAA,KAAAlH,EAAQb,qBAMvB,CClGA,MAAMksC,GAAwB,KAC5B,MAAMvrC,EAAcmD,GACjB/G,GAAqBA,EAAM4D,YAAYjD,QAE1C,OACEmK,EAACskC,GACC7jC,GAAI,CAAEH,MAAO,OAAQ6D,OAASlF,GAAUA,EAAMkF,OAAO+0B,OAAS,GAC9Dz5B,KAAM3G,EAAYxC,kBAElB0J,EAACukC,GAAiBjkC,MAAM,eCKxBkkC,GAAkB,KACtB,MAAMC,EAAUxoC,GAAa/G,GAAqBA,EAAM8D,QAAQnD,SACzD+L,EAAU8iC,GAAevpC,EAAS,KAClCwpC,EAAUC,GAAezpC,EAAS,KAClC0pC,EAAkBC,GAAuB3pC,GAAS,GACnD4pC,EAAmB9oC,GACtB/G,GAAqBA,EAAM2D,YAAYhD,QAEpC8F,EAAWC,IACXopC,EAAc/nC,UAClB,GAAgB,MAAZ2E,GAAgC,IAAZA,EAEtB,YADA9E,GAAMF,MAAM,mCAGd,GAAgB,MAAZ+nC,GAAgC,IAAZA,EAEtB,YADA7nC,GAAMF,MAAM,mCAGdkoC,GAAoB,GACpB,IAAIpoC,EAAgB,KACpB,IAWE,GAVAA,QAAiBP,GAAM0B,KACrB,GAAG4mC,EAAQxsC,4BACX,CACE2J,WACA+iC,YAEF,CACEpoC,iBAAiB,IAGA,MAAjBG,EAAS5F,MAAkC,KAAlB4F,EAAS5F,KAAa,CACjDguC,GAAoB,GACpB,MAAMjsC,EAAc,CAClB/C,iBAAiB,EACjBC,YAAa2G,EAAS5F,KAAKf,YAC3BC,YAAa0G,EAAS5F,MAExB6E,EAASxF,GAAmBF,iBAAiB4C,KAE/C,MAAOyJ,GACPwiC,GAAoB,GACpBhoC,GAAMF,MACJ0F,GAAG5F,UAAU5F,MACX,wDAIFmuC,EAAchpC,GACjB/G,GAAqBA,EAAM2D,YAAYhD,QAEpCqvC,EAAavS,EAAY73B,IA8B/B,OAHAQ,GAAU,KA1Be2B,WACvB,GAAIwnC,GAASxsC,YACwB,MAA/BgtC,EAAYnvC,gBACd,IACE,IAAI4G,QAAiBP,GAAMqB,IACzB,GAAGinC,EAAQxsC,+BACX,CACEsE,iBAAiB,IAGrB,GAAgB,MAAZG,GAAqC,MAAjBA,EAAS5F,KAAc,CAC7C,MAAM+B,EAAc,CAClB/C,iBAAiB,EACjBC,YAAa2G,EAAS5F,KAAKf,YAC3BC,YAAa0G,EAAS5F,MAExB6E,EAASxF,GAAmBF,iBAAiB4C,SAE7C8C,EAASxF,GAAmBD,sBAE9B,MAAO0G,GACPjB,EAASxF,GAAmBD,wBAMlCivC,KACC,CAACV,IAEFzkC,EAAColC,EAAa,CAACnmC,MAAOimC,EAAUhlC,SAC9BF,EAACu5B,EACC,CAAA94B,GAAI,CACFG,QAAS,OACTmD,OAAQ,QACRrE,MAAO,OACPsE,aAAc,EACd/B,WAAY,SACZG,eAAgB,UACjBlC,SAEoC,GAApC6kC,EAAiBjvC,gBAChBqK,EAAC2D,EAAG,CACFrD,GAAI,CACFG,QAAS,OACTkE,cAAe,SACf7C,WAAY,SACZG,eAAgB,UAGlBlC,SAAA,CAAAF,EAAA,MAAA,CAAKgB,IAAKyjC,GAASrsC,QAASsH,MAAO,IAAKqE,OAAQ,MAChD/D,EAACiB,EAAU,CAACR,GAAI,CAAEyX,EAAG,GAAKhX,QAAQ,KAAKZ,MAAM,yBAC1CmkC,GAASvsC,UAEZiI,EAACc,EAAU,CACTR,GAAI,CACFyE,aAAc,EACdxF,MAAO,OACPyK,UAAW,QACXxD,SAAU,IAEZzF,QAAQ,UACRZ,MAAM,gBAEHJ,SAAA,CAAA,KAAAukC,EAAQtsC,cAEb6H,EAACkP,EACC,CAAAxL,MAAM,WACNjD,GAAI,CAAEf,MAAO,IAAKwY,EAAG,GACrBriB,MAAO+L,EACPuL,SAAW/D,IACTs7B,EAAYt7B,EAAMqG,OAAO5Z,QAE3BwvC,UAAYj8B,IACQ,UAAdA,EAAMmB,KACRy6B,OAINhlC,EAACkP,GACCxL,MAAM,WACNjD,GAAI,CAAEf,MAAO,IAAKwY,EAAG,GACrBriB,MAAO8uC,EACPhrC,KAAK,WACLwT,SAAW/D,IACTw7B,EAAYx7B,EAAMqG,OAAO5Z,QAE3BwvC,UAAYj8B,IACQ,UAAdA,EAAMmB,KACRy6B,OAINhlC,EAACsL,EAAM,CACLg6B,QAAST,EACTtkC,QAASykC,EACT9jC,QAAQ,YACRZ,MAAM,UACNG,GAAI,CAAEyX,EAAG,GAGFhY,SAAA,aAGXC,EACE+L,EAAA,CAAAhM,SAAA,CAAAF,EAACukC,EAAgB,CAAC9jC,GAAI,CAAEb,YAAa,KACrCI,EAAyD,MAAA,CAAAE,SAAA,2DC1J/DqlC,GAAO1mC,EAAO,OAAQ,CAC1BE,kBAAoBC,GAAkB,SAATA,GADlBH,EAIV,EAAGI,MAAOmhB,EAAK3gB,WAChB,MAAM7G,EAAYqD,GAAa/G,GAAqBA,EAAM0D,YACpD+C,EAAWC,KACXC,KAAEA,EAAIC,KAAEA,GAASJ,KACjBgnC,EAAezmC,GAAa/G,GAAqBA,EAAM6D,eACvDkG,EAAQ6K,KACR7O,EAAWF,MACXkI,iBAAEA,GAAqBD,MAGvBhG,iBAAEA,GAAqBjB,KA+B7B,OAJAT,GAAU,KA1Be2B,WACvBpB,EAAK,2BACL,IAAI+mC,EAAY3mB,OAAOiB,KAAKwlB,GAC5B,IAAK,IAAI7qC,KAAY+qC,OAEsBvlC,IAAtCqlC,EAAa7qC,IAAWR,WACe,OAAtCqrC,EAAa7qC,IAAWR,YACxB4L,EAAiBy/B,EAAa7qC,IAAWR,YACZ,IAA/BqrC,EAAa7qC,IAAWd,MACY,IAApC2rC,EAAa7qC,GAAUhB,gBAEjBmG,EAAiB,CACrBG,YAAaulC,EAAa7qC,GAAUd,IACpCuG,UAAU,EACVI,gBAAkBhB,IAChBf,EAAS/D,GAAa,CAAEC,WAAUf,KAAM4F,EAAS5F,SAEnD6G,gBAAiB,KACfhC,EAAS/D,GAAa,CAAEC,WAAUf,KAAM,SAKhDgF,KAIA0pC,KACC,IAEI,CACL5kC,QAAS,OACTkE,cAAe,SACfmpB,SAAU,SACV3kB,SAAU,EACV5J,OAAQzE,GAAYwE,EAAO,qBAAmC,OAC9D+J,UAAW5Q,EAAU7D,aACrBqN,eAAgB,aAChBlD,YACW,IAATO,EACIR,EAAME,YAAY/C,OAAO,CAAC,SAAU,SAAU,CAC5CgD,OAAQH,EAAME,YAAYC,OAAOS,QACjCP,SAAUL,EAAME,YAAYG,SAASQ,iBAEvCb,EAAME,YAAY/C,OAAO,CAAC,SAAU,SAAU,CAC5CgD,OAAQH,EAAME,YAAYC,OAAOC,MACjCC,SAAUL,EAAME,YAAYG,SAASC,gBAE7CI,WACG1E,GAAuC,QAA3BrC,EAAU7D,eAAmC,IAAT0K,EAE7C,EADAlL,GAAe,KAErBqL,YACG3E,GAAuC,QAA3BrC,EAAU7D,eAAmC,IAAT0K,EAE7C,EADAlL,GAAe,SAKX,SAAUkxC,KACtB,MAAMv3B,EAAiBjS,GAAa/G,GAAqBA,EAAM0D,YACzDqC,EAAWF,KACXlC,EAAgCoD,GACnC/G,GAAqBA,EAAM2D,cAE9B,OACEsH,EAACulC,GAAa,CAAAxlC,SAAA,CACZF,EAAC2lC,GAAc,CAACC,WAAW,EAAM3lC,SAAS,kBAC1CD,EAACqkC,GAAW,KAC2B,IAAtCxrC,EAAYhD,MAAMC,gBACjBqK,EAAColC,GAAI,CAAC9lC,KAAMyO,EAAevZ,cAAauL,SAAA,CACtCF,EAAC6lC,GAAW,CAAA,GACZ7lC,EAACD,OACC9E,EAAyB,KAAd+E,EAAC6J,OACb5O,EAAW+E,EAAC4jC,OAAkB,KAC/B5jC,EAACgC,GAAY,CAAA,GACbhC,EAACqjC,UAGHrjC,EAACwkC,SAIT,CC7GA,MAAMsB,GAA0B5oC,IAC9B6oC,GAAYC,cAAc9oC,EAAM7E,eAChC,MAAMsD,EAAWC,IACXsS,EAAiBjS,GAAa/G,GAAqBA,EAAM0D,YAC/D,IAAIqtC,EAAe,IAAK/rC,IACS,SAA7BgU,EAAetZ,YACjBqxC,EAAe,IAAKnrC,KAEtB,MAAMmE,EAAQ0zB,EAAY,CACxBnpB,UAAW0E,EAAenZ,gBACvBkxC,IAML,OAJA3qC,GAAU,KACRhC,SAAS2R,MAAQ/N,EAAMlF,cACvB2D,EAAShD,GAAeD,WAAWwE,MAClC,IAED8C,EAAColC,EAAa,CAACnmC,MAAOA,EAAKiB,SACzBF,EAACylC,GAAS,CAAA,MCjBhBS,EAAQC,IAAIC,GACZF,EAAQC,IAAIE,GACZH,EAAQC,IAAIG,GAEC,MAAAC,GAA8BrpC,IACzC,GAAIA,GAAOzE,6BACT,IAAK,IAAI+tC,KAAoBvqB,OAAOiB,KAClChgB,EAAMzE,8BAEN9B,GAAyB6vC,GACvBtpC,EAAMzE,6BAA6B+tC,GAGzC,GAAItpC,GAAO1E,sBACT,IAAK,IAAIiuC,KAAsBxqB,OAAOiB,KAAKhgB,EAAM1E,uB1IX1B+R,E0IanBk8B,E1IbgC9wC,E0IchCuH,EAAM1E,sBAAsBiuC,G1Ib7BzxC,GAASuV,KACZvV,GAASuV,GAAO5U,GAFJ,IAAW4U,EAAa5U,E0IkBtC,OACEqK,EAAC0mC,EAAQ,CAACztC,MAAOA,GACfiH,SAAAF,EAAC8lC,GAAQ,IAAA5oC,OCtBf,SAASypB,GAAIpO,EAAGd,GACd,OAAOc,EAAE1P,QAAQhT,QAAU4hB,EAAEgP,QAAQ5wB,IACvC,CAEA,SAAS8wC,GAAapuB,EAAGd,GACvB,OAAOc,EAAE1P,QAAQhT,QAAU4hB,EAAEgP,QAAQ5wB,IACvC,CAcM,MAAA+wC,GAA4C,EAChDt4B,aAAa,KACbM,eAAe,OACfP,UAAU,GACVw4B,kBAAkB,GAClBC,mBAEA,MAAOv3B,EAASw3B,GAAc9/B,EAAM9L,SAAS,KACtCkK,EAAM2hC,GAAW//B,EAAM9L,SAASkT,IAChC+gB,EAAO6X,GAAYhgC,EAAM9L,SAAS0rC,IAElCK,EAAiBC,GAAsBlgC,EAAM9L,SAAiB,KAC9DisC,EAAkBC,GAAuBpgC,EAAM9L,SAAiB,IAEjEmsC,EAAcX,GAAap3B,EAASlK,GACpCkiC,EAAeZ,GAAap3B,EAAS6f,GAErCoY,EAAgB3xC,GAAU,KAC9B,MAAM4xC,EAAel4B,EAAQkX,QAAQ5wB,GAC/B6xC,EAAa,IAAIn4B,IAEF,IAAjBk4B,EACFC,EAAW52B,KAAKjb,GAEhB6xC,EAAW1F,OAAOyF,EAAc,GAGlCV,EAAWW,IAGPC,EAAmBz+B,GAAUy9B,GAAap3B,EAASrG,GAAOrG,OAE1D+kC,EAAmB1+B,GAAU,KA5CrC,IAAeqP,EAAGd,EA6CVkwB,EAAgBz+B,KAAWA,EAAMrG,OACnCkkC,EAAWpgB,GAAIpX,EAASrG,IAExB69B,GAhDSxuB,EAgDQhJ,EAhDLkI,EAgDcvO,EA/CvB,IAAIqP,KAAMoO,GAAIlP,EAAGc,OAuElBsvB,EAAa,CACjB58B,EACA68B,EACAC,KAEA,MAAM7+B,EAAQ4+B,EAAgBj/B,QAAQuF,IACpC,GAAIA,EAAOQ,GAAe,CACxB,MAAM/Y,EAAgBuY,EAAOQ,GAC7B,GACW,SAATm5B,GACAlyC,EACGmyC,oBACA9f,SAASgf,EAAgBc,qBAE5B,OAAO,EACF,GACI,UAATD,GACAlyC,EACGmyC,oBACA9f,SAASkf,EAAiBY,qBAE7B,OAAO,EAGX,OAAO,KAET,OACE7nC,EAAC8nC,GAAI,CAACxnC,GAAI,CAAEsD,OAAQ,QAAQ7D,SAAA,CAC1BF,EAACkoC,GAAU,CACTznC,GAAI,CAAEmsB,GAAI,EAAGC,GAAI,GACjBsb,OACEnoC,EAACsP,GAAQ,CACP/O,QAASqnC,EAAgB1+B,GACzBqG,QACEo4B,EAAgBz+B,KAAWA,EAAMrG,QAA2B,IAAjBqG,EAAMrG,OAEnDulC,cACET,EAAgBz+B,KAAWA,EAAMrG,QACN,IAA3B8kC,EAAgBz+B,GAElB9B,SAA2B,IAAjB8B,EAAMrG,OAChBwlC,WAAY,CACV,aAAc,wBAIpBp9B,MAAOA,EACPq9B,UAAW,GAAGX,EAAgBG,QAC5BA,EAAgBjlC,oBAGpB7C,EAAC8D,EAAG,CAACrD,GAAI,CAAEf,MAAO,OAAQuF,QAAS,GACjC/E,SAAAF,EAAC+0B,GAAiB,CAChBY,WAAS,EACTjyB,MAAM,SACN7N,MAAgB,SAATkyC,EAAkBb,EAAkBE,EAC3Cj6B,SAAW/D,IACI,SAAT2+B,EACFZ,EAAmB/9B,EAAMqG,OAAO5Z,OAEhCwxC,EAAoBj+B,EAAMqG,OAAO5Z,YAKzCmK,EAACoK,GAAU,CAAA,GACXpK,EAACuoC,GACC,CAAA9nC,GAAI,CACFf,MAAO,OACPqE,OAAQ,OACRE,QAAS,YACTgqB,SAAU,QAEZua,OACA,EAAApnC,UAAU,MACVqnC,KAAK,OAAMvoC,SAEVgJ,EAAMJ,KAAKjT,IACV,MAAM6yC,EAAU,0BAA0B7yC,EAAMyY,WAEhD,OACEnO,EAACwoC,GAAQ,CAEPF,KAAK,WACLrnC,UAAU,SACVb,QAASinC,EAAa3xC,GAAMqK,SAAA,CAE5BF,EAAC4oC,GAAY,CAAA1oC,SACXF,EAACsP,GAAQ,CACPC,SAAoC,IAA3BA,EAAQkX,QAAQ5wB,GACzBgzC,UAAU,EACVC,eACA,EAAAT,WAAY,CACV,kBAAmBK,OAIzB1oC,EAAC+oC,GAAY,CACX1lC,GAAIxN,EAAMyY,GACV9T,QAAS3E,EAAM+Y,OAjBZ/Y,EAAMyY,aA0BzB,OACEnO,EAACq1B,EACC,CAAAiB,WACA,EAAA/xB,QAAS,EACTjE,GAAI,CACF6I,SAAU,EACV2kB,SAAU,OACVrD,OAAQ,EACRhqB,QAAS,OACTlB,MAAO,QAET0C,eAAe,SACfH,WAAW,SAEX/B,SAAA,CAAAF,EAACw1B,EAAK,CAAC/0B,GAAI,CAAEsD,OAAQ,OAAQ1C,KAAM,YAChCwmC,EAAW,kBAAmBxiC,EAAM,UAEvCrF,EAACw1B,EACC,CAAAt1B,SAAAC,EAACq1B,EAAK,CAACiB,WAAS,EAACjtB,UAAU,SAASvH,WAAW,SAC7C/B,SAAA,CAAAF,EAACsL,GACC,CAAA7K,GAAI,CAAEgtB,GAAI,IACVvsB,QAAQ,WACRsL,KAAK,QACLjM,QAvJiB,KACzB0mC,GAAU+B,IACR,IAAIlF,EAAW1U,EAAMpE,OAAOsc,GAE5B,OADAR,EAAahD,GACNA,KAETkD,EAAQrgB,GAAIthB,EAAMiiC,IAClBP,EAAWpgB,GAAIpX,EAAS+3B,KAiJhBlgC,SAAiC,IAAvBkgC,EAAYzkC,OACX,aAAA,sBAGJ3C,SAAA,MACTF,EAACsL,GACC,CAAA7K,GAAI,CAAEgtB,GAAI,IACVvsB,QAAQ,WACRsL,KAAK,QACLjM,QAvJgB,KACxBymC,EAAQ3hC,EAAK2lB,OAAOuc,IACpBN,GAAU+B,IACR,IAAIlF,EAAWnd,GAAIyI,EAAOmY,GAE1B,OADAT,EAAahD,GACNA,KAETiD,EAAWpgB,GAAIpX,EAASg4B,KAiJhBngC,SAAkC,IAAxBmgC,EAAa1kC,OACZ,aAAA,yCAMjB7C,EAACw1B,EAAM,CAAA/0B,GAAI,CAAEsD,OAAQ,OAAQ1C,KAAM,GAAGnB,SACnC2nC,EAAW,qBAAsBzY,EAAO,eChP3C6Z,GAA2C/rC,IAE/C,MAAMgsC,EAAYhsC,EAAMpG,KAAKgS,KAAI,CAACsD,EAAaob,KACtC,CACLnkB,GAAImkB,EACJ3xB,MAAOuW,EAAOlP,EAAMoR,YACpB5K,MAAO0I,EAAOlP,EAAMisC,YAAc,OAItC,OADAtnC,QAAQC,IAAI,YAAaonC,GAEvBlpC,EAACopC,GAAQ,CACPC,OAAQ,CACN,CACEvyC,KAAMoyC,OCdVI,GAA2CpsC,GAE7C8C,EAACupC,IACCC,QAAStsC,EAAMpG,KACf2yC,MAAO,CAAC,CAAEC,QAASxsC,EAAMoR,WAAYq7B,UAAW,SAChDN,OAAQnsC,EAAMisC,YAAYnsB,MAAM,KAAKlU,KAAKqgC,IACjC,CAAEO,QAASP,EAAYzlC,MAAOylC,QCNvCS,GAA4C1sC,GAE9C8C,EAAC6pC,IACCL,QAAStsC,EAAMpG,KACf2yC,MAAO,CAAC,CAAEC,QAASxsC,EAAMoR,WAAYq7B,UAAW,SAChDN,OAAQnsC,EAAMisC,YAAYnsB,MAAM,KAAKlU,KAAKqgC,IACjC,CAAEO,QAASP,EAAYzlC,MAAOylC,QCLvCW,GAAoD5sC,GAEtDiD,EACE+L,EAAA,CAAAhM,SAAA,CAAAC,EAACc,EAAU,CAACR,GAAI,CAAEkG,SAAU,GAAIP,WAAY,QAAQlG,SAAA,CACjDhD,EAAM6sC,YAAW,MAAK7sC,EAAMkP,OAAOlP,EAAMisC,eAE5CnpC,EAACgqC,GAAK,CAACtqC,MAAO,IAAKqE,OAAQ,IAAKlO,MAAOqH,EAAMkP,OAAOlP,EAAMoR,iBCP1D27B,GAAuD/sC,GAEzDiD,EAACo5B,EAAK,CACJ94B,GAAI,CACFG,QAAS,OACTkE,cAAe,SACff,OAAQ,IACRkB,QAAS,EACTqE,SAAU,EACVlH,eAAgB,SAChBH,WAAY,UACb/B,SAAA,CAEDF,EAAC8D,EACC,CAAArD,GAAI,CACFG,QAAS,OACTlB,MAAO,OACP0C,eAAgB,eAChBH,WAAY,UAGd/B,SAAAF,EAACiB,EAAU,CAACR,GAAI,CAAEkG,SAAU,GAAIP,WAAY,QAAQlG,SACjDhD,EAAM6sC,gBAGX/pC,EAAC8D,EACC,CAAArD,GAAI,CACFY,KAAM,EACNT,QAAS,OACTlB,MAAO,OACP0C,eAAgB,eAChBH,WAAY,UAId/B,SAAAF,EAAA,MAAA,CAAAE,SAAM,GAAGhD,EAAMkP,OAAOlP,EAAMisC,iBAC1BjsC,EAAMkP,OAAOlP,EAAMoR,kBAIvBtO,EAAC8D,EACC,CAAArD,GAAI,CACFG,QAAS,OACTlB,MAAO,OACP0C,eAAgB,eAChBH,WAAY,eCxCtB,SAASioC,GACPhtC,GAEA,OACEiD,EAAC2D,GAAI,CAAArD,GAAI,CAAEG,QAAS,OAAQqB,WAAY,UAAU/B,SAAA,CAChDF,EAAC8D,GAAG,CAACrD,GAAI,CAAEf,MAAO,OAAQgB,GAAI,GAC5BR,SAAAF,EAACmqC,GAAe,CAAAjpC,QAAQ,iBAAkBhE,MAE5C8C,EAAC8D,GAAI,CAAArD,GAAI,CAAE4rB,SAAU,IAAInsB,SACvBF,EAACiB,GAAU,CACTC,QAAQ,QACRT,GAAI,CAAEH,MAAO,2BACb,GAAG8pB,KAAKggB,MAAMltC,EAAMrH,gBAI9B,CAEA,MAAMw0C,GACJntC,GAGEiD,EAAC2D,GAAI,CAAArD,GAAI,CAAEf,MAAO,QAChBQ,SAAA,CAAAC,EAACc,GAAW,CAAAR,GAAI,CAAEkG,SAAU,GAAIP,WAAY,QACzClG,SAAA,CAAAhD,EAAM6sC,YAAW,MAAK7sC,EAAMkP,OAAOlP,EAAMisC,eAE5CnpC,EAACkqC,GAAwB,CAAAr0C,MAAOqH,EAAMkP,OAAOlP,EAAMoR,iBCAnDg8B,GAAkD,EACtDpqC,WACAqqC,gBAGEvqC,EAACwqC,GAAI,CACHh+B,KAAM,CAAE4Y,GAAI,GAAIC,GAAI,EAAGC,GAAI,GAC3B7kB,GAAI,CACFwB,WAAY,SACZG,eAAgB,SAChB6C,QAAS,EACTrE,QAAS,OACTkE,cAA6B,QAAdylC,EAAuB,cAAWltC,EACjD0G,OAAQ,KAGT7D,SAAAA,IAKDuqC,GAA+CvtC,GAEjDiD,EAAA+L,EAAA,CAAAhM,SAAA,CACEF,EAACiB,EAAW,CAAAR,GAAI,CAAEkG,SAAU,GAAIP,WAAY,QACzClG,SAAAhD,EAAMwtC,iBAET1qC,EAACwqC,GACC,CAAA/T,WACA,EAAAh2B,GAAI,CACF6I,SAAU,EACV5J,MAAO,OACPgK,UAAW,OACXzE,QAAS,GAGV/E,SAAAhD,EAAMytC,iBAAiB7hC,KAAI,CAAC8hC,EAAkBpjB,IAEhB,SAA3BojB,EAAYL,YACe,UAA3BK,EAAYL,YACe,aAA3BK,EAAYL,WAGVvqC,EAAAkM,EAAA,CAAAhM,SACG0qC,EAAY9zC,KAAKgS,KAAI,CAACsD,EAAaob,KAClC,MAAMqjB,EAAmD,CACvDd,YAAaa,EAAYb,YACzB39B,SACA+8B,WAAYyB,EAAYzB,WACxB76B,WAAYs8B,EAAYt8B,YAE1B,OACEnO,EAACmqC,GAAe,CAEdC,WAAYK,EAAYL,qBAEI,SAA3BK,EAAYL,WACXvqC,EAACiqC,GAAqB,IAAAY,IACpB,KACwB,UAA3BD,EAAYL,WACXvqC,EAAC8pC,GAAa,IAAKe,IACjB,KACwB,aAA3BD,EAAYL,WACXvqC,EAACqqC,GAAoB,IAAKQ,IACxB,OAXCrjB,QAmBbrnB,EAACmqC,GAAe,CAAaC,WAAYK,EAAYL,qBACvB,QAA3BK,EAAYL,WACXvqC,EAACipC,GAAqB,IAAA2B,IACpB,KACwB,SAA3BA,EAAYL,WACXvqC,EAAC4pC,GAAiB,IAAKgB,IACrB,KACwB,QAA3BA,EAAYL,WACXvqC,EAACspC,GAAgB,IAAKsB,IACpB,OATgBpjB","x_google_ignoreList":[7,19,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,78,79,80,81,82,83]}
|