@pega/react-sdk-overrides 24.1.10 → 24.2.11
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/lib/designSystemExtension/AlertBanner/AlertBanner.tsx +1 -1
- package/lib/designSystemExtension/Banner/Banner.tsx +1 -1
- package/lib/designSystemExtension/CaseSummaryFields/CaseSummaryFields.css +0 -1
- package/lib/designSystemExtension/CaseSummaryFields/CaseSummaryFields.tsx +11 -2
- package/lib/designSystemExtension/DetailsFields/DetailsFields.tsx +4 -4
- package/lib/designSystemExtension/FieldGroup/FieldGroup.tsx +4 -4
- package/lib/designSystemExtension/FieldGroupList/FieldGroupList.tsx +4 -4
- package/lib/designSystemExtension/FieldValueList/FieldValueList.tsx +6 -6
- package/lib/designSystemExtension/Operator/Operator.tsx +6 -5
- package/lib/designSystemExtension/Pulse/Pulse.tsx +2 -2
- package/lib/designSystemExtension/RichTextEditor/RichTextEditor.tsx +3 -2
- package/lib/designSystemExtension/WssQuickCreate/WssQuickCreate.tsx +1 -1
- package/lib/field/AutoComplete/AutoComplete.tsx +4 -4
- package/lib/field/CancelAlert/CancelAlert.tsx +4 -7
- package/lib/field/Checkbox/Checkbox.tsx +4 -4
- package/lib/field/Currency/Currency.tsx +10 -7
- package/lib/field/Date/Date.tsx +27 -42
- package/lib/field/DateTime/DateTime.tsx +39 -36
- package/lib/field/Decimal/Decimal.tsx +9 -4
- package/lib/field/Dropdown/Dropdown.tsx +29 -22
- package/lib/field/Email/Email.tsx +29 -8
- package/lib/field/Group/Group.tsx +2 -2
- package/lib/field/Integer/Integer.tsx +22 -8
- package/lib/field/Multiselect/Multiselect.tsx +8 -14
- package/lib/field/Percentage/Percentage.tsx +8 -4
- package/lib/field/Phone/Phone.tsx +6 -5
- package/lib/field/Phone/config-ext.json +8 -0
- package/lib/field/RadioButtons/RadioButtons.tsx +3 -6
- package/lib/field/RichText/RichText.tsx +1 -1
- package/lib/field/RichText/config-ext.json +10 -0
- package/lib/field/ScalarList/ScalarList.tsx +3 -4
- package/lib/field/SemanticLink/SemanticLink.tsx +4 -4
- package/lib/field/TextArea/TextArea.tsx +26 -8
- package/lib/field/TextContent/TextContent.tsx +1 -1
- package/lib/field/TextInput/TextInput.tsx +2 -2
- package/lib/field/Time/Time.tsx +28 -21
- package/lib/field/URL/URL.tsx +26 -7
- package/lib/field/UserReference/UserReference.tsx +3 -5
- package/lib/helpers/common-utils.ts +24 -1
- package/lib/helpers/field-group-utils.ts +2 -2
- package/lib/helpers/formatters/Currency.ts +11 -16
- package/lib/helpers/formatters/common.ts +2 -1
- package/lib/helpers/formatters/index.ts +2 -4
- package/lib/helpers/simpleTableHelpers.ts +1 -1
- package/lib/infra/ActionButtons/ActionButtons.tsx +3 -3
- package/lib/infra/Assignment/Assignment.tsx +12 -12
- package/lib/infra/Containers/FlowContainer/FlowContainer.tsx +16 -28
- package/lib/infra/Containers/FlowContainer/helpers.ts +1 -5
- package/lib/infra/Containers/ModalViewContainer/ListViewActionButtons/ListViewActionButtons.tsx +9 -4
- package/lib/infra/Containers/ModalViewContainer/ModalViewContainer.tsx +8 -8
- package/lib/infra/Containers/SimpleView/helper.ts +1 -1
- package/lib/infra/Containers/ViewContainer/ViewContainer.tsx +1 -1
- package/lib/infra/DashboardFilter/DashboardFilter.tsx +3 -4
- package/lib/infra/DashboardFilter/filterUtils.tsx +3 -4
- package/lib/infra/DeferLoad/DeferLoad.tsx +8 -8
- package/lib/infra/MultiStep/MultiStep.tsx +15 -14
- package/lib/infra/NavBar/NavBar.css +1 -0
- package/lib/infra/NavBar/NavBar.tsx +25 -17
- package/lib/infra/RootContainer/RootContainer.tsx +5 -6
- package/lib/infra/Stages/Stages.tsx +4 -4
- package/lib/infra/VerticalTabs/LeftAlignVerticalTabs/LeftAlignVerticalTabs.tsx +4 -3
- package/lib/infra/VerticalTabs/VerticalTabs/VerticalTabs.tsx +2 -2
- package/lib/infra/View/View.tsx +37 -3
- package/lib/template/AppShell/AppShell.tsx +60 -10
- package/lib/template/BannerPage/config-ext.json +9 -0
- package/lib/template/CaseView/CaseView.tsx +10 -9
- package/lib/template/CaseViewActionsMenu/CaseViewActionsMenu.tsx +7 -7
- package/lib/template/Confirmation/Confirmation.tsx +3 -2
- package/lib/template/DataReference/DataReference.tsx +2 -2
- package/lib/template/Details/Details/Details.tsx +2 -2
- package/lib/template/Details/DetailsSubTabs/DetailsSubTabs.tsx +3 -3
- package/lib/template/Details/DetailsThreeColumn/DetailsThreeColumn.tsx +2 -2
- package/lib/template/Details/DetailsTwoColumn/DetailsTwoColumn.tsx +2 -2
- package/lib/template/Details/DynamicTabs/DynamicTabs.tsx +4 -4
- package/lib/template/FieldGroupTemplate/FieldGroupTemplate.tsx +10 -5
- package/lib/template/InlineDashboard/InlineDashboard.tsx +2 -2
- package/lib/template/InlineDashboardPage/config-ext.json +9 -0
- package/lib/template/ListView/ListView.tsx +79 -70
- package/lib/template/ListView/utils.ts +1 -2
- package/lib/template/NarrowWide/NarrowWideDetails/NarrowWideDetails.tsx +2 -2
- package/lib/template/OneColumn/OneColumn/OneColumn.tsx +2 -2
- package/lib/template/PromotedFilters/PromotedFilters.tsx +1 -2
- package/lib/template/SimpleTable/SimpleTable/SimpleTable.tsx +0 -2
- package/lib/template/SimpleTable/SimpleTableManual/SimpleTableManual.tsx +110 -86
- package/lib/template/SimpleTable/SimpleTableSelect/SimpleTableSelect.tsx +2 -4
- package/lib/template/SubTabs/SubTabs.tsx +2 -2
- package/lib/template/TwoColumn/TwoColumn/TwoColumn.tsx +2 -2
- package/lib/template/TwoColumn/TwoColumnTab/TwoColumnTab.tsx +2 -2
- package/lib/template/WideNarrow/WideNarrowDetails/WideNarrowDetails.tsx +2 -2
- package/lib/template/WssNavBar/WssNavBar.tsx +9 -9
- package/lib/widget/AppAnnouncement/AppAnnouncement.tsx +2 -2
- package/lib/widget/Attachment/Attachment.css +1 -0
- package/lib/widget/Attachment/Attachment.tsx +7 -9
- package/lib/widget/CaseHistory/CaseHistory.tsx +12 -10
- package/lib/widget/FileUtility/ActionButtonsForFileUtil/ActionButtonsForFileUtil.tsx +1 -1
- package/lib/widget/FileUtility/FileUtility/FileUtility.tsx +5 -4
- package/lib/widget/Followers/Followers.tsx +2 -2
- package/lib/widget/QuickCreate/QuickCreate.tsx +0 -1
- package/lib/widget/QuickCreate/config-ext.json +9 -0
- package/lib/widget/SummaryItem/SummaryItem.tsx +4 -3
- package/lib/widget/ToDo/ToDo.tsx +92 -22
- package/package.json +1 -1
- /package/lib/infra/Containers/{helpers.ts → container-helpers.ts} +0 -0
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
/* eslint-disable prefer-template */
|
|
2
2
|
/** This file contains various utility methods to generate filter components, regionLayout data, filter expressions, etc. */
|
|
3
3
|
|
|
4
|
-
import { Grid, Link } from '@material
|
|
4
|
+
import { Grid, Link } from '@mui/material';
|
|
5
5
|
|
|
6
6
|
import DashboardFilter from './DashboardFilter';
|
|
7
7
|
|
|
@@ -46,7 +46,6 @@ export const createFilterComponent = (getPConnect, filterMeta, index) => {
|
|
|
46
46
|
}
|
|
47
47
|
let propInfo: any = PCore.getMetadataUtils().getPropertyMetadata(cleanedName, filterMeta.config.ruleClass);
|
|
48
48
|
if (!propInfo) {
|
|
49
|
-
// @ts-ignore - PCore.getMetadataUtils().getPropertyMetadata - An argument for 'currentClassID' was not provided.
|
|
50
49
|
propInfo = PCore.getMetadataUtils().getPropertyMetadata(cleanedName);
|
|
51
50
|
}
|
|
52
51
|
const { type: propertyType } = propInfo || { type: 'Text' };
|
|
@@ -78,13 +77,13 @@ export const buildFilterComponents = (getPConnect, allFilters) => {
|
|
|
78
77
|
const filterComponents = allFilters.children.map((filter, index) => createFilterComponent(getPConnect, filter, index));
|
|
79
78
|
if (filterComponents && filterComponents.length > 0) {
|
|
80
79
|
filterComponents.push(
|
|
81
|
-
<Grid>
|
|
80
|
+
<Grid style={{ display: 'flex', alignItems: 'center' }}>
|
|
82
81
|
<Link
|
|
83
82
|
style={{ cursor: 'pointer' }}
|
|
84
83
|
onClick={() => {
|
|
85
|
-
// @ts-ignore - second parameter “payload” for publish method should be optional
|
|
86
84
|
PCore.getPubSubUtils().publish(PCore.getConstants().PUB_SUB_EVENTS.EVENT_DASHBOARD_FILTER_CLEAR_ALL);
|
|
87
85
|
}}
|
|
86
|
+
underline='hover'
|
|
88
87
|
>
|
|
89
88
|
Clear All
|
|
90
89
|
</Link>
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { useState, useEffect, createElement } from 'react';
|
|
2
|
-
import { Box, Card, CircularProgress } from '@material
|
|
3
|
-
import
|
|
2
|
+
import { Box, Card, CircularProgress } from '@mui/material';
|
|
3
|
+
import makeStyles from '@mui/styles/makeStyles';
|
|
4
4
|
|
|
5
5
|
import createPConnectComponent from '@pega/react-sdk-components/lib/bridge/react_pconnect';
|
|
6
6
|
|
|
@@ -12,6 +12,7 @@ interface DeferLoadProps extends PConnProps {
|
|
|
12
12
|
isChildDeferLoad?: boolean;
|
|
13
13
|
isTab: boolean;
|
|
14
14
|
deferLoadId: string;
|
|
15
|
+
lastUpdateCaseTime: any;
|
|
15
16
|
}
|
|
16
17
|
|
|
17
18
|
//
|
|
@@ -34,7 +35,7 @@ const useStyles = makeStyles(theme => ({
|
|
|
34
35
|
}));
|
|
35
36
|
|
|
36
37
|
export default function DeferLoad(props: DeferLoadProps) {
|
|
37
|
-
const { getPConnect, name, deferLoadId, isTab } = props;
|
|
38
|
+
const { getPConnect, name, deferLoadId, isTab, lastUpdateCaseTime } = props;
|
|
38
39
|
const [content, setContent] = useState<any>(null);
|
|
39
40
|
const [isLoading, setLoading] = useState(true);
|
|
40
41
|
const [currentLoadedAssignment, setCurrentLoadedAssignment] = useState('');
|
|
@@ -69,8 +70,8 @@ export default function DeferLoad(props: DeferLoadProps) {
|
|
|
69
70
|
const getViewOptions = () => ({
|
|
70
71
|
viewContext: resourceType,
|
|
71
72
|
pageClass: loadViewCaseID ? '' : (pConnect.getDataObject('') as any).pyPortal.classID, // 2nd arg empty string until typedef allows optional
|
|
72
|
-
container: isContainerPreview ? 'preview' :
|
|
73
|
-
containerName: isContainerPreview ? 'preview' :
|
|
73
|
+
container: isContainerPreview ? 'preview' : undefined,
|
|
74
|
+
containerName: isContainerPreview ? 'preview' : undefined,
|
|
74
75
|
updateData: isContainerPreview
|
|
75
76
|
});
|
|
76
77
|
|
|
@@ -95,7 +96,7 @@ export default function DeferLoad(props: DeferLoadProps) {
|
|
|
95
96
|
}
|
|
96
97
|
};
|
|
97
98
|
const configObject = PCore.createPConnect(config);
|
|
98
|
-
configObject.getPConnect().setInheritedProp('displayMode', '
|
|
99
|
+
configObject.getPConnect().setInheritedProp('displayMode', 'DISPLAY_ONLY');
|
|
99
100
|
setContent(createElement(createPConnectComponent(), configObject));
|
|
100
101
|
if (deferLoadId) {
|
|
101
102
|
PCore.getDeferLoadManager().stop(deferLoadId, getPConnect().getContextName());
|
|
@@ -113,7 +114,6 @@ export default function DeferLoad(props: DeferLoadProps) {
|
|
|
113
114
|
getPConnect()
|
|
114
115
|
.getActionsApi()
|
|
115
116
|
.showData(name, dataContext, dataContextParameters, {
|
|
116
|
-
// @ts-ignore - Type 'boolean' is not assignable to type 'string'
|
|
117
117
|
skipSemanticUrl: true,
|
|
118
118
|
// @ts-ignore
|
|
119
119
|
isDeferLoaded: true
|
|
@@ -145,7 +145,7 @@ export default function DeferLoad(props: DeferLoadProps) {
|
|
|
145
145
|
console.log(`deferload: ${error}`);
|
|
146
146
|
});
|
|
147
147
|
}
|
|
148
|
-
}, [name, getPConnect, currentLoadedAssignment]);
|
|
148
|
+
}, [name, getPConnect, currentLoadedAssignment, lastUpdateCaseTime]);
|
|
149
149
|
/* TODO Cosmos need to handle for now added a wrapper div with pos relative */
|
|
150
150
|
let deferLoadContent;
|
|
151
151
|
if (isLoading) {
|
|
@@ -11,7 +11,7 @@ interface MultiStepProps extends PConnProps {
|
|
|
11
11
|
actionButtons: any[];
|
|
12
12
|
onButtonPress: any;
|
|
13
13
|
bIsVertical: boolean;
|
|
14
|
-
arNavigationSteps: any
|
|
14
|
+
arNavigationSteps: any;
|
|
15
15
|
}
|
|
16
16
|
|
|
17
17
|
export default function MultiStep(props: PropsWithChildren<MultiStepProps>) {
|
|
@@ -21,6 +21,12 @@ export default function MultiStep(props: PropsWithChildren<MultiStepProps>) {
|
|
|
21
21
|
const { getPConnect, children, itemKey = '', actionButtons, onButtonPress } = props;
|
|
22
22
|
const { bIsVertical, arNavigationSteps } = props;
|
|
23
23
|
|
|
24
|
+
let currentStep = arNavigationSteps.find(({ visited_status: vs }) => vs === 'current');
|
|
25
|
+
if (!currentStep) {
|
|
26
|
+
const lastActiveStepIndex = arNavigationSteps.findLastIndex(({ visited_status: vs }) => vs === 'success');
|
|
27
|
+
currentStep = arNavigationSteps[lastActiveStepIndex >= 0 ? lastActiveStepIndex : 0];
|
|
28
|
+
}
|
|
29
|
+
|
|
24
30
|
// const svgCurrent = Utils.getImageSrc("circle-solid", Utils.getSDKStaticConentUrl());
|
|
25
31
|
// const svgNotCurrent = Utils.getImageSrc("circle-solid", Utils.getSDKStaticConentUrl());
|
|
26
32
|
|
|
@@ -48,16 +54,16 @@ export default function MultiStep(props: PropsWithChildren<MultiStepProps>) {
|
|
|
48
54
|
return 'psdk-vertical-step-body';
|
|
49
55
|
}
|
|
50
56
|
|
|
51
|
-
function _getHIconClass(
|
|
52
|
-
if (
|
|
57
|
+
function _getHIconClass(step): string {
|
|
58
|
+
if (step.ID === currentStep?.ID) {
|
|
53
59
|
return 'psdk-horizontal-step-icon-selected';
|
|
54
60
|
}
|
|
55
61
|
|
|
56
62
|
return 'psdk-horizontal-step-icon';
|
|
57
63
|
}
|
|
58
64
|
|
|
59
|
-
function _getHLabelClass(
|
|
60
|
-
if (
|
|
65
|
+
function _getHLabelClass(step): string {
|
|
66
|
+
if (step.ID === currentStep?.ID) {
|
|
61
67
|
return 'psdk-horizontal-step-label-selected';
|
|
62
68
|
}
|
|
63
69
|
|
|
@@ -65,12 +71,7 @@ export default function MultiStep(props: PropsWithChildren<MultiStepProps>) {
|
|
|
65
71
|
}
|
|
66
72
|
|
|
67
73
|
function _showHLine(index: number): boolean {
|
|
68
|
-
|
|
69
|
-
if (index < arNavigationSteps.length - 1) {
|
|
70
|
-
return true;
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
return false;
|
|
74
|
+
return index < arNavigationSteps.length - 1;
|
|
74
75
|
}
|
|
75
76
|
|
|
76
77
|
function buttonPress(sAction: string, sButtonType: string) {
|
|
@@ -138,12 +139,12 @@ export default function MultiStep(props: PropsWithChildren<MultiStepProps>) {
|
|
|
138
139
|
return (
|
|
139
140
|
<React.Fragment key={mainStep.actionID}>
|
|
140
141
|
<div className='psdk-horizontal-step-header'>
|
|
141
|
-
<div className={_getHIconClass(mainStep
|
|
142
|
+
<div className={_getHIconClass(mainStep)}>
|
|
142
143
|
<div className='psdk-horizontal-step-icon-content'>
|
|
143
144
|
<span>{index + 1}</span>
|
|
144
145
|
</div>
|
|
145
146
|
</div>
|
|
146
|
-
<div className={_getHLabelClass(mainStep
|
|
147
|
+
<div className={_getHLabelClass(mainStep)}>
|
|
147
148
|
<div className='psdk-horizontal-step-text-label' id='selected-label'>
|
|
148
149
|
{mainStep.name}
|
|
149
150
|
</div>
|
|
@@ -176,7 +177,7 @@ export default function MultiStep(props: PropsWithChildren<MultiStepProps>) {
|
|
|
176
177
|
))}
|
|
177
178
|
</ul>
|
|
178
179
|
)}
|
|
179
|
-
{!mainStep?.steps && mainStep.
|
|
180
|
+
{!mainStep?.steps && mainStep.ID === currentStep?.ID && (
|
|
180
181
|
<AssignmentCard getPConnect={getPConnect} itemKey={itemKey} actionButtons={actionButtons} onButtonPress={buttonPress}>
|
|
181
182
|
{children}
|
|
182
183
|
</AssignmentCard>
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { useEffect, useState } from 'react';
|
|
2
|
-
import {
|
|
2
|
+
import { useTheme } from '@mui/material/styles';
|
|
3
|
+
import makeStyles from '@mui/styles/makeStyles';
|
|
3
4
|
import clsx from 'clsx';
|
|
4
5
|
|
|
5
6
|
import {
|
|
@@ -15,19 +16,22 @@ import {
|
|
|
15
16
|
Menu,
|
|
16
17
|
MenuItem,
|
|
17
18
|
Typography
|
|
18
|
-
} from '@material
|
|
19
|
-
import PersonOutlineIcon from '@
|
|
20
|
-
import ChevronLeftIcon from '@
|
|
21
|
-
import ChevronRightIcon from '@
|
|
22
|
-
import FlagOutlinedIcon from '@
|
|
23
|
-
import HomeOutlinedIcon from '@
|
|
24
|
-
import
|
|
25
|
-
import
|
|
26
|
-
import
|
|
27
|
-
import
|
|
28
|
-
import
|
|
29
|
-
import
|
|
30
|
-
import
|
|
19
|
+
} from '@mui/material';
|
|
20
|
+
import PersonOutlineIcon from '@mui/icons-material/PersonOutlineOutlined';
|
|
21
|
+
import ChevronLeftIcon from '@mui/icons-material/ChevronLeft';
|
|
22
|
+
import ChevronRightIcon from '@mui/icons-material/ChevronRight';
|
|
23
|
+
import FlagOutlinedIcon from '@mui/icons-material/FlagOutlined';
|
|
24
|
+
import HomeOutlinedIcon from '@mui/icons-material/HomeOutlined';
|
|
25
|
+
import TabletAndroidOutlineIcon from '@mui/icons-material/TabletAndroidOutlined';
|
|
26
|
+
import AirportShuttleOutlinedIcon from '@mui/icons-material/AirportShuttleOutlined';
|
|
27
|
+
import EditOutlinedIcon from '@mui/icons-material/EditOutlined';
|
|
28
|
+
import ExpandLess from '@mui/icons-material/ExpandLess';
|
|
29
|
+
import ExpandMore from '@mui/icons-material/ExpandMore';
|
|
30
|
+
import AddIcon from '@mui/icons-material/Add';
|
|
31
|
+
import WorkOutlineIcon from '@mui/icons-material/WorkOutline';
|
|
32
|
+
import ClearOutlinedIcon from '@mui/icons-material/ClearOutlined';
|
|
33
|
+
import ArrowBackIcon from '@mui/icons-material/ArrowBack';
|
|
34
|
+
import useMediaQuery from '@mui/material/useMediaQuery';
|
|
31
35
|
import { logout } from '@pega/auth/lib/sdk-auth-manager';
|
|
32
36
|
|
|
33
37
|
import { useNavBar } from '@pega/react-sdk-components/lib/components/helpers/reactContextHelpers';
|
|
@@ -48,7 +52,11 @@ interface NavBarProps extends PConnProps {
|
|
|
48
52
|
const iconMap = {
|
|
49
53
|
'pi pi-headline': <HomeOutlinedIcon fontSize='large' />,
|
|
50
54
|
'pi pi-flag-solid': <FlagOutlinedIcon fontSize='large' />,
|
|
51
|
-
'pi pi-home-solid': <HomeOutlinedIcon fontSize='large'
|
|
55
|
+
'pi pi-home-solid': <HomeOutlinedIcon fontSize='large' />,
|
|
56
|
+
'pi pi-tablet': <TabletAndroidOutlineIcon fontSize='large' />,
|
|
57
|
+
'pi pi-ambulance': <AirportShuttleOutlinedIcon fontSize='large' />,
|
|
58
|
+
'pi pi-ink-solid': <EditOutlinedIcon fontSize='large' />,
|
|
59
|
+
'pi pi-columns': <HomeOutlinedIcon fontSize='large' />
|
|
52
60
|
};
|
|
53
61
|
|
|
54
62
|
const drawerWidth = 300;
|
|
@@ -203,7 +211,7 @@ export default function NavBar(props: NavBarProps) {
|
|
|
203
211
|
}
|
|
204
212
|
/>
|
|
205
213
|
<ListItemSecondaryAction>
|
|
206
|
-
<IconButton edge='end' onClick={handleDrawerOpen}>
|
|
214
|
+
<IconButton edge='end' onClick={handleDrawerOpen} size='large'>
|
|
207
215
|
<ChevronLeftIcon className={classes.appListIcon} />
|
|
208
216
|
</IconButton>
|
|
209
217
|
</ListItemSecondaryAction>
|
|
@@ -256,7 +264,7 @@ export default function NavBar(props: NavBarProps) {
|
|
|
256
264
|
<ListItemText primary={portalOperator} />
|
|
257
265
|
{open && (
|
|
258
266
|
<ListItemSecondaryAction>
|
|
259
|
-
<IconButton edge='end' onClick={navPanelOperatorButtonClick}>
|
|
267
|
+
<IconButton edge='end' onClick={navPanelOperatorButtonClick} size='large'>
|
|
260
268
|
<ChevronRightIcon />
|
|
261
269
|
</IconButton>
|
|
262
270
|
</ListItemSecondaryAction>
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { Children, createElement, PropsWithChildren, useContext, useEffect, useMemo, useRef, useState } from 'react';
|
|
2
|
-
import
|
|
3
|
-
import { Box, CircularProgress } from '@material-ui/core';
|
|
2
|
+
import { Box, CircularProgress } from '@mui/material';
|
|
4
3
|
|
|
5
4
|
import createPConnectComponent from '@pega/react-sdk-components/lib/bridge/react_pconnect';
|
|
6
5
|
import StoreContext from '@pega/react-sdk-components/lib/bridge/Context/StoreContext';
|
|
@@ -54,6 +53,7 @@ export default function RootContainer(props: PropsWithChildren<RootContainerProp
|
|
|
54
53
|
const pConn = getPConnect();
|
|
55
54
|
|
|
56
55
|
const options = { context: 'app' };
|
|
56
|
+
const rootView = useRef(null);
|
|
57
57
|
|
|
58
58
|
const [componentName, setComponentName] = useState('');
|
|
59
59
|
|
|
@@ -146,7 +146,6 @@ export default function RootContainer(props: PropsWithChildren<RootContainerProp
|
|
|
146
146
|
return noPortalContent;
|
|
147
147
|
}
|
|
148
148
|
|
|
149
|
-
let rootView: any;
|
|
150
149
|
let rootViewConfig: any = null;
|
|
151
150
|
|
|
152
151
|
useEffect(() => {
|
|
@@ -180,8 +179,8 @@ export default function RootContainer(props: PropsWithChildren<RootContainerProp
|
|
|
180
179
|
}
|
|
181
180
|
};
|
|
182
181
|
|
|
183
|
-
if (!
|
|
184
|
-
rootView = createElement(createPConnectComponent(), PCore.createPConnect(currentRootConfig));
|
|
182
|
+
if (prevRootConfig === null || !PCore.isDeepEqual(currentRootConfig, prevRootConfig)) {
|
|
183
|
+
rootView.current = createElement(createPConnectComponent(), PCore.createPConnect(currentRootConfig)) as any;
|
|
185
184
|
}
|
|
186
185
|
|
|
187
186
|
// debugging/investigation help
|
|
@@ -189,7 +188,7 @@ export default function RootContainer(props: PropsWithChildren<RootContainerProp
|
|
|
189
188
|
|
|
190
189
|
return (
|
|
191
190
|
<div id='ModalManager'>
|
|
192
|
-
{rootView}
|
|
191
|
+
{rootView.current}
|
|
193
192
|
{MemoizedModalViewContainer}
|
|
194
193
|
<div id='MemoizedPreviewViewContainer' />
|
|
195
194
|
<div id='ReAuthMessageModal' />
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { Breadcrumbs, Card, Typography } from '@material
|
|
2
|
-
import DoubleArrowIcon from '@
|
|
3
|
-
import DoneIcon from '@
|
|
4
|
-
import
|
|
1
|
+
import { Breadcrumbs, Card, Typography } from '@mui/material';
|
|
2
|
+
import DoubleArrowIcon from '@mui/icons-material/DoubleArrow';
|
|
3
|
+
import DoneIcon from '@mui/icons-material/Done';
|
|
4
|
+
import makeStyles from '@mui/styles/makeStyles';
|
|
5
5
|
|
|
6
6
|
import { PConnProps } from '@pega/react-sdk-components/lib/types/PConnProps';
|
|
7
7
|
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import
|
|
2
|
-
import { Tab, Divider } from '@material
|
|
1
|
+
import withStyles from '@mui/styles/withStyles';
|
|
2
|
+
import { Tab, Divider } from '@mui/material';
|
|
3
3
|
|
|
4
4
|
// LeftAlignVerticalTabs does NOT have getPConnect. So, no need to extend from PConnProps
|
|
5
5
|
|
|
@@ -18,7 +18,8 @@ interface LeftAlignVerticalTabsProps {
|
|
|
18
18
|
const LeftAlignVerticalTabs: any = withStyles((/* theme */) => ({
|
|
19
19
|
root: {
|
|
20
20
|
width: '100%',
|
|
21
|
-
maxWidth: '100%'
|
|
21
|
+
maxWidth: '100%',
|
|
22
|
+
alignItems: 'flex-start'
|
|
22
23
|
},
|
|
23
24
|
wrapper: {
|
|
24
25
|
display: 'block',
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import React, { useState, useEffect } from 'react';
|
|
2
|
-
import
|
|
3
|
-
import Tabs from '@material
|
|
2
|
+
import makeStyles from '@mui/styles/makeStyles';
|
|
3
|
+
import Tabs from '@mui/material/Tabs';
|
|
4
4
|
|
|
5
5
|
import { getComponentFromMap } from '@pega/react-sdk-components/lib/bridge/helpers/sdk_component_map';
|
|
6
6
|
|
package/lib/infra/View/View.tsx
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { PropsWithChildren } from 'react';
|
|
1
|
+
import { PropsWithChildren, useEffect } from 'react';
|
|
2
2
|
|
|
3
3
|
import { getComponentFromMap } from '@pega/react-sdk-components/lib/bridge/helpers/sdk_component_map';
|
|
4
4
|
import { getAllFields } from '@pega/react-sdk-components/lib/components/helpers/template-utils';
|
|
@@ -18,6 +18,7 @@ interface ViewProps extends PConnProps {
|
|
|
18
18
|
visibility?: boolean;
|
|
19
19
|
name?: string;
|
|
20
20
|
bInForm?: boolean;
|
|
21
|
+
type?: any;
|
|
21
22
|
}
|
|
22
23
|
|
|
23
24
|
//
|
|
@@ -36,12 +37,14 @@ const NO_HEADER_TEMPLATES = [
|
|
|
36
37
|
'NarrowWideDetails',
|
|
37
38
|
'WideNarrowDetails',
|
|
38
39
|
'Confirmation',
|
|
39
|
-
'DynamicTabs'
|
|
40
|
+
'DynamicTabs',
|
|
41
|
+
'DetailsSubTabs'
|
|
40
42
|
];
|
|
41
43
|
|
|
42
44
|
export default function View(props: PropsWithChildren<ViewProps>) {
|
|
43
|
-
const { children, template, getPConnect, mode, visibility, name: pageName } = props;
|
|
45
|
+
const { children, template, getPConnect, mode, visibility, name: pageName, type, title } = props;
|
|
44
46
|
let { label = '', showLabel = false } = props;
|
|
47
|
+
const { PAGE_TYPES: { PAGE, LANDINGPAGE, LISTPAGE } = {}, MODAL } = PCore.getConstants();
|
|
45
48
|
|
|
46
49
|
// Get the inherited props from the parent to determine label settings. For 8.6, this is only for embedded data form views
|
|
47
50
|
// Putting this logic here instead of copy/paste in every Form template index.js
|
|
@@ -49,12 +52,43 @@ export default function View(props: PropsWithChildren<ViewProps>) {
|
|
|
49
52
|
const inheritedProps: any = getPConnect().getInheritedProps(); // try to remove any when getInheritedProps typedefs are fixed
|
|
50
53
|
label = inheritedProps.label || label;
|
|
51
54
|
showLabel = inheritedProps.showLabel || showLabel;
|
|
55
|
+
const localeUtils = PCore.getLocaleUtils();
|
|
52
56
|
|
|
53
57
|
const isEmbeddedDataView = mode === 'editable'; // would be better to check the reference child for `context` attribute if possible
|
|
54
58
|
if (isEmbeddedDataView && showLabel === undefined) {
|
|
55
59
|
showLabel = true;
|
|
56
60
|
}
|
|
57
61
|
|
|
62
|
+
useEffect(() => {
|
|
63
|
+
// Get the localized application label
|
|
64
|
+
let applicationLabel = PCore.getEnvironmentInfo().getApplicationLabel();
|
|
65
|
+
applicationLabel = localeUtils.getLocaleValue(`${applicationLabel}`, '', '');
|
|
66
|
+
const caseInfo = getPConnect().getCaseInfo();
|
|
67
|
+
const isAssignmentInCreateStage = caseInfo && caseInfo.isAssignmentInCreateStage();
|
|
68
|
+
const isRenderingInModal = getPConnect().getContainerName().includes(MODAL);
|
|
69
|
+
const isRenderingInPreviewPanel = getPConnect().getContainerName().includes('preview');
|
|
70
|
+
|
|
71
|
+
/* If assignment is in create stage and rendering in modal don't update the title.
|
|
72
|
+
Title will be updated on completion of create stage and when the assignment is rendered inline to the page.
|
|
73
|
+
*/
|
|
74
|
+
const canUpdateTitle =
|
|
75
|
+
!isRenderingInPreviewPanel &&
|
|
76
|
+
(type === PAGE || type === LANDINGPAGE || type === LISTPAGE) &&
|
|
77
|
+
!(isRenderingInModal && isAssignmentInCreateStage) &&
|
|
78
|
+
PCore.getEnvironmentInfo().getRenderingMode() === 'FULL_PORTAL';
|
|
79
|
+
// Incase of home route title is same as applicationLabel so setting to empty to just show applicationLabel
|
|
80
|
+
let titleVar = title === applicationLabel ? '' : title;
|
|
81
|
+
|
|
82
|
+
if (canUpdateTitle) {
|
|
83
|
+
if (caseInfo) {
|
|
84
|
+
const name = caseInfo.getName();
|
|
85
|
+
const id = caseInfo.getBusinessID();
|
|
86
|
+
titleVar = name && id ? `${name} (${id})` : titleVar;
|
|
87
|
+
}
|
|
88
|
+
document.title = titleVar ? `${titleVar} - ${applicationLabel}` : applicationLabel;
|
|
89
|
+
}
|
|
90
|
+
}, [type, title, getPConnect, PAGE, LANDINGPAGE, LISTPAGE]);
|
|
91
|
+
|
|
58
92
|
const key = `${getPConnect().getContextName()}_${getPConnect().getPageReference()}_${pageName}`;
|
|
59
93
|
// As long as the template is defined in the dependencies of the view
|
|
60
94
|
// it will be loaded, otherwise fall back to single column
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { PropsWithChildren, useEffect, useState } from 'react';
|
|
2
|
-
import
|
|
3
|
-
import Avatar from '@material
|
|
2
|
+
import makeStyles from '@mui/styles/makeStyles';
|
|
3
|
+
import Avatar from '@mui/material/Avatar';
|
|
4
4
|
|
|
5
5
|
import { Utils } from '@pega/react-sdk-components/lib/components/helpers/utils';
|
|
6
6
|
import { NavContext } from '@pega/react-sdk-components/lib/components/helpers/reactContextHelpers';
|
|
@@ -24,6 +24,8 @@ interface AppShellProps extends PConnProps {
|
|
|
24
24
|
portalName: string;
|
|
25
25
|
portalLogo: string;
|
|
26
26
|
navDisplayOptions: { alignment: string; position: string };
|
|
27
|
+
httpMessages: string[];
|
|
28
|
+
pageMessages: string[];
|
|
27
29
|
}
|
|
28
30
|
|
|
29
31
|
const useStyles = makeStyles(theme => ({
|
|
@@ -49,8 +51,21 @@ export default function AppShell(props: PropsWithChildren<AppShellProps>) {
|
|
|
49
51
|
// Get emitted components from map (so we can get any override that may exist)
|
|
50
52
|
const NavBar = getComponentFromMap('NavBar');
|
|
51
53
|
const WssNavBar = getComponentFromMap('WssNavBar');
|
|
54
|
+
const AlertBanner = getComponentFromMap('AlertBanner');
|
|
52
55
|
|
|
53
|
-
const {
|
|
56
|
+
const {
|
|
57
|
+
pages = [],
|
|
58
|
+
caseTypes = [],
|
|
59
|
+
showAppName,
|
|
60
|
+
children = [],
|
|
61
|
+
getPConnect,
|
|
62
|
+
httpMessages = [],
|
|
63
|
+
pageMessages = [],
|
|
64
|
+
portalTemplate,
|
|
65
|
+
portalName,
|
|
66
|
+
portalLogo,
|
|
67
|
+
navDisplayOptions
|
|
68
|
+
} = props;
|
|
54
69
|
|
|
55
70
|
const [open, setOpen] = useState(true);
|
|
56
71
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
@@ -58,7 +73,7 @@ export default function AppShell(props: PropsWithChildren<AppShellProps>) {
|
|
|
58
73
|
const pConn = getPConnect();
|
|
59
74
|
const envInfo = PCore.getEnvironmentInfo();
|
|
60
75
|
const imageKey = envInfo.getOperatorImageInsKey();
|
|
61
|
-
const userName = envInfo.getOperatorName();
|
|
76
|
+
const userName = envInfo.getOperatorName() || '';
|
|
62
77
|
const currentUserInitials = Utils.getInitials(userName);
|
|
63
78
|
const appNameToDisplay = showAppName ? envInfo.getApplicationLabel() : '';
|
|
64
79
|
const portalClass = pConn.getValue('.classID', ''); // 2nd arg empty string until typedef marked correctly
|
|
@@ -75,9 +90,18 @@ export default function AppShell(props: PropsWithChildren<AppShellProps>) {
|
|
|
75
90
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
76
91
|
const [mapChildren, setMapChildren] = useState([]);
|
|
77
92
|
|
|
93
|
+
const messages = [...httpMessages, ...pageMessages];
|
|
94
|
+
|
|
95
|
+
const hasBanner = messages && messages.length ? messages.length > 0 : false;
|
|
96
|
+
let banners: any = null;
|
|
97
|
+
banners = hasBanner && (
|
|
98
|
+
<div style={{ display: 'flex', flexDirection: 'column', padding: '1em 0' }}>
|
|
99
|
+
<AlertBanner id='AppShell' variant='urgent' messages={messages} />
|
|
100
|
+
</div>
|
|
101
|
+
);
|
|
78
102
|
// Initial setting of appName and mapChildren
|
|
79
103
|
useEffect(() => {
|
|
80
|
-
setAppName(PCore.getEnvironmentInfo().getApplicationName());
|
|
104
|
+
setAppName(PCore.getEnvironmentInfo().getApplicationName() || '');
|
|
81
105
|
|
|
82
106
|
const tempMap: any = (pConn.getChildren() as any)?.map((child: any, index) => {
|
|
83
107
|
const theChildComp = child.getPConnect().getComponentName();
|
|
@@ -92,6 +116,25 @@ export default function AppShell(props: PropsWithChildren<AppShellProps>) {
|
|
|
92
116
|
setMapChildren(tempMap);
|
|
93
117
|
}, []);
|
|
94
118
|
|
|
119
|
+
useEffect(() => {
|
|
120
|
+
// @ts-ignore
|
|
121
|
+
const caseTypesAvailableToCreateDP = PCore.getEnvironmentInfo().environmentInfoObject?.pxApplication?.pyCaseTypesAvailableToCreateDP;
|
|
122
|
+
if (caseTypesAvailableToCreateDP) {
|
|
123
|
+
const portalID = pConn.getValue('.pyOwner');
|
|
124
|
+
PCore.getDataPageUtils()
|
|
125
|
+
.getPageDataAsync(caseTypesAvailableToCreateDP, pConn.getContextName(), {
|
|
126
|
+
PortalName: portalID
|
|
127
|
+
})
|
|
128
|
+
.then((response: { pyCaseTypesAvailableToCreate?: any }) => {
|
|
129
|
+
if (response?.pyCaseTypesAvailableToCreate) {
|
|
130
|
+
pConn.replaceState('.pyCaseTypesAvailableToCreate', response.pyCaseTypesAvailableToCreate, {
|
|
131
|
+
skipDirtyValidation: true
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
}, []);
|
|
137
|
+
|
|
95
138
|
const [iconURL, setIconURL] = useState('');
|
|
96
139
|
const [fullIconURL, setFullIconURL] = useState('');
|
|
97
140
|
useEffect(() => {
|
|
@@ -175,10 +218,10 @@ export default function AppShell(props: PropsWithChildren<AppShellProps>) {
|
|
|
175
218
|
portalName={portalName}
|
|
176
219
|
imageSrc={iconURL}
|
|
177
220
|
fullImageSrc={fullIconURL}
|
|
178
|
-
appName={localizedVal(appNameToDisplay, '', `${portalClass}!PORTAL!${envPortalName}`.toUpperCase())}
|
|
221
|
+
appName={localizedVal(appNameToDisplay || '', '', `${portalClass}!PORTAL!${envPortalName}`.toUpperCase())}
|
|
179
222
|
appInfo={{
|
|
180
223
|
imageSrc: iconURL,
|
|
181
|
-
appName: localizedVal(appNameToDisplay, '', `${portalClass}!PORTAL!${envPortalName}`.toUpperCase()),
|
|
224
|
+
appName: localizedVal(appNameToDisplay || '', '', `${portalClass}!PORTAL!${envPortalName}`.toUpperCase()),
|
|
182
225
|
onClick: links[0] && /* links[0].onClick ? */ links[0].onClick /* : undefined */
|
|
183
226
|
}}
|
|
184
227
|
navLinks={links.filter((link, index) => {
|
|
@@ -187,7 +230,10 @@ export default function AppShell(props: PropsWithChildren<AppShellProps>) {
|
|
|
187
230
|
operator={getOperator()}
|
|
188
231
|
navDisplayOptions={navDisplayOptions}
|
|
189
232
|
/>
|
|
190
|
-
<div className={classes.wsscontent}>
|
|
233
|
+
<div className={classes.wsscontent}>
|
|
234
|
+
{banners}
|
|
235
|
+
{children}
|
|
236
|
+
</div>
|
|
191
237
|
</div>
|
|
192
238
|
);
|
|
193
239
|
}
|
|
@@ -199,11 +245,15 @@ export default function AppShell(props: PropsWithChildren<AppShellProps>) {
|
|
|
199
245
|
<NavBar
|
|
200
246
|
getPConnect={getPConnect}
|
|
201
247
|
pConn={getPConnect()}
|
|
202
|
-
appName={localizedVal(appNameToDisplay, '', `${portalClass}!PORTAL!${envPortalName}`.toUpperCase())}
|
|
248
|
+
appName={localizedVal(appNameToDisplay || '', '', `${portalClass}!PORTAL!${envPortalName}`.toUpperCase())}
|
|
203
249
|
pages={pages}
|
|
204
250
|
caseTypes={caseTypes}
|
|
205
251
|
/>
|
|
206
|
-
|
|
252
|
+
|
|
253
|
+
<div className={classes.content}>
|
|
254
|
+
{banners}
|
|
255
|
+
{children}
|
|
256
|
+
</div>
|
|
207
257
|
</div>
|
|
208
258
|
</NavContext.Provider>
|
|
209
259
|
);
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
/* eslint-disable react/jsx-boolean-value */
|
|
2
2
|
|
|
3
3
|
import { PropsWithChildren, ReactElement, useContext, useEffect, useState } from 'react';
|
|
4
|
-
import { Avatar, Card, CardHeader, Divider, Typography } from '@material
|
|
5
|
-
import
|
|
6
|
-
import Box from '@material
|
|
7
|
-
import Button from '@material
|
|
8
|
-
import Grid from '@material
|
|
4
|
+
import { Avatar, Card, CardHeader, Divider, Typography } from '@mui/material';
|
|
5
|
+
import makeStyles from '@mui/styles/makeStyles';
|
|
6
|
+
import Box from '@mui/material/Box';
|
|
7
|
+
import Button from '@mui/material/Button';
|
|
8
|
+
import Grid from '@mui/material/Grid';
|
|
9
9
|
|
|
10
10
|
import { Utils } from '@pega/react-sdk-components/lib/components/helpers/utils';
|
|
11
11
|
import StoreContext from '@pega/react-sdk-components/lib/bridge/Context/StoreContext';
|
|
@@ -19,6 +19,7 @@ interface CaseViewProps extends PConnProps {
|
|
|
19
19
|
header: string;
|
|
20
20
|
showIconInHeader: boolean;
|
|
21
21
|
caseInfo: any;
|
|
22
|
+
lastUpdateCaseTime: any;
|
|
22
23
|
}
|
|
23
24
|
|
|
24
25
|
const useStyles = makeStyles(theme => ({
|
|
@@ -64,10 +65,10 @@ export default function CaseView(props: PropsWithChildren<CaseViewProps>) {
|
|
|
64
65
|
showIconInHeader = true,
|
|
65
66
|
caseInfo: { availableActions = [], availableProcesses = [], hasNewAttachments, caseTypeID = '', caseTypeName = '' }
|
|
66
67
|
} = props;
|
|
68
|
+
const { lastUpdateCaseTime = getPConnect().getValue('caseInfo.lastUpdateTime') } = props;
|
|
67
69
|
|
|
68
70
|
const currentCaseID = props.caseInfo.ID;
|
|
69
71
|
let isComponentMounted = true;
|
|
70
|
-
|
|
71
72
|
const { displayOnlyFA } = useContext<any>(StoreContext);
|
|
72
73
|
|
|
73
74
|
const thePConn = getPConnect();
|
|
@@ -79,7 +80,6 @@ export default function CaseView(props: PropsWithChildren<CaseViewProps>) {
|
|
|
79
80
|
const localizedVal = PCore.getLocaleUtils().getLocaleValue;
|
|
80
81
|
const localeCategory = 'CaseView';
|
|
81
82
|
const localeKey = `${caseTypeID}!CASE!${caseTypeName}`.toUpperCase();
|
|
82
|
-
|
|
83
83
|
/**
|
|
84
84
|
*
|
|
85
85
|
* @param inName the metadata <em>name</em> that will cause a region to be returned
|
|
@@ -169,7 +169,6 @@ export default function CaseView(props: PropsWithChildren<CaseViewProps>) {
|
|
|
169
169
|
|
|
170
170
|
useEffect(() => {
|
|
171
171
|
if (hasNewAttachments) {
|
|
172
|
-
// @ts-ignore - Argument of type 'boolean' is not assignable to parameter of type 'object'
|
|
173
172
|
PCore.getPubSubUtils().publish((PCore.getEvents().getCaseEvent() as any).CASE_ATTACHMENTS_UPDATED_FROM_CASEVIEW, true);
|
|
174
173
|
}
|
|
175
174
|
}, [hasNewAttachments]);
|
|
@@ -244,7 +243,9 @@ export default function CaseView(props: PropsWithChildren<CaseViewProps>) {
|
|
|
244
243
|
<Grid item xs={6}>
|
|
245
244
|
{theStagesRegion}
|
|
246
245
|
{theTodoRegion}
|
|
247
|
-
{deferLoadInfo.length > 0 &&
|
|
246
|
+
{deferLoadInfo.length > 0 && (
|
|
247
|
+
<DeferLoad getPConnect={getPConnect} name={deferLoadInfo[activeVertTab].config.name} isTab lastUpdateCaseTime={lastUpdateCaseTime} />
|
|
248
|
+
)}
|
|
248
249
|
</Grid>
|
|
249
250
|
|
|
250
251
|
<Grid item xs={3}>
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import React, { useState } from 'react';
|
|
2
|
-
import Button from '@material
|
|
3
|
-
import Menu from '@material
|
|
4
|
-
import MenuItem from '@material
|
|
2
|
+
import Button from '@mui/material/Button';
|
|
3
|
+
import Menu from '@mui/material/Menu';
|
|
4
|
+
import MenuItem from '@mui/material/MenuItem';
|
|
5
5
|
|
|
6
6
|
import { PConnProps } from '@pega/react-sdk-components/lib/types/PConnProps';
|
|
7
|
-
import Snackbar from '@material
|
|
8
|
-
import IconButton from '@material
|
|
9
|
-
import CloseIcon from '@
|
|
7
|
+
import Snackbar from '@mui/material/Snackbar';
|
|
8
|
+
import IconButton from '@mui/material/IconButton';
|
|
9
|
+
import CloseIcon from '@mui/icons-material/Close';
|
|
10
10
|
|
|
11
11
|
interface CaseViewActionsMenuProps extends PConnProps {
|
|
12
12
|
// If any, enter additional props that only exist on this component
|
|
@@ -44,7 +44,7 @@ export default function CaseViewActionsMenu(props: CaseViewActionsMenuProps) {
|
|
|
44
44
|
setShowSnackbar(true);
|
|
45
45
|
}
|
|
46
46
|
|
|
47
|
-
function handleSnackbarClose(event: React.SyntheticEvent |
|
|
47
|
+
function handleSnackbarClose(event: React.SyntheticEvent<any> | Event, reason?: string) {
|
|
48
48
|
if (reason === 'clickaway') {
|
|
49
49
|
return;
|
|
50
50
|
}
|