2016-09-15 18:56:08 +02:00
|
|
|
import React from 'react';
|
|
|
|
import pluralize from 'pluralize';
|
|
|
|
import { IndexLink } from 'react-router';
|
2016-09-16 15:01:19 +02:00
|
|
|
import { Menu, MenuItem, Button, IconButton } from 'react-toolbox';
|
2016-09-15 18:56:08 +02:00
|
|
|
import AppBar from 'react-toolbox/lib/app_bar';
|
2016-09-16 12:54:26 +02:00
|
|
|
import FindBar from '../FindBar/FindBar';
|
2016-09-15 18:56:08 +02:00
|
|
|
import styles from './AppHeader.css';
|
|
|
|
|
|
|
|
export default class AppHeader extends React.Component {
|
|
|
|
|
|
|
|
state = {
|
|
|
|
createMenuActive: false
|
2016-10-03 16:37:11 +02:00
|
|
|
};
|
2016-09-15 18:56:08 +02:00
|
|
|
|
|
|
|
handleCreatePostClick = collectionName => {
|
|
|
|
const { onCreateEntryClick } = this.props;
|
|
|
|
if (onCreateEntryClick) {
|
|
|
|
onCreateEntryClick(collectionName);
|
|
|
|
}
|
2016-10-03 16:37:11 +02:00
|
|
|
};
|
2016-09-15 18:56:08 +02:00
|
|
|
|
2016-09-16 15:01:19 +02:00
|
|
|
handleCreateButtonClick = () => {
|
2016-09-15 18:56:08 +02:00
|
|
|
this.setState({
|
|
|
|
createMenuActive: true
|
|
|
|
});
|
2016-10-03 16:37:11 +02:00
|
|
|
};
|
2016-09-15 18:56:08 +02:00
|
|
|
|
2016-09-16 15:01:19 +02:00
|
|
|
handleCreateMenuHide = () => {
|
2016-09-15 18:56:08 +02:00
|
|
|
this.setState({
|
|
|
|
createMenuActive: false
|
|
|
|
});
|
2016-10-03 16:37:11 +02:00
|
|
|
};
|
2016-09-15 18:56:08 +02:00
|
|
|
|
|
|
|
render() {
|
2016-09-16 15:01:19 +02:00
|
|
|
const {
|
|
|
|
collections,
|
|
|
|
commands,
|
|
|
|
defaultCommands,
|
|
|
|
runCommand,
|
|
|
|
toggleNavDrawer
|
|
|
|
} = this.props;
|
2016-09-15 18:56:08 +02:00
|
|
|
const { createMenuActive } = this.state;
|
|
|
|
|
|
|
|
return (
|
|
|
|
<AppBar
|
2016-10-03 16:57:48 +02:00
|
|
|
fixed
|
|
|
|
theme={styles}
|
2016-09-15 18:56:08 +02:00
|
|
|
>
|
2016-09-16 15:01:19 +02:00
|
|
|
<IconButton
|
2016-10-03 16:57:48 +02:00
|
|
|
icon="menu"
|
|
|
|
inverse
|
|
|
|
onClick={toggleNavDrawer}
|
2016-09-16 15:01:19 +02:00
|
|
|
/>
|
2016-09-15 18:56:08 +02:00
|
|
|
<IndexLink to="/">
|
|
|
|
Dashboard
|
|
|
|
</IndexLink>
|
|
|
|
<FindBar
|
2016-10-03 16:57:48 +02:00
|
|
|
commands={commands}
|
|
|
|
defaultCommands={defaultCommands}
|
|
|
|
runCommand={runCommand}
|
2016-09-15 18:56:08 +02:00
|
|
|
/>
|
|
|
|
<Button
|
2016-10-03 16:57:48 +02:00
|
|
|
className={styles.createBtn}
|
|
|
|
icon='add'
|
|
|
|
floating
|
|
|
|
accent
|
|
|
|
onClick={this.handleCreateButtonClick}
|
2016-09-15 18:56:08 +02:00
|
|
|
>
|
|
|
|
<Menu
|
2016-10-03 16:57:48 +02:00
|
|
|
active={createMenuActive}
|
|
|
|
position="topRight"
|
|
|
|
onHide={this.handleCreateMenuHide}
|
2016-09-15 18:56:08 +02:00
|
|
|
>
|
|
|
|
{
|
2016-09-16 14:28:25 +02:00
|
|
|
collections.valueSeq().map(collection =>
|
2016-09-15 18:56:08 +02:00
|
|
|
<MenuItem
|
2016-10-03 16:57:48 +02:00
|
|
|
key={collection.get('name')}
|
|
|
|
value={collection.get('name')}
|
|
|
|
onClick={this.handleCreatePostClick.bind(this, collection.get('name'))}
|
|
|
|
caption={pluralize(collection.get('label'), 1)}
|
2016-09-15 18:56:08 +02:00
|
|
|
/>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
</Menu>
|
|
|
|
</Button>
|
2016-09-16 15:01:19 +02:00
|
|
|
|
2016-09-15 18:56:08 +02:00
|
|
|
</AppBar>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|