blob: 7d4e1e16509634d0a1418b2d6b5dabd69d3ff4e4 [file] [log] [blame]
'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":";AAkBA,YAAY,CAAC;;;;AASb,SAAS,cAAc,GAAc;QAAb,IAAI,yDAAG,IAAI;;AAC/B,QAAI,IAAI,EAAE,IAAI,EAAE,SAAS,CAAC;AAC1B,QAAI,aAAa,GAAG,QAAQ,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;;;;;;AAC9E,6BAAgB,aAAa,8HAAE;gBAAtB,GAAG;;AACR,gBAAI,GAAG,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE;AAC/B,oBAAI,GAAG,GAAG,CAAC,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;aACvC;SACJ;;;;;;;;;;;;;;;;AACD,QAAI,GAAG,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;AAC9C,QAAI,IAAI,KAAK,UAAU,EAAE;AACrB,iBAAS,GAAG,IAAI,CAAC;KACpB,MAAM;AACH,iBAAS,GAAM,IAAI,SAAI,IAAI,AAAE,CAAC;KACjC;AACD,WAAO,CAAC,IAAI,GAAG,QAAQ,GAAG,GAAG,CAAA,GAAI,SAAS,CAAC;CAC9C;;AASD,SAAS,aAAa,CAAC,IAAI,EAAE;AACzB,QAAG,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC,aAAa,CAAC,KAAK,IAAI,EAAC;AAClE,eAAO,IAAI,CAAC,aAAa,CAAC,CAAC;KAC9B;AACD,WAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,WAAW,CAAC;CACnD;;AASD,SAAS,YAAY,CAAC,IAAI,EAAE;AACxB,QAAG,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,EAAC;AAClD,eAAO,IAAI,CAAC,KAAK,CAAC,CAAC;KACtB;AACD,WAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC;CAC3C;;AAED,IAAM,aAAa,GAAG,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC;AACxC,eAAW,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM;AACnC,QAAI,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU;AACvC,OAAG,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU;AACtC,eAAW,EAAE,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU;AAC5C,aAAS,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU;AAC5C,QAAI,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM;AAC5B,YAAQ,EAAE,KAAK,CAAC,SAAS,CAAC,KAAK;AAC/B,iBAAa,EAAE,KAAK,CAAC,SAAS,CAAC,KAAK;CACvC,CAAC,CAAC;;AAOH,IAAI,UAAU,GAAG,KAAK,CAAC,WAAW,CAAC;;;AAC/B,aAAS,EAAE;AACP,YAAI,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU;AACvC,WAAG,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU;AACtC,yBAAiB,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM;AACzC,qBAAa,EAAE,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU;AAC9C,eAAO,EAAE,KAAK,CAAC,SAAS,CAAC,KAAK;KACjC;;AAED,cAAU,EAAE,sBAAW;AACnB,eAAO,IAAI,CAAC,KAAK,CAAC,WAAW,KAAK,IAAI,CAAC;KAC1C;;AAED,UAAM,EAAE,kBAAW;AACf,YAAI,UAAU,GAAG,sBAAsB,CAAC;AACxC,YAAI,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE;AACxB,sBAAU,IAAI,WAAW,CAAC;SAC7B;AACD,YAAI,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,eAAe,CAAC;AAC1D,YAAI,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE;AACtB,uBAAW,IAAI,kBAAkB,CAAA;SACpC;;AAED,eACI;;cAAK,SAAS,EAAG,UAAU,AAAE;YACzB;;;gBACK,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,2BAAG,SAAS,EAAC,uBAAuB,EAAC,OAAO,EAAE,IAAI,CAAC,iBAAiB,AAAC,GAAK;gBAC7G;;;AACI,iCAAS,EAAE,WAAW,AAAC;AACvB,4CAAkB,IAAI,CAAC,KAAK,CAAC,WAAW,AAAC;oBACxC,IAAI,CAAC,KAAK,CAAC,IAAI;iBACb;aACP;YACH,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,IAAI,KAAK,IAAI,CAAC,KAAK,CAAC,WAAW,IAC9F,oBAAC,WAAW,eACJ,IAAI,CAAC,KAAK;AACd,uBAAO,EAAE,CAAC,cAAc,CAAC,AAAC;AAC1B,qBAAK,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO,AAAC;AAC1B,6BAAa,EAAE,IAAI,CAAC,KAAK,CAAC,aAAa,AAAC;eAC1C;SACJ,CACR;KACL;;AAED,qBAAiB,EAAE,2BAAS,KAAK,EAAE;AAC/B,YAAI,CAAC,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;KACpD;CACJ,CAAC,CAAC;;AAOH,IAAI,iBAAiB,GAAG,KAAK,CAAC,WAAW,CAAC;;;AACtC,aAAS,EAAE;AACP,oBAAY,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU;KAClD;AACD,mBAAe,EAAE,2BAAW;AACxB,eAAO;AACH,iBAAK,EAAE,IAAI,CAAC,KAAK,CAAC,YAAY;SACjC,CAAC;KACL;;AAED,gBAAY,EAAE,sBAAS,KAAK,EAAE;AAC1B,YAAI,CAAC,QAAQ,CAAC;AACV,iBAAK,EAAE,KAAK,CAAC,MAAM,CAAC,KAAK;SAC5B,CAAC,CAAC;AACH,YAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;KACvC;;AAED,UAAM,EAAE,kBAAW;AACf,eACI;;;YACM,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,IACvB;;kBAAK,EAAE,EAAC,kBAAkB;gBAC9B;;;oBACE;;0BAAO,OAAO,EAAC,iBAAiB;;qBAA2B;oBACzD,+BAAO,IAAI,EAAC,QAAQ,EAAC,IAAI,EAAC,iBAAiB,EAAC,SAAS,EAAC,SAAS;AACxD,6BAAK,EAAC,0CAA0C;AAChD,6BAAK,EAAG,IAAI,CAAC,KAAK,CAAC,KAAK,AAAE;AAC1B,gCAAQ,EAAG,IAAI,CAAC,YAAY,AAAE;AAC9B,2BAAG,EAAC,GAAG,EAAC,GAAG,EAAC,IAAI,GAAE;iBACpB;aACC;SACJ,CACR;KACL;CACJ,CAAC,CAAC;;AAOH,IAAI,aAAa,GAAG,KAAK,CAAC,WAAW,CAAC;;;AACpC,UAAM,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,eAAe,CAAC;;AAEpC,UAAM,EAAE,kBAAW;;AAEf,eACI;;cAAI,GAAG,eAAa,CAAC,CAAC,QAAQ,EAAE,AAAG;YAC/B;;kBAAG,IAAI,EAAG,IAAI,CAAC,KAAK,CAAC,GAAG,AAAE,EAAC,SAAS,EAAG,IAAI,CAAC,KAAK,CAAC,OAAO,AAAE;gBACrD,IAAI,CAAC,KAAK,CAAC,IAAI;aACjB;YACH,IAAI,CAAC,KAAK,CAAC,QAAQ;SACnB,CACP;KACL;CACJ,CAAC,CAAC;;AAOH,IAAI,gBAAgB,GAAG,KAAK,CAAC,WAAW,CAAC;;;AACrC,mBAAe,EAAE,2BAAW;AACxB,eAAO;AACH,mBAAO,EAAE,KAAK;SACjB,CAAC;KACL;AACD,gBAAY,EAAE,wBAAW;AACrB,YAAI,CAAC,QAAQ,CAAC;AACV,mBAAO,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO;SAC/B,CAAC,CAAC;KACN;AACG,qBAAiB,EAAE,2BAAS,KAAK,EAAE;AAC/B,eAAO,CAAC,GAAG,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;KAEnC;;AAED,UAAM,EAAE,kBAAY;AAChB,eACI;;;YACI;;kBAAG,OAAO,EAAG,IAAI,CAAC,YAAY,AAAE,EAAC,SAAS,EAAC,iBAAiB;;aAExD;YACH,IAAI,CAAC,KAAK,CAAC,OAAO,IACnB,oBAAC,WAAW,eACJ,IAAI,CAAC,KAAK;AACd,uBAAO,EAAE,CAAC,aAAa,CAAC,AAAC;AACzB,6BAAa,EAAE,IAAI,CAAC,iBAAiB,AAAC;AACtC,qBAAK,EAAE,IAAI,CAAC,KAAK,CAAC,gBAAgB,AAAC,IAAG;SAExC,CACT;KACJ;CACJ,CAAC,CAAC;;AAOH,IAAI,YAAY,GAAG,KAAK,CAAC,WAAW,CAAC;;;AACjC,aAAS,EAAE,mBAAS,IAAI,EAAE,CAAC,EAAE;AACzB,YAAI,OAAO,GAAG,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,iBAAiB,GAAG,EAAE,CAAC;;AAErF,YAAI,OAAO,CAAC;AACZ,YAAI,IAAI,CAAC,QAAQ,EAAE;AACf,mBAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;SAC/C;AACD,eACI;AAAC,yBAAa;cAAC,GAAG,EAAE,IAAI,CAAC,GAAG,AAAC,EAAC,IAAI,EAAE,IAAI,CAAC,IAAI,AAAC,EAAC,OAAO,EAAE,OAAO,AAAC,EAAC,GAAG,kBAAgB,CAAC,CAAC,QAAQ,EAAE,AAAG;YAC/F;;;gBACK,OAAO;aACP;SACO,CAClB;KACL;;AAED,iBAAa,EAAE,uBAAS,CAAC,EAAC;AACtB,eAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;KAClB;AACD,UAAM,EAAE,kBAAW;AACf,YAAI,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;;AAErD,YAAI,YAAY,GAAG,EAAE,CAAC;;;;;;AACtB,kCAAgB,IAAI,CAAC,KAAK,CAAC,KAAK,mIAAC;oBAAzB,IAAI;;AACR,oBAAG,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC,WAAW,KAAK,IAAI,EAAC;AAC/D,gCAAY,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;iBACvC,MAAM,IAAG,IAAI,CAAC,cAAc,CAAC,UAAU,CAAC,EAAC;;;;;;AACtC,8CAAiB,IAAI,CAAC,QAAQ,mIAAC;gCAAvB,KAAK;;AACT,wCAAY,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAA;yBACvC;;;;;;;;;;;;;;;iBACJ;aACJ;;;;;;;;;;;;;;;;AACD,eAAO,CAAC,GAAG,CAAC,cAAc,EAAE,YAAY,CAAC,CAAC;AAC1C,eACI;;;AACI,kBAAE,EAAC,gBAAgB;AACnB,yBAAS,EAAC,UAAU;YAClB,SAAS;YACX;;kBAAI,EAAE,EAAC,oBAAoB;gBACvB,oBAAC,gBAAgB,eACT,IAAI,CAAC,KAAK;AACd,yBAAK,EAAE,IAAI,CAAC,KAAK,CAAC,gBAAgB,AAAC;AACnC,iCAAa,EAAE,IAAI,CAAC,aAAa,AAAC,IAAG;aACxC;SACJ,CACP;KACL;CACJ,CAAC,CAAC;;AAMH,IAAI,QAAQ,GAAG,KAAK,CAAC,WAAW,CAAC;;;AAC7B,aAAS,EAAE;AACP,aAAK,EAAE,KAAK,CAAC,SAAS,CAAC,OAAO,CAAC,aAAa,CAAC;AAC7C,yBAAiB,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM;AACzC,qBAAa,EAAE,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU;KACjD;;AAED,aAAS,EAAE,mBAAU,KAAK,EAAmB;YAAjB,SAAS,yDAAC,KAAK;;AACvC,YAAI,KAAK,GAAG,IAAI,CAAC;YACZ,KAAK,GAAgC,EAAE;YAAhC,cAAc,GAAoB,EAAE;YAApB,SAAS,GAAa,EAAE;;AACpD,YAAI,OAAO,EAAE,gBAAgB,CAAC;;;;;;;AAE9B,kCAAiB,KAAK,mIAAE;oBAAf,IAAI;;AACT,oBAAI,IAAI,CAAC,QAAQ,EAAE;AACf,2BAAO,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;iBACjD,MAAM;AACH,2BAAO,GAAG,IAAI,CAAC;iBAClB;;AAED,oBAAI,OAAO,GAAG,SAAS,GAAG,sBAAsB,GAAG,kBAAkB,CAAC;;AAEtE,oBAAI,SAAS,EAAE,WAAW,CAAC;AAC3B,oBAAI,IAAI,CAAC,WAAW,KAAK,OAAO,EAAE;AAE9B,6BAAS,GAAG,SAAS,CAAC;AACtB,+BAAW,GAAG,IAAI,CAAC;iBACtB,MAAM,IAAI,IAAI,CAAC,WAAW,EAAE;AACzB,6BAAS,GAAG,cAAc,CAAC;AAC3B,+BAAW,GAAG,IAAI,CAAC;iBACtB,MAAM;AACH,6BAAS,GAAG,KAAK,CAAC;AAClB,+BAAW,GAAG,KAAK,CAAC;iBACvB;AACD,oBAAI,SAAS,GAAG,oBAAC,UAAU,eACnB,KAAK,CAAC,KAAK;AACf,+BAAW,EAAG,IAAI,CAAC,WAAW,AAAE;AAChC,wBAAI,EAAG,IAAI,CAAC,IAAI,AAAE;AAClB,8BAAU,EAAE,OAAO,AAAC;AACpB,6BAAS,EAAE,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,AAAC;AACrD,uBAAG,EAAG,IAAI,CAAC,GAAG,AAAE;AAChB,uBAAG,EAAG,UAAU,GAAG,CAAC,CAAC,QAAQ,EAAE,AAAE;AACjC,+BAAW,EAAG,WAAW,AAAE;AAC3B,2BAAO,EAAG,IAAI,CAAC,aAAa,AAAE;mBAChC,CAAC;AACH,oBAAI,OAAO,EAAE;AACT,oCAAgB,GAAG,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,aAAa,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;AACxG,6BAAS,CAAC,IAAI,CAAC,oBAAC,qBAAqB,IAAC,GAAG,EAAE,CAAC,CAAC,QAAQ,EAAE,AAAC,EAAC,IAAI,EAAE,SAAS,AAAC,EAAC,OAAO,EAAE,OAAO,AAAC,EAAC,gBAAgB,EAAE,gBAAgB,AAAC,GAAE,CAAC,CAAC;iBACtI,MAAM;AACH,6BAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;iBAC7B;aACJ;;;;;;;;;;;;;;;;AAED,eACI;;cAAK,SAAS,EAAC,YAAY;YACrB,cAAc;YAChB;AAAC,gCAAgB;;AACb,uBAAG,EAAG,UAAU,GAAG,CAAC,CAAC,QAAQ,EAAE,AAAE;AACjC,0BAAM,EAAE,GAAG,GAAG,OAAO,AAAC;AACtB,wBAAI,EAAG,SAAS,GAAG,MAAM,GAAG,MAAM,AAAE;AACpC,+BAAW,EAAG,KAAK,CAAC,KAAK,CAAC,eAAe,AAAE;AAC3C,0BAAM,EAAG,KAAK,CAAC,KAAK,CAAC,aAAa,AAAE;gBAClC,KAAK;aACQ;YACjB,SAAS;SACT,CACR;KACL;;AAED,UAAM,EAAE,kBAAY;AAChB,YAAI,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;AAC7C,eAAO;;;YAAM,KAAK;SAAO,CAAC;KAC7B;CACJ,CAAC,CAAC;;AAEH,IAAI,qBAAqB,GAAG,KAAK,CAAC,WAAW,CAAC;;;AAC1C,UAAM,EAAE,kBAAY;AAChB,eACI;;cAAK,SAAS,EAAE,mBAAmB,IAAI,IAAI,CAAC,KAAK,CAAC,gBAAgB,GAAG,qBAAqB,GAAG,EAAE,CAAA,AAAC,AAAC;YAC3F,IAAI,CAAC,KAAK,CAAC,IAAI;YAChB,IAAI,CAAC,KAAK,CAAC,OAAO,IACnB;AAAC,8BAAc;kBAAC,GAAG,EAAE,CAAC,CAAC,QAAQ,EAAE,AAAC;gBAC7B,IAAI,CAAC,KAAK,CAAC,OAAO;aACN;SAEf,CACR;KACL;CACJ,CAAC,CAAC;;AAOH,IAAI,cAAc,GAAG,KAAK,CAAC,WAAW,CAAC;;;AACnC,UAAM,EAAE,kBAAY;AAChB,eACI;;cAAK,SAAS,EAAC,iBAAiB;YAC3B,IAAI,CAAC,KAAK,CAAC,QAAQ;SAClB,CACR;KACL;CACJ,CAAC,CAAC;;AAOH,IAAI,iBAAiB,GAAG,KAAK,CAAC,WAAW,CAAC;;;AACtC,aAAS,EAAE;AACP,eAAO,EAAE,KAAK,CAAC,SAAS,CAAC,IAAI;KAChC;AACD,UAAM,EAAE,kBAAW;AACf,YAAI,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,cAAc,GAAG,YAAY,CAAC;AACjE,eACI;;cAAQ,EAAE,EAAC,kBAAkB,EAAC,OAAO,EAAG,IAAI,CAAC,KAAK,CAAC,gBAAgB,AAAE,EAAC,SAAS,EAAC,qBAAqB;YACjG,2BAAG,SAAS,EAAG,OAAO,AAAE,GAAK;SACxB,CACX;KACL;CACJ,CAAC,CAAC;;AAQH,IAAI,IAAI,GAAG,KAAK,CAAC,WAAW,CAAC;;;AACzB,aAAS,EAAE;AACP,mBAAW,EAAE,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC;AAC/B,gBAAI,EAAE,KAAK,CAAC,SAAS,CAAC,OAAO,CAAC,aAAa,CAAC;AAC5C,4BAAgB,EAAE,KAAK,CAAC,SAAS,CAAC,KAAK;AACvC,8BAAkB,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU;SACxD,CAAC;AACF,wBAAgB,EAAE,KAAK,CAAC,SAAS,CAAC,KAAK;KAC1C;AACD,mBAAe,EAAE,2BAAW;AACxB,eAAO;AACH,gBAAI,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW;AAC5B,mBAAO,EAAE,IAAI;AACb,uBAAW,EAAE,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC;AACpC,6BAAiB,EAAE;AACf,oBAAI,EAAE,IAAI;aACb;SACJ,CAAC;KACL;;AAKD,cAAU,EAAE,sBAAW;AACnB,SAAC,CAAC,GAAG,CAAI,cAAc,CAAC,KAAK,CAAC,iCAA8B,CAAA,UAAS,MAAM,EAAE;AACzE,gBAAI,IAAI,CAAC,SAAS,EAAE,EAAE;AAClB,oBAAI,CAAC,QAAQ,CAAC;AACV,wBAAI,EAAE,MAAM;iBACf,CAAC,CAAC;aACN;SACJ,CAAA,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;KACjB;;AAID,qBAAiB,EAAE,6BAAW;AAC1B,YAAI,CAAC,QAAQ,CAAC;AACV,mBAAO,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO;SAC/B,CAAC,CAAC;KACN;;AAED,wBAAoB,EAAE,8BAAU,WAAW,EAAE;AACzC,YAAI,CAAC,QAAQ,CAAC;AACV,6BAAiB,EAAE;AACf,oBAAI,EAAE,WAAW;aACpB;SACJ,CAAC,CAAC;KACN;;AAOD,qBAAiB,EAAE,2BAAS,KAAK,EAAE;AAC/B,YAAI,KAAK,GAAG,IAAI,CAAC;AACjB,YAAI,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;AAC/B,YAAI,GAAG,GAAM,cAAc,EAAE,mCAAgC,CAAC;AAC9D,YAAI,IAAI,GAAG,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;AACnC,YAAI,IAAI,GAAG;AACP,uBAAW,EAAE,IAAI;AACjB,8BAAkB,EAAE,KAAK;SAC5B,CAAC;AACF,YAAI,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;AAC5B,aAAK,CAAC,kBAAkB,GAAG,KAAK,CAAC;AACjC,YAAI,CAAC,QAAQ,CAAC;AACV,gBAAI,EAAE,KAAK;SACd,CAAC,CAAC;AACH,YAAI,CAAC,QAAQ,CAAC;AACV,uBAAW,EAAE,IAAI;SACpB,CAAC,CAAC;AACH,SAAC,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,EAAE,CAAA,YAAW,EAC5B,CAAA,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,YAAW;AAC5B,iBAAK,CAAC,QAAQ,CAAC;AACX,2BAAW,EAAE,KAAK;aACrB,CAAC,CAAC;SACN,CAAC,CAAC;;AAEH,aAAK,CAAC,UAAU,EAAE,CAAC;AACnB,eAAO,KAAK,CAAC;KAChB;;AAOD,iBAAa,EAAE,yBAAW;AACtB,SAAC,CAAC,sBAAsB,CAAC,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;;AAElD,YAAI,MAAM,GAAG,EAAC,WAAW,EAAE,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,EAAC,CAAC;AACpD,YAAI,SAAS,GAAG,CAAC,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC;AAChG,aAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;AACvC,kBAAM,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC;SAC/C;;AAED,YAAI,KAAK,GAAG,IAAI,CAAC;AACjB,YAAI,GAAG,GAAG,cAAc,EAAE,GAAG,oBAAoB,CAAC;AAClD,SAAC,CAAC,IAAI,CAAC;AACH,gBAAI,EAAE,MAAM;AACZ,eAAG,EAAE,GAAG;AACR,gBAAI,EAAE,MAAM;AACZ,mBAAO,EAAE,mBAAY;AACjB,iBAAC,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,oBAAoB,EACtC;AACI,0BAAM,EAAE,SAAS;AACjB,4BAAQ,EAAE,GAAG;AACb,yBAAK,EAAE,IAAI;iBACd,CAAC,CAAC;AACP,qBAAK,CAAC,UAAU,EAAE,CAAC;aACtB;;AAED,iBAAK,EAAE,iBAAW;AACd,iBAAC,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,0BAA0B,EAC5C;AACI,0BAAM,EAAE,OAAO;iBAClB,CAAC,CAAC;aACV;SACJ,CAAC,CAAC;KACN;;AAED,mBAAe,EAAE,yBAAS,GAAG,EAAE;AAI3B,YAAI,oBAAoB,GAAG,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,WAAW,CAAC;AAChE,SAAC,wBAAsB,oBAAoB,OAAI,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;KAC/F;;AAED,UAAM,EAAE,kBAAW;;;AACf,YAAI,KAAK,GAAG,IAAI,CAAC;AACjB,YAAI,YAAY,GAAG,SAAf,YAAY,CAAI,SAAS,EAAK;AAC9B,gBAAI,SAAS,EAAE;AACX,uBACI,oBAAC,QAAQ;AACL,yBAAK,EAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,AAAE;AAC/B,oCAAgB,EAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,iBAAiB,AAAE;AACvD,wBAAI,EAAG,KAAK,CAAC,KAAK,CAAC,IAAI,AAAE;AACzB,iCAAa,EAAG,KAAK,CAAC,aAAa,AAAE;AACrC,mCAAe,EAAG,KAAK,CAAC,eAAe,AAAE;AACzC,4BAAQ,EAAG,KAAK,CAAC,KAAK,CAAC,OAAO,AAAE;AAChC,qCAAiB,EAAG,KAAK,CAAC,KAAK,CAAC,iBAAiB,AAAE;AACnD,iCAAa,EAAG,KAAK,CAAC,oBAAoB,AAAE;AAC5C,sCAAkB,EAAE,OAAK,KAAK,CAAC,kBAAkB,AAAC;kBACpD,CACJ;aACL,MAAM;AACH,uBACI;;;oBACI,oBAAC,YAAY;AACT,6BAAK,EAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,AAAE;AAC/B,wCAAgB,EAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,iBAAiB,AAAE;sBACrD;iBACJ,CACR;aACL;SACJ,CAAC;AACF,YAAI,MAAM,GAAG,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;;AAE9C,YAAI,cAAc,GAAG,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAC5B,GAAG,CAAC,UAAC,IAAI,EAAK;AACX,mBAAO,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,IAAI,CAAC,SAAS,CAAA;SAC9E,CAAC,CACD,OAAO,EAAE,CACT,OAAO,EAAE,CACT,MAAM,EAAE,CACR,GAAG,EAAE,CACL,KAAK,EAAE,CAAC;AAC9B,YAAI,uBAAuB,GAAG,cAAc,GAAG,CAAC,CAAC;;AAEjD,eACI;;;AACI,yBAAS,EAAG,YAAY,AAAC;YACvB,MAAM;YACR;;kBAAK,EAAE,EAAC,YAAY;gBACf,uBAAuB,IACxB,oBAAC,iBAAiB;AACd,qCAAiB,EAAG,IAAI,CAAC,iBAAiB,AAAE;AAC5C,4BAAQ,EAAG,IAAI,CAAC,KAAK,CAAC,OAAO,AAAE;AAC/B,gCAAY,EAAG,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC,AAAE,GAAE;aACjE;YACN,oBAAC,iBAAiB;AACd,gCAAgB,EAAG,IAAI,CAAC,iBAAiB,AAAE;AAC3C,uBAAO,EAAG,IAAI,CAAC,KAAK,CAAC,OAAO,AAAE,GAAE;SAClC,CACR;KACL;CACJ,CAAC,CAAC","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"]}