
'use strict';

var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };

function _getProjectUrl() {
    var rest = arguments.length <= 0 || arguments[0] === undefined ? true : arguments[0];

    var nbhd, proj, nbhd_proj;
    var ident_classes = document.getElementById('page-body').className.split(' ');
    var _iteratorNormalCompletion = true;
    var _didIteratorError = false;
    var _iteratorError = undefined;

    try {
        for (var _iterator = ident_classes[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
            var cls = _step.value;

            if (cls.indexOf('project-') === 0) {
                proj = cls.slice('project-'.length);
            }
        }
    } catch (err) {
        _didIteratorError = true;
        _iteratorError = err;
    } finally {
        try {
            if (!_iteratorNormalCompletion && _iterator['return']) {
                _iterator['return']();
            }
        } finally {
            if (_didIteratorError) {
                throw _iteratorError;
            }
        }
    }

    nbhd = window.location.pathname.split('/')[1];
    if (proj === '--init--') {
        nbhd_proj = nbhd;
    } else {
        nbhd_proj = nbhd + '/' + proj;
    }
    return (rest ? '/rest/' : '/') + nbhd_proj;
}

function getMountPoint(node) {
    if (node.hasOwnProperty('mount_point') && node['mount_point'] !== null) {
        return node['mount_point'];
    }
    return node.props.children[0].props.mount_point;
}

function getUrlByNode(node) {
    if (node.hasOwnProperty('url') && node['url'] !== null) {
        return node['url'];
    }
    return node.props.children[0].props.url;
}

var ToolsPropType = React.PropTypes.shape({
    mount_point: React.PropTypes.string,
    name: React.PropTypes.string.isRequired,
    url: React.PropTypes.string.isRequired,
    is_anchored: React.PropTypes.bool.isRequired,
    tool_name: React.PropTypes.string.isRequired,
    icon: React.PropTypes.string,
    children: React.PropTypes.array,
    admin_options: React.PropTypes.array
});

var NavBarItem = React.createClass({
    displayName: 'NavBarItem',

    propTypes: {
        name: React.PropTypes.string.isRequired,
        url: React.PropTypes.string.isRequired,
        currentOptionMenu: React.PropTypes.object,
        onOptionClick: React.PropTypes.func.isRequired,
        options: React.PropTypes.array
    },

    isAnchored: function isAnchored() {
        return this.props.is_anchored !== null;
    },

    render: function render() {
        var divClasses = "tb-item tb-item-edit";
        if (this.props.is_anchored) {
            divClasses += " anchored";
        }
        var spanClasses = this.props.handleType + " ordinal-item";
        if (this.props.isGrouper) {
            spanClasses += " toolbar-grouper";
        }

        return React.createElement(
            'div',
            { className: divClasses },
            React.createElement(
                'a',
                null,
                !_.isEmpty(this.props.options) && React.createElement('i', { className: 'config-tool fa fa-cog', onClick: this.handleOptionClick }),
                React.createElement(
                    'span',
                    {
                        className: spanClasses,
                        'data-mount-point': this.props.mount_point },
                    this.props.name
                )
            ),
            this.props.currentOptionMenu.tool && this.props.currentOptionMenu.tool === this.props.mount_point && React.createElement(ContextMenu, _extends({}, this.props, {
                classes: ['tool-options'],
                items: this.props.options,
                onOptionClick: this.props.onOptionClick
            }))
        );
    },

    handleOptionClick: function handleOptionClick(event) {
        this.props.onOptionClick(this.props.mount_point);
    }
});

var GroupingThreshold = React.createClass({
    displayName: 'GroupingThreshold',

    propTypes: {
        initialValue: React.PropTypes.number.isRequired
    },
    getInitialState: function getInitialState() {
        return {
            value: this.props.initialValue
        };
    },

    handleChange: function handleChange(event) {
        this.setState({
            value: event.target.value
        });
        this.props.onUpdateThreshold(event);
    },

    render: function render() {
        return React.createElement(
            'div',
            null,
            !!this.props.isHidden && React.createElement(
                'div',
                { id: 'threshold-config' },
                React.createElement(
                    'span',
                    null,
                    React.createElement(
                        'label',
                        { htmlFor: 'threshold-input' },
                        'Grouping Threshold'
                    ),
                    React.createElement('input', { type: 'number', name: 'threshold-input', className: 'tooltip',
                        title: 'Number of tools allowed before grouping.',
                        value: this.state.value,
                        onChange: this.handleChange,
                        min: '1', max: '10' })
                )
            )
        );
    }
});

var NormalNavItem = React.createClass({
    displayName: 'NormalNavItem',

    mixins: [React.addons.PureRenderMixin],

    render: function render() {

        return React.createElement(
            'li',
            { key: 'tb-norm-' + _.uniqueId() },
            React.createElement(
                'a',
                { href: this.props.url, className: this.props.classes },
                this.props.name
            ),
            this.props.children
        );
    }
});

var ToggleAddNewTool = React.createClass({
    displayName: 'ToggleAddNewTool',

    getInitialState: function getInitialState() {
        return {
            visible: false
        };
    },
    handleToggle: function handleToggle() {
        this.setState({
            visible: !this.state.visible
        });
    },
    handleOptionClick: function handleOptionClick(event) {
        console.log('event', event);
    },

    render: function render() {
        return React.createElement(
            'div',
            null,
            React.createElement(
                'a',
                { onClick: this.handleToggle, className: 'add-tool-toggle' },
                'Add New...'
            ),
            this.state.visible && React.createElement(ContextMenu, _extends({}, this.props, {
                classes: ['admin_modal'],
                onOptionClick: this.handleOptionClick,
                items: this.props.installableTools }))
        );
    }
});

var NormalNavBar = React.createClass({
    displayName: 'NormalNavBar',

    buildMenu: function buildMenu(item, i) {
        var classes = window.location.pathname.startsWith(item.url) ? 'active-nav-link' : '';

        var subMenu;
        if (item.children) {
            subMenu = item.children.map(this.buildMenu);
        }
        return React.createElement(
            NormalNavItem,
            { url: item.url, name: item.name, classes: classes, key: 'normal-nav-' + _.uniqueId() },
            React.createElement(
                'ul',
                null,
                subMenu
            )
        );
    },

    onOptionClick: function onOptionClick(e) {
        console.log(e);
    },
    render: function render() {
        var listItems = this.props.items.map(this.buildMenu);

        var mount_points = [];
        var _iteratorNormalCompletion2 = true;
        var _didIteratorError2 = false;
        var _iteratorError2 = undefined;

        try {
            for (var _iterator2 = this.props.items[Symbol.iterator](), _step2; !(_iteratorNormalCompletion2 = (_step2 = _iterator2.next()).done); _iteratorNormalCompletion2 = true) {
                var item = _step2.value;

                if (item.hasOwnProperty('mount_point') && item.mount_point !== null) {
                    mount_points.push(item.mount_point);
                } else if (item.hasOwnProperty('children')) {
                    var _iteratorNormalCompletion3 = true;
                    var _didIteratorError3 = false;
                    var _iteratorError3 = undefined;

                    try {
                        for (var _iterator3 = item.children[Symbol.iterator](), _step3; !(_iteratorNormalCompletion3 = (_step3 = _iterator3.next()).done); _iteratorNormalCompletion3 = true) {
                            var child = _step3.value;

                            mount_points.push(child.mount_point);
                        }
                    } catch (err) {
                        _didIteratorError3 = true;
                        _iteratorError3 = err;
                    } finally {
                        try {
                            if (!_iteratorNormalCompletion3 && _iterator3['return']) {
                                _iterator3['return']();
                            }
                        } finally {
                            if (_didIteratorError3) {
                                throw _iteratorError3;
                            }
                        }
                    }
                }
            }
        } catch (err) {
            _didIteratorError2 = true;
            _iteratorError2 = err;
        } finally {
            try {
                if (!_iteratorNormalCompletion2 && _iterator2['return']) {
                    _iterator2['return']();
                }
            } finally {
                if (_didIteratorError2) {
                    throw _iteratorError2;
                }
            }
        }

        console.log("mount_points", mount_points);
        return React.createElement(
            'ul',
            {
                id: 'normal-nav-bar',
                className: 'dropdown' },
            listItems,
            React.createElement(
                'li',
                { id: 'add-tool-container' },
                React.createElement(ToggleAddNewTool, _extends({}, this.props, {
                    items: this.props.installableTools,
                    onOptionClick: this.onOptionClick }))
            )
        );
    }
});

var AdminNav = React.createClass({
    displayName: 'AdminNav',

    propTypes: {
        tools: React.PropTypes.arrayOf(ToolsPropType),
        currentOptionMenu: React.PropTypes.object,
        onOptionClick: React.PropTypes.func.isRequired
    },

    buildMenu: function buildMenu(items) {
        var isSubMenu = arguments.length <= 1 || arguments[1] === undefined ? false : arguments[1];

        var _this = this;
        var tools = [];
        var anchored_tools = [];
        var end_tools = [];

        var subMenu, childOptionsOpen;

        var _iteratorNormalCompletion4 = true;
        var _didIteratorError4 = false;
        var _iteratorError4 = undefined;

        try {
            for (var _iterator4 = items[Symbol.iterator](), _step4; !(_iteratorNormalCompletion4 = (_step4 = _iterator4.next()).done); _iteratorNormalCompletion4 = true) {
                var item = _step4.value;

                if (item.children) {
                    subMenu = this.buildMenu(item.children, true);
                } else {
                    subMenu = null;
                }

                var _handle = isSubMenu ? "draggable-handle-sub" : 'draggable-handle';

                var tool_list, is_anchored;
                if (item.mount_point === 'admin') {
                    tool_list = end_tools;
                    is_anchored = true;
                } else if (item.is_anchored) {
                    tool_list = anchored_tools;
                    is_anchored = true;
                } else {
                    tool_list = tools;
                    is_anchored = false;
                }
                var core_item = React.createElement(NavBarItem, _extends({}, _this.props, {
                    mount_point: item.mount_point,
                    name: item.name,
                    handleType: _handle,
                    isGrouper: item.children && item.children.length > 0,
                    url: item.url,
                    key: 'tb-item-' + _.uniqueId(),
                    is_anchored: is_anchored,
                    options: item.admin_options
                }));
                if (subMenu) {
                    childOptionsOpen = _.contains(_.pluck(item.children, 'mount_point'), this.props.currentOptionMenu.tool);
                    tool_list.push(React.createElement(NavBarItemWithSubMenu, { key: _.uniqueId(), tool: core_item, subMenu: subMenu, childOptionsOpen: childOptionsOpen }));
                } else {
                    tool_list.push(core_item);
                }
            }
        } catch (err) {
            _didIteratorError4 = true;
            _iteratorError4 = err;
        } finally {
            try {
                if (!_iteratorNormalCompletion4 && _iterator4['return']) {
                    _iterator4['return']();
                }
            } finally {
                if (_didIteratorError4) {
                    throw _iteratorError4;
                }
            }
        }

        return React.createElement(
            'div',
            { className: 'react-drag' },
            anchored_tools,
            React.createElement(
                ReactReorderable,
                {
                    key: 'reorder-' + _.uniqueId(),
                    handle: "." + _handle,
                    mode: isSubMenu ? 'list' : 'grid',
                    onDragStart: _this.props.onToolDragStart,
                    onDrop: _this.props.onToolReorder },
                tools
            ),
            end_tools
        );
    },

    render: function render() {
        var tools = this.buildMenu(this.props.tools);
        return React.createElement(
            'div',
            null,
            tools
        );
    }
});

var NavBarItemWithSubMenu = React.createClass({
    displayName: 'NavBarItemWithSubMenu',

    render: function render() {
        return React.createElement(
            'div',
            { className: "tb-item-container" + (this.props.childOptionsOpen ? " child-options-open" : "") },
            this.props.tool,
            this.props.subMenu && React.createElement(
                AdminItemGroup,
                { key: _.uniqueId() },
                this.props.subMenu
            )
        );
    }
});

var AdminItemGroup = React.createClass({
    displayName: 'AdminItemGroup',

    render: function render() {
        return React.createElement(
            'div',
            { className: 'tb-item-grouper' },
            this.props.children
        );
    }
});

var ToggleAdminButton = React.createClass({
    displayName: 'ToggleAdminButton',

    propTypes: {
        visible: React.PropTypes.bool
    },
    render: function render() {
        var classes = this.props.visible ? 'fa fa-unlock' : 'fa fa-lock';
        return React.createElement(
            'button',
            { id: 'toggle-admin-btn', onClick: this.props.handleButtonPush, className: 'admin-toolbar-right' },
            React.createElement('i', { className: classes })
        );
    }
});

var Main = React.createClass({
    displayName: 'Main',

    propTypes: {
        initialData: React.PropTypes.shape({
            menu: React.PropTypes.arrayOf(ToolsPropType),
            installableTools: React.PropTypes.array,
            grouping_threshold: React.PropTypes.number.isRequired
        }),
        installableTools: React.PropTypes.array
    },
    getInitialState: function getInitialState() {
        return {
            data: this.props.initialData,
            visible: true,
            _session_id: $.cookie('_session_id'),
            currentOptionMenu: {
                tool: null
            }
        };
    },

    getNavJson: function getNavJson() {
        $.get(_getProjectUrl(false) + '/_nav.json?admin_options=1', (function (result) {
            if (this.isMounted()) {
                this.setState({
                    data: result
                });
            }
        }).bind(this));
    },

    handleToggleAdmin: function handleToggleAdmin() {
        this.setState({
            visible: !this.state.visible
        });
    },

    handleShowOptionMenu: function handleShowOptionMenu(mount_point) {
        this.setState({
            currentOptionMenu: {
                tool: mount_point
            }
        });
    },

    onUpdateThreshold: function onUpdateThreshold(event) {
        var _this = this;
        var thres = event.target.value;
        var url = _getProjectUrl() + '/admin/configure_tool_grouping';
        var csrf = $.cookie('_session_id');
        var data = {
            _session_id: csrf,
            grouping_threshold: thres
        };
        var _data = this.state.data;
        _data.grouping_threshold = thres;
        this.setState({
            data: _data
        });
        this.setState({
            in_progress: true
        });
        $.post(url, data, (function () {}).bind(this)).always(function () {
            _this.setState({
                in_progress: false
            });
        });

        _this.getNavJson();
        return false;
    },

    onToolReorder: function onToolReorder() {
        $('.react-drag.dragging').removeClass('dragging');

        var params = { _session_id: $.cookie('_session_id') };
        var toolNodes = $(ReactDOM.findDOMNode(this)).find('span.ordinal-item').not(".toolbar-grouper");
        for (var i = 0; i < toolNodes.length; i++) {
            params[i] = toolNodes[i].dataset.mountPoint;
        }

        var _this = this;
        var url = _getProjectUrl() + '/admin/mount_order';
        $.ajax({
            type: 'POST',
            url: url,
            data: params,
            success: function success() {
                $('#messages').notify('Tool order updated', {
                    status: 'confirm',
                    interval: 500,
                    timer: 2000
                });
                _this.getNavJson();
            },

            error: function error() {
                $('#messages').notify('Error saving tool order.', {
                    status: 'error'
                });
            }
        });
    },

    onToolDragStart: function onToolDragStart(obj) {
        var dragging_mount_point = obj.props.children.props.mount_point;
        $('[data-mount-point=' + dragging_mount_point + ']').closest('.react-drag').addClass('dragging');
    },

    render: function render() {
        var _this2 = this;

        var _this = this;
        var navBarSwitch = function navBarSwitch(showAdmin) {
            if (showAdmin) {
                return React.createElement(AdminNav, {
                    tools: _this.state.data.menu,
                    installableTools: _this.state.data.installable_tools,
                    data: _this.state.data,
                    onToolReorder: _this.onToolReorder,
                    onToolDragStart: _this.onToolDragStart,
                    editMode: _this.state.visible,
                    currentOptionMenu: _this.state.currentOptionMenu,
                    onOptionClick: _this.handleShowOptionMenu,
                    currentToolOptions: _this2.state.currentToolOptions
                });
            } else {
                return React.createElement(
                    'div',
                    null,
                    React.createElement(NormalNavBar, {
                        items: _this.state.data.menu,
                        installableTools: _this.state.data.installable_tools
                    })
                );
            }
        };
        var navBar = navBarSwitch(this.state.visible);

        var max_tool_count = _.chain(this.state.data.menu).map(function (item) {
            return item.children ? _.pluck(item.children, 'tool_name') : item.tool_name;
        }).flatten().countBy().values().max().value();
        var show_grouping_threshold = max_tool_count > 1;

        return React.createElement(
            'div',
            {
                className: 'nav_admin ' },
            navBar,
            React.createElement(
                'div',
                { id: 'bar-config' },
                show_grouping_threshold && React.createElement(GroupingThreshold, {
                    onUpdateThreshold: this.onUpdateThreshold,
                    isHidden: this.state.visible,
                    initialValue: parseInt(this.state.data.grouping_threshold) })
            ),
            React.createElement(ToggleAdminButton, {
                handleButtonPush: this.handleToggleAdmin,
                visible: this.state.visible })
        );
    }
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["navbar.es6.js"],"names":[],"mappings":"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","file":"navbar.es6.js","sourcesContent":["/*\n       Licensed to the Apache Software Foundation (ASF) under one\n       or more contributor license agreements.  See the NOTICE file\n       distributed with this work for additional information\n       regarding copyright ownership.  The ASF licenses this file\n       to you under the Apache License, Version 2.0 (the\n       \"License\"); you may not use this file except in compliance\n       with the License.  You may obtain a copy of the License at\n\n         http://www.apache.org/licenses/LICENSE-2.0\n\n       Unless required by applicable law or agreed to in writing,\n       software distributed under the License is distributed on an\n       \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n       KIND, either express or implied.  See the License for the\n       specific language governing permissions and limitations\n       under the License.\n*/\n'use strict';\n\n/**\n * Gets the current project url.\n\n * @constructor\n * @param {bool} rest - Return a \"rest\" version of the url.\n * @returns {string}\n */\nfunction _getProjectUrl(rest = true) {\n    var nbhd, proj, nbhd_proj;\n    var ident_classes = document.getElementById('page-body').className.split(' ');\n    for (var cls of ident_classes) {\n        if (cls.indexOf('project-') === 0) {\n            proj = cls.slice('project-'.length);\n        }\n    }\n    nbhd = window.location.pathname.split('/')[1];\n    if (proj === '--init--') {\n        nbhd_proj = nbhd;\n    } else {\n        nbhd_proj = `${nbhd}/${proj}`;\n    }\n    return (rest ? '/rest/' : '/') + nbhd_proj;\n}\n\n/**\n * Get a mount point from a NavBarItem node.\n\n * @constructor\n * @param {NavBarItem} node\n * @returns {string}\n */\nfunction getMountPoint(node) {\n    if(node.hasOwnProperty('mount_point') && node['mount_point'] !== null){\n        return node['mount_point'];\n    }\n    return node.props.children[0].props.mount_point;\n}\n\n/**\n * Get a url from a NavBarItem node.\n\n * @constructor\n * @param {NavBarItem} node\n * @returns {string}\n */\nfunction getUrlByNode(node) {\n    if(node.hasOwnProperty('url') && node['url'] !== null){\n        return node['url'];\n    }\n    return node.props.children[0].props.url;\n}\n\nconst ToolsPropType = React.PropTypes.shape({\n    mount_point: React.PropTypes.string,\n    name: React.PropTypes.string.isRequired,\n    url: React.PropTypes.string.isRequired,\n    is_anchored: React.PropTypes.bool.isRequired,\n    tool_name: React.PropTypes.string.isRequired,\n    icon: React.PropTypes.string,\n    children: React.PropTypes.array,\n    admin_options: React.PropTypes.array\n});\n\n/**\n * A single NavBar item.\n\n * @constructor\n */\nvar NavBarItem = React.createClass({\n    propTypes: {\n        name: React.PropTypes.string.isRequired,\n        url: React.PropTypes.string.isRequired,\n        currentOptionMenu: React.PropTypes.object,\n        onOptionClick: React.PropTypes.func.isRequired,\n        options: React.PropTypes.array\n    },\n\n    isAnchored: function() {\n        return this.props.is_anchored !== null;\n    },\n\n    render: function() {\n        var divClasses = \"tb-item tb-item-edit\";\n        if (this.props.is_anchored) {\n            divClasses += \" anchored\";\n        }\n        var spanClasses = this.props.handleType + \" ordinal-item\";\n        if (this.props.isGrouper) {\n            spanClasses += \" toolbar-grouper\"\n        }\n\n        return (\n            <div className={ divClasses }>\n                <a>\n                    {!_.isEmpty(this.props.options) && <i className='config-tool fa fa-cog' onClick={this.handleOptionClick}></i>}\n                    <span\n                        className={spanClasses}\n                        data-mount-point={this.props.mount_point}>\n                        {this.props.name}\n                    </span>\n                </a>\n                {this.props.currentOptionMenu.tool && this.props.currentOptionMenu.tool === this.props.mount_point &&\n                    <ContextMenu\n                        {...this.props}\n                        classes={['tool-options']}\n                        items={this.props.options}\n                        onOptionClick={this.props.onOptionClick}\n                    />}\n            </div>\n        );\n    },\n\n    handleOptionClick: function(event) {\n        this.props.onOptionClick(this.props.mount_point);\n    }\n});\n\n/**\n * An input component that updates the NavBar's grouping threshold.\n\n * @constructor\n */\nvar GroupingThreshold = React.createClass({\n    propTypes: {\n        initialValue: React.PropTypes.number.isRequired\n    },\n    getInitialState: function() {\n        return {\n            value: this.props.initialValue\n        };\n    },\n\n    handleChange: function(event) {\n        this.setState({\n            value: event.target.value\n        });\n        this.props.onUpdateThreshold(event);\n    },\n\n    render: function() {\n        return (\n            <div>\n                { !!this.props.isHidden &&\n                <div id='threshold-config'>\n            <span>\n              <label htmlFor='threshold-input'>Grouping Threshold</label>\n                <input type='number' name='threshold-input' className='tooltip'\n                       title='Number of tools allowed before grouping.'\n                       value={ this.state.value }\n                       onChange={ this.handleChange }\n                       min='1' max='10'/>\n              </span>\n                </div> }\n            </div>\n        );\n    }\n});\n\n/**\n * The NavBar when in \"Normal\" mode.\n\n * @constructor\n */\nvar NormalNavItem = React.createClass({\n  mixins: [React.addons.PureRenderMixin],\n\n    render: function() {\n\n        return (\n            <li key={`tb-norm-${_.uniqueId()}`}>\n                <a href={ this.props.url } className={ this.props.classes }>\n                    { this.props.name }\n                </a>\n                {this.props.children}\n            </li>\n        );\n    }\n});\n\n/**\n * Toggle Button\n\n * @constructor\n */\nvar ToggleAddNewTool = React.createClass({\n    getInitialState: function() {\n        return {\n            visible: false\n        };\n    },\n    handleToggle: function() {\n        this.setState({\n            visible: !this.state.visible\n        });\n    },\n        handleOptionClick: function(event) {\n            console.log('event', event);\n        //this.props.onOptionClick(this.props.mount_point);\n    },\n\n    render: function () {\n        return (\n            <div>\n                <a onClick={ this.handleToggle } className=\"add-tool-toggle\">\n                    Add New...\n                </a>\n                {this.state.visible &&\n                <ContextMenu\n                    {...this.props}\n                    classes={['admin_modal']}\n                    onOptionClick={this.handleOptionClick}\n                    items={this.props.installableTools} />\n                }\n            </div>\n        )\n    }\n});\n\n/**\n * The NavBar when in \"Normal\" mode.\n\n * @constructor\n */\nvar NormalNavBar = React.createClass({\n    buildMenu: function(item, i) {\n        let classes = window.location.pathname.startsWith(item.url) ? 'active-nav-link' : '';\n\n        var subMenu;\n        if (item.children) {\n            subMenu = item.children.map(this.buildMenu);\n        }\n        return (\n            <NormalNavItem url={item.url} name={item.name} classes={classes} key={`normal-nav-${_.uniqueId()}`}>\n                <ul>\n                    {subMenu}\n                </ul>\n            </NormalNavItem>\n        );\n    },\n\n    onOptionClick: function(e){\n        console.log(e);\n    },\n    render: function() {\n        var listItems = this.props.items.map(this.buildMenu);\n\n        var mount_points = [];\n        for(let item of this.props.items){\n            if(item.hasOwnProperty('mount_point') && item.mount_point !== null){\n                mount_points.push(item.mount_point);\n            } else if(item.hasOwnProperty('children')){\n                for(let child of item.children){\n                    mount_points.push(child.mount_point)\n                }\n            }\n        }\n        console.log(\"mount_points\", mount_points);\n        return (\n            <ul\n                id=\"normal-nav-bar\"\n                className=\"dropdown\">\n                { listItems }\n                <li id=\"add-tool-container\">\n                    <ToggleAddNewTool\n                        {...this.props}\n                        items={this.props.installableTools}\n                        onOptionClick={this.onOptionClick} />\n                </li>\n            </ul>\n        );\n    }\n});\n\n/**\n * The NavBar when in \"Admin\" mode.\n * @constructor\n */\nvar AdminNav = React.createClass({\n    propTypes: {\n        tools: React.PropTypes.arrayOf(ToolsPropType),\n        currentOptionMenu: React.PropTypes.object,\n        onOptionClick: React.PropTypes.func.isRequired\n    },\n\n    buildMenu: function (items, isSubMenu=false) {\n        var _this = this;\n        var [tools, anchored_tools, end_tools] = [[], [], []];\n        var subMenu, childOptionsOpen;\n\n        for (let item of items) {\n            if (item.children) {\n                subMenu = this.buildMenu(item.children, true);\n            } else {\n                subMenu = null;\n            }\n\n            var _handle = isSubMenu ? \"draggable-handle-sub\" : 'draggable-handle';\n\n            var tool_list, is_anchored;\n            if (item.mount_point === 'admin') {\n                // force admin to end, just like 'Project.sitemap()' does\n                tool_list = end_tools;\n                is_anchored = true;\n            } else if (item.is_anchored) {\n                tool_list = anchored_tools;\n                is_anchored = true;\n            } else {\n                tool_list = tools;\n                is_anchored = false;\n            }\n            var core_item = <NavBarItem\n                {..._this.props}\n                mount_point={ item.mount_point }\n                name={ item.name }\n                handleType={_handle}\n                isGrouper={item.children && item.children.length > 0}\n                url={ item.url }\n                key={ 'tb-item-' + _.uniqueId() }\n                is_anchored={ is_anchored }\n                options={ item.admin_options }\n            />;\n            if (subMenu) {\n                childOptionsOpen = _.contains(_.pluck(item.children, 'mount_point'), this.props.currentOptionMenu.tool);\n                tool_list.push(<NavBarItemWithSubMenu key={_.uniqueId()} tool={core_item} subMenu={subMenu} childOptionsOpen={childOptionsOpen}/>);\n            } else {\n                tool_list.push(core_item);\n            }\n        }\n\n        return (\n            <div className='react-drag'>\n                { anchored_tools }\n                <ReactReorderable\n                    key={ 'reorder-' + _.uniqueId() }\n                    handle={\".\" + _handle}\n                    mode={ isSubMenu ? 'list' : 'grid' }\n                    onDragStart={ _this.props.onToolDragStart }\n                    onDrop={ _this.props.onToolReorder }>\n                    { tools }\n                </ReactReorderable>\n                { end_tools }\n            </div>\n        );\n    },\n\n    render: function () {\n        var tools = this.buildMenu(this.props.tools);\n        return <div>{tools}</div>;\n    }\n});\n\nvar NavBarItemWithSubMenu = React.createClass({\n    render: function () {\n        return (\n            <div className={\"tb-item-container\" + (this.props.childOptionsOpen ? \" child-options-open\" : \"\")}>\n                { this.props.tool }\n                {this.props.subMenu &&\n                <AdminItemGroup key={_.uniqueId()}>\n                    {this.props.subMenu}\n                </AdminItemGroup>\n                    }\n            </div>\n        );\n    }\n});\n\n\n/**\n * The NavBar when in \"Admin\" mode.\n * @constructor\n */\nvar AdminItemGroup = React.createClass({\n    render: function () {\n        return (\n            <div className=\"tb-item-grouper\">\n                {this.props.children}\n            </div>\n        );\n    }\n});\n\n/**\n * The button that toggles NavBar modes.\n\n * @constructor\n */\nvar ToggleAdminButton = React.createClass({\n    propTypes: {\n        visible: React.PropTypes.bool\n    },\n    render: function() {\n        var classes = this.props.visible ? 'fa fa-unlock' : 'fa fa-lock';\n        return (\n            <button id='toggle-admin-btn' onClick={ this.props.handleButtonPush } className='admin-toolbar-right'>\n                <i className={ classes }></i>\n            </button>\n        );\n    }\n});\n\n/**\n * The main \"controller view\" of the NavBar.\n\n * @constructor\n * @param {object} initialData\n */\nvar Main = React.createClass({\n    propTypes: {\n        initialData: React.PropTypes.shape({\n            menu: React.PropTypes.arrayOf(ToolsPropType),\n            installableTools: React.PropTypes.array,\n            grouping_threshold: React.PropTypes.number.isRequired\n        }),\n        installableTools: React.PropTypes.array\n    },\n    getInitialState: function() {\n        return {\n            data: this.props.initialData,\n            visible: true,\n            _session_id: $.cookie('_session_id'),\n            currentOptionMenu: {\n                tool: null\n            }\n        };\n    },\n\n    /**\n     * When invoked, this updates the state with the latest data from the server.\n     */\n    getNavJson: function() {\n        $.get(`${_getProjectUrl(false)}/_nav.json?admin_options=1`, function(result) {\n            if (this.isMounted()) {\n                this.setState({\n                    data: result\n                });\n            }\n        }.bind(this));\n    },\n    /**\n     * Handles the locking and unlocking of the NavBar\n     */\n    handleToggleAdmin: function() {\n        this.setState({\n            visible: !this.state.visible\n        });\n    },\n\n    handleShowOptionMenu: function (mount_point) {\n        this.setState({\n            currentOptionMenu: {\n                tool: mount_point,\n            }\n        });\n    },\n\n    /**\n     * Handles the changing of the NavBars grouping threshold.\n\n     * @param {object} event\n     */\n    onUpdateThreshold: function(event) {\n        var _this = this;\n        var thres = event.target.value;\n        var url = `${_getProjectUrl()}/admin/configure_tool_grouping`;\n        var csrf = $.cookie('_session_id');\n        var data = {\n            _session_id: csrf,\n            grouping_threshold: thres\n        };\n        var _data = this.state.data;\n        _data.grouping_threshold = thres;\n        this.setState({\n            data: _data\n        });\n        this.setState({\n            in_progress: true\n        });\n        $.post(url, data, function() {\n        }.bind(this)).always(function() {\n            _this.setState({\n                in_progress: false\n            });\n        });\n\n        _this.getNavJson();\n        return false;\n    },\n\n    /**\n     * Handles the sending and updating tool ordinals.\n\n     * @param {array} data - Array of tools\n     */\n    onToolReorder: function() {\n        $('.react-drag.dragging').removeClass('dragging');\n\n        var params = {_session_id: $.cookie('_session_id')};\n        var toolNodes = $(ReactDOM.findDOMNode(this)).find('span.ordinal-item').not(\".toolbar-grouper\");\n        for (var i = 0; i < toolNodes.length; i++) {\n            params[i] = toolNodes[i].dataset.mountPoint;\n        }\n\n        var _this = this;\n        var url = _getProjectUrl() + '/admin/mount_order';\n        $.ajax({\n            type: 'POST',\n            url: url,\n            data: params,\n            success: function () {\n                $('#messages').notify('Tool order updated',\n                    {\n                        status: 'confirm',\n                        interval: 500,\n                        timer: 2000\n                    });\n                _this.getNavJson();\n            },\n\n            error: function() {\n                $('#messages').notify('Error saving tool order.',\n                    {\n                        status: 'error'\n                    });\n            }\n        });\n    },\n\n    onToolDragStart: function(obj) {\n        // this is done with jQuery instead of rendering different HTML with react\n        // because that means you re-render the HTML while the drag is happening\n        // and the actual dragging doesn't work any more\n        var dragging_mount_point = obj.props.children.props.mount_point;\n        $(`[data-mount-point=${dragging_mount_point}]`).closest('.react-drag').addClass('dragging');\n    },\n\n    render: function() {\n        var _this = this;\n        var navBarSwitch = (showAdmin) => {\n            if (showAdmin) {\n                return (\n                    <AdminNav\n                        tools={ _this.state.data.menu }\n                        installableTools={ _this.state.data.installable_tools }\n                        data={ _this.state.data }\n                        onToolReorder={ _this.onToolReorder }\n                        onToolDragStart={ _this.onToolDragStart }\n                        editMode={ _this.state.visible }\n                        currentOptionMenu={ _this.state.currentOptionMenu }\n                        onOptionClick={ _this.handleShowOptionMenu }\n                        currentToolOptions={this.state.currentToolOptions}\n                    />\n                );\n            } else {\n                return (\n                    <div>\n                        <NormalNavBar\n                            items={ _this.state.data.menu }\n                            installableTools={ _this.state.data.installable_tools }\n                            />\n                    </div>\n                );\n            }\n        };\n        var navBar = navBarSwitch(this.state.visible);\n\n        var max_tool_count = _.chain(this.state.data.menu)\n                             .map((item) => {\n                                 return item.children ? _.pluck(item.children, 'tool_name') : item.tool_name\n                             })\n                             .flatten()\n                             .countBy()\n                             .values()\n                             .max()\n                             .value();\n        var show_grouping_threshold = max_tool_count > 1;\n\n        return (\n            <div\n                className={ 'nav_admin '}>\n                { navBar }\n                <div id='bar-config'>\n                    {show_grouping_threshold &&\n                    <GroupingThreshold\n                        onUpdateThreshold={ this.onUpdateThreshold }\n                        isHidden={ this.state.visible }\n                        initialValue={ parseInt(this.state.data.grouping_threshold) }/> }\n                </div>\n                <ToggleAdminButton\n                    handleButtonPush={ this.handleToggleAdmin }\n                    visible={ this.state.visible }/>\n            </div>\n        );\n    }\n});\n"]}