summaryrefslogtreecommitdiff
path: root/opendc-web/opendc-web-ui/src/components/app/sidebars/topology/TopologySidebarComponent.js
blob: 450df6cd475446ebe8784ea51028a29feb9c839f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
import React from 'react'
import BuildingSidebarContainer from '../../../../containers/app/sidebars/topology/building/BuildingSidebarContainer'
import MachineSidebarContainer from '../../../../containers/app/sidebars/topology/machine/MachineSidebarContainer'
import RackSidebarContainer from '../../../../containers/app/sidebars/topology/rack/RackSidebarContainer'
import RoomSidebarContainer from '../../../../containers/app/sidebars/topology/room/RoomSidebarContainer'
import Sidebar from '../Sidebar'
import { InteractionLevel } from '../../../../shapes'

const TopologySidebarComponent = ({ interactionLevel }) => {
    let sidebarContent

    switch (interactionLevel.mode) {
        case 'BUILDING':
            sidebarContent = <BuildingSidebarContainer />
            break
        case 'ROOM':
            sidebarContent = <RoomSidebarContainer />
            break
        case 'RACK':
            sidebarContent = <RackSidebarContainer />
            break
        case 'MACHINE':
            sidebarContent = <MachineSidebarContainer />
            break
        default:
            sidebarContent = 'Missing Content'
    }

    return <Sidebar isRight={true}>{sidebarContent}</Sidebar>
}

TopologySidebarComponent.propTypes = {
    interactionLevel: InteractionLevel,
}

export default TopologySidebarComponent