|
1 | 1 | import React, { memo, forwardRef } from "react" |
2 | 2 | import styled from "styled-components" |
3 | | -import { Flex } from "@netdata/netdata-ui" |
| 3 | +import { Flex, Text } from "@netdata/netdata-ui" |
4 | 4 | import { useContainer } from "domains/charts/charts" |
5 | 5 | import { withMenuGroupIds } from "./context" |
6 | 6 | import { MenuGroupContainer } from "./menuGroup" |
@@ -40,15 +40,53 @@ export const MenuSidebar = props => { |
40 | 40 | return props.isFixedPosition ? <StyledMenuSidebar top={top} {...props} /> : <Flex {...props} /> |
41 | 41 | } |
42 | 42 |
|
| 43 | +const StyledText = styled(Text)` |
| 44 | + line-height: 25px; |
| 45 | +` |
| 46 | + |
| 47 | +const NodeInfo = memo(({ showCounters, chartsCount, metricsCount, alarmsCount, nodeName }) => { |
| 48 | + const shouldShowCounters = showCounters && chartsCount && metricsCount && alarmsCount |
| 49 | + |
| 50 | + if (!shouldShowCounters) return null |
| 51 | + return ( |
| 52 | + <StyledText margin={[5]} color="textLite"> |
| 53 | + Every second, Netdata collects |
| 54 | + <Text strong color="textLite" margin={[0, 1]}> |
| 55 | + {metricsCount} |
| 56 | + </Text> |
| 57 | + metrics on {nodeName}, presents them in |
| 58 | + <Text strong color="textLite" margin={[0, 1]}> |
| 59 | + {chartsCount} |
| 60 | + </Text> |
| 61 | + charts, and monitors them with |
| 62 | + <Text strong color="textLite" margin={[0, 1]}> |
| 63 | + {alarmsCount} |
| 64 | + </Text> |
| 65 | + alarms. |
| 66 | + </StyledText> |
| 67 | + ) |
| 68 | +}) |
| 69 | + |
43 | 70 | export const MenuSidebarContainer = ({ |
44 | 71 | onMenuGroupClick, |
45 | 72 | onSubMenuClick, |
46 | 73 | isFixedPosition = true, |
47 | 74 | ...rest |
48 | | -}) => ( |
49 | | - <MenuSidebar isFixedPosition={isFixedPosition} {...rest}> |
50 | | - <MenuContainer onMenuGroupClick={onMenuGroupClick} onSubMenuClick={onSubMenuClick} /> |
51 | | - </MenuSidebar> |
52 | | -) |
| 75 | +}) => { |
| 76 | + const { showCounters, chartsCount, metricsCount, alarmsCount, nodeName } = rest |
| 77 | + |
| 78 | + return ( |
| 79 | + <MenuSidebar isFixedPosition={isFixedPosition} {...rest}> |
| 80 | + <MenuContainer onMenuGroupClick={onMenuGroupClick} onSubMenuClick={onSubMenuClick} /> |
| 81 | + <NodeInfo |
| 82 | + nodeName={nodeName} |
| 83 | + chartsCount={chartsCount} |
| 84 | + metricsCount={metricsCount} |
| 85 | + alarmsCount={alarmsCount} |
| 86 | + showCounters={showCounters} |
| 87 | + /> |
| 88 | + </MenuSidebar> |
| 89 | + ) |
| 90 | +} |
53 | 91 |
|
54 | 92 | export const SidebarContainer = memo(MenuSidebarContainer) |
0 commit comments