2021-05-10 13:22:22 +02:00
|
|
|
import { useContext, useEffect, useState } from 'react';
|
2021-03-30 15:14:02 +02:00
|
|
|
import PropTypes from 'prop-types';
|
|
|
|
import classnames from 'classnames';
|
|
|
|
import { Link, useHistory } from 'react-router-dom';
|
|
|
|
import useMediaQuery from '@material-ui/core/useMediaQuery';
|
|
|
|
|
2021-11-29 14:29:58 +01:00
|
|
|
import {
|
|
|
|
IconButton,
|
|
|
|
List,
|
|
|
|
ListItem,
|
|
|
|
ListItemAvatar,
|
|
|
|
ListItemText,
|
|
|
|
Tooltip,
|
|
|
|
} from '@material-ui/core';
|
|
|
|
import {
|
|
|
|
Add,
|
|
|
|
Delete,
|
|
|
|
Extension,
|
|
|
|
Visibility,
|
|
|
|
VisibilityOff,
|
|
|
|
} from '@material-ui/icons';
|
2021-06-29 10:21:54 +02:00
|
|
|
|
2021-11-29 14:29:58 +01:00
|
|
|
import {
|
|
|
|
CREATE_STRATEGY,
|
|
|
|
DELETE_STRATEGY,
|
|
|
|
UPDATE_STRATEGY,
|
|
|
|
} from '../../providers/AccessProvider/permissions';
|
2021-03-30 15:14:02 +02:00
|
|
|
|
|
|
|
import ConditionallyRender from '../../common/ConditionallyRender/ConditionallyRender';
|
|
|
|
import PageContent from '../../common/PageContent/PageContent';
|
|
|
|
import HeaderTitle from '../../common/HeaderTitle';
|
|
|
|
|
|
|
|
import { useStyles } from './styles';
|
2021-04-20 19:13:31 +02:00
|
|
|
import AccessContext from '../../../contexts/AccessContext';
|
2021-05-10 13:22:22 +02:00
|
|
|
import Dialogue from '../../common/Dialogue';
|
2021-09-30 11:44:30 +02:00
|
|
|
import { ADD_NEW_STRATEGY_ID } from '../../../testIds';
|
2021-10-21 13:25:39 +02:00
|
|
|
import PermissionIconButton from '../../common/PermissionIconButton/PermissionIconButton';
|
|
|
|
import PermissionButton from '../../common/PermissionButton/PermissionButton';
|
2021-11-29 14:29:58 +01:00
|
|
|
import { getHumanReadableStrategyName } from '../../../utils/strategy-names';
|
2021-03-30 15:14:02 +02:00
|
|
|
|
|
|
|
const StrategiesList = ({
|
|
|
|
strategies,
|
|
|
|
fetchStrategies,
|
|
|
|
removeStrategy,
|
|
|
|
deprecateStrategy,
|
|
|
|
reactivateStrategy,
|
|
|
|
}) => {
|
|
|
|
const history = useHistory();
|
|
|
|
const styles = useStyles();
|
|
|
|
const smallScreen = useMediaQuery('(max-width:700px)');
|
2021-04-20 19:13:31 +02:00
|
|
|
const { hasAccess } = useContext(AccessContext);
|
2021-05-10 13:22:22 +02:00
|
|
|
const [dialogueMetaData, setDialogueMetaData] = useState({ show: false });
|
2021-03-30 15:14:02 +02:00
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
fetchStrategies();
|
2021-04-07 09:04:48 +02:00
|
|
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
2021-03-30 15:14:02 +02:00
|
|
|
}, []);
|
|
|
|
|
|
|
|
const headerButton = () => (
|
|
|
|
<ConditionallyRender
|
2021-04-20 19:13:31 +02:00
|
|
|
condition={hasAccess(CREATE_STRATEGY)}
|
2021-03-30 15:14:02 +02:00
|
|
|
show={
|
|
|
|
<ConditionallyRender
|
|
|
|
condition={smallScreen}
|
|
|
|
show={
|
2021-11-29 14:29:58 +01:00
|
|
|
<PermissionIconButton
|
|
|
|
data-test={ADD_NEW_STRATEGY_ID}
|
|
|
|
onClick={() => history.push('/strategies/create')}
|
|
|
|
permission={CREATE_STRATEGY}
|
|
|
|
tooltip={'Add new strategy'}
|
|
|
|
>
|
|
|
|
<Add />
|
|
|
|
</PermissionIconButton>
|
2021-03-30 15:14:02 +02:00
|
|
|
}
|
|
|
|
elseShow={
|
2021-10-21 13:25:39 +02:00
|
|
|
<PermissionButton
|
2021-04-23 15:21:24 +02:00
|
|
|
onClick={() => history.push('/strategies/create')}
|
|
|
|
color="primary"
|
2021-10-21 13:25:39 +02:00
|
|
|
permission={CREATE_STRATEGY}
|
2021-04-23 15:21:24 +02:00
|
|
|
variant="contained"
|
2021-09-30 11:44:30 +02:00
|
|
|
data-test={ADD_NEW_STRATEGY_ID}
|
2021-10-21 13:25:39 +02:00
|
|
|
tooltip={'Add new strategy'}
|
2021-04-23 15:21:24 +02:00
|
|
|
>
|
2021-03-30 15:14:02 +02:00
|
|
|
Add new strategy
|
2021-10-21 13:25:39 +02:00
|
|
|
</PermissionButton>
|
2021-03-30 15:14:02 +02:00
|
|
|
}
|
|
|
|
/>
|
|
|
|
}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
|
|
|
|
const strategyLink = ({ name, deprecated }) => (
|
|
|
|
<Link to={`/strategies/view/${name}`}>
|
2021-11-29 14:29:58 +01:00
|
|
|
<strong>{getHumanReadableStrategyName(name)}</strong>
|
2021-04-23 15:21:24 +02:00
|
|
|
<ConditionallyRender
|
|
|
|
condition={deprecated}
|
|
|
|
show={<small> (Deprecated)</small>}
|
|
|
|
/>
|
2021-03-30 15:14:02 +02:00
|
|
|
</Link>
|
|
|
|
);
|
|
|
|
|
|
|
|
const reactivateButton = strategy => (
|
|
|
|
<Tooltip title="Reactivate activation strategy">
|
2021-10-21 13:25:39 +02:00
|
|
|
<PermissionIconButton
|
2021-05-10 13:22:22 +02:00
|
|
|
onClick={() =>
|
|
|
|
setDialogueMetaData({
|
|
|
|
show: true,
|
|
|
|
title: 'Really reactivate strategy?',
|
|
|
|
onConfirm: () => reactivateStrategy(strategy),
|
|
|
|
})
|
|
|
|
}
|
2021-10-21 13:25:39 +02:00
|
|
|
permission={UPDATE_STRATEGY}
|
|
|
|
tooltip={'Reactivate activation strategy'}
|
2021-11-29 14:29:58 +01:00
|
|
|
>
|
|
|
|
<VisibilityOff />
|
|
|
|
</PermissionIconButton>
|
2021-03-30 15:14:02 +02:00
|
|
|
</Tooltip>
|
|
|
|
);
|
|
|
|
|
|
|
|
const deprecateButton = strategy => (
|
|
|
|
<ConditionallyRender
|
|
|
|
condition={strategy.name === 'default'}
|
|
|
|
show={
|
|
|
|
<Tooltip title="You cannot deprecate the default strategy">
|
|
|
|
<div>
|
|
|
|
<IconButton disabled>
|
2021-10-21 13:25:39 +02:00
|
|
|
<Visibility />
|
2021-03-30 15:14:02 +02:00
|
|
|
</IconButton>
|
|
|
|
</div>
|
|
|
|
</Tooltip>
|
|
|
|
}
|
|
|
|
elseShow={
|
2021-10-21 13:25:39 +02:00
|
|
|
<div>
|
|
|
|
<PermissionIconButton
|
|
|
|
onClick={() =>
|
|
|
|
setDialogueMetaData({
|
|
|
|
show: true,
|
|
|
|
title: 'Really deprecate strategy?',
|
2021-11-29 14:29:58 +01:00
|
|
|
onConfirm: () => deprecateStrategy(strategy),
|
2021-10-21 13:25:39 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
permission={UPDATE_STRATEGY}
|
|
|
|
tooltip={'Deprecate activation strategy'}
|
|
|
|
>
|
|
|
|
<Visibility />
|
|
|
|
</PermissionIconButton>
|
|
|
|
</div>
|
2021-03-30 15:14:02 +02:00
|
|
|
}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
|
|
|
|
const deleteButton = strategy => (
|
|
|
|
<ConditionallyRender
|
|
|
|
condition={strategy.editable}
|
|
|
|
show={
|
2021-11-29 14:29:58 +01:00
|
|
|
<PermissionIconButton
|
|
|
|
onClick={() =>
|
|
|
|
setDialogueMetaData({
|
|
|
|
show: true,
|
|
|
|
title: 'Really delete strategy?',
|
|
|
|
onConfirm: () => removeStrategy(strategy),
|
|
|
|
})
|
|
|
|
}
|
|
|
|
permission={DELETE_STRATEGY}
|
|
|
|
tooltip={'Delete strategy'}
|
|
|
|
>
|
|
|
|
<Delete />
|
|
|
|
</PermissionIconButton>
|
2021-03-30 15:14:02 +02:00
|
|
|
}
|
|
|
|
elseShow={
|
|
|
|
<Tooltip title="You cannot delete a built-in strategy">
|
|
|
|
<div>
|
|
|
|
<IconButton disabled>
|
2021-06-29 10:21:54 +02:00
|
|
|
<Delete />
|
2021-03-30 15:14:02 +02:00
|
|
|
</IconButton>
|
|
|
|
</div>
|
|
|
|
</Tooltip>
|
|
|
|
}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
|
|
|
|
const strategyList = () =>
|
|
|
|
strategies.map(strategy => (
|
|
|
|
<ListItem
|
|
|
|
key={strategy.name}
|
|
|
|
classes={{
|
|
|
|
root: classnames(styles.listItem, {
|
|
|
|
[styles.deprecated]: strategy.deprecated,
|
|
|
|
}),
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
<ListItemAvatar>
|
2021-06-29 10:21:54 +02:00
|
|
|
<Extension style={{ color: '#0000008a' }} />
|
2021-03-30 15:14:02 +02:00
|
|
|
</ListItemAvatar>
|
2021-04-23 15:21:24 +02:00
|
|
|
<ListItemText
|
|
|
|
primary={strategyLink(strategy)}
|
|
|
|
secondary={strategy.description}
|
|
|
|
/>
|
2021-03-30 15:14:02 +02:00
|
|
|
<ConditionallyRender
|
|
|
|
condition={strategy.deprecated}
|
|
|
|
show={reactivateButton(strategy)}
|
|
|
|
elseShow={deprecateButton(strategy)}
|
|
|
|
/>
|
2021-04-23 15:21:24 +02:00
|
|
|
<ConditionallyRender
|
|
|
|
condition={hasAccess(DELETE_STRATEGY)}
|
|
|
|
show={deleteButton(strategy)}
|
|
|
|
/>
|
2021-03-30 15:14:02 +02:00
|
|
|
</ListItem>
|
|
|
|
));
|
|
|
|
|
2021-05-10 13:22:22 +02:00
|
|
|
const onDialogConfirm = () => {
|
|
|
|
dialogueMetaData?.onConfirm();
|
|
|
|
setDialogueMetaData(prev => ({ ...prev, show: false }));
|
|
|
|
};
|
|
|
|
|
2021-03-30 15:14:02 +02:00
|
|
|
return (
|
2021-04-23 15:21:24 +02:00
|
|
|
<PageContent
|
|
|
|
headerContent={
|
|
|
|
<HeaderTitle title="Strategies" actions={headerButton()} />
|
|
|
|
}
|
|
|
|
>
|
2021-05-10 13:22:22 +02:00
|
|
|
<Dialogue
|
|
|
|
open={dialogueMetaData.show}
|
|
|
|
onClick={onDialogConfirm}
|
|
|
|
title={dialogueMetaData?.title}
|
|
|
|
onClose={() =>
|
|
|
|
setDialogueMetaData(prev => ({ ...prev, show: false }))
|
|
|
|
}
|
|
|
|
/>
|
2021-03-30 15:14:02 +02:00
|
|
|
<List>
|
|
|
|
<ConditionallyRender
|
|
|
|
condition={strategies.length > 0}
|
|
|
|
show={strategyList()}
|
|
|
|
elseShow={<ListItem>No strategies found</ListItem>}
|
|
|
|
/>
|
|
|
|
</List>
|
|
|
|
</PageContent>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
StrategiesList.propTypes = {
|
|
|
|
strategies: PropTypes.array.isRequired,
|
|
|
|
fetchStrategies: PropTypes.func.isRequired,
|
|
|
|
removeStrategy: PropTypes.func.isRequired,
|
|
|
|
deprecateStrategy: PropTypes.func.isRequired,
|
|
|
|
reactivateStrategy: PropTypes.func.isRequired,
|
|
|
|
history: PropTypes.object.isRequired,
|
|
|
|
name: PropTypes.string,
|
|
|
|
deprecated: PropTypes.bool,
|
|
|
|
};
|
|
|
|
|
|
|
|
export default StrategiesList;
|