redoc/src/components/SideMenu/MenuItems.tsx
2018-01-23 15:04:50 +02:00

30 lines
779 B
TypeScript

import { observer } from 'mobx-react';
import * as React from 'react';
import { IMenuItem } from '../../services';
import { MenuItem } from './MenuItem';
import { MenuItemUl } from './styled.elements';
interface MenuItemsProps {
items: IMenuItem[];
active?: boolean;
onActivate?: (item: IMenuItem) => void;
style?: React.CSSProperties;
}
@observer
export class MenuItems extends React.Component<MenuItemsProps> {
render() {
const { items } = this.props;
const active = this.props.active == null ? true : this.props.active;
return (
<MenuItemUl style={this.props.style} active={active}>
{items.map((item, idx) => (
<MenuItem key={idx} item={item} onActivate={this.props.onActivate} />
))}
</MenuItemUl>
);
}
}