| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460 |
- import { PageContainer } from '@ant-design/pro-layout';
- import SearchComponent from '@/components/SearchComponent';
- import type { ActionType, ProColumns } from '@jetlinks/pro-table';
- import { PermissionButton } from '@/components';
- import {
- CloseCircleOutlined,
- DeleteOutlined,
- EditOutlined,
- LikeOutlined,
- PlayCircleOutlined,
- PlusOutlined,
- } from '@ant-design/icons';
- import { useIntl } from '@@/plugin-locale/localeExports';
- import { useEffect, useRef, useState } from 'react';
- import { Badge, Space, Tooltip } from 'antd';
- import ProTableCard from '@/components/ProTableCard';
- import Save from './Save';
- import Service from '@/pages/rule-engine/Alarm/Configuration/service';
- import AlarmConfig from '@/components/ProTableCard/CardItems/AlarmConfig';
- import { Store } from 'jetlinks-store';
- import { getMenuPathByCode, MENUS_CODE } from '@/utils/menu';
- import { useHistory } from 'umi';
- import { onlyMessage } from '@/utils/util';
- import encodeQuery from '@/utils/encodeQuery';
- const service = new Service('alarm/config');
- const Configuration = () => {
- const intl = useIntl();
- const history = useHistory();
- const [visible, setVisible] = useState<boolean>(false);
- const actionRef = useRef<ActionType>();
- const { permission } = PermissionButton.usePermission('rule-engine/Alarm/Configuration');
- const [current, setCurrent] = useState<any>();
- const columns: ProColumns<ConfigurationItem>[] = [
- {
- dataIndex: 'name',
- title: '名称',
- ellipsis: true,
- fixed: 'left',
- },
- {
- title: '类型',
- dataIndex: 'targetType',
- renderText: (text: string) => {
- const map = {
- product: '产品',
- device: '设备',
- org: '部门',
- other: '其他',
- };
- return map[text];
- },
- valueType: 'select',
- valueEnum: {
- product: {
- text: '产品',
- status: 'product',
- },
- device: {
- text: '设备',
- status: 'device',
- },
- org: {
- text: '部门',
- status: 'org',
- },
- other: {
- text: '其他',
- status: 'other',
- },
- },
- },
- {
- title: '告警级别',
- dataIndex: 'level',
- render: (text: any) => (
- <Tooltip
- placement="topLeft"
- title={
- (Store.get('default-level') || []).find((item: any) => item?.level === text)?.title ||
- text
- }
- >
- <div className="ellipsis">
- {(Store.get('default-level') || []).find((item: any) => item?.level === text)?.title ||
- text}
- </div>
- </Tooltip>
- ),
- valueType: 'select',
- request: async () => {
- const res = await service.queryDefaultLevel();
- if (res.status === 200) {
- return (res?.result?.levels || [])
- .filter((i: any) => i?.level && i?.title)
- .map((item: any) => ({
- label: item.title,
- value: item.level,
- }));
- }
- return [];
- },
- },
- {
- title: '关联场景联动',
- dataIndex: 'sceneName',
- width: 250,
- render: (text: any, record: any) => (
- <PermissionButton
- type={'link'}
- isPermission={!!getMenuPathByCode(MENUS_CODE['rule-engine/Scene'])}
- style={{ padding: 0, height: 'auto' }}
- tooltip={{
- title: !!getMenuPathByCode(MENUS_CODE['rule-engine/Scene'])
- ? text
- : '没有权限,请联系管理员',
- }}
- onClick={() => {
- const url = getMenuPathByCode('rule-engine/Scene/Save');
- history.push(`${url}?id=${record.sceneId}`);
- }}
- >
- <span
- style={{
- width: '200px',
- overflow: 'hidden',
- textAlign: 'left',
- textOverflow: 'ellipsis',
- }}
- >
- {text}
- </span>
- </PermissionButton>
- ),
- valueType: 'select',
- request: async () => {
- const res: any = await service.getScene(
- encodeQuery({
- sorts: { createTime: 'desc' },
- }),
- );
- if (res.status === 200) {
- return res.result.map((item: any) => ({ label: item.name, value: item.name }));
- }
- return [];
- },
- },
- {
- title: '状态',
- dataIndex: 'state',
- valueType: 'select',
- renderText: (state) => (
- <Badge text={state?.text} status={state?.value === 'disabled' ? 'error' : 'success'} />
- ),
- valueEnum: {
- disabled: {
- text: intl.formatMessage({
- id: 'pages.device.product.status.disabled',
- defaultMessage: '禁用',
- }),
- status: 'disabled',
- },
- enabled: {
- text: intl.formatMessage({
- id: 'pages.device.product.status.enabled',
- defaultMessage: '正常',
- }),
- status: 'enabled',
- },
- },
- },
- {
- title: '说明',
- dataIndex: 'description',
- ellipsis: true,
- },
- {
- title: '操作',
- valueType: 'option',
- align: 'left',
- fixed: 'right',
- width: 150,
- render: (_, record) => [
- record.sceneTriggerType === 'manual' && (
- <PermissionButton
- key="trigger"
- type="link"
- style={{ padding: 0 }}
- isPermission={permission.tigger}
- tooltip={{
- title: record.state?.value === 'disabled' ? '未启用,不能手动触发' : '手动触发',
- }}
- disabled={record.state?.value === 'disabled'}
- popConfirm={{
- disabled: record.state?.value === 'disabled',
- title: '确认手动触发?',
- onConfirm: async () => {
- await service._execute(record.sceneId);
- onlyMessage(
- intl.formatMessage({
- id: 'pages.data.option.success',
- defaultMessage: '操作成功!',
- }),
- );
- actionRef.current?.reload();
- },
- }}
- >
- <LikeOutlined />
- </PermissionButton>
- ),
- <PermissionButton
- isPermission={permission.update}
- key="edit"
- style={{ padding: 0 }}
- tooltip={{
- title: intl.formatMessage({
- id: 'pages.data.option.edit',
- defaultMessage: '编辑',
- }),
- }}
- type="link"
- onClick={() => {
- setVisible(true);
- setCurrent(record);
- }}
- >
- <EditOutlined />
- </PermissionButton>,
- <PermissionButton
- isPermission={permission.action}
- key="action"
- style={{ padding: 0 }}
- popConfirm={{
- title: `${
- record.state?.value !== 'disabled'
- ? '禁用告警不会影响关联的场景状态,确定要禁用吗'
- : '确认启用'
- }?`,
- onConfirm: async () => {
- if (record.state?.value === 'disabled') {
- await service._enable(record.id);
- } else {
- await service._disable(record.id);
- }
- onlyMessage(
- intl.formatMessage({
- id: 'pages.data.option.success',
- defaultMessage: '操作成功!',
- }),
- );
- actionRef.current?.reload();
- },
- }}
- tooltip={{
- title: intl.formatMessage({
- id: `pages.data.option.${
- record.state?.value !== 'disabled' ? 'disabled' : 'enabled'
- }`,
- defaultMessage: record.state?.value !== 'disabled' ? '禁用' : '启用',
- }),
- }}
- type="link"
- >
- {record.state?.value === 'disabled' ? <PlayCircleOutlined /> : <CloseCircleOutlined />}
- </PermissionButton>,
- <PermissionButton
- type="link"
- isPermission={permission.delete}
- key="delete"
- disabled={record.state?.value !== 'disabled'}
- style={{ padding: 0 }}
- popConfirm={{
- disabled: record.state?.value !== 'disabled',
- title: '确认删除?',
- onConfirm: () => service.remove(record.id),
- }}
- tooltip={{
- title: record.state?.value === 'disabled' ? '删除' : '已启用,不能删除',
- }}
- >
- <DeleteOutlined />
- </PermissionButton>,
- ],
- },
- ];
- const [param, setParam] = useState({});
- useEffect(() => {
- service.queryDefaultLevel().then((resp) => {
- if (resp.status === 200) {
- Store.set('default-level', resp.result?.levels || []);
- }
- });
- }, []);
- return (
- <PageContainer>
- <SearchComponent
- field={columns}
- onSearch={(data) => {
- actionRef.current?.reset?.();
- setParam(data);
- }}
- />
- <ProTableCard<any>
- actionRef={actionRef}
- rowKey="id"
- search={false}
- scroll={{ x: 1366 }}
- params={param}
- columns={columns}
- columnEmptyText={''}
- request={(params) =>
- service.query({ ...params, sorts: [{ name: 'createTime', order: 'desc' }] })
- }
- gridColumn={3}
- cardRender={(record) => (
- <AlarmConfig
- {...record}
- actions={[
- record.sceneTriggerType === 'manual' ? (
- <PermissionButton
- key="trigger"
- type="link"
- tooltip={{
- title: record.state?.value === 'disabled' ? '未启用,不能手动触发' : '',
- }}
- disabled={record.state?.value === 'disabled'}
- isPermission={permission.tigger}
- popConfirm={{
- title: '确认手动触发?',
- disabled: record.state?.value === 'disabled',
- onConfirm: async () => {
- await service._execute(record.sceneId);
- onlyMessage(
- intl.formatMessage({
- id: 'pages.data.option.success',
- defaultMessage: '操作成功!',
- }),
- );
- actionRef.current?.reload();
- },
- }}
- >
- <LikeOutlined />
- 手动触发
- </PermissionButton>
- ) : null,
- <PermissionButton
- isPermission={permission.update}
- key="edit"
- type="link"
- onClick={() => {
- setCurrent(record);
- setVisible(true);
- }}
- >
- <EditOutlined />
- 编辑
- </PermissionButton>,
- <PermissionButton
- isPermission={permission.action}
- style={{ padding: 0 }}
- popConfirm={{
- title: `${
- record.state?.value !== 'disabled'
- ? '禁用告警不会影响关联的场景状态,确定要禁用吗'
- : '确认启用'
- }?`,
- onConfirm: async () => {
- if (record.state?.value === 'disabled') {
- await service._enable(record.id);
- } else {
- await service._disable(record.id);
- }
- onlyMessage(
- intl.formatMessage({
- id: 'pages.data.option.success',
- defaultMessage: '操作成功!',
- }),
- );
- actionRef.current?.reload();
- },
- }}
- tooltip={{
- title: intl.formatMessage({
- id: `pages.data.option.${
- record.state?.value !== 'disabled' ? 'disabled' : 'enabled'
- }`,
- defaultMessage: record.state?.value !== 'disabled' ? '禁用' : '启用',
- }),
- }}
- key="action"
- type="link"
- >
- {record.state?.value !== 'disabled' ? (
- <CloseCircleOutlined />
- ) : (
- <PlayCircleOutlined />
- )}
- {record.state?.value !== 'disabled' ? '禁用' : '启用'}
- </PermissionButton>,
- <PermissionButton
- type="link"
- tooltip={{
- title: record.state?.value === 'disabled' ? '删除' : '已启用,不能删除',
- }}
- disabled={record.state?.value !== 'disabled'}
- popConfirm={{
- disabled: record.state?.value !== 'disabled',
- title: '确认删除?',
- onConfirm: async () => {
- await service.remove(record.id);
- actionRef.current?.reset?.();
- },
- }}
- isPermission={permission.delete}
- key="delete"
- >
- <DeleteOutlined />
- </PermissionButton>,
- ]}
- />
- )}
- headerTitle={
- <Space>
- <PermissionButton
- isPermission={permission.add}
- onClick={() => {
- setCurrent(undefined);
- setVisible(true);
- }}
- key="button"
- icon={<PlusOutlined />}
- type="primary"
- >
- {intl.formatMessage({
- id: 'pages.data.option.add',
- defaultMessage: '新增',
- })}
- </PermissionButton>
- </Space>
- }
- />
- <Save
- data={current}
- visible={visible}
- close={() => {
- setVisible(false);
- actionRef.current?.reset?.();
- }}
- />
- </PageContainer>
- );
- };
- export default Configuration;
|