device.tsx 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. import React from 'react';
  2. import { StatusColorEnum } from '@/components/BadgeStatus';
  3. import { TableCard, Ellipsis } from '@/components';
  4. import '@/style/common.less';
  5. import './index.less';
  6. export interface CollectorCardProps extends Partial<CollectorItem> {
  7. detail?: React.ReactNode;
  8. actions?: React.ReactNode[];
  9. avatarSize?: number;
  10. className?: string;
  11. content?: React.ReactNode[];
  12. onClick?: () => void;
  13. grantedPermissions?: string[];
  14. onUnBind?: (e: any) => void;
  15. showBindBtn?: boolean;
  16. cardType?: 'bind' | 'unbind';
  17. showTool?: boolean;
  18. }
  19. const modbusImage = require('/public/images/DataCollect/device-modbus.png');
  20. const opcuaImage = require('/public/images/DataCollect/device-opcua.png');
  21. export default (props: CollectorCardProps) => {
  22. return (
  23. <TableCard
  24. showMask={false}
  25. actions={props.actions}
  26. status={props.state?.value}
  27. statusText={props.state?.text}
  28. statusNames={{
  29. enabled: StatusColorEnum.success,
  30. disabled: StatusColorEnum.error,
  31. }}
  32. >
  33. <div className={'pro-table-card-item'}>
  34. <div className={'card-item-avatar'}>
  35. <img
  36. width={88}
  37. height={88}
  38. src={props.provider === 'MODBUS_TCP' ? modbusImage : opcuaImage}
  39. alt={''}
  40. />
  41. </div>
  42. <div className={'card-item-body'}>
  43. <div className={'card-item-header'}>
  44. <Ellipsis title={props.name} titleClassName={'card-item-header-name'} />
  45. </div>
  46. <div className={'card-item-content'}>
  47. <div>
  48. <label>协议</label>
  49. <Ellipsis title={props.provider} />
  50. </div>
  51. <div>
  52. <label>所属通道</label>
  53. <Ellipsis title={props?.channelName || props?.channelId || ''} />
  54. </div>
  55. </div>
  56. </div>
  57. </div>
  58. </TableCard>
  59. );
  60. };