channel.tsx 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  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 ChannelCardProps extends Partial<ChannelItem> {
  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/channel-modbus.png');
  20. const opcuaImage = require('/public/images/DataCollect/channel-opcua.png');
  21. export default (props: ChannelCardProps) => {
  22. return (
  23. <TableCard
  24. actions={props.actions}
  25. status={props.state?.value}
  26. statusText={props.state?.text}
  27. showMask={false}
  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
  54. title={
  55. props.provider === 'MODBUS_TCP'
  56. ? props?.configuration?.host
  57. : props?.configuration?.endpoint
  58. }
  59. />
  60. </div>
  61. </div>
  62. </div>
  63. </div>
  64. </TableCard>
  65. );
  66. };