|
| 1 | +import {DefinitionList} from '@gravity-ui/uikit'; |
| 2 | + |
| 3 | +import {EMPTY_DATA_PLACEHOLDER} from '../../utils/constants'; |
| 4 | +import { |
| 5 | + formatDateTime, |
| 6 | + getDowntimeFromDateFormatted, |
| 7 | + getUptimeFromDateFormatted, |
| 8 | +} from '../../utils/dataFormatters/dataFormatters'; |
| 9 | +import {CellWithPopover} from '../CellWithPopover/CellWithPopover'; |
| 10 | + |
| 11 | +import i18n from './i18n'; |
| 12 | + |
| 13 | +interface NodeUptimeProps { |
| 14 | + StartTime?: string; |
| 15 | + DisconnectTime?: string; |
| 16 | +} |
| 17 | + |
| 18 | +export function NodeUptime({StartTime, DisconnectTime}: NodeUptimeProps) { |
| 19 | + let uptime: string | undefined; |
| 20 | + |
| 21 | + if (DisconnectTime) { |
| 22 | + uptime = getDowntimeFromDateFormatted(DisconnectTime); |
| 23 | + } else if (StartTime) { |
| 24 | + uptime = getUptimeFromDateFormatted(StartTime); |
| 25 | + } |
| 26 | + |
| 27 | + if (!uptime) { |
| 28 | + return EMPTY_DATA_PLACEHOLDER; |
| 29 | + } |
| 30 | + return ( |
| 31 | + <CellWithPopover |
| 32 | + placement={['top', 'auto']} |
| 33 | + content={ |
| 34 | + <DefinitionList responsive> |
| 35 | + {StartTime ? ( |
| 36 | + <DefinitionList.Item key={'StartTime'} name={i18n('start-time')}> |
| 37 | + {formatDateTime(StartTime, {withTimeZone: true})} |
| 38 | + </DefinitionList.Item> |
| 39 | + ) : null} |
| 40 | + {DisconnectTime ? ( |
| 41 | + <DefinitionList.Item key={'DisconnectTime'} name={i18n('disconnect-time')}> |
| 42 | + {formatDateTime(DisconnectTime, {withTimeZone: true})} |
| 43 | + </DefinitionList.Item> |
| 44 | + ) : null} |
| 45 | + </DefinitionList> |
| 46 | + } |
| 47 | + > |
| 48 | + {uptime} |
| 49 | + </CellWithPopover> |
| 50 | + ); |
| 51 | +} |
| 52 | + |
| 53 | +interface TabletUptimeProps { |
| 54 | + ChangeTime?: string; |
| 55 | +} |
| 56 | + |
| 57 | +export function TabletUptime({ChangeTime}: TabletUptimeProps) { |
| 58 | + let uptime: string | undefined; |
| 59 | + |
| 60 | + if (ChangeTime) { |
| 61 | + uptime = getUptimeFromDateFormatted(ChangeTime); |
| 62 | + } |
| 63 | + |
| 64 | + if (!uptime) { |
| 65 | + return EMPTY_DATA_PLACEHOLDER; |
| 66 | + } |
| 67 | + return ( |
| 68 | + <CellWithPopover |
| 69 | + placement={['top', 'auto']} |
| 70 | + content={ |
| 71 | + <DefinitionList responsive> |
| 72 | + <DefinitionList.Item key={'changeTime'} name={i18n('change-time')}> |
| 73 | + {formatDateTime(ChangeTime, {withTimeZone: true})} |
| 74 | + </DefinitionList.Item> |
| 75 | + </DefinitionList> |
| 76 | + } |
| 77 | + > |
| 78 | + {uptime} |
| 79 | + </CellWithPopover> |
| 80 | + ); |
| 81 | +} |
0 commit comments