(function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.PydioComponents = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o child into a function."))}function a(){!d&&p&&(d=!0,console.error("With React 0.13, you need to wrap child into a function."))}function l(e){return e<0?0:e}function s(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:function(e){return e},n={};for(var o in e)e.hasOwnProperty(o)&&(n[o]=t(e[o]));return n}function u(e){var t=e.version;if("string"!=typeof t)return!0;var n=t.split("."),o=parseInt(n[0],10),r=parseInt(n[1],10);return 0===o&&13===r}Object.defineProperty(t,"__esModule",{value:!0}),t.findDOMNode=r,t.warnAboutFunctionChild=i,t.warnAboutElementChild=a,t.positiveOrZero=l,t.modifyObjValues=s,t.isReact13=u;var c=n(1),f=o(c),p=u(f.default),d=!1},function(e,t){function n(){throw new Error("setTimeout has not been defined")}function o(){throw new Error("clearTimeout has not been defined")}function r(e){if(c===setTimeout)return setTimeout(e,0);if((c===n||!c)&&setTimeout)return c=setTimeout,setTimeout(e,0);try{return c(e,0)}catch(t){try{return c.call(null,e,0)}catch(t){return c.call(this,e,0)}}}function i(e){if(f===clearTimeout)return clearTimeout(e);if((f===o||!f)&&clearTimeout)return f=clearTimeout,clearTimeout(e);try{return f(e)}catch(t){try{return f.call(null,e)}catch(t){return f.call(this,e)}}}function a(){y&&d&&(y=!1,d.length?h=d.concat(h):v=-1,h.length&&l())}function l(){if(!y){var e=r(a);y=!0;for(var t=h.length;t;){for(d=h,h=[];++v1)for(var n=1;nt.realHeight-t.containerHeight&&(e=t.realHeight-t.containerHeight),e<0&&(e=0),e}},{key:"normalizeLeftPosition",value:function(e,t){return e>t.realWidth-t.containerWidth?e=t.realWidth-t.containerWidth:e<0&&(e=0),e}},{key:"computeSizes",value:function(){var e=this.content.offsetHeight,t=this.wrapper.offsetHeight,n=this.content.offsetWidth,o=this.wrapper.offsetWidth;return{realHeight:e,containerHeight:t,realWidth:n,containerWidth:o}}},{key:"setSizesToState",value:function(){var e=this.computeSizes();e.realHeight===this.state.realHeight&&e.realWidth===this.state.realWidth||this.setStateFromEvent(this.getModifiedPositionsIfNeeded(e))}},{key:"scrollTop",value:function(){this.scrollYTo(0)}},{key:"scrollBottom",value:function(){this.scrollYTo(this.state.realHeight-this.state.containerHeight)}},{key:"scrollLeft",value:function(){this.scrollXTo(0)}},{key:"scrollRight",value:function(){this.scrollXTo(this.state.realWidth-this.state.containerWidth)}},{key:"scrollYTo",value:function(e){if(this.canScrollY()){var t=this.normalizeTopPosition(e,this.computeSizes());this.setStateFromEvent({topPosition:t},g.api)}}},{key:"scrollXTo",value:function(e){if(this.canScrollX()){var t=this.normalizeLeftPosition(e,this.computeSizes());this.setStateFromEvent({leftPosition:t},g.api)}}},{key:"canScrollY",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.state,t=e.realHeight>e.containerHeight;return t&&this.props.vertical}},{key:"canScrollX",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.state,t=e.realWidth>e.containerWidth;return t&&this.props.horizontal}},{key:"canScroll",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.state;return this.canScrollY(e)||this.canScrollX(e)}},{key:"getModifiedPositionsIfNeeded",value:function(e){var t=e.realHeight-e.containerHeight;this.state.topPosition>=t&&(e.topPosition=this.canScrollY(e)?(0,m.positiveOrZero)(t):0);var n=e.realWidth-e.containerWidth;return this.state.leftPosition>=n&&(e.leftPosition=this.canScrollX(e)?(0,m.positiveOrZero)(n):0),e}},{key:"focusContent",value:function(){this.content&&(0,m.findDOMNode)(this.content).focus()}}]),t}(f.default.Component);t.default=w,w.childContextTypes={scrollArea:d.default.object},w.propTypes={className:d.default.string,style:d.default.object,speed:d.default.number,contentClassName:d.default.string,contentStyle:d.default.object,vertical:d.default.bool,verticalContainerStyle:d.default.object,verticalScrollbarStyle:d.default.object,horizontal:d.default.bool,horizontalContainerStyle:d.default.object,horizontalScrollbarStyle:d.default.object,onScroll:d.default.func,contentWindow:d.default.any,ownerDocument:d.default.any,smoothScrolling:d.default.bool,minScrollSize:d.default.number,swapWheelAxes:d.default.bool,stopScrollPropagation:d.default.bool,focusableTabIndex:d.default.number},w.defaultProps={speed:1,vertical:!0,horizontal:!0,smoothScrolling:!1,swapWheelAxes:!1,contentWindow:"object"===("undefined"==typeof window?"undefined":l(window))?window:void 0,ownerDocument:"object"===("undefined"==typeof document?"undefined":l(document))?document:void 0,focusableTabIndex:1}},function(e,t,n){"use strict";function o(e){return e&&e.__esModule?e:{default:e}}function r(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function i(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function a(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}Object.defineProperty(t,"__esModule",{value:!0});var l=Object.assign||function(e){for(var t=1;t10*k&&(o.accumulatedTime=0),0===o.accumulatedTime)return o.animationID=null,void o.startAnimationIfNecessary();var i=(o.accumulatedTime-Math.floor(o.accumulatedTime/k)*k)/k,a=Math.floor(o.accumulatedTime/k),l={},s={},u={},c={};for(var f in t)if(Object.prototype.hasOwnProperty.call(t,f)){var p=t[f];if("number"==typeof p)u[f]=p,c[f]=0,l[f]=p,s[f]=0;else{for(var h=o.state.lastIdealStyle[f],v=o.state.lastIdealVelocity[f],m=0;m10*O&&(o.accumulatedTime=0),0===o.accumulatedTime)return o.animationID=null,void o.startAnimationIfNecessary();for(var i=(o.accumulatedTime-Math.floor(o.accumulatedTime/O)*O)/O,l=Math.floor(o.accumulatedTime/O),s=[],u=[],c=[],f=[],p=0;p10*D&&(o.accumulatedTime=0),0===o.accumulatedTime)return o.animationID=null,void o.startAnimationIfNecessary();for(var u=(o.accumulatedTime-Math.floor(o.accumulatedTime/D)*D)/D,c=Math.floor(o.accumulatedTime/D),f=s(o.props.willEnter,o.props.willLeave,o.props.didLeave,o.state.mergedPropsStyles,n,o.state.currentStyles,o.state.currentVelocities,o.state.lastIdealStyles,o.state.lastIdealVelocities),p=f[0],d=f[1],h=f[2],y=f[3],m=f[4],b=0;bo[c])return-1;if(r>i[c]&&so[c])return 1;if(a>i[c]&&l=0&&S.splice(t,1)}function l(e){var t=document.createElement("style");return t.type="text/css",i(e,t),t}function s(e){var t=document.createElement("link");return t.rel="stylesheet",i(e,t),t}function u(e,t){var n,o,r;if(t.singleton){var i=b++;n=m||(m=l(t)),o=c.bind(null,n,i,!1),r=c.bind(null,n,i,!0)}else e.sourceMap&&"function"==typeof URL&&"function"==typeof URL.createObjectURL&&"function"==typeof URL.revokeObjectURL&&"function"==typeof Blob&&"function"==typeof btoa?(n=s(t),o=p.bind(null,n),r=function(){a(n),n.href&&URL.revokeObjectURL(n.href)}):(n=l(t),o=f.bind(null,n),r=function(){a(n)});return o(e),function(t){if(t){if(t.css===e.css&&t.media===e.media&&t.sourceMap===e.sourceMap)return;o(e=t)}else r()}}function c(e,t,n,o){var r=n?"":o.css;if(e.styleSheet)e.styleSheet.cssText=g(t,r);else{var i=document.createTextNode(r),a=e.childNodes;a[t]&&e.removeChild(a[t]),a.length?e.insertBefore(i,a[t]):e.appendChild(i)}}function f(e,t){var n=t.css,o=t.media;if(o&&e.setAttribute("media",o),e.styleSheet)e.styleSheet.cssText=n;else{for(;e.firstChild;)e.removeChild(e.firstChild);e.appendChild(document.createTextNode(n))}}function p(e,t){var n=t.css,o=t.sourceMap;o&&(n+="\n/*# sourceMappingURL=data:application/json;base64,"+btoa(unescape(encodeURIComponent(JSON.stringify(o))))+" */");var r=new Blob([n],{type:"text/css"}),i=e.href;e.href=URL.createObjectURL(r),i&&URL.revokeObjectURL(i)}var d={},h=function(e){var t;return function(){return"undefined"==typeof t&&(t=e.apply(this,arguments)),t}},y=h(function(){return/msie [6-9]\b/.test(window.navigator.userAgent.toLowerCase())}),v=h(function(){return document.head||document.getElementsByTagName("head")[0]}),m=null,b=0,S=[];e.exports=function(e,t){t=t||{},"undefined"==typeof t.singleton&&(t.singleton=y()),"undefined"==typeof t.insertAt&&(t.insertAt="bottom");var n=r(e);return o(n,t),function(e){for(var i=[],a=0;a * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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 _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } var _Store = require('./Store'); var _Store2 = _interopRequireDefault(_Store); var _GridBuilder = require('./GridBuilder'); var _GridBuilder2 = _interopRequireDefault(_GridBuilder); /** * Automatic layout for presenting draggable cards to users. Used for user and admin dashboard. */ var React = require('react'); var Pydio = require('pydio'); var _require = require('react-grid-layout'); var Responsive = _require.Responsive; var WidthProvider = _require.WidthProvider; var _Pydio$requireLib = Pydio.requireLib('boot'); var PydioContextConsumer = _Pydio$requireLib.PydioContextConsumer; var CardsGrid = React.createClass({ displayName: 'CardsGrid', /** * Save layouts in the users preference. * * @param {object} allLayouts Responsive layouts passed for saving */ saveFullLayouts: function saveFullLayouts(allLayouts) { var savedPref = this.props.store.getUserPreference('Layout'); // Compare JSON versions to avoid saving unnecessary changes if (savedPref && this.previousLayout && this.previousLayout == JSON.stringify(allLayouts)) { return; } this.previousLayout = JSON.stringify(allLayouts); this.props.store.saveUserPreference('Layout', allLayouts); }, onLayoutChange: function onLayoutChange(currentLayout, allLayouts) { if (this._blockLayoutSave) return; this.saveFullLayouts(allLayouts); }, componentWillUnmount: function componentWillUnmount() { this.props.store.stopObserving("cards", this._storeObserver); }, componentWillReceiveProps: function componentWillReceiveProps(nextProps) { if (this.props && nextProps.editMode !== this.props.editMode) { Object.keys(this.refs).forEach((function (k) { this.refs[k].toggleEditMode(nextProps.editMode); }).bind(this)); } }, shouldComponentUpdate: function shouldComponentUpdate(nextProps, nextState) { return this._forceUpdate || false; }, getInitialState: function getInitialState() { this._storeObserver = (function (e) { var _this = this; this._forceUpdate = true; this.setState({ cards: this.props.store.getCards() }, function () { _this._forceUpdate = false; }); }).bind(this); this.props.store.observe("cards", this._storeObserver); return { cards: this.props.store.getCards() }; }, removeCard: function removeCard(itemKey) { this.props.removeCard(itemKey); }, buildCards: function buildCards(cards) { var index = 0; var layouts = { lg: [], md: [], sm: [], xs: [], xxs: [] }; var items = []; var additionalNamespaces = []; var rand = Math.random(); var savedLayouts = this.props.store.getUserPreference('Layout'); var buildLayout = function buildLayout(classObject, itemKey, item, x, y) { var layout = classObject.getGridLayout(x, y); layout['handle'] = 'h4'; if (item['gridHandle']) { layout['handle'] = item['gridHandle']; } layout['i'] = itemKey; return layout; }; cards.map((function (item) { var parts = item.componentClass.split("."); var classNS = parts[0]; var className = parts[1]; var classObject; if (global[classNS] && global[classNS][className]) { classObject = global[classNS][className]; } else { if (!global[classNS]) { additionalNamespaces.push(classNS); } return; } var props = _extends({}, item.props); var itemKey = props['key'] = item['id'] || 'item_' + index; props.ref = itemKey; props.pydio = this.props.pydio; props.onCloseAction = (function () { this.removeCard(itemKey); }).bind(this); props.preferencesProvider = this.props.store; var defaultX = 0, defaultY = 0; if (item.defaultPosition) { defaultX = item.defaultPosition.x; defaultY = item.defaultPosition.y; } var defaultLayout = buildLayout(classObject, itemKey, item, defaultX, defaultY); for (var breakpoint in layouts) { if (!layouts.hasOwnProperty(breakpoint)) continue; var breakLayout = layouts[breakpoint]; // Find corresponding element in preference var existing; if (savedLayouts && savedLayouts[breakpoint]) { savedLayouts[breakpoint].map(function (gridData) { if (gridData['i'] == itemKey && gridData['h'] == defaultLayout['h']) { existing = gridData; } }); } if (existing) { breakLayout.push(existing); } else if (item.defaultLayouts && item.defaultLayouts[breakpoint]) { var crtLayout = buildLayout(classObject, itemKey, item, item.defaultLayouts[breakpoint].x, item.defaultLayouts[breakpoint].y); breakLayout.push(crtLayout); } else { breakLayout.push(defaultLayout); } } index++; items.push(React.createElement(classObject, props)); }).bind(this)); if (additionalNamespaces.length) { this._blockLayoutSave = true; ResourcesManager.loadClassesAndApply(additionalNamespaces, (function () { this.setState({ additionalNamespacesLoaded: additionalNamespaces }, (function () { this._blockLayoutSave = false; }).bind(this)); }).bind(this)); } return { cards: items, layouts: layouts }; }, render: function render() { var _buildCards = this.buildCards(this.state.cards); var cards = _buildCards.cards; var layouts = _buildCards.layouts; var ResponsiveGridLayout = WidthProvider(Responsive); return React.createElement( ResponsiveGridLayout, { className: 'dashboard-layout', cols: this.props.cols || { lg: 10, md: 8, sm: 8, xs: 4, xxs: 2 }, layouts: layouts, rowHeight: 5, onLayoutChange: this.onLayoutChange, isDraggable: !this.props.disableDrag, style: this.props.style, autoSize: false }, cards ); } }); var DynamicGrid = React.createClass({ displayName: 'DynamicGrid', propTypes: { storeNamespace: React.PropTypes.string.isRequired, builderNamespaces: React.PropTypes.array, defaultCards: React.PropTypes.array, pydio: React.PropTypes.instanceOf(Pydio), disableDrag: React.PropTypes.bool }, removeCard: function removeCard(cardId) { this.state.store.removeCard(cardId); }, addCard: function addCard(cardDefinition) { this.state.store.addCard(cardDefinition); }, resetCardsAndLayout: function resetCardsAndLayout() { this.state.store.saveUserPreference('Layout', null); this.state.store.setCards(this.props.defaultCards); }, getInitialState: function getInitialState() { var store = new _Store2['default'](this.props.storeNamespace, this.props.defaultCards, this.props.pydio); return { editMode: false, store: store }; }, toggleEditMode: function toggleEditMode() { this.setState({ editMode: !this.state.editMode }); }, render: function render() { var _this2 = this; var monitorWidgetEditing = (function (status) { this.setState({ widgetEditing: status }); }).bind(this); var builder = undefined; if (this.props.builderNamespaces && this.state.editMode) { builder = React.createElement(_GridBuilder2['default'], { className: 'admin-helper-panel', namespaces: this.props.builderNamespaces, onCreateCard: this.addCard, onResetLayout: this.resetCardsAndLayout, onEditStatusChange: monitorWidgetEditing, getMessage: function (id) { var ns = arguments.length <= 1 || arguments[1] === undefined ? 'ajxp_admin' : arguments[1]; return _this2.props.getMessage(id, ns); } }); } var propStyle = this.props.style || {}; var rglStyle = this.props.rglStyle || {}; return React.createElement( 'div', { style: _extends({}, this.props.style, { width: '100%', flex: '1' }), className: this.state.editMode ? "builder-open" : "" }, React.createElement( 'div', { style: { position: 'absolute', bottom: 30, right: 18, zIndex: 11 } }, React.createElement(MaterialUI.FloatingActionButton, { tooltip: this.props.getMessage('home.49'), onClick: this.toggleEditMode, iconClassName: this.state.editMode ? "icon-ok" : "mdi mdi-pencil", mini: this.state.editMode, disabled: this.state.editMode && this.state.widgetEditing }) ), builder, React.createElement( 'div', { className: 'home-dashboard', style: { height: '100%' } }, React.createElement(CardsGrid, { disableDrag: this.props.disableDrag, cols: this.props.cols, store: this.state.store, style: rglStyle, pydio: this.props.pydio, editMode: this.state.editMode, removeCard: this.removeCard }) ) ); } }); exports['default'] = DynamicGrid = PydioContextConsumer(DynamicGrid); exports['default'] = DynamicGrid; module.exports = exports['default']; }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) },{"./GridBuilder":3,"./Store":5,"pydio":"pydio","react":"react","react-grid-layout":"react-grid-layout"}],3:[function(require,module,exports){ (function (global){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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; }; var React = require('react'); var Pydio = require('pydio'); var _Pydio$requireLib = Pydio.requireLib('boot'); var PydioContextConsumer = _Pydio$requireLib.PydioContextConsumer; var AsyncComponent = _Pydio$requireLib.AsyncComponent; var GridBuilder = React.createClass({ displayName: 'GridBuilder', propTypes: { namespaces: React.PropTypes.array, onCreateCard: React.PropTypes.func, onEditStatusChange: React.PropTypes.func }, getInitialState: function getInitialState() { return { selectedIndex: 0, availableWidgets: this.listAvailableWidgets() }; }, listAvailableWidgets: function listAvailableWidgets() { var secondPass = arguments.length <= 0 || arguments[0] === undefined ? false : arguments[0]; var widgets = []; var additionalNamespaces = []; this.props.namespaces.map(function (ns) { if (!global[ns]) { additionalNamespaces.push(ns); return; } for (var k in global[ns]) { if (global[ns].hasOwnProperty(k)) { var widgetClass = global[ns][k]; if (widgetClass.hasBuilderFields && widgetClass.hasBuilderFields()) { widgets.push({ reactClass: widgetClass, fullName: ns + '.' + widgetClass.displayName }); } } } }); if (additionalNamespaces.length && !secondPass) { ResourcesManager.loadClassesAndApply(additionalNamespaces, (function () { this.setState({ availableWidgets: this.listAvailableWidgets(true) }); }).bind(this)); } return widgets; }, onDropDownChange: function onDropDownChange(event, index, item) { var defaultValues = {}; if (index != 0) { item.payload['reactClass'].getBuilderFields().map(function (f) { if (f['default']) defaultValues[f.name] = f['default']; }); } if (this.props.onEditStatusChange) { this.props.onEditStatusChange(index != 0); } this.setState({ selectedIndex: index, selectedWidget: item.payload, currentFormValues: defaultValues }); }, cancel: function cancel() { if (this.props.onEditStatusChange) { this.props.onEditStatusChange(false); } this.setState({ selectedIndex: 0 }); }, onFormValueChange: function onFormValueChange(newValues) { this.setState({ currentFormValues: newValues }); }, onFormSubmit: function onFormSubmit() { var values = this.state.currentFormValues; var selectedWidget = this.state.selectedWidget; var title = values.title ? values.title : values.legend; if (!title) title = this.state.selectedWidget['reactClass'].builderDisplayName; this.props.onCreateCard({ componentClass: selectedWidget.fullName, title: title, props: values }); this.cancel(); }, resetLayout: function resetLayout() { if (window.confirm(this.props.getMessage('home.51'))) { this.props.onResetLayout(); } }, render: function render() { var getMessage = this.props.getMessage; var selectorItems = [{ payload: 0, text: getMessage('home.50') }].concat(this.state.availableWidgets.map(function (w, index) { return { payload: w, text: w['reactClass'].builderDisplayName }; })); var selector = React.createElement(ReactMUI.DropDownMenu, { menuItems: selectorItems, onChange: this.onDropDownChange, selectedIndex: this.state.selectedIndex, autoWidth: false, className: 'widget-type-selector' }); var form, add; if (this.state.selectedIndex != 0) { var fields = this.state.selectedWidget['reactClass'].getBuilderFields(); var defaultValues = {}; fields.map(function (f) { if (f['default']) defaultValues[f.name] = f['default']; }); if (this.state.currentFormValues) { defaultValues = LangUtils.mergeObjectsRecursive(defaultValues, this.state.currentFormValues); } form = React.createElement(AsyncComponent, { namespace: 'PydioForm', componentName: 'FormPanel', parameters: fields, depth: -1, values: defaultValues, onChange: this.onFormValueChange }); add = React.createElement( 'div', { style: { textAlign: 'center', paddingBottom: 100 } }, React.createElement(ReactMUI.RaisedButton, { label: getMessage('home.52'), onClick: this.onFormSubmit }), ' ', React.createElement(ReactMUI.RaisedButton, { label: getMessage('54', ''), onClick: this.cancel }) ); } return React.createElement( ReactMUI.Paper, _extends({}, this.props, { zDepth: 3 }), React.createElement( 'h3', null, getMessage('home.53') ), React.createElement( 'div', { className: 'legend' }, getMessage('home.54'), React.createElement('br', null), getMessage('home.55') ), selector, form, add, React.createElement( 'div', { style: { position: 'absolute', bottom: 30, left: 10 } }, React.createElement(ReactMUI.FlatButton, { disabled: this.state.selectedIndex != 0, label: getMessage('home.56'), secondary: true, onClick: this.resetLayout }) ) ); } }); exports['default'] = GridBuilder = PydioContextConsumer(GridBuilder); exports['default'] = GridBuilder; module.exports = exports['default']; }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) },{"pydio":"pydio","react":"react"}],4:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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; }; exports['default'] = { propTypes: { showCloseAction: React.PropTypes.bool, onCloseAction: React.PropTypes.func }, focusItem: function focusItem() { this.setState({ focus: true }); }, blurItem: function blurItem() { this.setState({ focus: false }); }, mergeStyleWithFocus: function mergeStyleWithFocus() { return _extends({}, this.props.style, { zIndex: this.state.focus ? 1 : null }); }, getInitialSate: function getInitialSate() { return { focus: false, showCloseAction: false }; }, toggleEditMode: function toggleEditMode() { var value = arguments.length <= 0 || arguments[0] === undefined ? undefined : arguments[0]; if (value === undefined) { this.setState({ showCloseAction: !(this.state && this.state.showCloseAction) }); } else { this.setState({ showCloseAction: value }); } }, getCloseButton: function getCloseButton() { if (this.state && this.state.showCloseAction) { var closeAction = this.props.onCloseAction || function () {}; var overlayStyle = { position: 'absolute', backgroundColor: 'rgba(0,0,0,0.53)', zIndex: 10, top: 0, left: 0, bottom: 0, right: 0, display: 'flex', alignItems: 'center', justifyContent: 'center' }; return React.createElement( 'div', { style: overlayStyle }, React.createElement(MaterialUI.FlatButton, { label: pydio.MessageHash['ajxp_admin.home.48'], className: 'card-close-button', onTouchTap: closeAction, style: { color: 'white' } }) ); } else { return null; } }, statics: { getGridLayout: function getGridLayout(x, y) { return { x: x || 0, y: y || 0, w: this.gridWidth || 4, h: this.gridHeight || 12, isResizable: false }; }, hasBuilderFields: function hasBuilderFields() { return this.builderFields ? true : false; }, getBuilderFields: function getBuilderFields() { return this.builderFields; } } }; module.exports = exports['default']; },{}],5:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var Store = (function (_Observable) { _inherits(Store, _Observable); /** * Init a card store * @param prefNamespace Namespace for getting/setting user preferences * @param defaultCards Array of cards to be displayed by default */ function Store(prefNamespace, defaultCards, pydioObject) { _classCallCheck(this, Store); _Observable.call(this); this._namespace = prefNamespace; this._pydio = pydioObject; this._cards = this.getUserPreference("Cards"); if (!this._cards) { this._cards = defaultCards; } } Store.prototype.getUserPreference = function getUserPreference(prefName) { var prefKey = this._namespace + prefName; var guiPrefs = this._pydio.user.getPreference('gui_preferences', true); if (guiPrefs && guiPrefs[prefKey]) { return guiPrefs[prefKey]; } else { return null; } }; Store.prototype.saveUserPreference = function saveUserPreference(prefName, prefValue) { var prefKey = this._namespace + prefName; var guiPrefs = this._pydio.user.getPreference('gui_preferences', true); if (!guiPrefs) guiPrefs = {}; guiPrefs[prefKey] = prefValue; this._pydio.user.setPreference('gui_preferences', guiPrefs, true); this._pydio.user.savePreference('gui_preferences'); }; Store.prototype.saveCards = function saveCards(cards) { this.saveUserPreference('Cards', cards); }; Store.prototype.resetCards = function resetCards() { this.saveUserPreference('Cards', null); }; Store.prototype.setCards = function setCards(newCards) { this._cards = newCards; this.notify("cards", this._cards); this.saveCards(newCards); }; Store.prototype.getCards = function getCards() { return this._cards; }; Store.prototype.removeCard = function removeCard(cardId) { var index = -1; var currentCards = this.getCards(); currentCards.map(function (card, arrayIndex) { if (card.id == cardId) index = arrayIndex; }); if (index == -1) { console.warn('Card ID not found, this is strange.', cardId); return; } var newCards; if (index == 0) newCards = currentCards.slice(1);else if (index == currentCards.length - 1) newCards = currentCards.slice(0, -1);else newCards = currentCards.slice(0, index).concat(currentCards.slice(index + 1)); this.setCards(newCards); }; Store.prototype.createCardId = function createCardId(cardDefinition) { var randomize = arguments.length <= 1 || arguments[1] === undefined ? false : arguments[1]; var id = LangUtils.computeStringSlug(cardDefinition['title']); if (randomize) { id += '-' + Math.round(Math.random() * 100 + 10); } var alreadyExists = false; this._cards.map((function (card) { if (card.id == id) alreadyExists = true; }).bind(this)); if (alreadyExists) { id = this.createCardId(cardDefinition, true); } return id; }; Store.prototype.addCard = function addCard(cardDefinition) { //console.log(cardDefinition); cardDefinition['id'] = this.createCardId(cardDefinition); this.setCards(this._cards.concat([cardDefinition])); }; return Store; })(Observable); exports['default'] = Store; module.exports = exports['default']; },{}],6:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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 _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var _require = require('react'); var Component = _require.Component; var PropTypes = _require.PropTypes; var _require2 = require('material-ui'); var FlatButton = _require2.FlatButton; var _require3 = require('material-ui/styles'); var muiThemeable = _require3.muiThemeable; exports['default'] = function (PydioComponent, displayName) { var gridDimension = arguments.length <= 2 || arguments[2] === undefined ? { gridWidth: 4, gridHeight: 12 } : arguments[2]; var builderFields = arguments.length <= 3 || arguments[3] === undefined ? undefined : arguments[3]; var originalDisplayName = PydioComponent.displayName || PydioComponent.name; PydioComponent = muiThemeable()(PydioComponent); var GridItem = (function (_Component) { _inherits(GridItem, _Component); function GridItem(props, context) { _classCallCheck(this, GridItem); _Component.call(this, props, context); this.state = { focus: false, showCloseAction: false }; } GridItem.prototype.focusItem = function focusItem() { this.setState({ focus: true }); }; GridItem.prototype.blurItem = function blurItem() { this.setState({ focus: false }); }; GridItem.prototype.mergeStyleWithFocus = function mergeStyleWithFocus() { return _extends({}, this.props.style, { zIndex: this.state.focus ? 1 : null }); }; GridItem.prototype.toggleEditMode = function toggleEditMode() { var value = arguments.length <= 0 || arguments[0] === undefined ? undefined : arguments[0]; if (value === undefined) { this.setState({ showCloseAction: !(this.state && this.state.showCloseAction) }); } else { this.setState({ showCloseAction: value }); } }; GridItem.prototype.getCloseButton = function getCloseButton() { var closeAction = this.props.onCloseAction || function () {}; var overlayStyle = { position: 'absolute', backgroundColor: 'rgba(0,0,0,0.53)', zIndex: 10, top: 0, left: 0, bottom: 0, right: 0, display: 'flex', alignItems: 'center', justifyContent: 'center' }; return React.createElement( 'div', { style: overlayStyle }, React.createElement(FlatButton, { label: this.props.pydio.MessageHash['ajxp_admin.home.48'], className: 'card-close-button', onTouchTap: closeAction, style: { color: 'white' } }) ); }; GridItem.prototype.render = function render() { var props = _extends({}, this.props, { style: this.mergeStyleWithFocus(), closeButton: this.state.showCloseAction ? this.getCloseButton() : null, onFocusItem: this.focusItem.bind(this), onBlurItem: this.blurItem.bind(this) }); return React.createElement(PydioComponent, props); }; return GridItem; })(Component); GridItem.propTypes = { onCloseAction: PropTypes.func }; GridItem.displayName = originalDisplayName; GridItem.builderDisplayName = displayName; GridItem.getGridLayout = function (x, y) { return { x: x || 0, y: y || 0, w: gridDimension.gridWidth || 4, h: gridDimension.gridHeight || 12, isResizable: false }; }; GridItem.hasBuilderFields = function () { return builderFields !== undefined; }; GridItem.getBuilderFields = function () { return builderFields; }; return GridItem; }; module.exports = exports['default']; },{"material-ui":"material-ui","material-ui/styles":"material-ui/styles","react":"react"}],7:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ /** * Two columns layout used for Workspaces and Plugins editors */ 'use strict'; exports.__esModule = true; var PaperEditorLayout = React.createClass({ displayName: 'PaperEditorLayout', propTypes: { title: React.PropTypes.any, titleActionBar: React.PropTypes.any, leftNav: React.PropTypes.any, contentFill: React.PropTypes.bool, className: React.PropTypes.string }, toggleMenu: function toggleMenu() { var crtLeftOpen = this.state && this.state.forceLeftOpen; this.setState({ forceLeftOpen: !crtLeftOpen }); }, render: function render() { return React.createElement( 'div', { className: "paper-editor-content layout-fill vertical-layout" + (this.props.className ? ' ' + this.props.className : '') }, React.createElement( 'div', { className: 'paper-editor-title' }, React.createElement( 'h2', null, this.props.title, ' ', React.createElement( 'div', { className: 'left-picker-toggle' }, React.createElement(ReactMUI.IconButton, { iconClassName: 'icon-caret-down', onClick: this.toggleMenu }) ) ), React.createElement( 'div', { className: 'title-bar' }, this.props.titleActionBar ) ), React.createElement( 'div', { className: 'layout-fill main-layout-nav-to-stack' }, React.createElement( 'div', { className: "paper-editor-left" + (this.state && this.state.forceLeftOpen ? ' picker-open' : ''), onClick: this.toggleMenu }, this.props.leftNav ), React.createElement( 'div', { className: "layout-fill paper-editor-right" + (this.props.contentFill ? ' vertical-layout' : ''), style: this.props.contentFill ? {} : { overflowY: 'auto' } }, this.props.children ) ) ); } }); /** * Navigation subheader used by PaperEditorLayout */ var PaperEditorNavHeader = React.createClass({ displayName: 'PaperEditorNavHeader', propTypes: { label: React.PropTypes.string }, render: function render() { return React.createElement( 'div', { className: 'mui-subheader' }, this.props.children, this.props.label ); } }); /** * Navigation entry used by PaperEditorLayout. */ var PaperEditorNavEntry = React.createClass({ displayName: 'PaperEditorNavEntry', propTypes: { keyName: React.PropTypes.string.isRequired, onClick: React.PropTypes.func.isRequired, label: React.PropTypes.string, selectedKey: React.PropTypes.string, isLast: React.PropTypes.bool, // Drop Down Data dropDown: React.PropTypes.bool, dropDownData: React.PropTypes.object, dropDownChange: React.PropTypes.func, dropDownDefaultItems: React.PropTypes.array }, onClick: function onClick() { this.props.onClick(this.props.keyName); }, captureDropDownClick: function captureDropDownClick() { if (this.preventClick) { this.preventClick = false; return; } this.props.onClick(this.props.keyName); }, dropDownChange: function dropDownChange(event, index, item) { this.preventClick = true; this.props.dropDownChange(item); }, render: function render() { if (!this.props.dropDown || !this.props.dropDownData) { return React.createElement( 'div', { className: 'menu-entry' + (this.props.keyName == this.props.selectedKey ? ' menu-entry-selected' : '') + (this.props.isLast ? ' last' : ''), onClick: this.onClick }, this.props.children, this.props.label ); } // dropDown & dropDownData are loaded var menuItemsTpl = [{ text: this.props.label, payload: '-1' }]; if (this.props.dropDownDefaultItems) { menuItemsTpl = menuItemsTpl.concat(this.props.dropDownDefaultItems); } this.props.dropDownData.forEach(function (v, k) { menuItemsTpl.push({ text: v.label, payload: v }); }); return React.createElement( 'div', { onClick: this.captureDropDownClick, className: 'menu-entry-dropdown' + (this.props.keyName == this.props.selectedKey ? ' menu-entry-selected' : '') + (this.props.isLast ? ' last' : '') }, React.createElement(ReactMUI.DropDownMenu, { menuItems: menuItemsTpl, className: 'dropdown-full-width', style: { width: 256 }, autoWidth: false, onChange: this.dropDownChange }) ); } }); exports.PaperEditorLayout = PaperEditorLayout; exports.PaperEditorNavEntry = PaperEditorNavEntry; exports.PaperEditorNavHeader = PaperEditorNavHeader; },{}],8:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ "use strict"; exports.__esModule = true; function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var propTypes = { node: React.PropTypes.instanceOf(AjxpNode).isRequired, registry: React.PropTypes.instanceOf(Registry).isRequired, editorData: React.PropTypes.object.isRequired, icon: React.PropTypes.bool }; var defaultProps = { icon: false }; var ReactEditorOpener = (function (_React$Component) { _inherits(ReactEditorOpener, _React$Component); function ReactEditorOpener(props) { _classCallCheck(this, ReactEditorOpener); _React$Component.call(this, props); var node = props.node; var editorData = props.editorData; this.state = { ready: false }; } ReactEditorOpener.prototype.componentDidMount = function componentDidMount() { var _this = this; var _props = this.props; var editorData = _props.editorData; var registry = _props.registry; registry.loadEditorResources(editorData.resourcesManager, function () { return _this.setState({ ready: true }); }); }; ReactEditorOpener.prototype.render = function render() { var editorData = this.props.editorData; var ready = this.state.ready; if (!ready) return null; var EditorClass = null; if (!(EditorClass = FuncUtils.getFunctionByName(editorData.editorClass, window))) { return React.createElement( "div", null, "Cannot find editor component (" + editorData.editorClass + ")!" ); } // Getting HOC of the class return React.createElement(EditorClass.Editor, this.props); }; return ReactEditorOpener; })(React.Component); ReactEditorOpener.propTypes = propTypes; ReactEditorOpener.defaultProps = defaultProps; exports["default"] = ReactEditorOpener; module.exports = exports["default"]; },{}],9:[function(require,module,exports){ (function (global){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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; }; exports['default'] = React.createClass({ displayName: 'ClipboardTextField', propTypes: { floatingLabelText: React.PropTypes.string, inputValue: React.PropTypes.string, inputClassName: React.PropTypes.string, getMessage: React.PropTypes.func, inputCopyMessage: React.PropTypes.string }, getInitialState: function getInitialState() { return { copyMessage: null }; }, componentDidMount: function componentDidMount() { this.attachClipboard(); }, componentDidUpdate: function componentDidUpdate() { this.attachClipboard(); }, attachClipboard: function attachClipboard() { if (this._clip) { this._clip.destroy(); } if (!this.refs['copy-button']) { return; } this._clip = new Clipboard(this.refs['copy-button'], { text: (function (trigger) { return this.props.inputValue; }).bind(this) }); this._clip.on('success', (function () { this.setState({ copyMessage: this.props.getMessage(this.props.inputCopyMessage || '192') }, this.clearCopyMessage); }).bind(this)); this._clip.on('error', (function () { var copyMessage; if (global.navigator.platform.indexOf("Mac") === 0) { copyMessage = this.props.getMessage('144'); } else { copyMessage = this.props.getMessage('143'); } this.refs['input'].focus(); this.setState({ copyMessage: copyMessage }, this.clearCopyMessage); }).bind(this)); }, clearCopyMessage: function clearCopyMessage() { global.setTimeout((function () { this.setState({ copyMessage: '' }); }).bind(this), 3000); }, render: function render() { var select = function select(e) { e.currentTarget.select(); }; var copyMessage = null; if (this.state.copyMessage) { var setHtml = (function () { return { __html: this.state.copyMessage }; }).bind(this); copyMessage = React.createElement('div', { style: { color: 'rgba(0,0,0,0.23)' }, className: 'copy-message', dangerouslySetInnerHTML: setHtml() }); } var buttonStyle = _extends({ position: 'absolute', right: -8, bottom: 13, fontSize: 15, color: this.props.buttonColor || 'rgba(0, 150, 136, 0.52)', height: 26, width: 26, lineHeight: '28px', textAlign: 'center', cursor: 'pointer', borderRadius: '50%' }, this.props.buttonStyle); return React.createElement( 'div', null, React.createElement( 'div', { style: { position: 'relative' } }, React.createElement(MaterialUI.TextField, { fullWidth: true, ref: 'input', floatingLabelText: this.props.floatingLabelText, floatingLabelStyle: { whiteSpace: 'nowrap' }, underlineShow: this.props.underlineShow, defaultValue: this.props.inputValue, className: this.props.inputClassName, multiLine: this.props.multiLine, rows: this.props.rows, rowsMax: this.props.rowsMax, readOnly: true, onClick: select, style: { marginTop: -10, width: '92%', fontSize: 14 } }), React.createElement('span', { ref: 'copy-button', style: buttonStyle, title: this.props.getMessage('191'), className: 'copy-button mdi mdi-content-copy' }) ), copyMessage ); } }); module.exports = exports['default']; }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) },{}],10:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; exports['default'] = React.createClass({ displayName: 'LabelWithTip', propTypes: { label: React.PropTypes.string, labelElement: React.PropTypes.object, tooltip: React.PropTypes.string, tooltipClassName: React.PropTypes.string, className: React.PropTypes.string, style: React.PropTypes.object }, getInitialState: function getInitialState() { return { show: false }; }, show: function show() { this.setState({ show: true }); }, hide: function hide() { this.setState({ show: false }); }, render: function render() { if (this.props.tooltip) { var tooltipStyle = {}; if (this.props.label || this.props.labelElement) { if (this.state.show) { tooltipStyle = { bottom: -10, top: 'inherit' }; } } else { tooltipStyle = { position: 'relative' }; } var label = undefined; if (this.props.label) { label = React.createElement( 'span', { className: 'ellipsis-label' }, this.props.label ); } else if (this.props.labelElement) { label = this.props.labelElement; } var style = this.props.style || { position: 'relative' }; return React.createElement( 'span', { onMouseEnter: this.show, onMouseLeave: this.hide, style: style, className: this.props.className }, label, this.props.children, React.createElement(ReactMUI.Tooltip, { label: this.props.tooltip, style: tooltipStyle, className: this.props.tooltipClassName, show: this.state.show }) ); } else { if (this.props.label) { return React.createElement( 'span', null, this.props.label ); } else if (this.props.labelElement) { return this.props.labelElement; } else { return React.createElement( 'span', null, this.props.children ); } } } }); module.exports = exports['default']; },{}],11:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ /** * Simple MuiPaper with a figure and a legend */ 'use strict'; exports.__esModule = true; exports['default'] = React.createClass({ displayName: 'SimpleFigureBadge', propTypes: { colorIndicator: React.PropTypes.string, figure: React.PropTypes.number.isRequired, legend: React.PropTypes.string }, getDefaultProps: function getDefaultProps() { return { colorIndicator: '' }; }, render: function render() { return React.createElement( ReactMUI.Paper, { style: { display: 'inline-block', marginLeft: 16 } }, React.createElement( 'div', { className: 'figure-badge', style: this.props.colorIndicator ? { borderLeftColor: this.props.colorIndicator } : {} }, React.createElement( 'div', { className: 'figure' }, this.props.figure ), React.createElement( 'div', { className: 'legend' }, this.props.legend ) ) ); } }); module.exports = exports['default']; },{}],12:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } var _listSortableList = require('./list/SortableList'); var _listSortableList2 = _interopRequireDefault(_listSortableList); var _listSimpleList = require('./list/SimpleList'); var _listSimpleList2 = _interopRequireDefault(_listSimpleList); var _listNodeListCustomProvider = require('./list/NodeListCustomProvider'); var _listNodeListCustomProvider2 = _interopRequireDefault(_listNodeListCustomProvider); var _listListEntry = require('./list/ListEntry'); var _listListPaginator = require('./list/ListPaginator'); var _listListPaginator2 = _interopRequireDefault(_listListPaginator); var _viewsTreeView = require('./views/TreeView'); var _elementsLabelWithTip = require('./elements/LabelWithTip'); var _elementsLabelWithTip2 = _interopRequireDefault(_elementsLabelWithTip); var _elementsSimpleFigureBadge = require('./elements/SimpleFigureBadge'); var _elementsSimpleFigureBadge2 = _interopRequireDefault(_elementsSimpleFigureBadge); var _viewsSearchBox = require('./views/SearchBox'); var _viewsSearchBox2 = _interopRequireDefault(_viewsSearchBox); var _elementsClipboardTextField = require('./elements/ClipboardTextField'); var _elementsClipboardTextField2 = _interopRequireDefault(_elementsClipboardTextField); var _viewsEmptyStateView = require('./views/EmptyStateView'); var _viewsEmptyStateView2 = _interopRequireDefault(_viewsEmptyStateView); var _viewsModalAppBar = require('./views/ModalAppBar'); var _viewsModalAppBar2 = _interopRequireDefault(_viewsModalAppBar); var _editorReactEditorOpener = require('./editor/ReactEditorOpener'); var _editorReactEditorOpener2 = _interopRequireDefault(_editorReactEditorOpener); var _editorPaperEditor = require('./editor/PaperEditor'); var _dynamicGridDynamicGrid = require('./dynamic-grid/DynamicGrid'); var _dynamicGridDynamicGrid2 = _interopRequireDefault(_dynamicGridDynamicGrid); var _dynamicGridStore = require('./dynamic-grid/Store'); var _dynamicGridStore2 = _interopRequireDefault(_dynamicGridStore); var _dynamicGridGridItemMixin = require('./dynamic-grid/GridItemMixin'); var _dynamicGridGridItemMixin2 = _interopRequireDefault(_dynamicGridGridItemMixin); var _dynamicGridAsGridItem = require('./dynamic-grid/asGridItem'); var _dynamicGridAsGridItem2 = _interopRequireDefault(_dynamicGridAsGridItem); var _utilDND = require('./util/DND'); var _usersAvatarUserAvatar = require('./users/avatar/UserAvatar'); var _usersAvatarUserAvatar2 = _interopRequireDefault(_usersAvatarUserAvatar); var _usersUsersCompleter = require('./users/UsersCompleter'); var _usersUsersCompleter2 = _interopRequireDefault(_usersUsersCompleter); var _usersTeamCreationForm = require('./users/TeamCreationForm'); var _usersTeamCreationForm2 = _interopRequireDefault(_usersTeamCreationForm); var _menuButtonMenu = require('./menu/ButtonMenu'); var _menuButtonMenu2 = _interopRequireDefault(_menuButtonMenu); var _menuContextMenu = require('./menu/ContextMenu'); var _menuContextMenu2 = _interopRequireDefault(_menuContextMenu); var _menuIconButtonMenu = require('./menu/IconButtonMenu'); var _menuIconButtonMenu2 = _interopRequireDefault(_menuIconButtonMenu); var _menuToolbar = require('./menu/Toolbar'); var _menuToolbar2 = _interopRequireDefault(_menuToolbar); var _usersAddressbookAddressBook = require('./users/addressbook/AddressBook'); var _usersAddressbookAddressBook2 = _interopRequireDefault(_usersAddressbookAddressBook); var PydioComponents = { SortableList: _listSortableList2['default'], SimpleList: _listSimpleList2['default'], NodeListCustomProvider: _listNodeListCustomProvider2['default'], ListEntry: _listListEntry.ListEntry, ListPaginator: _listListPaginator2['default'], TreeView: _viewsTreeView.TreeView, DNDTreeView: _viewsTreeView.DNDTreeView, FoldersTree: _viewsTreeView.FoldersTree, ClipboardTextField: _elementsClipboardTextField2['default'], LabelWithTip: _elementsLabelWithTip2['default'], EmptyStateView: _viewsEmptyStateView2['default'], SimpleFigureBadge: _elementsSimpleFigureBadge2['default'], SearchBox: _viewsSearchBox2['default'], ModalAppBar: _viewsModalAppBar2['default'], ReactEditorOpener: _editorReactEditorOpener2['default'], PaperEditorLayout: _editorPaperEditor.PaperEditorLayout, PaperEditorNavEntry: _editorPaperEditor.PaperEditorNavEntry, PaperEditorNavHeader: _editorPaperEditor.PaperEditorNavHeader, DynamicGrid: _dynamicGridDynamicGrid2['default'], DynamicGridItemMixin: _dynamicGridGridItemMixin2['default'], asGridItem: _dynamicGridAsGridItem2['default'], DynamicGridStore: _dynamicGridStore2['default'], DND: { Types: _utilDND.Types, collect: _utilDND.collect, collectDrop: _utilDND.collectDrop, nodeDragSource: _utilDND.nodeDragSource, nodeDropTarget: _utilDND.nodeDropTarget, DNDActionParameter: _utilDND.DNDActionParameter }, DNDActionParameter: _utilDND.DNDActionParameter, UserAvatar: _usersAvatarUserAvatar2['default'], UsersCompleter: _usersUsersCompleter2['default'], TeamCreationForm: _usersTeamCreationForm2['default'], AddressBook: _usersAddressbookAddressBook2['default'], ContextMenu: _menuContextMenu2['default'], Toolbar: _menuToolbar2['default'], ButtonMenu: _menuButtonMenu2['default'], IconButtonMenu: _menuIconButtonMenu2['default'] }; exports['default'] = PydioComponents; module.exports = exports['default']; },{"./dynamic-grid/DynamicGrid":2,"./dynamic-grid/GridItemMixin":4,"./dynamic-grid/Store":5,"./dynamic-grid/asGridItem":6,"./editor/PaperEditor":7,"./editor/ReactEditorOpener":8,"./elements/ClipboardTextField":9,"./elements/LabelWithTip":10,"./elements/SimpleFigureBadge":11,"./list/ListEntry":15,"./list/ListPaginator":17,"./list/NodeListCustomProvider":18,"./list/SimpleList":19,"./list/SortableList":21,"./menu/ButtonMenu":24,"./menu/ContextMenu":25,"./menu/IconButtonMenu":26,"./menu/Toolbar":30,"./users/TeamCreationForm":32,"./users/UsersCompleter":33,"./users/addressbook/AddressBook":34,"./users/avatar/UserAvatar":46,"./util/DND":47,"./views/EmptyStateView":49,"./views/ModalAppBar":50,"./views/SearchBox":51,"./views/TreeView":53}],13:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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 _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _ListEntryNodeListenerMixin = require('./ListEntryNodeListenerMixin'); var _ListEntryNodeListenerMixin2 = _interopRequireDefault(_ListEntryNodeListenerMixin); var _InlineEditor = require('./InlineEditor'); var _InlineEditor2 = _interopRequireDefault(_InlineEditor); var _ListEntry = require('./ListEntry'); var _materialUi = require('material-ui'); /** * Callback based material list entry with custom icon render, firstLine, secondLine, etc. */ exports['default'] = _react2['default'].createClass({ displayName: 'ConfigurableListEntry', mixins: [_ListEntryNodeListenerMixin2['default']], propTypes: { node: _react2['default'].PropTypes.instanceOf(AjxpNode), // SEE ALSO ListEntry PROPS renderIcon: _react2['default'].PropTypes.func, renderFirstLine: _react2['default'].PropTypes.func, renderSecondLine: _react2['default'].PropTypes.func, renderThirdLine: _react2['default'].PropTypes.func, renderActions: _react2['default'].PropTypes.func, style: _react2['default'].PropTypes.object }, render: function render() { var _this = this; var icon = undefined, firstLine = undefined, secondLine = undefined, thirdLine = undefined, style = this.props.style || {}; if (this.props.renderIcon) { icon = this.props.renderIcon(this.props.node, this.props); } else { var node = this.props.node; var iconClass = node.getMetadata().get("icon_class") ? node.getMetadata().get("icon_class") : node.isLeaf() ? "icon-file-alt" : "icon-folder-close"; icon = _react2['default'].createElement(_materialUi.FontIcon, { className: iconClass }); } if (this.props.renderFirstLine) { firstLine = this.props.renderFirstLine(this.props.node); } else { firstLine = this.props.node.getLabel(); } if (this.state && this.state.inlineEdition) { firstLine = _react2['default'].createElement( 'span', null, _react2['default'].createElement(_InlineEditor2['default'], { node: this.props.node, onClose: function () { _this.setState({ inlineEdition: false }); }, callback: this.state.inlineEditionCallback }), firstLine ); style.position = 'relative'; } if (this.props.renderSecondLine) { secondLine = this.props.renderSecondLine(this.props.node); } if (this.props.renderThirdLine) { thirdLine = this.props.renderThirdLine(this.props.node); } var actions = this.props.actions; if (this.props.renderActions) { actions = this.props.renderActions(this.props.node); } return _react2['default'].createElement(_ListEntry.DragDropListEntry, _extends({}, this.props, { iconCell: icon, firstLine: firstLine, secondLine: secondLine, thirdLine: thirdLine, actions: actions, style: style })); } }); module.exports = exports['default']; },{"./InlineEditor":14,"./ListEntry":15,"./ListEntryNodeListenerMixin":16,"material-ui":"material-ui","react":"react"}],14:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; var React = require('react'); var Pydio = require('pydio'); var AjxpNode = require('pydio/model/node'); var _Pydio$requireLib = Pydio.requireLib('boot'); var PydioContextConsumer = _Pydio$requireLib.PydioContextConsumer; var _require = require('material-ui'); var Paper = _require.Paper; var TextField = _require.TextField; var FlatButton = _require.FlatButton; var InlineEditor = React.createClass({ displayName: 'InlineEditor', propTypes: { node: React.PropTypes.instanceOf(AjxpNode), callback: React.PropTypes.func, onClose: React.PropTypes.func, detached: React.PropTypes.bool }, submit: function submit() { if (!this.state || !this.state.value || this.state.value === this.props.node.getLabel()) { this.setState({ errorString: 'Please use a different value for renaming!' }); this.props.getPydio().displayMessage('ERROR', 'Please use a different value for renaming!'); } else { this.props.callback(this.state.value); this.props.onClose(); } }, componentDidMount: function componentDidMount() { this.refs.text.focus(); }, catchClicks: function catchClicks(e) { e.stopPropagation(); }, onKeyDown: function onKeyDown(e) { if (e.key === 'Enter') { this.submit(); } this.setState({ errorString: '' }); e.stopPropagation(); }, render: function render() { var _this = this; return React.createElement( Paper, { className: "inline-editor" + (this.props.detached ? " detached" : ""), style: { padding: 8 }, zDepth: 2 }, React.createElement(TextField, { ref: 'text', defaultValue: this.props.node.getLabel(), onChange: function (e, value) { _this.setState({ value: value }); }, onClick: this['catch'], onDoubleClick: this.catchClicks, tabIndex: '0', onKeyDown: this.onKeyDown, errorText: this.state ? this.state.errorString : null }), React.createElement( 'div', { style: { textAlign: 'right', paddingTop: 8 } }, React.createElement(FlatButton, { label: 'Cancel', onClick: this.props.onClose }), React.createElement(FlatButton, { label: 'Submit', onClick: this.submit }) ) ); } }); exports['default'] = InlineEditor = PydioContextConsumer(InlineEditor); exports['default'] = InlineEditor; module.exports = exports['default']; },{"material-ui":"material-ui","pydio":"pydio","pydio/model/node":"pydio/model/node","react":"react"}],15:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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 _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var _reactDom = require('react-dom'); var _reactDom2 = _interopRequireDefault(_reactDom); var _utilDND = require('../util/DND'); var _reactDnd = require('react-dnd'); var _materialUi = require('material-ui'); var _materialUiStyles = require('material-ui/styles'); var _color = require('color'); var _color2 = _interopRequireDefault(_color); /** * Material List Entry */ var ListEntry = (function (_React$Component) { _inherits(ListEntry, _React$Component); function ListEntry() { _classCallCheck(this, ListEntry); _React$Component.apply(this, arguments); } ListEntry.prototype.onClick = function onClick(event) { if (this.props.showSelector) { if (this.props.selectorDisabled) return; this.props.onSelect(this.props.node, event); event.stopPropagation(); event.preventDefault(); } else if (this.props.onClick) { this.props.onClick(this.props.node, event); } }; ListEntry.prototype.onDoubleClick = function onDoubleClick(event) { if (this.props.onDoubleClick) { this.props.onDoubleClick(this.props.node, event); } }; ListEntry.prototype.render = function render() { var _this = this; var selector = undefined, icon = undefined, additionalClassName = undefined; var _props = this.props; var node = _props.node; var showSelector = _props.showSelector; var selected = _props.selected; var selectorDisabled = _props.selectorDisabled; var firstLine = _props.firstLine; var secondLine = _props.secondLine; var thirdLine = _props.thirdLine; var style = _props.style; var actions = _props.actions; var iconCell = _props.iconCell; var mainIcon = _props.mainIcon; var className = _props.className; var canDrop = _props.canDrop; var isOver = _props.isOver; var connectDragSource = _props.connectDragSource; var connectDropTarget = _props.connectDropTarget; var mainClasses = ['material-list-entry', 'material-list-entry-' + (thirdLine ? 3 : secondLine ? 2 : 1) + '-lines']; if (className) mainClasses.push(className); if (showSelector) { selector = React.createElement( 'div', { className: 'material-list-selector' }, React.createElement(_materialUi.Checkbox, { checked: selected, ref: 'selector', disabled: selectorDisabled }) ); } if (iconCell) { icon = this.props.iconCell; } else if (this.props.mainIcon) { icon = React.createElement(_materialUi.FontIcon, { className: "mui-font-icon " + this.props.mainIcon, style: { fontSize: 18 /*, color: "#FFFFFF"*/ } }); } if (canDrop && isOver) { mainClasses.push('droppable-active'); } if (node) { mainClasses.push('listentry' + node.getPath().replace(/\//g, '_')); mainClasses.push('ajxp_node_' + (node.isLeaf() ? 'leaf' : 'collection')); if (node.getAjxpMime()) { mainClasses.push('ajxp_mime_' + node.getAjxpMime()); } } var additionalStyle = { /*transition:'background-color 250ms cubic-bezier(0.23, 1, 0.32, 1) 0ms, color 250ms cubic-bezier(0.23, 1, 0.32, 1) 0ms'*/ }; if (this.state && this.state.hover && !this.props.noHover) { additionalStyle = _extends({}, additionalStyle, { backgroundColor: 'rgba(0,0,0,0.05)', borderBottom: '1px solid transparent' }); } if (selected) { var selectionColor = this.props.muiTheme.palette.accent2Color; var selectionColorDark = _color2['default'](selectionColor).dark(); additionalStyle = _extends({}, additionalStyle, { backgroundColor: selectionColor, color: selectionColorDark ? 'white' : 'rgba(0,0,0,.87)' }); mainClasses.push('selected'); mainClasses.push('selected-' + (selectionColorDark ? 'dark' : 'light')); } return React.createElement( ContextMenuWrapper, _extends({}, this.props, { ref: function (instance) { var node = _reactDom2['default'].findDOMNode(instance); if (typeof connectDropTarget === 'function') connectDropTarget(node); if (typeof connectDragSource === 'function') connectDragSource(node); }, onClick: this.onClick.bind(this), onDoubleClick: showSelector ? null : this.onDoubleClick.bind(this), className: mainClasses.join(' '), onMouseOver: function () { _this.setState({ hover: true }); }, onMouseOut: function () { _this.setState({ hover: false }); }, style: _extends({}, style, additionalStyle) }), selector, React.createElement( 'div', { className: "material-list-icon" + (mainIcon || iconCell ? "" : " material-list-icon-none") }, icon ), React.createElement( 'div', { className: 'material-list-text' }, React.createElement( 'div', { key: 'line-1', className: 'material-list-line-1' }, firstLine ), React.createElement( 'div', { key: 'line-2', className: 'material-list-line-2' }, secondLine ), React.createElement( 'div', { key: 'line-3', className: 'material-list-line-3' }, thirdLine ) ), React.createElement( 'div', { className: 'material-list-actions' }, actions ) ); }; return ListEntry; })(React.Component); var ContextMenuWrapper = function ContextMenuWrapper(props) { return React.createElement('div', props); }; ContextMenuWrapper = PydioHOCs.withContextMenu(ContextMenuWrapper); ListEntry.propTypes = { showSelector: React.PropTypes.bool, selected: React.PropTypes.bool, selectorDisabled: React.PropTypes.bool, onSelect: React.PropTypes.func, onClick: React.PropTypes.func, iconCell: React.PropTypes.element, mainIcon: React.PropTypes.string, firstLine: React.PropTypes.node, secondLine: React.PropTypes.node, thirdLine: React.PropTypes.node, actions: React.PropTypes.element, activeDroppable: React.PropTypes.bool, className: React.PropTypes.string, style: React.PropTypes.object, noHover: React.PropTypes.bool }; exports.ListEntry = ListEntry = _materialUiStyles.muiThemeable()(ListEntry); var DragDropListEntry = _reactDnd.flow(_reactDnd.DragSource(_utilDND.Types.NODE_PROVIDER, _utilDND.nodeDragSource, _utilDND.collect), _reactDnd.DropTarget(_utilDND.Types.NODE_PROVIDER, _utilDND.nodeDropTarget, _utilDND.collectDrop))(ListEntry); exports.DragDropListEntry = DragDropListEntry; exports.ListEntry = ListEntry; },{"../util/DND":47,"color":"color","material-ui":"material-ui","material-ui/styles":"material-ui/styles","react-dnd":"react-dnd","react-dom":"react-dom"}],16:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ "use strict"; exports.__esModule = true; exports["default"] = { attach: function attach(node) { this._nodeListener = (function () { if (!this.isMounted()) { this.detach(node); return; } this.forceUpdate(); }).bind(this); this._actionListener = (function (eventMemo) { if (!this.isMounted()) { this.detach(node); return; } if (eventMemo && eventMemo.type === 'prompt-rename' && eventMemo.callback) { this.setState({ inlineEdition: true, inlineEditionCallback: eventMemo.callback }); } return true; }).bind(this); node.observe("node_replaced", this._nodeListener); node.observe("node_action", this._actionListener); }, detach: function detach(node) { if (this._nodeListener) { node.stopObserving("node_replaced", this._nodeListener); node.stopObserving("node_action", this._actionListener); } }, componentDidMount: function componentDidMount() { this.attach(this.props.node); }, componentWillUnmount: function componentWillUnmount() { this.detach(this.props.node); } }; module.exports = exports["default"]; },{}],17:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ "use strict"; exports.__esModule = true; function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } var _utilMessagesConsumerMixin = require('../util/MessagesConsumerMixin'); var _utilMessagesConsumerMixin2 = _interopRequireDefault(_utilMessagesConsumerMixin); /** * Pagination component reading metadata "paginationData" from current node. */ exports["default"] = React.createClass({ displayName: "ListPaginator", mixins: [_utilMessagesConsumerMixin2["default"]], propTypes: { dataModel: React.PropTypes.instanceOf(PydioDataModel).isRequired, node: React.PropTypes.instanceOf(AjxpNode) }, componentDidMount: function componentDidMount() { var _this = this; if (!this.props.node) { (function () { var dm = _this.props.dataModel; _this._dmObserver = (function () { this.setState({ node: dm.getContextNode() }); }).bind(_this); dm.observe("context_changed", _this._dmObserver); _this.setState({ node: dm.getContextNode() }); })(); } }, componentWillUnmount: function componentWillUnmount() { if (this._dmObserver) { this.props.dataModel.stopObserving("context_changed", this._dmObserver); } }, getInitialState: function getInitialState() { return { node: this.props.node }; }, changePage: function changePage(event) { this.state.node.getMetadata().get("paginationData").set("new_page", event.currentTarget.getAttribute('data-page')); this.props.dataModel.requireContextChange(this.state.node); }, onMenuChange: function onMenuChange(event, index, item) { this.state.node.getMetadata().get("paginationData").set("new_page", item.payload); this.props.dataModel.requireContextChange(this.state.node); }, render: function render() { if (!this.state.node || !this.state.node.getMetadata().get("paginationData")) { return null; } var pData = this.state.node.getMetadata().get("paginationData"); var current = parseInt(pData.get("current")); var total = parseInt(pData.get("total")); var pages = [], next, last, previous, first; var pageWord = this.context.getMessage ? this.context.getMessage('331', '') : this.props.getMessage('331', ''); for (var i = 1; i <= total; i++) { pages.push({ payload: i, text: pageWord + ' ' + i + (i == current ? ' / ' + total : '') }); } if (pages.length <= 1) { return null; } var sep = undefined; if (this.props.toolbarDisplay) { if (current > 1) previous = React.createElement( "span", { className: "toolbars-button-menu" }, React.createElement(ReactMUI.IconButton, { onClick: this.changePage, "data-page": current - 1, iconClassName: "icon-caret-left" }) ); if (current < total) next = React.createElement( "span", { className: "toolbars-button-menu" }, React.createElement(ReactMUI.IconButton, { onClick: this.changePage, "data-page": current + 1, iconClassName: "icon-caret-right" }) ); } else { if (current > 1) previous = React.createElement(ReactMUI.FontIcon, { onClick: this.changePage, "data-page": current - 1, className: "icon-angle-left" }); if (current < total) next = React.createElement(ReactMUI.FontIcon, { onClick: this.changePage, "data-page": current + 1, className: "icon-angle-right" }); sep = React.createElement( "span", { className: "mui-toolbar-separator" }, " " ); } return React.createElement( "span", { id: this.props.id, style: this.props.style }, first, previous, React.createElement(ReactMUI.DropDownMenu, { onChange: this.onMenuChange, menuItems: pages, selectedIndex: current - 1 }), next, last, sep ); } }); module.exports = exports["default"]; },{"../util/MessagesConsumerMixin":48}],18:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ "use strict"; exports.__esModule = true; 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 _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } var _SimpleList = require('./SimpleList'); var _SimpleList2 = _interopRequireDefault(_SimpleList); /** * Simple to use list component encapsulated with its own query mechanism * using a set of properties for the remote node provider. */ exports["default"] = React.createClass({ displayName: "NodeListCustomProvider", propTypes: { nodeProviderProperties: React.PropTypes.object, presetDataModel: React.PropTypes.instanceOf(PydioDataModel), autoRefresh: React.PropTypes.number, actionBarGroups: React.PropTypes.array, heightAutoWithMax: React.PropTypes.number, elementHeight: React.PropTypes.number.isRequired, nodeClicked: React.PropTypes.func, reloadOnServerMessage: React.PropTypes.string, entryRenderAsCard: React.PropTypes.func }, reload: function reload() { if (this.refs.list && this.isMounted()) { this.refs.list.reload(); } }, componentWillUnmount: function componentWillUnmount() { if (this._smObs) { this.props.pydio.stopObserving("server_message", this._smObs); this.props.pydio.stopObserving("server_message:" + this.props.reloadOnServerMessage, this.reload); } }, componentWillReceiveProps: function componentWillReceiveProps(nextProps) { if (this.props.nodeProviderProperties && this.props.nodeProviderProperties !== nextProps.nodeProviderProperties) { var _state = this.state; var dataModel = _state.dataModel; var node = _state.node; var provider = new RemoteNodeProvider(nextProps.nodeProviderProperties); dataModel.setAjxpNodeProvider(provider); node.updateProvider(provider); this.setState({ dataModel: dataModel, node: node }); } else if (this.props.presetDataModel !== nextProps.presetDataModel) { this.setState({ dataModel: nextProps.presetDataModel, node: nextProps.presetDataModel.getRootNode() }); } }, getInitialState: function getInitialState() { var dataModel = undefined; if (this.props.presetDataModel) { dataModel = this.props.presetDataModel; } else { dataModel = PydioDataModel.RemoteDataModelFactory(this.props.nodeProviderProperties); } var rootNode = dataModel.getRootNode(); if (this.props.nodeClicked) { // leaf this.openEditor = (function (node) { this.props.nodeClicked(node); return false; }).bind(this); // dir dataModel.observe("selection_changed", (function (event) { var selectedNodes = event.memo.getSelectedNodes(); if (selectedNodes.length) { this.props.nodeClicked(selectedNodes[0]); event.memo.setSelectedNodes([]); } }).bind(this)); } if (this.props.reloadOnServerMessage && this.props.pydio) { this._smObs = (function (event) { if (XMLUtils.XPathSelectSingleNode(event, this.props.reloadOnServerMessage)) this.reload(); }).bind(this); this.props.pydio.observe("server_message", this._smObs); this.props.pydio.observe("server_message:" + this.props.reloadOnServerMessage, this.reload); } return { node: rootNode, dataModel: dataModel }; }, render: function render() { var legend; if (this.props.legend) { legend = React.createElement( "div", { className: "subtitle" }, this.props.legend ); } return React.createElement( "div", { className: this.props.heightAutoWithMax ? "" : "layout-fill vertical-layout" }, React.createElement(_SimpleList2["default"], _extends({}, this.props, { openEditor: this.openEditor, ref: "list", style: Object.assign({ height: '100%' }, this.props.style || {}), node: this.state.node, dataModel: this.state.dataModel, actionBarGroups: this.props.actionBarGroups, skipParentNavigation: true, observeNodeReload: true })) ); } }); module.exports = exports["default"]; },{"./SimpleList":19}],19:[function(require,module,exports){ (function (global){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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 _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } var _reactScrollbar = require('react-scrollbar'); var _reactScrollbar2 = _interopRequireDefault(_reactScrollbar); var _utilMessagesConsumerMixin = require('../util/MessagesConsumerMixin'); var _utilMessagesConsumerMixin2 = _interopRequireDefault(_utilMessagesConsumerMixin); var _ListEntry = require('./ListEntry'); var _TableListEntry = require('./TableListEntry'); var _TableListEntry2 = _interopRequireDefault(_TableListEntry); var _TableListHeader = require('./TableListHeader'); var _TableListHeader2 = _interopRequireDefault(_TableListHeader); var _ConfigurableListEntry = require('./ConfigurableListEntry'); var _ConfigurableListEntry2 = _interopRequireDefault(_ConfigurableListEntry); var _SortColumns = require('./SortColumns'); var _SortColumns2 = _interopRequireDefault(_SortColumns); var _ListPaginator = require('./ListPaginator'); var _ListPaginator2 = _interopRequireDefault(_ListPaginator); var _viewsSimpleReactActionBar = require('../views/SimpleReactActionBar'); var _viewsSimpleReactActionBar2 = _interopRequireDefault(_viewsSimpleReactActionBar); var _InlineEditor = require('./InlineEditor'); var _InlineEditor2 = _interopRequireDefault(_InlineEditor); var _viewsEmptyStateView = require('../views/EmptyStateView'); var _viewsEmptyStateView2 = _interopRequireDefault(_viewsEmptyStateView); var React = require('react'); var Infinite = require('react-infinite'); var DOMUtils = require('pydio/util/dom'); var LangUtils = require('pydio/util/lang'); var PydioDataModel = require('pydio/model/data-model'); var PeriodicalExecuter = require('pydio/util/periodical-executer'); /** * Generic List component, using Infinite for cell virtualization, pagination, various * displays, etc... It provides many hooks for rendering cells on-demand. */ var SimpleList = React.createClass({ displayName: 'SimpleList', mixins: [_utilMessagesConsumerMixin2['default']], propTypes: { infiniteSliceCount: React.PropTypes.number, filterNodes: React.PropTypes.func, customToolbar: React.PropTypes.object, tableKeys: React.PropTypes.object, autoRefresh: React.PropTypes.number, reloadAtCursor: React.PropTypes.bool, clearSelectionOnReload: React.PropTypes.bool, heightAutoWithMax: React.PropTypes.number, containerHeight: React.PropTypes.number, observeNodeReload: React.PropTypes.bool, defaultGroupBy: React.PropTypes.string, defaultGroupByLabel: React.PropTypes.string, defaultSortingInfo: React.PropTypes.object, skipParentNavigation: React.PropTypes.bool, skipInternalDataModel: React.PropTypes.bool, delayInitialLoad: React.PropTypes.number, entryEnableSelector: React.PropTypes.func, renderCustomEntry: React.PropTypes.func, entryRenderIcon: React.PropTypes.func, entryRenderActions: React.PropTypes.func, entryRenderFirstLine: React.PropTypes.func, entryRenderSecondLine: React.PropTypes.func, entryRenderThirdLine: React.PropTypes.func, entryHandleClicks: React.PropTypes.func, hideToolbar: React.PropTypes.bool, computeActionsForNode: React.PropTypes.bool, multipleActions: React.PropTypes.array, openEditor: React.PropTypes.func, openCollection: React.PropTypes.func, elementStyle: React.PropTypes.object, passScrollingStateToChildren: React.PropTypes.bool, elementHeight: React.PropTypes.oneOfType([React.PropTypes.number, React.PropTypes.object]).isRequired }, statics: { HEIGHT_ONE_LINE: 50, HEIGHT_TWO_LINES: 73, CLICK_TYPE_SIMPLE: 'simple', CLICK_TYPE_DOUBLE: 'double', PARENT_FOLDER_ICON: 'mdi mdi-chevron-left' }, getDefaultProps: function getDefaultProps() { return { infiniteSliceCount: 30, clearSelectionOnReload: true }; }, clickRow: function clickRow(gridRow, event) { var node = undefined; if (gridRow.props) { node = gridRow.props.data.node; } else { node = gridRow; } if (this.props.entryHandleClicks) { this.props.entryHandleClicks(node, SimpleList.CLICK_TYPE_SIMPLE, event); return; } if (node.isLeaf() && this.props.openEditor) { if (this.props.openEditor(node) === false) { return; } var uniqueSelection = new Map(); uniqueSelection.set(node, true); this.setState({ selection: uniqueSelection }, this.rebuildLoadedElements); } else if (!node.isLeaf()) { if (this.props.openCollection) { this.props.openCollection(node); } else { this.props.dataModel.setSelectedNodes([node]); } } }, doubleClickRow: function doubleClickRow(gridRow, event) { var node = undefined; if (gridRow.props) { node = gridRow.props.data.node; } else { node = gridRow; } if (this.props.entryHandleClicks) { this.props.entryHandleClicks(node, SimpleList.CLICK_TYPE_DOUBLE, event); } }, onColumnSort: function onColumnSort(column) { var stateSetCallback = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; var pagination = this.props.node.getMetadata().get('paginationData'); if (pagination && pagination.get('total') > 1 && pagination.get('remote_order')) { var dir = 'asc'; if (this.props.node.getMetadata().get('paginationData').get('currentOrderDir')) { dir = this.props.node.getMetadata().get('paginationData').get('currentOrderDir') === 'asc' ? 'desc' : 'asc'; } var orderData = new Map(); orderData.set('order_column', column['remoteSortAttribute'] ? column.remoteSortAttribute : column.name); orderData.set('order_direction', dir); this.props.node.getMetadata().set("remote_order", orderData); this.props.dataModel.requireContextChange(this.props.node, true); } else { var att = column['sortAttribute'] ? column['sortAttribute'] : column.name; var sortingInfo = undefined; var _state$sortingInfo = this.state.sortingInfo; var attribute = _state$sortingInfo.attribute; var direction = _state$sortingInfo.direction; if (attribute === att && direction) { if (direction === 'asc') { // Switch direction sortingInfo = { attribute: att, sortType: column.sortType, direction: 'desc' }; } else { // Reset sorting sortingInfo = this.props.defaultSortingInfo || {}; } } else { sortingInfo = { attribute: att, sortType: column.sortType, direction: 'asc' }; } this.setState({ sortingInfo: sortingInfo }, (function () { this.rebuildLoadedElements(); if (stateSetCallback) { stateSetCallback(); } }).bind(this)); } }, computeSelectionFromCurrentPlusTargetNode: function computeSelectionFromCurrentPlusTargetNode(currentSelection, targetNode) { var currentIndexStart = undefined, currentIndexEnd = undefined, nodeBefore = false; if (!this.indexedElements) { return []; } var firstSelected = currentSelection[0]; var lastSelected = currentSelection[currentSelection.length - 1]; var newSelection = []; for (var i = 0; i < this.indexedElements.length; i++) { if (currentIndexStart !== undefined) { newSelection.push(this.indexedElements[i].node); } if (this.indexedElements[i].node === targetNode) { if (currentIndexStart !== undefined && currentIndexEnd === undefined) { currentIndexEnd = i; break; } currentIndexStart = i; nodeBefore = true; newSelection.push(this.indexedElements[i].node); } if (this.indexedElements[i].node === firstSelected && currentIndexStart === undefined) { currentIndexStart = i; newSelection.push(this.indexedElements[i].node); } if (this.indexedElements[i].node === lastSelected && nodeBefore) { currentIndexEnd = i; break; } } return newSelection; }, onKeyDown: function onKeyDown(e) { var currentIndexStart = undefined, currentIndexEnd = undefined; var contextHolder = window.pydio.getContextHolder(); var elementsPerLine = this.props.elementsPerLine || 1; var shiftKey = e.shiftKey; var key = e.key; if (contextHolder.isEmpty() || !this.indexedElements) { return; } var downKeys = ['ArrowDown', 'ArrowRight', 'PageDown', 'End']; var position = shiftKey && downKeys.indexOf(key) > -1 ? 'first' : 'last'; var currentSelection = contextHolder.getSelectedNodes(); var firstSelected = currentSelection[0]; var lastSelected = currentSelection[currentSelection.length - 1]; if (key === 'Enter') { this.doubleClickRow(firstSelected); return; } if (key === 'Delete' && global.pydio.Controller.fireActionByKey('key_delete')) { return; } for (var i = 0; i < this.indexedElements.length; i++) { if (this.indexedElements[i].node === firstSelected) { currentIndexStart = i; } if (this.indexedElements[i].node === lastSelected) { currentIndexEnd = i; break; } } var selectionIndex = undefined; var maxIndex = this.indexedElements.length - 1; var increment = key === 'PageDown' || key === 'PageUp' ? 10 : 1; if (key === 'ArrowDown' || key === 'PageDown') { selectionIndex = Math.min(currentIndexEnd + elementsPerLine * increment, maxIndex); } else if (key === 'ArrowUp' || key === 'PageUp') { selectionIndex = Math.max(currentIndexStart - elementsPerLine * increment, 0); } else if (key === 'Home') { selectionIndex = 0; } else if (key === 'End') { selectionIndex = maxIndex; } if (elementsPerLine > 1) { if (key === 'ArrowRight') { selectionIndex = currentIndexEnd + 1; } else if (key === 'ArrowLeft') { selectionIndex = currentIndexStart - 1; } } if (shiftKey && selectionIndex !== undefined) { var min = Math.min(currentIndexStart, currentIndexEnd, selectionIndex); var max = Math.max(currentIndexStart, currentIndexEnd, selectionIndex); if (min !== max) { var selection = []; for (var i = min; i < max + 1; i++) { if (this.indexedElements[i]) selection.push(this.indexedElements[i].node); } contextHolder.setSelectedNodes(selection); } } else if (this.indexedElements[selectionIndex] && this.indexedElements[selectionIndex].node) { contextHolder.setSelectedNodes([this.indexedElements[selectionIndex].node]); } }, getInitialState: function getInitialState() { this.actionsCache = { multiple: new Map() }; if (!this.props.skipInternalDataModel) { this.dm = new PydioDataModel(); this.dm.setRootNode(this.props.dataModel.getContextNode()); this.dm.setContextNode(this.props.dataModel.getContextNode()); } else { this.dm = this.props.dataModel; } var sortingInfo = this.props.defaultSortingInfo || null; var state = { loaded: this.props.node.isLoaded(), loading: !this.props.node.isLoaded(), showSelector: false, elements: this.props.node.isLoaded() ? this.buildElements(sortingInfo, 0, this.props.infiniteSliceCount) : [], containerHeight: this.props.containerHeight ? this.props.containerHeight : this.props.heightAutoWithMax ? 0 : 500, sortingInfo: sortingInfo }; if (this.props.elementHeight instanceof Object) { state.elementHeight = this.computeElementHeightResponsive(); } state.infiniteLoadBeginBottomOffset = 200; return state; }, componentWillReceiveProps: function componentWillReceiveProps(nextProps) { var _this = this; this.indexedElements = null; var currentLength = Math.max(this.state.elements.length, nextProps.infiniteSliceCount); var sortingInfo = this.state.sortingInfo || nextProps.defaultSortingInfo || null; this.setState({ loaded: nextProps.node.isLoaded(), loading: !nextProps.node.isLoaded(), showSelector: false, elements: nextProps.node.isLoaded() ? this.buildElements(sortingInfo, 0, currentLength, nextProps.node) : [], infiniteLoadBeginBottomOffset: 200, sortingInfo: sortingInfo }, function () { if (nextProps.node.isLoaded()) _this.updateInfiniteContainerHeight(); }); if (!nextProps.autoRefresh && this.refreshInterval) { window.clearInterval(this.refreshInterval); this.refreshInterval = null; } else if (nextProps.autoRefresh && !this.refreshInterval) { this.refreshInterval = window.setInterval(this.reload, nextProps.autoRefresh); } this.patchInfiniteGrid(nextProps.elementsPerLine); if (this.props.node && nextProps.node !== this.props.node) { this.observeNodeChildren(this.props.node, true); } if (this._manualScrollPe) { this._manualScrollPe.stop(); this._manualScrollPe = null; } }, observeNodeChildren: function observeNodeChildren(node) { var stop = arguments.length <= 1 || arguments[1] === undefined ? false : arguments[1]; if (stop && !this._childrenObserver) return; if (!this._childrenObserver) { this._childrenObserver = (function () { this.indexedElements = null; this.rebuildLoadedElements(); }).bind(this); } if (!this._childrenActionsObserver) { this._childrenActionsObserver = (function (eventMemo) { if (eventMemo.type === 'prompt-rename') { this.setState({ inlineEditionForNode: eventMemo.child, inlineEditionCallback: eventMemo.callback }); } }).bind(this); } if (stop) { node.stopObserving("child_added", this._childrenObserver); node.stopObserving("child_removed", this._childrenObserver); node.stopObserving("child_node_action", this._childrenActionsObserver); } else { node.observe("child_added", this._childrenObserver); node.observe("child_removed", this._childrenObserver); node.observe("child_node_action", this._childrenActionsObserver); } }, _loadNodeIfNotLoaded: function _loadNodeIfNotLoaded() { var node = this.props.node; if (!node.isLoaded()) { node.observeOnce("loaded", (function () { if (!this.isMounted()) return; if (this.props.node === node) { this.observeNodeChildren(node); this.setState({ loaded: true, loading: false, elements: this.buildElements(this.state.sortingInfo, 0, this.props.infiniteSliceCount) }); } if (this.props.heightAutoWithMax) { this.updateInfiniteContainerHeight(); } }).bind(this)); node.load(); } else { this.observeNodeChildren(node); } }, _loadingListener: function _loadingListener() { this.observeNodeChildren(this.props.node, true); this.setState({ loaded: false, loading: true }); this.indexedElements = null; }, _loadedListener: function _loadedListener() { var currentLength = Math.max(this.state.elements.length, this.props.infiniteSliceCount); this.setState({ loading: false, elements: this.buildElements(this.state.sortingInfo, 0, currentLength, this.props.node) }); if (this.props.heightAutoWithMax) { this.updateInfiniteContainerHeight(); } this.observeNodeChildren(this.props.node); }, reload: function reload() { if (this.props.reloadAtCursor && this._currentCursor) { this.loadStartingAtCursor(); return; } if (this.props.clearSelectionOnReload) { this.props.dataModel.setSelectedNodes([]); } this._loadingListener(); this.props.node.observeOnce("loaded", this._loadedListener); this.props.node.reload(); }, loadStartingAtCursor: function loadStartingAtCursor() { this._loadingListener(); var node = this.props.node; var cachedChildren = node.getChildren(); var newChildren = []; node.observeOnce("loaded", (function () { var reorderedChildren = new Map(); newChildren.map(function (c) { reorderedChildren.set(c.getPath(), c); }); cachedChildren.forEach(function (c) { reorderedChildren.set(c.getPath(), c); }); node._children = reorderedChildren; this._loadedListener(); }).bind(this)); node.setLoaded(false); node.observe("child_added", function (newChild) { newChildren.push(node._children.get(newChild)); }); this.props.node.load(null, { cursor: this._currentCursor }); }, wireReloadListeners: function wireReloadListeners() { this.wrappedLoading = this._loadingListener; this.wrappedLoaded = this._loadedListener; this.props.node.observe("loading", this.wrappedLoading); this.props.node.observe("loaded", this.wrappedLoaded); }, stopReloadListeners: function stopReloadListeners() { this.props.node.stopObserving("loading", this.wrappedLoading); this.props.node.stopObserving("loaded", this.wrappedLoaded); }, toggleSelector: function toggleSelector() { // Force rebuild elements this.setState({ showSelector: !this.state.showSelector, selection: new Map() }, this.rebuildLoadedElements); }, toggleSelection: function toggleSelection(node) { var selection = this.state.selection || new Map(); if (selection.get(node)) selection['delete'](node);else selection.set(node, true); if (this.refs.all_selector) this.refs.all_selector.setChecked(false); this.setState({ selection: selection }, this.rebuildLoadedElements); }, selectAll: function selectAll() { var _this2 = this; if (this.refs.all_selector && !this.refs.all_selector.isChecked()) { this.setState({ selection: new Map() }, this.rebuildLoadedElements); } else { (function () { var selection = new Map(); _this2.props.node.getChildren().forEach((function (child) { if (this.props.filterNodes && !this.props.filterNodes(child)) { return; } if (child.isLeaf()) { selection.set(child, true); } }).bind(_this2)); if (_this2.refs.all_selector) _this2.refs.all_selector.setChecked(true); _this2.setState({ selection: selection }, _this2.rebuildLoadedElements); })(); } }, applyMultipleAction: function applyMultipleAction(ev) { if (!this.state.selection || !this.state.selection.size) { return; } var actionName = ev.currentTarget.getAttribute('data-action'); var dm = this.dm || new PydioDataModel(); dm.setContextNode(this.props.node); var selNodes = []; this.state.selection.forEach(function (v, node) { selNodes.push(node); }); dm.setSelectedNodes(selNodes); var a = this.props.pydio.Controller.getActionByName(actionName); a.fireContextChange(dm, true, this.props.pydio.user); a.apply([dm]); ev.stopPropagation(); ev.preventDefault(); }, getActionsForNode: function getActionsForNode(dm, node) { if (!this.props.computeActionsForNode) { return []; } var cacheKey = node.isLeaf() ? 'file-' + node.getAjxpMime() : 'folder'; var selectionType = node.isLeaf() ? 'file' : 'dir'; var nodeActions = []; if (this.actionsCache[cacheKey]) { nodeActions = this.actionsCache[cacheKey]; } else { dm.setSelectedNodes([node]); window.pydio.Controller.actions.forEach((function (a) { a.fireContextChange(dm, true, window.pydio.user); if (a.context.selection && a.context.actionBar && a.selectionContext[selectionType] && !a.deny && a.options.icon_class && (!this.props.actionBarGroups || this.props.actionBarGroups.indexOf(a.context.actionBarGroup) !== -1) && (!a.selectionContext.allowedMimes.length || a.selectionContext.allowedMimes.indexOf(node.getAjxpMime()) !== -1)) { nodeActions.push(a); if (node.isLeaf() && a.selectionContext.unique === false) { this.actionsCache.multiple.set(a.options.name, a); } } }).bind(this)); this.actionsCache[cacheKey] = nodeActions; } return nodeActions; }, updateInfiniteContainerHeight: function updateInfiniteContainerHeight() { var retries = arguments.length <= 0 || arguments[0] === undefined ? false : arguments[0]; if (this.props.containerHeight) { return this.props.containerHeight; } if (!this.refs.infiniteParent) { return; } var containerHeight = this.refs.infiniteParent.clientHeight; if (this.props.heightAutoWithMax) { var number = this.indexedElements ? this.indexedElements.length : this.props.node.getChildren().size; var elementHeight = this.state.elementHeight ? this.state.elementHeight : this.props.elementHeight; containerHeight = Math.min(number * elementHeight, this.props.heightAutoWithMax); } if (!containerHeight && !retries) { global.setTimeout((function () { this.updateInfiniteContainerHeight(true); }).bind(this), 50); } this.setState({ containerHeight: containerHeight }); }, computeElementHeightResponsive: function computeElementHeightResponsive() { var breaks = this.props.elementHeight; if (!(breaks instanceof Object)) { breaks = { "min-width:480px": this.props.elementHeight, "max-width:480px": Object.keys(this.props.tableKeys).length * 24 + 33 }; } if (window.matchMedia) { for (var k in breaks) { if (breaks.hasOwnProperty(k) && window.matchMedia('(' + k + ')').matches) { return breaks[k]; } } } else { var width = DOMUtils.getViewportWidth(); if (width < 480) return breaks["max-width:480px"];else return breaks["max-width:480px"]; } return 50; }, updateElementHeightResponsive: function updateElementHeightResponsive() { var newH = this.computeElementHeightResponsive(); if (!this.state || !this.state.elementHeight || this.state.elementHeight != newH) { this.setState({ elementHeight: newH }, (function () { if (this.props.heightAutoWithMax) { this.updateInfiniteContainerHeight(); } }).bind(this)); } }, patchInfiniteGrid: function patchInfiniteGrid(els) { if (this.refs.infinite && els > 1) { this.refs.infinite.state.infiniteComputer.__proto__.getDisplayIndexStart = function (windowTop) { return els * Math.floor(windowTop / this.heightData / els); }; this.refs.infinite.state.infiniteComputer.__proto__.getDisplayIndexEnd = function (windowBottom) { return els * Math.ceil(windowBottom / this.heightData / els); }; } }, componentDidMount: function componentDidMount() { var _this3 = this; if (this.props.delayInitialLoad) { setTimeout(function () { _this3._loadNodeIfNotLoaded(); }, this.props.delayInitialLoad); } else { this._loadNodeIfNotLoaded(); } this.patchInfiniteGrid(this.props.elementsPerLine); if (this.refs.infiniteParent) { this.updateInfiniteContainerHeight(); if (!this.props.heightAutoWithMax && !this.props.externalResize) { if (window.addEventListener) { window.addEventListener('resize', this.updateInfiniteContainerHeight); } else { window.attachEvent('onresize', this.updateInfiniteContainerHeight); } } } if (this.props.autoRefresh) { this.refreshInterval = window.setInterval(this.reload, this.props.autoRefresh); } if (this.props.observeNodeReload) { this.wireReloadListeners(); } if (this.props.elementHeight instanceof Object || this.props.tableKeys) { if (window.addEventListener) { window.addEventListener('resize', this.updateElementHeightResponsive); } else { window.attachEvent('onresize', this.updateElementHeightResponsive); } this.updateElementHeightResponsive(); } this.props.dataModel.observe('selection_changed', (function () { var _this4 = this; if (!this.isMounted()) return; var selection = new Map(); var selectedNodes = this.props.dataModel.getSelectedNodes(); selectedNodes.map(function (n) { selection.set(n, true); }); this.setState({ selection: selection }, function () { _this4.rebuildLoadedElements(); if (selectedNodes.length === 1) { _this4.scrollToView(selectedNodes[0]); } }); }).bind(this)); }, componentWillUnmount: function componentWillUnmount() { if (!this.props.heightAutoWithMax) { if (window.removeEventListener) { window.removeEventListener('resize', this.updateInfiniteContainerHeight); } else { window.detachEvent('onresize', this.updateInfiniteContainerHeight); } } if (this.props.elementHeight instanceof Object || this.props.tableKeys) { if (window.removeEventListener) { window.removeEventListener('resize', this.updateElementHeightResponsive); } else { window.detachEvent('resize', this.updateElementHeightResponsive); } } if (this.refreshInterval) { window.clearInterval(this.refreshInterval); } if (this.props.observeNodeReload) { this.stopReloadListeners(); } if (this.props.node) { this.observeNodeChildren(this.props.node, true); } }, componentDidUpdate: function componentDidUpdate(prevProps, prevState) { if (prevProps.node && this.props.node && prevProps.node.getPath() === this.props.node.getPath()) { return; } this._loadNodeIfNotLoaded(); }, onScroll: function onScroll(scrollTop) { if (!this.props.passScrollingStateToChildren) { return; } // Maintains a series of timeouts to set this.state.isScrolling // to be true when the element is scrolling. if (this.state.scrollTimeout) { clearTimeout(this.state.scrollTimeout); } var that = this, scrollTimeout = setTimeout(function () { that.setState({ isScrolling: false, scrollTimeout: undefined }); }, 150); this.setState({ isScrolling: true, scrollTimeout: scrollTimeout }); }, scrollToLast: function scrollToLast() { if (this.indexedElements && this.indexedElements[this.indexedElements.length - 1].node) { this.scrollToView(this.indexedElements[this.indexedElements.length - 1].node); } }, scrollToView: function scrollToView(node) { var _this5 = this; if (!this.indexedElements || !this.refs.infinite || !this.refs.infinite.scrollable) return; var scrollable = this.refs.infinite.scrollable; var visibleFrame = { top: scrollable.scrollTop + this.props.elementHeight / 2, bottom: scrollable.scrollTop + this.state.containerHeight - this.props.elementHeight / 2 }; var realMaxScrollTop = this.indexedElements.length * this.props.elementHeight - this.state.containerHeight; var position = -1; this.indexedElements.forEach(function (e, k) { if (e.node && e.node === node) position = k; }); if (position === -1) return; var elementHeight = this.props.elementHeight; var scrollTarget = position * elementHeight; if (scrollTarget > visibleFrame.top && scrollTarget < visibleFrame.bottom) { // already visible; return; } else if (scrollTarget >= visibleFrame.bottom) { scrollTarget -= this.state.containerHeight - elementHeight * 2; } scrollTarget = Math.min(scrollTarget, realMaxScrollTop); scrollable.scrollTop = scrollTarget; if (this._manualScrollPe) this._manualScrollPe.stop(); if (scrollable.scrollHeight < scrollTarget) { this._manualScrollPe = new PeriodicalExecuter(function () { scrollable.scrollTop = scrollTarget; if (scrollable.scrollHeight >= scrollTarget) { _this5._manualScrollPe.stop(); _this5._manualScrollPe = null; } }, .25); } }, buildElementsFromNodeEntries: function buildElementsFromNodeEntries(nodeEntries, showSelector) { var components = [], index = 0; var nodeEntriesLength = nodeEntries.length; nodeEntries.forEach((function (entry) { var data = undefined; if (entry.parent) { data = { node: entry.node, key: entry.node.getPath(), id: entry.node.getPath(), mainIcon: SimpleList.PARENT_FOLDER_ICON, firstLine: "..", className: "list-parent-node", secondLine: this.context.getMessage('react.1'), onClick: this.clickRow, onDoubleClick: this.doubleClickRow, showSelector: false, selectorDisabled: true, noHover: false }; if (this.props.entryRenderParentIcon && !this.props.tableKeys) { data['iconCell'] = this.props.entryRenderParentIcon(entry.node, entry); } else { data['mainIcon'] = SimpleList.PARENT_FOLDER_ICON; } if (this.props.elementStyle) { data['style'] = this.props.elementStyle; } if (this.props.passScrollingStateToChildren) { data['parentIsScrolling'] = this.state.isScrolling; } components.push(React.createElement(_ListEntry.ListEntry, data)); } else if (entry.groupHeader) { var id = entry.groupHeader, firstLine = entry.groupHeaderLabel; if (this.props.entryRenderGroupHeader) { firstLine = this.props.entryRenderGroupHeader(id, firstLine); } data = { node: null, key: entry.groupHeader, id: id, mainIcon: null, firstLine: firstLine, className: 'list-group-header', onClick: null, showSelector: false, selectorDisabled: true, noHover: true }; if (this.props.passScrollingStateToChildren) { data['parentIsScrolling'] = this.state.isScrolling; } components.push(React.createElement(_ListEntry.ListEntry, data)); } else { data = { node: entry.node, onClick: this.clickRow, onDoubleClick: this.doubleClickRow, onSelect: this.toggleSelection, key: entry.node.getPath(), id: entry.node.getPath(), renderIcon: this.props.entryRenderIcon, renderFirstLine: this.props.entryRenderFirstLine, renderSecondLine: this.props.entryRenderSecondLine, renderThirdLine: this.props.entryRenderThirdLine, renderActions: this.props.entryRenderActions, showSelector: showSelector, selected: this.state && this.state.selection ? this.state.selection.get(entry.node) : false, actions: React.createElement(_viewsSimpleReactActionBar2['default'], { node: entry.node, actions: entry.actions, dataModel: this.dm }), selectorDisabled: !(this.props.entryEnableSelector ? this.props.entryEnableSelector(entry.node) : entry.node.isLeaf()) }; data['isFirst'] = index === 0; data['isLast'] = index === nodeEntriesLength - 1; index++; if (this.props.elementStyle) { data['style'] = this.props.elementStyle; } if (this.props.passScrollingStateToChildren) { data['parentIsScrolling'] = this.state.isScrolling; } if (this.props.renderCustomEntry) { components.push(this.props.renderCustomEntry(data)); } else if (this.props.tableKeys) { if (this.props.defaultGroupBy) { data['tableKeys'] = LangUtils.deepCopy(this.props.tableKeys); delete data['tableKeys'][this.props.defaultGroupBy]; } else { data['tableKeys'] = this.props.tableKeys; } components.push(React.createElement(_TableListEntry2['default'], data)); } else { components.push(React.createElement(_ConfigurableListEntry2['default'], data)); } } }).bind(this)); return components; }, buildElements: function buildElements(sortingInfo, start, end, node, showSelector) { var _this6 = this; var theNode = this.props.node; if (node) theNode = node; var theShowSelector = this.state && this.state.showSelector; if (showSelector !== undefined) theShowSelector = showSelector; if (!this.indexedElements || this.indexedElements.length !== theNode.getChildren().size) { (function () { _this6.indexedElements = []; var groupBy = undefined, groupByLabel = undefined, groups = undefined, groupKeys = undefined, groupLabels = undefined; if (_this6.props.defaultGroupBy) { groupBy = _this6.props.defaultGroupBy; groupByLabel = _this6.props.groupByLabel || false; groups = {}, groupKeys = [], groupLabels = {}; } if (!_this6.props.skipParentNavigation && theNode.getParent() && (_this6.props.dataModel.getContextNode() !== theNode || _this6.props.skipInternalDataModel)) { _this6.indexedElements.push({ node: theNode.getParent(), parent: true, actions: null }); } theNode.getChildren().forEach((function (child) { if (child.getMetadata().has('cursor')) { var childCursor = parseInt(child.getMetadata().get('cursor')); this._currentCursor = Math.max(this._currentCursor ? this._currentCursor : 0, childCursor); } if (this.props.filterNodes && !this.props.filterNodes(child)) { return; } var nodeActions = this.getActionsForNode(this.dm, child); if (groupBy) { var groupValue = child.getMetadata().get(groupBy) || 'N/A'; if (!groups[groupValue]) { groups[groupValue] = []; groupKeys.push(groupValue); } if (groupByLabel && child.getMetadata().has(groupByLabel) && !groupLabels[groupValue]) { groupLabels[groupValue] = child.getMetadata().get(groupByLabel); } groups[groupValue].push({ node: child, parent: false, actions: nodeActions }); } else { this.indexedElements.push({ node: child, parent: false, actions: nodeActions }); } }).bind(_this6)); if (groupBy) { groupKeys = groupKeys.sort(); groupKeys.map((function (k) { var label = k; if (groupLabels[k]) { label = groupLabels[k]; } else if (this.props.renderGroupLabels) { label = this.props.renderGroupLabels(groupBy, k); } this.indexedElements.push({ node: null, groupHeader: k, groupHeaderLabel: label, parent: false, actions: null }); this.indexedElements = this.indexedElements.concat(groups[k]); }).bind(_this6)); } })(); } if (sortingInfo && !this.remoteSortingInfo()) { (function () { var attribute = sortingInfo.attribute; var direction = sortingInfo.direction; var sortType = sortingInfo.sortType; var sortFunction = undefined; if (sortType === 'file-natural') { sortFunction = function (a, b) { if (a.parent) { return -1; } if (b.parent) { return 1; } var nodeA = a.node; var nodeB = b.node; // Recycle always last if (nodeA.isRecycle()) return 1; if (nodeB.isRecycle()) return -1; // Folders first var aLeaf = nodeA.isLeaf(); var bLeaf = nodeB.isLeaf(); var res = aLeaf && !bLeaf ? 1 : !aLeaf && bLeaf ? -1 : 0; if (res !== 0) return res; res = nodeA.getLabel().localeCompare(nodeB.getLabel()); return res; }; } else { sortFunction = function (a, b) { if (a.parent) { return -1; } var aMeta = a.node.getMetadata().get(attribute) || ""; var bMeta = b.node.getMetadata().get(attribute) || ""; var res = undefined; if (sortType === 'number') { aMeta = parseFloat(aMeta); bMeta = parseFloat(bMeta); res = direction === 'asc' ? aMeta - bMeta : bMeta - aMeta; } else if (sortType === 'string') { res = direction === 'asc' ? aMeta.localeCompare(bMeta) : bMeta.localeCompare(aMeta); } if (res === 0) { // Resort by label to make it stable var labComp = a.node.getLabel().localeCompare(b.node.getLabel()); res = direction === 'asc' ? labComp : -labComp; } return res; }; } _this6.indexedElements.sort(sortFunction); })(); } if (this.props.elementPerLine > 1) { end = end * this.props.elementPerLine; start = start * this.props.elementPerLine; } return this.indexedElements.slice(start, end); }, rebuildLoadedElements: function rebuildLoadedElements() { var newElements = this.buildElements(this.state.sortingInfo, 0, Math.max(this.state.elements.length, this.props.infiniteSliceCount)); var infiniteLoadBeginBottomOffset = newElements.length ? 200 : 0; this.setState({ elements: newElements, infiniteLoadBeginBottomOffset: infiniteLoadBeginBottomOffset }); this.updateInfiniteContainerHeight(); }, handleInfiniteLoad: function handleInfiniteLoad() { var elemLength = this.state.elements.length; var newElements = this.buildElements(this.state.sortingInfo, elemLength, elemLength + this.props.infiniteSliceCount); var infiniteLoadBeginBottomOffset = newElements.length ? 200 : 0; this.setState({ isInfiniteLoading: false, elements: this.state.elements.concat(newElements), infiniteLoadBeginBottomOffset: infiniteLoadBeginBottomOffset }); }, /** * Extract remote sorting info from current node metadata */ remoteSortingInfo: function remoteSortingInfo() { var meta = this.props.node.getMetadata().get('paginationData'); if (meta && meta.get('total') > 1 && meta.has('remote_order')) { var col = meta.get('currentOrderCol'); var dir = meta.get('currentOrderDir'); if (col && dir) { return { remote: true, attribute: col, direction: dir }; } } return null; }, renderToolbar: function renderToolbar() { var _this7 = this; var rightButtons = [React.createElement(ReactMUI.FontIcon, { key: 1, tooltip: 'Reload', className: "icon-refresh" + (this.state.loading ? " rotating" : ""), onClick: this.reload })]; var i = 2; if (this.props.sortKeys) { var sortingInfo = undefined, remoteSortingInfo = this.remoteSortingInfo(); if (remoteSortingInfo) { sortingInfo = remoteSortingInfo; } else { sortingInfo = this.state ? this.state.sortingInfo : null; } rightButtons.push(React.createElement(_SortColumns2['default'], { key: i, displayMode: 'menu', tableKeys: this.props.sortKeys, columnClicked: this.onColumnSort, sortingInfo: sortingInfo })); i++; } if (this.props.additionalActions) { rightButtons.push(this.props.additionalActions); } var leftToolbar = undefined, paginator = undefined; if (this.props.node.getMetadata().get("paginationData") && this.props.node.getMetadata().get("paginationData").get('total') > 1) { paginator = React.createElement(_ListPaginator2['default'], { dataModel: this.dm, node: this.props.node }); } if (this.props.listTitle) { leftToolbar = React.createElement( ReactMUI.ToolbarGroup, { key: 0, float: 'left' }, React.createElement( 'div', { className: 'list-title' }, this.props.listTitle ) ); } if (this.props.searchResultData) { leftToolbar = React.createElement( ReactMUI.ToolbarGroup, { key: 0, float: 'left' }, React.createElement( 'h2', { className: 'search-results-title' }, this.context.getMessage('react.3').replace('%s', this.props.searchResultData.term) ) ); rightButtons = React.createElement(ReactMUI.RaisedButton, { key: 1, label: this.context.getMessage('react.4'), primary: true, onClick: this.props.searchResultData.toggleState }); } else if (this.actionsCache.multiple.size || this.props.multipleActions) { var bulkLabel = this.context.getMessage('react.2'); if (this.state.selection && this.state.showSelector) { bulkLabel += " (" + this.state.selection.size + ")"; } leftToolbar = React.createElement( ReactMUI.ToolbarGroup, { key: 0, float: 'left', className: 'hide-on-vertical-layout' }, React.createElement(ReactMUI.Checkbox, { ref: 'all_selector', onClick: this.selectAll }), React.createElement(ReactMUI.FlatButton, { label: bulkLabel, onClick: this.toggleSelector }) ); if (this.state.showSelector) { (function () { rightButtons = []; var index = 0; var actions = _this7.props.multipleActions || _this7.actionsCache.multiple; actions.forEach((function (a) { rightButtons.push(React.createElement(ReactMUI.RaisedButton, { key: index, label: a.options.text, 'data-action': a.options.name, onClick: this.applyMultipleAction, primary: true })); }).bind(_this7)); rightButtons = React.createElement( 'span', null, rightButtons ); })(); } } return React.createElement( ReactMUI.Toolbar, null, leftToolbar, React.createElement( ReactMUI.ToolbarGroup, { key: 1, float: 'right' }, paginator, rightButtons ) ); }, render: function render() { var _this8 = this; var containerClasses = "material-list vertical-layout layout-fill"; if (this.props.className) { containerClasses += " " + this.props.className; } if (this.state.showSelector) { containerClasses += " list-show-selectors"; } if (this.props.tableKeys) { containerClasses += " table-mode"; } var toolbar = undefined; if (this.props.tableKeys) { var tableKeys = undefined; if (this.props.defaultGroupBy) { tableKeys = LangUtils.deepCopy(this.props.tableKeys); delete tableKeys[this.props.defaultGroupBy]; } else { tableKeys = this.props.tableKeys; } var sortingInfo = undefined, remoteSortingInfo = this.remoteSortingInfo(); if (remoteSortingInfo) { sortingInfo = remoteSortingInfo; } else { sortingInfo = this.state ? this.state.sortingInfo : null; } toolbar = React.createElement(_TableListHeader2['default'], { tableKeys: tableKeys, loading: this.state.loading, reload: this.reload, ref: 'loading_indicator', dm: this.props.dataModel, node: this.props.node, additionalActions: this.props.additionalActions, onHeaderClick: this.onColumnSort, sortingInfo: sortingInfo }); } else { toolbar = this.props.customToolbar ? this.props.customToolbar : !this.props.hideToolbar ? this.renderToolbar() : null; } var inlineEditor = undefined; if (this.state.inlineEditionForNode) { inlineEditor = React.createElement(_InlineEditor2['default'], { detached: true, node: this.state.inlineEditionForNode, callback: this.state.inlineEditionCallback, onClose: function () { _this8.setState({ inlineEditionForNode: null }); } }); } var emptyState = undefined; var _props = this.props; var emptyStateProps = _props.emptyStateProps; var node = _props.node; if (emptyStateProps && this.props.node.isLoaded() && !this.props.node.isLoading() && (!this.state.elements.length || this.state.elements.length === 1 && this.state.elements[0].parent)) { var actionProps = {}; if (this.state.elements.length === 1 && this.state.elements[0].parent) { (function () { var parentNode = _this8.state.elements[0].node; actionProps = { actionLabelId: 'react.1', actionIconClassName: SimpleList.PARENT_FOLDER_ICON, actionCallback: function actionCallback(e) { if (_this8.props.entryHandleClicks) { _this8.props.entryHandleClicks(parentNode, SimpleList.CLICK_TYPE_DOUBLE, e); } } }; })(); } emptyState = React.createElement(_viewsEmptyStateView2['default'], _extends({}, emptyStateProps, actionProps)); } else if (emptyStateProps && emptyStateProps.checkEmptyState && emptyStateProps.checkEmptyState(this.props.node)) { emptyState = React.createElement(_viewsEmptyStateView2['default'], emptyStateProps); } var elements = this.buildElementsFromNodeEntries(this.state.elements, this.state.showSelector); return React.createElement( 'div', { className: containerClasses, onContextMenu: this.contextMenuResponder, tabIndex: '0', onKeyDown: this.onKeyDown, style: this.props.style }, toolbar, inlineEditor, React.createElement( 'div', { className: this.props.heightAutoWithMax ? "infinite-parent-smooth-height" : emptyState ? "layout-fill vertical_layout" : "layout-fill", ref: 'infiniteParent' }, !emptyState && !this.props.verticalScroller && React.createElement( Infinite, { elementHeight: this.state.elementHeight ? this.state.elementHeight : this.props.elementHeight, containerHeight: this.state.containerHeight ? this.state.containerHeight : 1, infiniteLoadBeginEdgeOffset: this.state.infiniteLoadBeginBottomOffset, onInfiniteLoad: this.handleInfiniteLoad, handleScroll: this.onScroll, ref: 'infinite' }, elements ), !emptyState && this.props.verticalScroller && React.createElement( _reactScrollbar2['default'], { speed: 0.8, horizontalScroll: false, style: { height: this.state.containerHeight }, verticalScrollbarStyle: { borderRadius: 10, width: 6 }, verticalContainerStyle: { width: 8 } }, React.createElement( 'div', null, elements ) ), emptyState ) ); } }); exports['default'] = SimpleList; module.exports = exports['default']; }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) },{"../util/MessagesConsumerMixin":48,"../views/EmptyStateView":49,"../views/SimpleReactActionBar":52,"./ConfigurableListEntry":13,"./InlineEditor":14,"./ListEntry":15,"./ListPaginator":17,"./SortColumns":20,"./TableListEntry":22,"./TableListHeader":23,"pydio/model/data-model":"pydio/model/data-model","pydio/util/dom":"pydio/util/dom","pydio/util/lang":"pydio/util/lang","pydio/util/periodical-executer":"pydio/util/periodical-executer","react":"react","react-infinite":"react-infinite","react-scrollbar":1}],20:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } var _menuIconButtonMenu = require('../menu/IconButtonMenu'); var _menuIconButtonMenu2 = _interopRequireDefault(_menuIconButtonMenu); var React = require('react'); var Pydio = require('pydio'); var _Pydio$requireLib = Pydio.requireLib('boot'); var PydioContextConsumer = _Pydio$requireLib.PydioContextConsumer; var _require = require('material-ui-legacy'); var ToolbarGroup = _require.ToolbarGroup; var SortColumns = React.createClass({ displayName: 'SortColumns', propTypes: { tableKeys: React.PropTypes.object.isRequired, columnClicked: React.PropTypes.func, sortingInfo: React.PropTypes.object, displayMode: React.PropTypes.string }, onMenuClicked: function onMenuClicked(object) { this.props.columnClicked(object.payload); }, onHeaderClick: function onHeaderClick(key, callback) { var data = this.props.tableKeys[key]; if (data && data['sortType'] && this.props.columnClicked) { data['name'] = key; this.props.columnClicked(data, callback); } }, getColumnsItems: function getColumnsItems(displayMode) { var _this = this; var controller = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; var items = []; var _callback = function _callback() { if (controller) { controller.notify('actions_refreshed'); } }; var _loop = function (key) { if (!_this.props.tableKeys.hasOwnProperty(key)) return 'continue'; var data = _this.props.tableKeys[key]; var style = data['width'] ? { width: data['width'] } : null; var icon = undefined; var className = 'cell header_cell cell-' + key; if (data['sortType']) { className += ' sortable'; if (_this.props.sortingInfo && (_this.props.sortingInfo.attribute === key || _this.props.sortingInfo.attribute === data['sortAttribute'] || _this.props.sortingInfo.attribute === data['remoteSortAttribute'])) { icon = _this.props.sortingInfo.direction === 'asc' ? 'mdi mdi-arrow-up' : 'mdi mdi-arrow-down'; className += ' active-sort-' + _this.props.sortingInfo.direction; } } if (displayMode === 'menu') { data['name'] = key; items.push({ payload: data, text: data['label'], iconClassName: icon }); } else if (displayMode === 'menu_data') { items.push({ name: data['label'], callback: function callback() { _this.onHeaderClick(key, _callback); }, icon_class: icon || '__INSET__' }); } else { items.push(React.createElement( 'span', { key: key, className: className, style: style, onClick: function () { _this.onHeaderClick(key, _callback); } }, data['label'] )); } }; for (var key in this.props.tableKeys) { var _ret = _loop(key); if (_ret === 'continue') continue; } return items; }, buildSortingMenuItems: function buildSortingMenuItems(controller) { return this.getColumnsItems('menu_data', controller); }, componentDidMount: function componentDidMount() { var sortAction = new Action({ name: 'sort_action', icon_class: 'mdi mdi-sort-descending', text_id: 450, title_id: 450, text: this.props.getMessage(450), title: this.props.getMessage(450), hasAccessKey: false, subMenu: true, subMenuUpdateImage: true }, { selection: false, dir: true, actionBar: true, actionBarGroup: 'display_toolbar', contextMenu: false, infoPanel: false }, {}, {}, { dynamicBuilder: this.buildSortingMenuItems }); var buttons = new Map(); buttons.set('sort_action', sortAction); this.props.pydio.getController().updateGuiActions(buttons); }, componentWillUnmount: function componentWillUnmount() { this.props.pydio.getController().deleteFromGuiActions('sort_action'); }, render: function render() { if (this.props.displayMode === 'menu') { return React.createElement(_menuIconButtonMenu2['default'], { buttonTitle: 'Sort by...', buttonClassName: 'mdi mdi-sort-descending', menuItems: this.getColumnsItems('menu', this.props.pydio.getController()), onMenuClicked: this.onMenuClicked }); } else { return React.createElement( ToolbarGroup, { float: 'left' }, this.getColumnsItems('header', this.props.pydio.getController()) ); } } }); exports['default'] = SortColumns = PydioContextConsumer(SortColumns); exports['default'] = SortColumns; module.exports = exports['default']; },{"../menu/IconButtonMenu":26,"material-ui-legacy":"material-ui-legacy","pydio":"pydio","react":"react"}],21:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ "use strict"; exports.__esModule = true; var _utilDND = require('../util/DND'); /***************************/ /* REACT DND SORTABLE LIST /**************************/ /** * Specifies the drag source contract. * Only `beginDrag` function is required. */ var sortableItemSource = { beginDrag: function beginDrag(props) { // Return the data describing the dragged item return { id: props.id }; }, endDrag: function endDrag(props) { props.endSwitching(); } }; var sortableItemTarget = { hover: function hover(props, monitor) { var draggedId = monitor.getItem().id; if (draggedId !== props.id) { props.switchItems(draggedId, props.id); } } }; var sortableItem = React.createClass({ displayName: "sortableItem", propTypes: { connectDragSource: React.PropTypes.func.isRequired, connectDropTarget: React.PropTypes.func.isRequired, isDragging: React.PropTypes.bool.isRequired, id: React.PropTypes.any.isRequired, label: React.PropTypes.string.isRequired, switchItems: React.PropTypes.func.isRequired, removable: React.PropTypes.bool, onRemove: React.PropTypes.func }, removeClicked: function removeClicked() { this.props.onRemove(this.props.id); }, render: function render() { // Your component receives its own props as usual var id = this.props.id; // These two props are injected by React DnD, // as defined by your `collect` function above: var isDragging = this.props.isDragging; var connectDragSource = this.props.connectDragSource; var connectDropTarget = this.props.connectDropTarget; var remove; if (this.props.removable) { remove = React.createElement("span", { className: "button mdi mdi-close", onClick: this.removeClicked }); } return React.createElement( ReactMUI.Paper, { ref: function (instance) { connectDropTarget(ReactDOM.findDOMNode(instance)); connectDragSource(ReactDOM.findDOMNode(instance)); }, zDepth: 1, style: { opacity: isDragging ? 0 : 1 } }, React.createElement( "div", { className: this.props.className }, this.props.label, remove ) ); } }); var NonDraggableListItem = React.createClass({ displayName: "NonDraggableListItem", render: function render() { var remove; if (this.props.removable) { remove = React.createElement("span", { className: "button mdi mdi-close", onClick: this.removeClicked }); } return React.createElement( ReactMUI.Paper, { zDepth: 1 }, React.createElement( "div", { className: this.props.className }, this.props.label, remove ) ); } }); var DraggableListItem; if (window.ReactDND) { DraggableListItem = ReactDND.flow(ReactDND.DragSource(_utilDND.Types.SORTABLE_LIST_ITEM, sortableItemSource, _utilDND.collect), ReactDND.DropTarget(_utilDND.Types.SORTABLE_LIST_ITEM, sortableItemTarget, _utilDND.collectDrop))(sortableItem); } else { DraggableListItem = NonDraggableListItem; } var SortableList = React.createClass({ displayName: "SortableList", propTypes: { values: React.PropTypes.array.isRequired, onOrderUpdated: React.PropTypes.func, removable: React.PropTypes.bool, onRemove: React.PropTypes.func, className: React.PropTypes.string, itemClassName: React.PropTypes.string }, getInitialState: function getInitialState() { return { values: this.props.values }; }, componentWillReceiveProps: function componentWillReceiveProps(props) { this.setState({ values: props.values, switchData: null }); }, findItemIndex: function findItemIndex(itemId, data) { for (var i = 0; i < data.length; i++) { if (data[i]['payload'] == itemId) { return i; } } }, switchItems: function switchItems(oldId, newId) { var oldIndex = this.findItemIndex(oldId, this.state.values); var oldItem = this.state.values[oldIndex]; var newIndex = this.findItemIndex(newId, this.state.values); var newItem = this.state.values[newIndex]; var currentValues = this.state.values.slice(); currentValues[oldIndex] = newItem; currentValues[newIndex] = oldItem; // Check that it did not come back to original state var oldPrevious = this.findItemIndex(oldId, this.props.values); var newPrevious = this.findItemIndex(newId, this.props.values); if (oldPrevious == newIndex && newPrevious == oldIndex) { this.setState({ values: currentValues, switchData: null }); //console.log("no more moves"); } else { this.setState({ values: currentValues, switchData: { oldId: oldId, newId: newId } }); //console.log({oldId:oldIndex, newId:newIndex}); } }, endSwitching: function endSwitching() { if (this.state.switchData) { // Check that it did not come back to original state if (this.props.onOrderUpdated) { this.props.onOrderUpdated(this.state.switchData.oldId, this.state.switchData.newId, this.state.values); } } this.setState({ switchData: null }); }, render: function render() { var switchItems = this.switchItems; return React.createElement( "div", { className: this.props.className }, this.state.values.map((function (item) { return React.createElement(DraggableListItem, { id: item.payload, key: item.payload, label: item.text, switchItems: switchItems, endSwitching: this.endSwitching, removable: this.props.removable, onRemove: this.props.onRemove, className: this.props.itemClassName }); }).bind(this)) ); } }); exports["default"] = SortableList; module.exports = exports["default"]; },{"../util/DND":47}],22:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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 _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } var _ListEntryNodeListenerMixin = require('./ListEntryNodeListenerMixin'); var _ListEntryNodeListenerMixin2 = _interopRequireDefault(_ListEntryNodeListenerMixin); var _ListEntry = require('./ListEntry'); var _InlineEditor = require('./InlineEditor'); var _InlineEditor2 = _interopRequireDefault(_InlineEditor); /** * Specific list entry rendered as a table row. Not a real table, CSS used. */ exports['default'] = React.createClass({ displayName: 'TableListEntry', mixins: [_ListEntryNodeListenerMixin2['default']], propTypes: { node: React.PropTypes.instanceOf(AjxpNode), tableKeys: React.PropTypes.object.isRequired, renderActions: React.PropTypes.func // See also ListEntry nodes }, render: function render() { var _this = this; var actions = this.props.actions; if (this.props.renderActions) { actions = this.props.renderActions(this.props.node); } var cells = []; var firstKey = true; var meta = this.props.node.getMetadata(); for (var key in this.props.tableKeys) { if (!this.props.tableKeys.hasOwnProperty(key)) continue; var data = this.props.tableKeys[key]; var style = data['width'] ? { width: data['width'] } : null; var value = undefined, rawValue = undefined; if (data.renderCell) { data['name'] = key; value = data.renderCell(this.props.node, data); } else if (key === 'ajxp_modiftime' && meta.get('ajxp_relativetime')) { value = meta.get('ajxp_relativetime'); } else { value = meta.get(key); } rawValue = meta.get(key); var inlineEditor = undefined; if (this.state && this.state.inlineEdition && firstKey) { inlineEditor = React.createElement(_InlineEditor2['default'], { node: this.props.node, onClose: function () { _this.setState({ inlineEdition: false }); }, callback: this.state.inlineEditionCallback }); var _style = this.props.style || {}; _style.position = 'relative'; this.props.style = _style; } cells.push(React.createElement( 'span', { key: key, className: 'cell cell-' + key, title: rawValue, style: style, 'data-label': data['label'] }, inlineEditor, value )); firstKey = false; } return React.createElement(_ListEntry.DragDropListEntry, _extends({}, this.props, { iconCell: null, firstLine: cells, actions: actions })); } }); module.exports = exports['default']; },{"./InlineEditor":14,"./ListEntry":15,"./ListEntryNodeListenerMixin":16}],23:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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 _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } var _utilMessagesConsumerMixin = require('../util/MessagesConsumerMixin'); var _utilMessagesConsumerMixin2 = _interopRequireDefault(_utilMessagesConsumerMixin); var _SortColumns = require('./SortColumns'); var _SortColumns2 = _interopRequireDefault(_SortColumns); var _ListPaginator = require('./ListPaginator'); var _ListPaginator2 = _interopRequireDefault(_ListPaginator); /** * Specific header for Table layout, reading metadata from node and using keys */ exports['default'] = React.createClass({ displayName: 'TableListHeader', mixins: [_utilMessagesConsumerMixin2['default']], propTypes: { tableKeys: React.PropTypes.object.isRequired, loading: React.PropTypes.bool, reload: React.PropTypes.func, dm: React.PropTypes.instanceOf(PydioDataModel), node: React.PropTypes.instanceOf(AjxpNode), onHeaderClick: React.PropTypes.func, sortingInfo: React.PropTypes.object }, render: function render() { var headers = undefined, paginator = undefined; if (this.props.node.getMetadata().get("paginationData") && this.props.node.getMetadata().get("paginationData").get('total') > 1) { paginator = React.createElement(_ListPaginator2['default'], { dataModel: this.props.dm, node: this.props.node }); } return React.createElement( ReactMUI.Toolbar, { className: 'toolbarTableHeader' }, React.createElement(_SortColumns2['default'], _extends({ displayMode: 'tableHeader' }, this.props, { columnClicked: this.props.onHeaderClick })), React.createElement( ReactMUI.ToolbarGroup, { float: 'right' }, paginator, React.createElement(ReactMUI.FontIcon, { key: 1, tooltip: this.context.getMessage('149', ''), className: "icon-refresh" + (this.props.loading ? " rotating" : ""), onClick: this.props.reload }), this.props.additionalActions ) ); } }); module.exports = exports['default']; },{"../util/MessagesConsumerMixin":48,"./ListPaginator":17,"./SortColumns":20}],24:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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 _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } var _Utils = require('./Utils'); var _Utils2 = _interopRequireDefault(_Utils); var _MenuItemsConsumer = require('./MenuItemsConsumer'); var _MenuItemsConsumer2 = _interopRequireDefault(_MenuItemsConsumer); var React = require('react'); var ReactDOM = require('react-dom'); var _require = require('material-ui'); var Menu = _require.Menu; var Controller = require('pydio/model/controller'); var ButtonMenu = React.createClass({ displayName: 'ButtonMenu', propTypes: { buttonTitle: React.PropTypes.oneOfType([React.PropTypes.string, React.PropTypes.object]).isRequired, menuItems: React.PropTypes.array.isRequired, className: React.PropTypes.string, raised: React.PropTypes.bool, direction: React.PropTypes.oneOf(['left', 'right']) }, componentDidMount: function componentDidMount() { var _this = this; if (this.props.openOnEvent) { this.props.pydio.observe(this.props.openOnEvent, function () { _this.showMenu(); }); } }, getInitialState: function getInitialState() { return { showMenu: false }; }, showMenu: function showMenu(event) { var anchor = undefined; if (event) { anchor = event.currentTarget; } else { anchor = this._buttonDOM; } this.setState({ showMenu: true, anchor: anchor }); }, menuClicked: function menuClicked(event, index, object) { //object.payload(); this.setState({ showMenu: false }); }, render: function render() { var _this2 = this; var label = React.createElement( 'span', null, this.props.buttonTitle, ' ', React.createElement('span', { className: 'icon-caret-down' }) ); var button = undefined; var props = { primary: this.props.primary, secondary: this.props.secondary, disabled: this.props.disabeld, label: label, onTouchTap: this.showMenu, onClick: function onClick(e) { return e.stopPropagation(); } }; var menuItems = this.props.menuItems; var _state = this.state; var showMenu = _state.showMenu; var anchor = _state.anchor; if (menuItems.length) { if (this.props.raised) { button = React.createElement(MaterialUI.RaisedButton, _extends({}, props, { style: this.props.buttonStyle, labelStyle: this.props.buttonLabelStyle, ref: function (b) { _this2._buttonDOM = ReactDOM.findDOMNode(b); } })); } else { button = React.createElement(MaterialUI.FlatButton, _extends({}, props, { style: this.props.buttonStyle, labelStyle: this.props.buttonLabelStyle, ref: function (b) { _this2._buttonDOM = ReactDOM.findDOMNode(b); } })); } } return React.createElement( 'span', { id: this.props.id, className: this.props.className }, button, React.createElement( MaterialUI.Popover, { className: 'menuPopover', open: showMenu, anchorEl: anchor, anchorOrigin: { horizontal: this.props.direction || 'left', vertical: 'bottom' }, targetOrigin: { horizontal: this.props.direction || 'left', vertical: 'top' }, onRequestClose: function () { _this2.setState({ showMenu: false }); }, style: { marginTop: 1 }, useLayerForClickAway: false }, _Utils2['default'].itemsToMenu(menuItems, this.menuClicked) ) ); } }); exports['default'] = _MenuItemsConsumer2['default'](ButtonMenu); module.exports = exports['default']; },{"./MenuItemsConsumer":28,"./Utils":31,"material-ui":"material-ui","pydio/model/controller":"pydio/model/controller","react":"react","react-dom":"react-dom"}],25:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var _pydioModelContextMenu = require('pydio/model/context-menu'); var _pydioModelContextMenu2 = _interopRequireDefault(_pydioModelContextMenu); var _Utils = require('./Utils'); var _Utils2 = _interopRequireDefault(_Utils); var _PopupMenu = require('./PopupMenu'); var _PopupMenu2 = _interopRequireDefault(_PopupMenu); var _require = require('react'); var Component = _require.Component; var dims = { MENU_ITEM_HEIGHT: 32, //48 if not display:compact MENU_SEP_HEIGHT: 16, MENU_VERTICAL_PADDING: 8, MENU_WIDTH: 250, OFFSET_VERTICAL: 8, OFFSET_HORIZONTAL: 8 }; var ContextMenu = (function (_Component) { _inherits(ContextMenu, _Component); function ContextMenu() { _classCallCheck(this, ContextMenu); _Component.apply(this, arguments); } ContextMenu.prototype.modelOpen = function modelOpen(node) { var position = _pydioModelContextMenu2['default'].getInstance().getPosition(); var items = undefined; if (node) { var dm = pydio.getContextHolder(); if (dm.getSelectedNodes().indexOf(node) !== -1) { this.openMenu('selectionContext', position); } else { pydio.observeOnce("actions_refreshed", (function (dataModel) { this.openMenu('selectionContext', position); }).bind(this)); dm.setSelectedNodes([node]); } } else { this.openMenu('genericContext', position); } }; ContextMenu.prototype.openMenu = function openMenu(context, position) { var items = this.computeMenuItems(context); this._items = items; var mobile = this.props.pydio.UI.MOBILE_EXTENSIONS; if (!mobile) { position = this.computeVisiblePosition(position, items); this.refs['menu'].showMenu({ top: position.y, left: position.x }, items); } else { this.refs['menu'].showMenu({ bottom: 0, left: 0, right: 0, height: 200, zIndex: 10000, overflowY: 'auto' }, items); } }; ContextMenu.prototype.computeMenuItems = function computeMenuItems(context) { var actions = this.props.pydio.Controller.getContextActions(context, ['inline', 'info_panel', 'info_panel_share']); return _Utils2['default'].pydioActionsToItems(actions); }; ContextMenu.prototype.computeVisiblePosition = function computeVisiblePosition(position, items) { var menuHeight = dims.MENU_VERTICAL_PADDING * 2; items.map(function (it) { if (it.separator) menuHeight += dims.MENU_SEP_HEIGHT;else menuHeight += dims.MENU_ITEM_HEIGHT; }); var menuWidth = dims.MENU_WIDTH; var windowW = Math.max(document.documentElement.clientWidth, window.innerWidth || 0); var windowH = Math.max(document.documentElement.clientHeight, window.innerHeight || 0); if (position.x + menuWidth > windowW) { position.x = Math.max(position.x - menuWidth, 10) - dims.OFFSET_HORIZONTAL; } else { position.x += dims.OFFSET_HORIZONTAL; } if (position.y + menuHeight > windowH) { position.y = Math.max(position.y - menuHeight, 10) - dims.OFFSET_VERTICAL; } else { position.y += dims.OFFSET_VERTICAL; } return position; }; ContextMenu.prototype.componentDidMount = function componentDidMount() { this._modelOpen = this.modelOpen.bind(this); _pydioModelContextMenu2['default'].getInstance().observe("open", this._modelOpen); }; ContextMenu.prototype.componentWillUnmount = function componentWillUnmount() { _pydioModelContextMenu2['default'].getInstance().stopObserving("open", this._modelOpen); }; ContextMenu.prototype.render = function render() { var mobile = this.props.pydio.UI.MOBILE_EXTENSIONS; return React.createElement(_PopupMenu2['default'], { ref: 'menu', menuItems: this._items || [], onMenuClosed: this.props.onMenuClosed, menuProps: mobile ? { width: 600, autoWidth: false, desktop: false } : {}, zDepth: mobile ? 2 : 1 }); }; return ContextMenu; })(Component); exports['default'] = ContextMenu; module.exports = exports['default']; },{"./PopupMenu":29,"./Utils":31,"pydio/model/context-menu":"pydio/model/context-menu","react":"react"}],26:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var _Utils = require('./Utils'); var _Utils2 = _interopRequireDefault(_Utils); var _MenuItemsConsumer = require('./MenuItemsConsumer'); var _MenuItemsConsumer2 = _interopRequireDefault(_MenuItemsConsumer); var React = require('react'); var _require = require('material-ui'); var IconButton = _require.IconButton; var Popover = _require.Popover; var IconButtonMenu = (function (_React$Component) { _inherits(IconButtonMenu, _React$Component); function IconButtonMenu(props, context) { _classCallCheck(this, IconButtonMenu); _React$Component.call(this, props, context); this.state = { showMenu: false }; } IconButtonMenu.prototype.showMenu = function showMenu(event) { this.setState({ showMenu: true, anchor: event.currentTarget }); }; IconButtonMenu.prototype.closeMenu = function closeMenu(event, index, menuItem) { this.setState({ showMenu: false }); }; IconButtonMenu.prototype.render = function render() { var _this = this; return React.createElement( 'span', { className: "toolbars-button-menu " + (this.props.className ? this.props.className : '') }, React.createElement(IconButton, { ref: 'menuButton', tooltip: this.props.buttonTitle, iconClassName: this.props.buttonClassName, onTouchTap: this.showMenu.bind(this), iconStyle: this.props.buttonStyle }), React.createElement( Popover, { open: this.state.showMenu, anchorEl: this.state.anchor, anchorOrigin: { horizontal: this.props.popoverDirection || 'right', vertical: this.props.popoverTargetPosition || 'bottom' }, targetOrigin: { horizontal: this.props.popoverDirection || 'right', vertical: 'top' }, onRequestClose: function () { _this.setState({ showMenu: false }); }, useLayerForClickAway: false }, _Utils2['default'].itemsToMenu(this.props.menuItems, this.closeMenu.bind(this), false, this.props.menuProps || undefined) ) ); }; return IconButtonMenu; })(React.Component); IconButtonMenu.propTypes = { buttonTitle: React.PropTypes.string.isRequired, buttonClassName: React.PropTypes.string.isRequired, className: React.PropTypes.string, popoverDirection: React.PropTypes.oneOf(['right', 'left']), popoverPosition: React.PropTypes.oneOf(['top', 'bottom']), menuProps: React.PropTypes.object, menuItems: React.PropTypes.array.isRequired }; exports['default'] = _MenuItemsConsumer2['default'](IconButtonMenu); module.exports = exports['default']; },{"./MenuItemsConsumer":28,"./Utils":31,"material-ui":"material-ui","react":"react"}],27:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var React = require('react'); var _require = require('material-ui'); var IconButton = _require.IconButton; var Popover = _require.Popover; var IconButtonPopover = (function (_React$Component) { _inherits(IconButtonPopover, _React$Component); function IconButtonPopover(props, context) { _classCallCheck(this, IconButtonPopover); _React$Component.call(this, props, context); this.state = { showPopover: false }; } IconButtonPopover.prototype.showPopover = function showPopover(event) { this.setState({ showPopover: true, anchor: event.currentTarget }); }; IconButtonPopover.prototype.render = function render() { var _this = this; return React.createElement( 'span', { className: "toolbars-button-menu " + (this.props.className ? this.props.className : '') }, React.createElement(IconButton, { ref: 'menuButton', tooltip: this.props.buttonTitle, iconClassName: this.props.buttonClassName, onTouchTap: this.showPopover.bind(this), iconStyle: this.props.buttonStyle }), React.createElement( Popover, { open: this.state.showPopover, anchorEl: this.state.anchor, anchorOrigin: { horizontal: this.props.direction || 'right', vertical: 'bottom' }, targetOrigin: { horizontal: this.props.direction || 'right', vertical: 'top' }, onRequestClose: function () { _this.setState({ showPopover: false }); }, useLayerForClickAway: false }, this.props.popoverContent ) ); }; return IconButtonPopover; })(React.Component); IconButtonPopover.propTypes = { buttonTitle: React.PropTypes.string.isRequired, buttonClassName: React.PropTypes.string.isRequired, className: React.PropTypes.string, direction: React.PropTypes.oneOf(['right', 'left']), popoverContent: React.PropTypes.object.isRequired }; exports['default'] = IconButtonPopover; module.exports = exports['default']; },{"material-ui":"material-ui","react":"react"}],28:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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 _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var _Utils = require('./Utils'); var _Utils2 = _interopRequireDefault(_Utils); var React = require('react'); var Controller = require('pydio/model/controller'); exports['default'] = function (Component) { var Wrapped = (function (_React$Component) { _inherits(Wrapped, _React$Component); function Wrapped(props, context) { _classCallCheck(this, Wrapped); _React$Component.call(this, props, context); this.state = { menuItems: this.props.menuItems || [] }; } Wrapped.prototype.componentDidMount = function componentDidMount() { var _this = this; if (this.props.controller && !this.props.menuItems) { this._observer = function () { var actions = _this.props.controller.getContextActions('genericContext', null, _this.props.toolbars); var menuItems = _Utils2['default'].pydioActionsToItems(actions); _this.setState({ menuItems: menuItems }); }; if (this.props.controller === this.props.pydio.Controller) { this.props.pydio.observe("actions_refreshed", this._observer); } else { this.props.controller.observe("actions_refreshed", this._observer); } this._observer(); } }; Wrapped.prototype.componentWillUnmount = function componentWillUnmount() { if (this._observer) { if (this.props.controller === this.props.pydio.Controller) { this.props.pydio.stopObserving("actions_refreshed", this._observer); } else { this.props.controller.stopObserving("actions_refreshed", this._observer); } } }; Wrapped.prototype.componentWillReceiveProps = function componentWillReceiveProps(nextProps) { if (nextProps.menuItems && nextProps.menuItems !== this.props.menuItems) { this.setState({ menuItems: nextProps.menuItems }); } }; Wrapped.prototype.render = function render() { return React.createElement(Component, _extends({}, this.props, { menuItems: this.state.menuItems })); }; return Wrapped; })(React.Component); Wrapped.propTypes = { menuItems: React.PropTypes.array, toolbars: React.PropTypes.array, controller: React.PropTypes.instanceOf(Controller), pydio: React.PropTypes.instanceOf(Pydio) }; return Wrapped; }; module.exports = exports['default']; },{"./Utils":31,"pydio/model/controller":"pydio/model/controller","react":"react"}],29:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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 _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } var _Utils = require('./Utils'); var _Utils2 = _interopRequireDefault(_Utils); var React = require('react'); var ReactDOM = require('react-dom'); var _require = require('material-ui'); var Menu = _require.Menu; var Paper = _require.Paper; exports['default'] = React.createClass({ displayName: 'PopupMenu', propTypes: { menuItems: React.PropTypes.array.isRequired, onExternalClickCheckElements: React.PropTypes.func, className: React.PropTypes.string, style: React.PropTypes.object, onMenuClosed: React.PropTypes.func }, getInitialState: function getInitialState() { return { showMenu: false, menuItems: this.props.menuItems }; }, showMenu: function showMenu() { var style = arguments.length <= 0 || arguments[0] === undefined ? null : arguments[0]; var menuItems = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1]; this.setState({ showMenu: true, style: style, menuItems: menuItems ? menuItems : this.state.menuItems }); }, hideMenu: function hideMenu(event) { if (!event) { this.setState({ showMenu: false }); if (this.props.onMenuClosed) this.props.onMenuClosed(); return; } // Firefox trigger a click event when you mouse up on contextmenu event if (typeof event !== 'undefined' && event.button === 2 && event.type !== 'contextmenu') { return; } var node = ReactDOM.findDOMNode(this.refs.menuContainer); if (node.contains(event.target) || node === event.target) { return; } this.setState({ showMenu: false }); if (this.props.onMenuClosed) this.props.onMenuClosed(); }, componentDidMount: function componentDidMount() { this._observer = this.hideMenu; }, componentWillUnmount: function componentWillUnmount() { document.removeEventListener('click', this._observer, false); }, componentWillReceiveProps: function componentWillReceiveProps(nextProps) { if (nextProps.menuItems) { this.setState({ menuItems: nextProps.menuItems }); } }, componentDidUpdate: function componentDidUpdate(prevProps, nextProps) { if (this.state.showMenu) { document.addEventListener('click', this._observer, false); } else { document.removeEventListener('click', this._observer, false); } }, menuClicked: function menuClicked(event, index, menuItem) { this.hideMenu(); }, render: function render() { var style = this.state.style || {}; style = _extends({}, style, { zIndex: 1000 }); var menu = _Utils2['default'].itemsToMenu(this.state.menuItems, this.menuClicked, false, _extends({ desktop: true, display: 'right', width: 250 }, this.props.menuProps)); if (this.state.showMenu) { return React.createElement( Paper, { zDepth: this.props.zDepth || 1, ref: 'menuContainer', className: 'menu-positioner', style: style }, menu ); } else { return null; } } }); module.exports = exports['default']; },{"./Utils":31,"material-ui":"material-ui","react":"react","react-dom":"react-dom"}],30:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } var _Utils = require('./Utils'); var _Utils2 = _interopRequireDefault(_Utils); var _IconButtonMenu = require('./IconButtonMenu'); var _IconButtonMenu2 = _interopRequireDefault(_IconButtonMenu); var _ButtonMenu = require('./ButtonMenu'); var _ButtonMenu2 = _interopRequireDefault(_ButtonMenu); var _IconButtonPopover = require('./IconButtonPopover'); var _IconButtonPopover2 = _interopRequireDefault(_IconButtonPopover); (function (global) { exports['default'] = React.createClass({ displayName: 'Toolbar', propTypes: { toolbars: React.PropTypes.array, groupOtherList: React.PropTypes.array, renderingType: React.PropTypes.string, controller: React.PropTypes.instanceOf(Controller), toolbarStyle: React.PropTypes.object, buttonStyle: React.PropTypes.object }, componentDidMount: function componentDidMount() { this._observer = (function () { if (!this.isMounted()) return; this.setState({ groups: this.props.controller.getToolbarsActions(this.props.toolbars, this.props.groupOtherList) }); }).bind(this); if (this.props.controller === pydio.Controller) { pydio.observe("actions_refreshed", this._observer); } else { this.props.controller.observe("actions_refreshed", this._observer); } }, componentWillUnmount: function componentWillUnmount() { if (this.props.controller === pydio.Controller) { pydio.stopObserving("actions_refreshed", this._observer); } else { this.props.controller.stopObserving("actions_refreshed", this._observer); } }, componentWillReceiveProps: function componentWillReceiveProps(nextProps) { if (nextProps.toolbars !== this.props.toolbars) { this.setState({ groups: this.props.controller.getToolbarsActions(nextProps.toolbars, nextProps.groupOtherList) }); } }, getInitialState: function getInitialState() { return { groups: this.props.controller.getToolbarsActions(this.props.toolbars, this.props.groupOtherList) }; }, getDefaultProps: function getDefaultProps() { return { controller: global.pydio.Controller, renderingType: 'button', groupOtherList: [] }; }, render: function render() { var groups = this.state.groups; var actions = []; var _props = this.props; var toolbars = _props.toolbars; var renderingType = _props.renderingType; var groupOtherList = _props.groupOtherList; var buttonStyle = _props.buttonStyle; var tooltipPosition = _props.tooltipPosition; var controller = _props.controller; var allToolbars = [].concat(toolbars); if (groupOtherList.length) { allToolbars = allToolbars.concat(['MORE_ACTION']); } allToolbars.map(function (barName) { if (!groups.has(barName)) return; groups.get(barName).map(function (action) { if (action.deny) return; var menuItems = undefined, popoverContent = undefined, menuTitle = undefined, menuIcon = undefined; var actionName = action.options.name; menuTitle = action.options.text; menuIcon = action.options.icon_class; if (barName === 'MORE_ACTION') { (function () { var subItems = action.subMenuItems.dynamicItems; var items = []; subItems.map(function (obj) { if (obj.separator) { items.push(obj); } else if (obj.actionId && !obj.actionId.deny) { items.push(obj.actionId.getMenuData()); } }); menuItems = _Utils2['default'].pydioActionsToItems(items); })(); } else if (action.subMenuItems.staticItems) { menuItems = _Utils2['default'].pydioActionsToItems(action.subMenuItems.staticItems); } else if (action.subMenuItems.dynamicBuilder) { menuItems = _Utils2['default'].pydioActionsToItems(action.subMenuItems.dynamicBuilder(controller)); } else if (action.subMenuItems.popoverContent) { popoverContent = action.subMenuItems.popoverContent; } else {} var id = 'action-' + action.options.name; if (renderingType === 'button-icon') { menuTitle = React.createElement( 'span', { className: 'button-icon' }, React.createElement('span', { className: "button-icon-icon " + menuIcon }), React.createElement( 'span', { className: 'button-icon-label' }, menuTitle ) ); } if (menuItems) { if (renderingType === 'button' || renderingType === 'button-icon') { actions.push(React.createElement(_ButtonMenu2['default'], { key: actionName, className: id, buttonTitle: menuTitle, menuItems: menuItems, buttonLabelStyle: buttonStyle })); } else { actions.push(React.createElement(_IconButtonMenu2['default'], { key: actionName, className: id, onMenuClicked: function (object) { object.payload(); }, buttonClassName: menuIcon, buttonTitle: menuTitle, menuItems: menuItems, buttonStyle: buttonStyle })); } } else if (popoverContent) { actions.push(React.createElement(_IconButtonPopover2['default'], { key: actionName, className: id, buttonClassName: menuIcon, buttonTitle: menuTitle, buttonStyle: buttonStyle, popoverContent: popoverContent })); } else { var click = function click(synthEvent) { action.apply(); }; if (renderingType === 'button-icon') { actions.push(React.createElement(ReactMUI.FlatButton, { key: actionName, className: id, onTouchTap: click, label: menuTitle, labelStyle: buttonStyle })); } else if (renderingType === 'button') { actions.push(React.createElement(MaterialUI.FlatButton, { key: actionName, className: id, onTouchTap: click, label: menuTitle, labelStyle: buttonStyle })); } else { actions.push(React.createElement(MaterialUI.IconButton, { key: actionName, iconClassName: menuIcon + ' ' + id, iconStyle: buttonStyle, onTouchTap: click, tooltip: menuTitle, tooltipPosition: tooltipPosition })); } } }); }); var cName = this.props.className ? this.props.className : ''; cName += ' ' + 'toolbar'; if (!actions.length) { cName += ' empty-toolbar'; } return React.createElement( 'div', { className: cName, style: this.props.toolbarStyle, id: this.props.id }, actions ); } }); })(window); module.exports = exports['default']; },{"./ButtonMenu":24,"./IconButtonMenu":26,"./IconButtonPopover":27,"./Utils":31}],31:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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; }; var _require = require('material-ui'); var Divider = _require.Divider; var Menu = _require.Menu; var MenuItem = _require.MenuItem; var FontIcon = _require.FontIcon; function pydioActionsToItems() { var actions = arguments.length <= 0 || arguments[0] === undefined ? [] : arguments[0]; var items = []; var lastIsSeparator = false; actions.map((function (action, index) { if (action.separator) { if (lastIsSeparator) return; items.push(action); lastIsSeparator = true; return; } lastIsSeparator = false; var label = action.raw_name ? action.raw_name : action.name; var iconClass = action.icon_class; var payload = undefined; if (action.subMenu) { var subItems = action.subMenuBeforeShow ? pydioActionsToItems(action.subMenuBeforeShow()) : action.subMenu; items.push({ text: label, iconClassName: iconClass, subItems: subItems }); } else { items.push({ text: label, iconClassName: iconClass, payload: action.callback }); } }).bind(this)); if (lastIsSeparator) { items = items.slice(0, items.length - 1); } if (items.length && items[0] && items[0].separator) { items.shift(); } return items; } function itemsToMenu(items, closeMenuCallback) { var subItemsOnly = arguments.length <= 2 || arguments[2] === undefined ? false : arguments[2]; var menuProps = arguments.length <= 3 || arguments[3] === undefined ? {} : arguments[3]; menuProps = _extends({ display: 'normal', width: 216, desktop: true, autoWidth: false }, menuProps); var menuItems = items.map(function (item, index) { if (item.separator) return React.createElement(Divider, { key: "divider" + index }); var subItems = undefined, payload = undefined; if (item.subItems) { subItems = itemsToMenu(item.subItems, closeMenuCallback, true); } else if (item.payload) { payload = function () { item.payload(); closeMenuCallback(); }; } var leftIcon = undefined, rightIcon = undefined; var iconClassName = item.iconClassName;var inset = false; if (iconClassName === '__INSET__') { iconClassName = ''; inset = true; } if (menuProps.display === 'normal') { leftIcon = iconClassName ? React.createElement(FontIcon, { className: item.iconClassName + ' menu-icons', style: { fontSize: 16, padding: 5 } }) : null; } else if (menuProps.display === 'right') { rightIcon = iconClassName ? React.createElement(FontIcon, { className: item.iconClassName + ' menu-icons', style: { fontSize: 16, padding: 5 } }) : null; } rightIcon = subItems && subItems.length ? React.createElement(FontIcon, { className: 'mdi mdi-menu-right menu-icons' }) : rightIcon; return React.createElement(MenuItem, { key: item.text, primaryText: item.text, insetChildren: inset, leftIcon: leftIcon, rightIcon: rightIcon, onTouchTap: payload, menuItems: subItems }); }); if (subItemsOnly) { return menuItems; } else { return React.createElement( Menu, menuProps, menuItems ); } } exports['default'] = { pydioActionsToItems: pydioActionsToItems, itemsToMenu: itemsToMenu }; module.exports = exports['default']; },{"material-ui":"material-ui"}],32:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var _require = require('react'); var Component = _require.Component; var PropTypes = _require.PropTypes; var _require2 = require('material-ui'); var TextField = _require2.TextField; var FlatButton = _require2.FlatButton; var _require$requireLib = require('pydio').requireLib('boot'); var PydioContextConsumer = _require$requireLib.PydioContextConsumer; /** * Simple form for creating a team */ var TeamCreationForm = (function (_Component) { _inherits(TeamCreationForm, _Component); TeamCreationForm.updateTeamUsers = function updateTeamUsers(team, operation, users, callback) { var teamId = team.id.replace('/AJXP_TEAM/', ''); var clearUserCache = function clearUserCache(uId) { MetaCacheService.getInstance().deleteKey('user_public_data-rich', uId); }; if (operation === 'add') { users.forEach(function (user) { var userId = user.getId ? user.getId() : user.id; PydioUsers.Client.addUserToTeam(teamId, userId, callback); clearUserCache(userId); }); } else if (operation === 'delete') { users.forEach(function (user) { var userId = user.getId ? user.getId() : user.id; PydioUsers.Client.removeUserFromTeam(teamId, userId, callback); clearUserCache(userId); }); } else if (operation === 'create') { PydioUsers.Client.saveSelectionAsTeam(teamId, users, callback); users.forEach(function (user) { clearUserCache(user.getId ? user.getId() : user.id); }); } }; function TeamCreationForm(props, context) { _classCallCheck(this, TeamCreationForm); _Component.call(this, props, context); this.state = { value: '' }; } TeamCreationForm.prototype.onChange = function onChange(e, value) { this.setState({ value: value }); }; TeamCreationForm.prototype.submitCreationForm = function submitCreationForm() { var value = this.state.value; TeamCreationForm.updateTeamUsers({ id: value }, 'create', [], this.props.onTeamCreated); }; TeamCreationForm.prototype.render = function render() { var getMessage = this.props.getMessage; return React.createElement( 'div', { style: { padding: 20 } }, React.createElement( 'div', null, getMessage(591) ), React.createElement(TextField, { floatingLabelText: getMessage(578), value: this.state.value, onChange: this.onChange.bind(this), fullWidth: true }), React.createElement( 'div', null, React.createElement( 'div', { style: { textAlign: 'right', paddingTop: 10 } }, React.createElement(FlatButton, { label: getMessage(49), onTouchTap: this.props.onCancel.bind(this) }), React.createElement(FlatButton, { label: getMessage(579), secondary: true, onTouchTap: this.submitCreationForm.bind(this) }) ) ) ); }; return TeamCreationForm; })(Component); TeamCreationForm.propTypes = { /** * Callback triggered after team creation succeeded */ onTeamCreated: PropTypes.func.isRequired, /** * Request modal close */ onCancel: PropTypes.func.isRequired }; exports['default'] = TeamCreationForm = PydioContextConsumer(TeamCreationForm); exports['default'] = TeamCreationForm; module.exports = exports['default']; },{"material-ui":"material-ui","pydio":"pydio","react":"react"}],33:[function(require,module,exports){ (function (global){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } var _addressbookAddressBook = require('./addressbook/AddressBook'); var _addressbookAddressBook2 = _interopRequireDefault(_addressbookAddressBook); var _require$requireLib = require('pydio/http/resources-manager').requireLib('boot'); var AsyncComponent = _require$requireLib.AsyncComponent; var _require = require('material-ui'); var TextField = _require.TextField; var AutoComplete = _require.AutoComplete; var RefreshIndicator = _require.RefreshIndicator; var IconButton = _require.IconButton; var Popover = _require.Popover; var React = require('react'); var FuncUtils = require('pydio/util/func'); /** * Ready to use autocomplete field that will load users/groups/roles from * the server (using user_list_authorized_users API). * Used for sharing, addressbooks, send email, etc. * * Can also open a "selector-style" adress book. */ var UsersLoader = React.createClass({ displayName: 'UsersLoader', propTypes: { /** * Method called to render a commponent, taking a UserObject as input */ renderSuggestion: React.PropTypes.func.isRequired, /** * Callback when a value is finally selected */ onValueSelected: React.PropTypes.func.isRequired, /** * Floating Label Text displayed on the field */ fieldLabel: React.PropTypes.string.isRequired, /** * Array of values to ignore */ excludes: React.PropTypes.array.isRequired, /** * Display only users, no groups nor roles */ usersOnly: React.PropTypes.bool, /** * Display users from local directory and/or from remote. */ usersFrom: React.PropTypes.oneOf(['local', 'remote', 'any']), /** * Do not propose a "Create user" option */ existingOnly: React.PropTypes.bool, /** * Allow free typing */ freeValueAllowed: React.PropTypes.bool, /** * Will be passed to the root component */ className: React.PropTypes.string }, getInitialState: function getInitialState() { return { dataSource: [], loading: false, searchText: '', minChars: parseInt(global.pydio.getPluginConfigs("core.conf").get("USERS_LIST_COMPLETE_MIN_CHARS")) }; }, /** * Loads values from server * @param {string} input Currently searched text * @param {Function} callback Called with the values */ suggestionLoader: function suggestionLoader(input, callback) { var excludes = this.props.excludes; var disallowTemporary = this.props.existingOnly && !this.props.freeValueAllowed; this.setState({ loading: this.state.loading + 1 }); PydioUsers.Client.authorizedUsersStartingWith(input, (function (users) { this.setState({ loading: this.state.loading - 1 }); if (disallowTemporary) { users = users.filter(function (user) { return !user.getTemporary(); }); } if (excludes && excludes.length) { users = users.filter(function (user) { return excludes.indexOf(user.getId()) == -1; }); } callback(users); }).bind(this), this.props.usersOnly, this.props.existingOnly); }, /** * Called when the field is updated * @param value */ textFieldUpdate: function textFieldUpdate(value) { this.setState({ searchText: value }); if (this.state.minChars && value && value.length < this.state.minChars) { return; } this.loadBuffered(value, 350); }, getPendingSearchText: function getPendingSearchText() { return this.state.searchText || false; }, /** * Debounced call for rendering search * @param value {string} * @param timeout {int} */ loadBuffered: function loadBuffered(value, timeout) { if (!value && this._emptyValueList) { this.setState({ dataSource: this._emptyValueList }); return; } FuncUtils.bufferCallback('remote_users_search', timeout, (function () { this.setState({ loading: true }); this.suggestionLoader(value, (function (users) { var crtValueFound = false; var values = users.map((function (userObject) { var component = React.createElement( MaterialUI.MenuItem, null, this.props.renderSuggestion(userObject) ); return { userObject: userObject, text: userObject.getExtendedLabel(), value: component }; }).bind(this)); if (!value) { this._emptyValueList = values; } this.setState({ dataSource: values, loading: false }); }).bind(this)); }).bind(this)); }, /** * Called when user selects a value from the list * @param value * @param index */ onCompleterRequest: function onCompleterRequest(value, index) { if (index === -1) { this.state.dataSource.map(function (entry) { if (entry.text === value) { value = entry; } }); if (value && !value.userObject && this.props.freeValueAllowed) { var fake = new PydioUsers.User(value, value, 'user', null, null, true); this.props.onValueSelected(fake); this.setState({ searchText: '', dataSource: [] }); return; } } if (value && value.userObject) { var object = value.userObject; if (object.getTemporary()) { if (this.props.freeValueAllowed) { this.props.onValueSelected(object); } else { this.setState({ createUser: object.getLabel() }); } } else { this.props.onValueSelected(object); } this.setState({ searchText: '', dataSource: [] }); } }, /** * Triggers onValueSelected props callback * @param {Pydio.User} newUser */ onUserCreated: function onUserCreated(newUser) { this.props.onValueSelected(newUser); this.setState({ createUser: null }); }, /** * Close user creation form */ onCreationCancelled: function onCreationCancelled() { this.setState({ createUser: null }); }, /** * Open address book inside a Popover * @param event */ openAddressBook: function openAddressBook(event) { this.setState({ addressBookOpen: true, addressBookAnchor: event.currentTarget }); }, /** * Close address book popover */ closeAddressBook: function closeAddressBook() { this.setState({ addressBookOpen: false }); }, /** * Triggered when user clicks on an entry from adress book. * @param item */ onAddressBookItemSelected: function onAddressBookItemSelected(item) { this.props.onValueSelected(item); }, render: function render() { var _this = this; var _state = this.state; var dataSource = _state.dataSource; var createUser = _state.createUser; var containerStyle = { position: 'relative', overflow: 'visible' }; /* if(createUser){ return (
); } */ return React.createElement( 'div', { style: containerStyle, ref: function (el) { _this._popoverAnchor = el; } }, !createUser && React.createElement(AutoComplete, { filter: MaterialUI.AutoComplete.noFilter, dataSource: dataSource, searchText: this.state.searchText, onUpdateInput: this.textFieldUpdate, className: this.props.className, openOnFocus: true, floatingLabelText: this.props.fieldLabel, underlineShow: !this.props.underlineHide, fullWidth: true, onNewRequest: this.onCompleterRequest, listStyle: { maxHeight: 350, overflowY: 'auto' }, onFocus: function () { _this.loadBuffered(_this.state.searchText, 100); } }), createUser && React.createElement(TextField, { floatingLabelText: this.props.fieldLabel, value: global.pydio.MessageHash[485] + ' (' + this.state.createUser + ')', disabled: true, fullWidth: true, underlineShow: !this.props.underlineHide }), !createUser && React.createElement( 'div', { style: { position: 'absolute', right: 4, bottom: 14, height: 20, width: 20 } }, React.createElement(RefreshIndicator, { size: 20, left: 0, top: 0, status: this.state.loading ? 'loading' : 'hide' }) ), this.props.showAddressBook && !createUser && React.createElement(_addressbookAddressBook2['default'], { mode: 'popover', pydio: this.props.pydio, loaderStyle: { width: 320, height: 420 }, onItemSelected: this.onAddressBookItemSelected, usersFrom: this.props.usersFrom, disableSearch: true }), React.createElement( Popover, { open: createUser, anchorEl: this._popoverAnchor, anchorOrigin: { horizontal: 'left', vertical: 'bottom' }, targetOrigin: { horizontal: 'left', vertical: 'top' }, onRequestClose: this.onCreationCancelled, canAutoPosition: false }, createUser && React.createElement(AsyncComponent, { namespace: "PydioForm", componentName: "UserCreationForm", style: { width: 350, height: 320 }, newUserName: this.state.createUser, onUserCreated: this.onUserCreated, onCancel: this.onCreationCancelled, pydio: this.props.pydio }) ) ); } }); exports['default'] = UsersLoader; module.exports = exports['default']; }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) },{"./addressbook/AddressBook":34,"material-ui":"material-ui","pydio/http/resources-manager":"pydio/http/resources-manager","pydio/util/func":"pydio/util/func","react":"react"}],34:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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 _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } var _NestedListItem = require('./NestedListItem'); var _NestedListItem2 = _interopRequireDefault(_NestedListItem); var _UsersList = require('./UsersList'); var _UsersList2 = _interopRequireDefault(_UsersList); var _RightPanelCard = require('./RightPanelCard'); var _RightPanelCard2 = _interopRequireDefault(_RightPanelCard); var _SearchPanel = require('./SearchPanel'); var _SearchPanel2 = _interopRequireDefault(_SearchPanel); var _Loaders = require('./Loaders'); var _Loaders2 = _interopRequireDefault(_Loaders); var _TeamCreationForm = require('../TeamCreationForm'); var _TeamCreationForm2 = _interopRequireDefault(_TeamCreationForm); var React = require('react'); var Pydio = require('pydio'); var _Pydio$requireLib = Pydio.requireLib('boot'); var AsyncComponent = _Pydio$requireLib.AsyncComponent; var PydioContextConsumer = _Pydio$requireLib.PydioContextConsumer; var _require = require('material-ui'); var Popover = _require.Popover; var IconButton = _require.IconButton; var _require2 = require('material-ui/styles'); var muiThemeable = _require2.muiThemeable; var colors = _require2.colors; /** * High level component to browse users, groups and teams, either in a large format (mode='book') or a more compact * format (mode='selector'|'popover'). * Address book allows to create external users, teams, and also to browse trusted server directories if Federated Sharing * is active. */ var AddressBook = React.createClass({ displayName: 'AddressBook', propTypes: { /** * Main instance of pydio */ pydio: React.PropTypes.instanceOf(Pydio), /** * Display mode, either large (book) or small picker ('selector', 'popover'). */ mode: React.PropTypes.oneOf(['book', 'selector', 'popover']).isRequired, /** * Callback triggered in 'selector' mode whenever an item is clicked. */ onItemSelected: React.PropTypes.func, /** * Display users only, no teams or groups */ usersOnly: React.PropTypes.bool, /** * Choose various user sources, either the local directory or remote ( = trusted ) servers. */ usersFrom: React.PropTypes.oneOf(['local', 'remote', 'any']), /** * Disable the search engine */ disableSearch: React.PropTypes.bool, /** * Theme object passed by muiThemeable() wrapper */ muiTheme: React.PropTypes.object, /** * Will be passed to the Popover object */ popoverStyle: React.PropTypes.object, /** * Used as a button to open the selector in a popover */ popoverButton: React.PropTypes.object, /** * Will be passed to the Popover container object */ popoverContainerStyle: React.PropTypes.object, /** * Will be passed to the Popover Icon Button. */ popoverIconButtonStyle: React.PropTypes.object }, getDefaultProps: function getDefaultProps() { return { mode: 'book', usersOnly: false, usersFrom: 'any', teamsOnly: false, disableSearch: false }; }, getInitialState: function getInitialState() { var _this = this; var _props = this.props; var pydio = _props.pydio; var mode = _props.mode; var usersOnly = _props.usersOnly; var usersFrom = _props.usersFrom; var teamsOnly = _props.teamsOnly; var disableSearch = _props.disableSearch; var getMessage = function getMessage(id) { return _this.props.getMessage(id, ''); }; var confConfigs = pydio.getPluginConfigs('core.conf'); var root = undefined; if (teamsOnly) { root = { id: 'teams', label: getMessage(568), childrenLoader: _Loaders2['default'].loadTeams, _parent: null, _notSelectable: true, actions: { type: 'teams', create: '+ ' + getMessage(569), remove: getMessage(570), multiple: true } }; return { root: root, selectedItem: root, loading: false, rightPaneItem: null }; } root = { id: 'root', label: getMessage(592), type: 'root', collections: [] }; if (usersFrom !== 'remote') { if (confConfigs.get('USER_CREATE_USERS')) { root.collections.push({ id: 'ext', label: getMessage(593), //icon:'mdi mdi-account-network', itemsLoader: _Loaders2['default'].loadExternalUsers, _parent: root, _notSelectable: true, actions: { type: 'users', create: '+ ' + getMessage(484), remove: getMessage(582), multiple: true } }); } if (!usersOnly) { root.collections.push({ id: 'teams', label: getMessage(568), //icon: 'mdi mdi-account-multiple', childrenLoader: _Loaders2['default'].loadTeams, _parent: root, _notSelectable: true, actions: { type: 'teams', create: '+ ' + getMessage(569), remove: getMessage(570), multiple: true } }); } if (confConfigs.get('ALLOW_CROSSUSERS_SHARING')) { var groupOrUsers = confConfigs.get('ADDRESSBOOK_GROUP_OR_USERS'); if (groupOrUsers && groupOrUsers.group_switch_value) groupOrUsers = groupOrUsers.group_switch_value;else groupOrUsers = 'both'; if (groupOrUsers === 'search') { if (!disableSearch) { root.collections.push({ id: 'search', label: getMessage(583), //icon:'mdi mdi-account-search', type: 'search', _parent: root, _notSelectable: true }); } } else { root.collections.push({ id: 'AJXP_GRP_/', label: getMessage(584), //icon:'mdi mdi-account-box', childrenLoader: groupOrUsers === 'both' || groupOrUsers === 'groups' ? _Loaders2['default'].loadGroups : null, itemsLoader: groupOrUsers === 'both' || groupOrUsers === 'users' ? _Loaders2['default'].loadGroupUsers : null, _parent: root, _notSelectable: true }); } } } var ocsRemotes = pydio.getPluginConfigs('core.ocs').get('TRUSTED_SERVERS'); if (ocsRemotes && !usersOnly && usersFrom !== 'local') { var remotes = JSON.parse(ocsRemotes); var remotesNodes = { id: 'remotes', label: getMessage(594), //icon:'mdi mdi-server', collections: [], _parent: root, _notSelectable: true }; for (var k in remotes) { if (!remotes.hasOwnProperty(k)) continue; remotesNodes.collections.push({ id: k, label: remotes[k], icon: 'mdi mdi-server-network', type: 'remote', _parent: remotesNodes, _notSelectable: true }); } if (remotesNodes.collections.length) { root.collections.push(remotesNodes); } } return { root: root, selectedItem: mode === 'selector' ? root : root.collections[0], loading: false, rightPaneItem: null }; }, componentDidMount: function componentDidMount() { this.state.selectedItem && this.onFolderClicked(this.state.selectedItem); }, onFolderClicked: function onFolderClicked(item) { var _this2 = this; var callback = arguments.length <= 1 || arguments[1] === undefined ? undefined : arguments[1]; // Special case for teams if (item.type === 'group' && item.id.indexOf('/AJXP_TEAM/') === 0) { this.onUserListItemClicked(item); return; } this.setState({ loading: true }); _Loaders2['default'].childrenAsPromise(item, false).then(function (children) { _Loaders2['default'].childrenAsPromise(item, true).then(function (children) { _this2.setState({ selectedItem: item, loading: false }, callback); }); }); }, onUserListItemClicked: function onUserListItemClicked(item) { if (this.props.onItemSelected) { var uObject = new PydioUsers.User(item.id, item.label, item.type, item.group, item.avatar, item.temporary, item.external); if (item.trusted_server_id) { uObject.trustedServerId = item.trusted_server_id; uObject.trustedServerLabel = item.trusted_server_label; } this.props.onItemSelected(uObject); } else { this.setState({ rightPaneItem: item }); } }, onCreateAction: function onCreateAction(item) { this.setState({ createDialogItem: item }); }, closeCreateDialogAndReload: function closeCreateDialogAndReload() { this.setState({ createDialogItem: null }); this.reloadCurrentNode(); }, onCardUpdateAction: function onCardUpdateAction(item) { if (item._parent && item._parent === this.state.selectedItem) { this.reloadCurrentNode(); } }, onDeleteAction: function onDeleteAction(parentItem, selection) { if (!confirm(this.props.getMessage(278))) { return; } switch (parentItem.actions.type) { case 'users': selection.forEach((function (user) { if (this.state.rightPaneItem === user) this.setState({ rightPaneItem: null }); PydioUsers.Client.deleteUser(user.id, this.reloadCurrentNode.bind(this)); }).bind(this)); break; case 'teams': selection.forEach((function (team) { if (this.state.rightPaneItem === team) this.setState({ rightPaneItem: null }); PydioUsers.Client.deleteTeam(team.id.replace('/AJXP_TEAM/', ''), this.reloadCurrentNode.bind(this)); }).bind(this)); break; case 'team': _TeamCreationForm2['default'].updateTeamUsers(parentItem, 'delete', selection, this.reloadCurrentNode.bind(this)); break; default: break; } }, openPopover: function openPopover(event) { this.setState({ popoverOpen: true, popoverAnchor: event.currentTarget }); }, closePopover: function closePopover() { this.setState({ popoverOpen: false }); }, reloadCurrentNode: function reloadCurrentNode() { var _this3 = this; this.state.selectedItem.leafLoaded = false; this.state.selectedItem.collectionsLoaded = false; this.onFolderClicked(this.state.selectedItem, function () { if (_this3.state.rightPaneItem) { (function () { var rPaneId = _this3.state.rightPaneItem.id; var foundItem = null; var leafs = _this3.state.selectedItem.leafs || []; var collections = _this3.state.selectedItem.collections || []; [].concat(leafs, collections).forEach(function (leaf) { if (leaf.id === rPaneId) foundItem = leaf; }); _this3.setState({ rightPaneItem: foundItem }); })(); } }); }, reloadCurrentAtPage: function reloadCurrentAtPage(letterOrRange) { this.state.selectedItem.leafLoaded = false; this.state.selectedItem.collectionsLoaded = false; if (letterOrRange === -1) { this.state.selectedItem.currentParams = null; } else if (letterOrRange.indexOf('-') !== -1) { this.state.selectedItem.range = letterOrRange; } else { this.state.selectedItem.range = null; this.state.selectedItem.currentParams = { alpha_pages: 'true', value: letterOrRange }; } this.onFolderClicked(this.state.selectedItem); }, reloadCurrentWithSearch: function reloadCurrentWithSearch(value) { if (!value) { this.reloadCurrentAtPage(-1); return; } this.state.selectedItem.leafLoaded = false; this.state.selectedItem.collectionsLoaded = false; this.state.selectedItem.currentParams = { has_search: true, value: value, existing_only: true }; this.onFolderClicked(this.state.selectedItem); }, render: function render() { var _this4 = this; var _props2 = this.props; var mode = _props2.mode; var muiTheme = _props2.muiTheme; var getMessage = _props2.getMessage; if (mode === 'popover') { var popoverStyle = this.props.popoverStyle || {}; var popoverContainerStyle = this.props.popoverContainerStyle || {}; var iconButtonStyle = this.props.popoverIconButtonStyle || {}; var iconButton = React.createElement(IconButton, { style: _extends({ position: 'absolute', padding: 15, zIndex: 100, right: 0, top: 25, display: this.state.loading ? 'none' : 'initial' }, iconButtonStyle), iconStyle: { fontSize: 19, color: 'rgba(0,0,0,0.6)' }, iconClassName: 'mdi mdi-book-open-variant', onTouchTap: this.openPopover }); if (this.props.popoverButton) { iconButton = React.createElement(this.props.popoverButton.type, _extends({}, this.props.popoverButton.props, { onTouchTap: this.openPopover })); } return React.createElement( 'span', null, iconButton, React.createElement( Popover, { open: this.state.popoverOpen, anchorEl: this.state.popoverAnchor, anchorOrigin: { horizontal: 'right', vertical: 'top' }, targetOrigin: { horizontal: 'left', vertical: 'top' }, onRequestClose: this.closePopover, style: _extends({ marginLeft: 20 }, popoverStyle), zDepth: 2 }, React.createElement( 'div', { style: _extends({ width: 320, height: 420 }, popoverContainerStyle) }, React.createElement(AddressBook, _extends({}, this.props, { mode: 'selector' })) ) ) ); } var _state = this.state; var selectedItem = _state.selectedItem; var root = _state.root; var rightPaneItem = _state.rightPaneItem; var createDialogItem = _state.createDialogItem; var leftColumnStyle = { backgroundColor: colors.grey100, width: 256, overflowY: 'auto', overflowX: 'hidden' }; var centerComponent = undefined, rightPanel = undefined, leftPanel = undefined; if (selectedItem.id === 'search') { centerComponent = React.createElement(_SearchPanel2['default'], { item: selectedItem, title: getMessage(583, ''), searchLabel: getMessage(595, ''), onItemClicked: this.onUserListItemClicked, onFolderClicked: this.onFolderClicked, mode: mode }); } else if (selectedItem.type === 'remote') { centerComponent = React.createElement(_SearchPanel2['default'], { item: selectedItem, params: { trusted_server_id: selectedItem.id }, searchLabel: getMessage(595, ''), title: getMessage(596, '').replace('%s', selectedItem.label), onItemClicked: this.onUserListItemClicked, onFolderClicked: this.onFolderClicked, mode: mode }); } else { var emptyStatePrimary = undefined; var emptyStateSecondary = undefined; var otherProps = {}; if (selectedItem.id === 'teams') { emptyStatePrimary = getMessage(571, ''); emptyStateSecondary = getMessage(572, ''); } else if (selectedItem.id === 'ext') { emptyStatePrimary = getMessage(585, ''); emptyStateSecondary = getMessage(586, ''); } else if (selectedItem.id.indexOf('AJXP_GRP_/') === 0) { otherProps = { showSubheaders: true, paginatorType: !(selectedItem.currentParams && selectedItem.currentParams.has_search) && 'alpha', paginatorCallback: this.reloadCurrentAtPage.bind(this), enableSearch: !this.props.disableSearch, searchLabel: getMessage(595, ''), onSearch: this.reloadCurrentWithSearch.bind(this) }; } centerComponent = React.createElement(_UsersList2['default'], _extends({ item: selectedItem, onItemClicked: this.onUserListItemClicked, onFolderClicked: this.onFolderClicked, onCreateAction: this.onCreateAction, onDeleteAction: this.onDeleteAction, loading: this.state.loading, mode: mode, emptyStatePrimaryText: emptyStatePrimary, emptyStateSecondaryText: emptyStateSecondary, onTouchTap: this.state.rightPaneItem ? function () { _this4.setState({ rightPaneItem: null }); } : null }, otherProps)); } var rightPanelStyle = _extends({}, leftColumnStyle, { transformOrigin: 'right', backgroundColor: 'white' }); if (!rightPaneItem) { rightPanelStyle = _extends({}, rightPanelStyle, { transform: 'translateX(256px)', width: 0 }); } rightPanel = React.createElement(_RightPanelCard2['default'], { pydio: this.props.pydio, onRequestClose: function () { _this4.setState({ rightPaneItem: null }); }, style: rightPanelStyle, onCreateAction: this.onCreateAction, onDeleteAction: this.onDeleteAction, onUpdateAction: this.onCardUpdateAction, item: rightPaneItem }); if (mode === 'book') { leftPanel = React.createElement( MaterialUI.Paper, { zDepth: 0, style: _extends({}, leftColumnStyle, { zIndex: 2 }) }, React.createElement( MaterialUI.List, null, root.collections.map((function (e) { return React.createElement(_NestedListItem2['default'], { key: e.id, selected: selectedItem.id, nestedLevel: 0, entry: e, onTouchTap: this.onFolderClicked }); }).bind(this)) ) ); } var dialogTitle = undefined, dialogContent = undefined; if (createDialogItem) { if (createDialogItem.actions.type === 'users') { dialogTitle = getMessage(484, ''); dialogContent = React.createElement( 'div', { style: { height: 500 } }, React.createElement(AsyncComponent, { namespace: 'PydioForm', componentName: 'UserCreationForm', zDepth: 0, style: { height: 500 }, newUserName: "", onUserCreated: this.closeCreateDialogAndReload, onCancel: function () { _this4.setState({ createDialogItem: null }); }, pydio: this.props.pydio }) ); } else if (createDialogItem.actions.type === 'teams') { dialogTitle = getMessage(569, ''); dialogContent = React.createElement(_TeamCreationForm2['default'], { onTeamCreated: this.closeCreateDialogAndReload, onCancel: function () { _this4.setState({ createDialogItem: null }); } }); } else if (createDialogItem.actions.type === 'team') { var selectUser = function selectUser(item) { _TeamCreationForm2['default'].updateTeamUsers(createDialogItem, 'add', [item], _this4.reloadCurrentNode.bind(_this4)); }; dialogTitle = null; dialogContent = React.createElement(AddressBook, { pydio: this.props.pydio, mode: 'selector', usersOnly: true, disableSearch: true, onItemSelected: selectUser }); } } var style = this.props.style || {}; return React.createElement( 'div', { style: _extends({ display: 'flex', height: mode === 'selector' ? 420 : 450 }, style) }, leftPanel, centerComponent, rightPanel, React.createElement( MaterialUI.Dialog, { contentStyle: { width: 380, minWidth: 380, maxWidth: 380, padding: 0 }, bodyStyle: { padding: 0 }, title: React.createElement( 'div', { style: { padding: 20 } }, dialogTitle ), actions: null, modal: false, open: createDialogItem ? true : false, onRequestClose: function () { _this4.setState({ createDialogItem: null }); } }, dialogContent ) ); } }); exports['default'] = AddressBook = PydioContextConsumer(AddressBook); exports['default'] = AddressBook = muiThemeable()(AddressBook); exports['default'] = AddressBook; module.exports = exports['default']; },{"../TeamCreationForm":32,"./Loaders":36,"./NestedListItem":37,"./RightPanelCard":38,"./SearchPanel":40,"./UsersList":43,"material-ui":"material-ui","material-ui/styles":"material-ui/styles","pydio":"pydio","react":"react"}],35:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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 _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var _react = require('react'); var _materialUiStyles = require('material-ui/styles'); var _pydio = require('pydio'); var _pydio2 = _interopRequireDefault(_pydio); var _materialUi = require('material-ui'); /** * Alphabet and pages generator to give a first-letter-based pagination */ var _Pydio$requireLib = _pydio2['default'].requireLib('boot'); var PydioContextConsumer = _Pydio$requireLib.PydioContextConsumer; var AlphaPaginator = (function (_Component) { _inherits(AlphaPaginator, _Component); function AlphaPaginator() { _classCallCheck(this, AlphaPaginator); _Component.apply(this, arguments); } AlphaPaginator.prototype.render = function render() { var letters = 'abcdefghijklmnopqrstuvwxyz0123456789'.split(''); letters = [-1].concat(letters); var _props = this.props; var item = _props.item; var paginatorCallback = _props.paginatorCallback; var style = _props.style; var getMessage = _props.getMessage; var paginator = undefined; if (item.pagination) { (function () { var _item$pagination = item.pagination; var start = _item$pagination.start; var end = _item$pagination.end; var max = _item$pagination.max; var interval = _item$pagination.interval; var total_pages = Math.ceil(max / interval); var current = Math.ceil(start / interval); var pages = []; for (var i = 0; i < total_pages; i++) { pages.push(i); }paginator = React.createElement( _materialUi.SelectField, { floatingLabelText: getMessage(331), style: { width: 60 }, fullWidth: true, value: current, onChange: function (e, i, v) { paginatorCallback(v * interval + '-' + (v + 1) * interval); } }, pages.map(function (p) { return React.createElement(_materialUi.MenuItem, { value: p, key: p, primaryText: p + 1 }); }) ); })(); } var currentPage = item.currentParams && item.currentParams.alpha_pages && item.currentParams.value || -1; return React.createElement( 'div', { style: _extends({}, style, { display: 'flex', paddingRight: 8, alignItems: 'center' }) }, React.createElement( 'div', { style: { flex: 1 } }, getMessage(249, '') ), paginator, React.createElement( _materialUi.SelectField, { floatingLabelText: getMessage(625), style: { width: 60, marginLeft: 20 }, fullWidth: true, value: currentPage, onChange: function (e, i, v) { paginatorCallback(v); } }, letters.map(function (l) { return React.createElement(_materialUi.MenuItem, { value: l, key: l, primaryText: l === -1 ? getMessage(597, '') : l }); }) ) ); }; return AlphaPaginator; })(_react.Component); AlphaPaginator.propTypes = { /** * Currently selected Item */ item: _react.PropTypes.object, /** * When a letter is clicked, function(letter) */ paginatorCallback: _react.PropTypes.func.isRequired, /** * Main instance of pydio */ pydio: _react.PropTypes.instanceOf(_pydio2['default']), /** * Display mode, either large (book) or small picker ('selector', 'popover'). */ mode: _react.PropTypes.oneOf(['book', 'selector', 'popover']).isRequired }; exports['default'] = AlphaPaginator = PydioContextConsumer(AlphaPaginator); exports['default'] = AlphaPaginator = _materialUiStyles.muiThemeable()(AlphaPaginator); exports['default'] = AlphaPaginator; module.exports = exports['default']; },{"material-ui":"material-ui","material-ui/styles":"material-ui/styles","pydio":"pydio","react":"react"}],36:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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 _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } var Loaders = (function () { function Loaders() { _classCallCheck(this, Loaders); } Loaders.childrenAsPromise = function childrenAsPromise(item) { var leaf = arguments.length <= 1 || arguments[1] === undefined ? false : arguments[1]; var childrenLoader = item.childrenLoader; var itemsLoader = item.itemsLoader; var leafLoaded = item.leafLoaded; var collectionsLoaded = item.collectionsLoaded; var leafs = item.leafs; var collections = item.collections; var loader = leaf ? itemsLoader : childrenLoader; var loaded = leaf ? leafLoaded : collectionsLoaded; return new Promise(function (resolve, reject) { if (!loaded && loader) { loader(item, function (newChildren) { if (leaf) { item.leafs = newChildren; item.leafLoaded = true; } else { item.collections = newChildren; item.collectionsLoaded = true; } resolve(newChildren); }); } else { var res = (leaf ? leafs : collections) || []; resolve(res); } }); }; Loaders.listUsers = function listUsers(params, callback) { var parent = arguments.length <= 2 || arguments[2] === undefined ? null : arguments[2]; var baseParams = { get_action: 'user_list_authorized_users', format: 'json' }; baseParams = _extends({}, baseParams, params); var cb = callback; if (parent) { if (parent.range) { baseParams['range'] = parent.range; } cb = function (children) { callback(children.map(function (c) { c._parent = parent;return c; })); }; } PydioApi.getClient().request(baseParams, function (transport) { cb(transport.responseJSON); var cRange = transport.responseObject.headers.get('Content-Range'); var aRange = transport.responseObject.headers.get('Accept-Range'); if (cRange && aRange && parent) { var _aRange$split = aRange.split(' '); var type = _aRange$split[0]; var interval = _aRange$split[1]; var _cRange$split = cRange.split('/'); var range = _cRange$split[0]; var max = _cRange$split[1]; var _range$split = range.split('-'); var start = _range$split[0]; var end = _range$split[1]; parent.pagination = { start: parseInt(start), end: parseInt(end), max: parseInt(max), interval: parseInt(interval) }; } }); }; Loaders.loadTeams = function loadTeams(entry, callback) { var wrapped = function wrapped(children) { children.map(function (child) { child.icon = 'mdi mdi-account-multiple'; child.itemsLoader = Loaders.loadTeamUsers; child.actions = { type: 'team', create: '573', remove: '574', multiple: true }; child._notSelectable = true; }); callback(children); }; Loaders.listUsers({ filter_value: 8 }, wrapped, entry); }; Loaders.loadGroups = function loadGroups(entry, callback) { var wrapped = function wrapped(children) { children.map(function (child) { child.icon = 'mdi mdi-account-multiple'; child.childrenLoader = entry.childrenLoader ? Loaders.loadGroups : null; child.itemsLoader = entry.itemsLoader ? Loaders.loadGroupUsers : null; if (entry.currentParams && entry.currentParams.alpha_pages) { child.currentParams = _extends({}, entry.currentParams); } }); callback(children); }; var path = entry.id.replace('AJXP_GRP_', ''); var params = { filter_value: 4, group_path: path }; if (entry.currentParams && !entry.currentParams.alpha_pages) { params = _extends({}, params, entry.currentParams); } Loaders.listUsers(params, wrapped, entry); }; Loaders.loadExternalUsers = function loadExternalUsers(entry, callback) { Loaders.listUsers({ filter_value: 2 }, callback, entry); }; Loaders.loadGroupUsers = function loadGroupUsers(entry, callback) { var path = entry.id.replace('AJXP_GRP_', ''); var params = { filter_value: 1, group_path: path }; if (entry.currentParams) { params = _extends({}, params, entry.currentParams); } Loaders.listUsers(params, callback, entry); }; Loaders.loadTeamUsers = function loadTeamUsers(entry, callback) { Loaders.listUsers({ filter_value: 3, group_path: entry.id }, callback, entry); }; return Loaders; })(); exports['default'] = Loaders; module.exports = exports['default']; },{}],37:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var _require = require('react'); var Component = _require.Component; var PropTypes = _require.PropTypes; /** * Left panel of the address book * Display treeview hierarchy of users, teams, groups. */ var NestedListItem = (function (_Component) { _inherits(NestedListItem, _Component); function NestedListItem() { _classCallCheck(this, NestedListItem); _Component.apply(this, arguments); } /** * Triggers this.props.onTouchTap */ NestedListItem.prototype.onTouchTap = function onTouchTap() { this.props.onTouchTap(this.props.entry); }; /** * Recursively build other NestedListItem * @param data */ NestedListItem.prototype.buildNestedItems = function buildNestedItems(data) { return data.map((function (entry) { return React.createElement(NestedListItem, { nestedLevel: this.props.nestedLevel + 1, entry: entry, onTouchTap: this.props.onTouchTap, selected: this.props.selected }); }).bind(this)); }; NestedListItem.prototype.render = function render() { var _props$entry = this.props.entry; var id = _props$entry.id; var label = _props$entry.label; var icon = _props$entry.icon; var selected = _props$entry.selected; var children = this.props.entry.collections || []; var nested = this.buildNestedItems(children); var fontIcon = undefined; if (icon) { fontIcon = React.createElement(MaterialUI.FontIcon, { className: icon }); } return React.createElement(MaterialUI.ListItem, { nestedLevel: this.props.nestedLevel, key: id, primaryText: label, onTouchTap: this.onTouchTap.bind(this), nestedItems: nested, initiallyOpen: true, leftIcon: false && fontIcon, innerDivStyle: { fontWeight: this.props.selected === this.props.entry.id ? 500 : 400 } }); }; return NestedListItem; })(Component); NestedListItem.propTypes = { /** * Keeps track of the current depth level */ nestedLevel: PropTypes.number, /** * Currently selected node id */ selected: PropTypes.string, /** * Callback triggered when an entry is selected */ onTouchTap: PropTypes.func }; exports['default'] = NestedListItem; module.exports = exports['default']; },{"react":"react"}],38:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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 _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var _TeamCard = require('./TeamCard'); var _TeamCard2 = _interopRequireDefault(_TeamCard); var _UserCard = require('./UserCard'); var _UserCard2 = _interopRequireDefault(_UserCard); var React = require('react'); var _require = require('material-ui'); var Paper = _require.Paper; /** * Container for UserCard or TeamCard */ var RightPanelCard = (function (_React$Component) { _inherits(RightPanelCard, _React$Component); function RightPanelCard() { _classCallCheck(this, RightPanelCard); _React$Component.apply(this, arguments); } RightPanelCard.prototype.render = function render() { var content = undefined; var item = this.props.item || {}; if (item.type === 'user') { content = React.createElement(_UserCard2['default'], this.props); } else if (item.type === 'group' && item.id.indexOf('/AJXP_TEAM/') === 0) { content = React.createElement(_TeamCard2['default'], this.props); } return React.createElement( Paper, { zDepth: 2, style: _extends({ position: 'relative' }, this.props.style) }, content ); }; return RightPanelCard; })(React.Component); RightPanelCard.propTypes = { /** * Pydio instance */ pydio: React.PropTypes.instanceOf(Pydio), /** * Selected item */ item: React.PropTypes.object, /** * Applies to root container */ style: React.PropTypes.object, /** * Forwarded to child */ onRequestClose: React.PropTypes.func, /** * Forwarded to child */ onDeleteAction: React.PropTypes.func, /** * Forwarded to child */ onUpdateAction: React.PropTypes.func }; exports['default'] = RightPanelCard; module.exports = exports['default']; },{"./TeamCard":41,"./UserCard":42,"material-ui":"material-ui","react":"react"}],39:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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 _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var _require = require('react'); var Component = _require.Component; var PropTypes = _require.PropTypes; /** * Ready to use Form + Result List for search users */ var SearchForm = (function (_Component) { _inherits(SearchForm, _Component); function SearchForm(props, context) { _classCallCheck(this, SearchForm); _Component.call(this, props.context); this.state = { value: '' }; } SearchForm.prototype.search = function search() { this.props.onSearch(this.state.value); }; SearchForm.prototype.onChange = function onChange(event, value) { this.setState({ value: value }); FuncUtils.bufferCallback('search_users_list', 300, this.search.bind(this)); }; SearchForm.prototype.render = function render() { return React.createElement( 'div', { style: _extends({ minWidth: 320 }, this.props.style) }, React.createElement(MaterialUI.TextField, { fullWidth: true, value: this.state.value, onChange: this.onChange.bind(this), hintText: this.props.searchLabel }) ); }; return SearchForm; })(Component); SearchForm.propTypes = { /** * Label displayed in the search field */ searchLabel: PropTypes.string.isRequired, /** * Callback triggered to search */ onSearch: PropTypes.func.isRequired, /** * Will be appended to the root element */ style: PropTypes.object }; exports['default'] = SearchForm; module.exports = exports['default']; },{"react":"react"}],40:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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 _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var _SearchForm = require('./SearchForm'); var _SearchForm2 = _interopRequireDefault(_SearchForm); var _UsersList = require('./UsersList'); var _UsersList2 = _interopRequireDefault(_UsersList); var _Loaders = require('./Loaders'); var _Loaders2 = _interopRequireDefault(_Loaders); /** * Ready to use Form + Result List for search users */ var _require = require('react'); var Component = _require.Component; var PropTypes = _require.PropTypes; var _require$requireLib = require('pydio').requireLib('boot'); var PydioContextConsumer = _require$requireLib.PydioContextConsumer; var SearchPanel = (function (_Component) { _inherits(SearchPanel, _Component); function SearchPanel(props, context) { _classCallCheck(this, SearchPanel); _Component.call(this, props.context); this.state = { items: [] }; } SearchPanel.prototype.onSearch = function onSearch(value) { var _this = this; if (!value) { this.setState({ items: [] }); return; } var params = { value: value, existing_only: 'true' }; if (this.props.params) { params = _extends({}, params, this.props.params); } _Loaders2['default'].listUsers(params, function (children) { _this.setState({ items: children }); }); }; SearchPanel.prototype.render = function render() { var _this2 = this; var _props = this.props; var mode = _props.mode; var item = _props.item; var getMessage = _props.getMessage; return React.createElement( 'div', { style: { flex: 1, display: 'flex', flexDirection: 'column' } }, React.createElement( 'div', { style: { padding: 10, height: 56, backgroundColor: this.state.select ? activeTbarColor : '#fafafa', display: 'flex', alignItems: 'center', transition: DOMUtils.getBeziersTransition() } }, mode === "selector" && item._parent && React.createElement(MaterialUI.IconButton, { iconClassName: 'mdi mdi-chevron-left', onTouchTap: function () { _this2.props.onFolderClicked(item._parent); } }), mode === 'book' && React.createElement( 'div', { style: { fontSize: 20, color: 'rgba(0,0,0,0.87)', flex: 1 } }, this.props.title ), React.createElement(_SearchForm2['default'], { style: mode === 'book' ? { minWidth: 320 } : { flex: 1 }, searchLabel: this.props.searchLabel, onSearch: this.onSearch.bind(this) }) ), React.createElement(_UsersList2['default'], { mode: this.props.mode, onItemClicked: this.props.onItemClicked, item: { leafs: this.state.items }, noToolbar: true, emptyStatePrimaryText: getMessage(587, ''), emptyStateSecondaryText: getMessage(588, '') }) ); }; return SearchPanel; })(Component); SearchPanel.propTypes = { /** * Optional parameters added to listUsers() request */ params: PropTypes.object, /** * Label displayed in the toolbar */ searchLabel: PropTypes.string, /** * Callback triggered when a search result is clicked */ onItemClicked: PropTypes.func, /** * Currently selected item, required for navigation */ item: PropTypes.object, /** * Callback triggered if the result is a collection */ onFolderClicked: PropTypes.func }; exports['default'] = SearchPanel = PydioContextConsumer(SearchPanel); exports['default'] = SearchPanel; module.exports = exports['default']; },{"./Loaders":36,"./SearchForm":39,"./UsersList":43,"pydio":"pydio","react":"react"}],41:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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 _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var _UsersList = require('./UsersList'); var _UsersList2 = _interopRequireDefault(_UsersList); var _Loaders = require('./Loaders'); var _Loaders2 = _interopRequireDefault(_Loaders); var _avatarActionsPanel = require('../avatar/ActionsPanel'); var _avatarActionsPanel2 = _interopRequireDefault(_avatarActionsPanel); var React = require('react'); var _require = require('material-ui'); var TextField = _require.TextField; var FlatButton = _require.FlatButton; var CardTitle = _require.CardTitle; var Divider = _require.Divider; var _require$requireLib = require('pydio').requireLib('boot'); var PydioContextConsumer = _require$requireLib.PydioContextConsumer; /** * Display info about a Team inside a popover-able card */ var TeamCard = (function (_React$Component) { _inherits(TeamCard, _React$Component); function TeamCard(props, context) { _classCallCheck(this, TeamCard); _React$Component.call(this, props, context); this.state = { label: this.props.item.label }; } /** * Use loader to get team participants * @param item */ TeamCard.prototype.loadMembers = function loadMembers(item) { var _this = this; this.setState({ loading: true }); _Loaders2['default'].childrenAsPromise(item, false).then(function (children) { _Loaders2['default'].childrenAsPromise(item, true).then(function (children) { _this.setState({ members: item.leafs, loading: false }); }); }); }; TeamCard.prototype.componentWillMount = function componentWillMount() { this.loadMembers(this.props.item); }; TeamCard.prototype.componentWillReceiveProps = function componentWillReceiveProps(nextProps) { this.loadMembers(nextProps.item); this.setState({ label: nextProps.item.label }); }; TeamCard.prototype.onLabelChange = function onLabelChange(e, value) { this.setState({ label: value }); }; TeamCard.prototype.updateLabel = function updateLabel() { var _this2 = this; if (this.state.label !== this.props.item.label) { PydioUsers.Client.updateTeamLabel(this.props.item.id.replace('/AJXP_TEAM/', ''), this.state.label, function () { _this2.props.onUpdateAction(_this2.props.item); }); } this.setState({ editMode: false }); }; TeamCard.prototype.render = function render() { var _this3 = this; var _props = this.props; var item = _props.item; var onDeleteAction = _props.onDeleteAction; var onCreateAction = _props.onCreateAction; var getMessage = _props.getMessage; var editProps = { team: item, userEditable: true, onDeleteAction: function onDeleteAction() { _this3.props.onDeleteAction(item._parent, [item]); }, onEditAction: function onEditAction() { _this3.setState({ editMode: !_this3.state.editMode }); }, reloadAction: function reloadAction() { _this3.props.onUpdateAction(item); } }; var title = undefined; if (this.state.editMode) { title = React.createElement( 'div', { style: { display: 'flex', alignItems: 'center', margin: 16 } }, React.createElement(TextField, { style: { flex: 1, fontSize: 24 }, fullWidth: true, disabled: false, underlineShow: false, value: this.state.label, onChange: this.onLabelChange.bind(this) }), React.createElement(FlatButton, { secondary: true, label: getMessage(48), onTouchTap: function () { _this3.updateLabel(); } }) ); } else { title = React.createElement(CardTitle, { title: this.state.label, subtitle: item.leafs && item.leafs.length ? getMessage(576).replace('%s', item.leafs.length) : getMessage(577) }); } return React.createElement( 'div', null, title, React.createElement(_avatarActionsPanel2['default'], _extends({}, this.props, editProps)), React.createElement(Divider, null), React.createElement(_UsersList2['default'], { subHeader: getMessage(575), onItemClicked: function () {}, item: item, mode: 'inner', onDeleteAction: onDeleteAction }) ); }; return TeamCard; })(React.Component); TeamCard.propTypes = { /** * Pydio instance */ pydio: React.PropTypes.instanceOf(Pydio), /** * Team data object */ item: React.PropTypes.object, /** * Applied to root container */ style: React.PropTypes.object, /** * Called to dismiss the popover */ onRequestClose: React.PropTypes.func, /** * Delete current team */ onDeleteAction: React.PropTypes.func, /** * Update current team */ onUpdateAction: React.PropTypes.func }; exports['default'] = TeamCard = PydioContextConsumer(TeamCard); exports['default'] = TeamCard; module.exports = exports['default']; },{"../avatar/ActionsPanel":44,"./Loaders":36,"./UsersList":43,"material-ui":"material-ui","pydio":"pydio","react":"react"}],42:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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 _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var _avatarUserAvatar = require('../avatar/UserAvatar'); var _avatarUserAvatar2 = _interopRequireDefault(_avatarUserAvatar); var React = require('react'); var _require$requireLib = require('pydio').requireLib('boot'); var AsyncComponent = _require$requireLib.AsyncComponent; /** * Card presentation of a user. Relies on the UserAvatar object, * plus the PydioForm.UserCreationForm when in edit mode. */ var UserCard = (function (_React$Component) { _inherits(UserCard, _React$Component); function UserCard(props, context) { _classCallCheck(this, UserCard); _React$Component.call(this, props, context); this.state = { editForm: false }; } UserCard.prototype.render = function render() { var _this = this; var item = this.props.item; var editableProps = {}, editForm = undefined; if (item._parent && item._parent.id === 'ext') { editableProps = { userEditable: true, onDeleteAction: function onDeleteAction() { _this.props.onDeleteAction(item._parent, [item]); }, onEditAction: function onEditAction() { _this.setState({ editForm: true }); }, reloadAction: function reloadAction() { _this.props.onUpdateAction(item); } }; } if (this.state.editForm) { editForm = React.createElement(AsyncComponent, { namespace: 'PydioForm', componentName: 'UserCreationForm', pydio: this.props.pydio, zDepth: 0, style: { height: 500 }, newUserName: item.id, editMode: true, userData: item, onUserCreated: function () { _this.props.onUpdateAction(item);_this.setState({ editForm: false }); }, onCancel: function () { _this.setState({ editForm: false }); } }); } return React.createElement( 'div', null, React.createElement( _avatarUserAvatar2['default'], _extends({ userId: this.props.item.id, richCard: true, pydio: this.props.pydio, cardSize: this.props.style.width }, editableProps), editForm ) ); }; return UserCard; })(React.Component); UserCard.propTypes = { /** * Pydio instance */ pydio: React.PropTypes.instanceOf(Pydio), /** * Team data object */ item: React.PropTypes.object, /** * Applied to root container */ style: React.PropTypes.object, /** * Called to dismiss the popover */ onRequestClose: React.PropTypes.func, /** * Delete current team */ onDeleteAction: React.PropTypes.func, /** * Update current team */ onUpdateAction: React.PropTypes.func }; exports['default'] = UserCard; module.exports = exports['default']; },{"../avatar/UserAvatar":46,"pydio":"pydio","react":"react"}],43:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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 _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var _avatarUserAvatar = require('../avatar/UserAvatar'); var _avatarUserAvatar2 = _interopRequireDefault(_avatarUserAvatar); var _viewsEmptyStateView = require('../../views/EmptyStateView'); var _viewsEmptyStateView2 = _interopRequireDefault(_viewsEmptyStateView); var _AlphaPaginator = require('./AlphaPaginator'); var _AlphaPaginator2 = _interopRequireDefault(_AlphaPaginator); var _SearchForm = require('./SearchForm'); var _SearchForm2 = _interopRequireDefault(_SearchForm); var _require = require('material-ui'); var IconButton = _require.IconButton; var Checkbox = _require.Checkbox; var FlatButton = _require.FlatButton; var RaisedButton = _require.RaisedButton; var ListItem = _require.ListItem; var FontIcon = _require.FontIcon; var Avatar = _require.Avatar; var Divider = _require.Divider; var Subheader = _require.Subheader; var List = _require.List; var _require2 = require('material-ui/styles'); var muiThemeable = _require2.muiThemeable; var _require$requireLib = require('pydio').requireLib('boot'); var Loader = _require$requireLib.Loader; var PydioContextConsumer = _require$requireLib.PydioContextConsumer; var UsersList = (function (_React$Component) { _inherits(UsersList, _React$Component); function UsersList(props, context) { _classCallCheck(this, UsersList); _React$Component.call(this, props, context); this.state = { select: false, selection: [] }; } UsersList.prototype.render = function render() { var _this = this; var _props = this.props; var item = _props.item; var mode = _props.mode; var paginatorType = _props.paginatorType; var loading = _props.loading; var enableSearch = _props.enableSearch; var showSubheaders = _props.showSubheaders; var getMessage = _props.getMessage; var folders = item.collections || []; var leafs = item.leafs || []; var foldersSubHeader = folders.length && (leafs.length || showSubheaders) ? [{ subheader: getMessage('532') }] : []; var usersSubHeader = []; if ((showSubheaders || paginatorType) && leafs.length) { usersSubHeader = [{ subheader: paginatorType ? React.createElement(_AlphaPaginator2['default'], _extends({}, this.props, { style: { lineHeight: '20px', padding: '14px 0' } })) : getMessage('249') }]; } var items = [].concat(foldersSubHeader, folders, usersSubHeader, leafs); var total = items.length; var elements = []; var toggleSelect = function toggleSelect() { _this.setState({ select: !_this.state.select, selection: [] }); }; var createAction = function createAction() { _this.props.onCreateAction(item); }; var deleteAction = function deleteAction() { _this.props.onDeleteAction(item, _this.state.selection);_this.setState({ select: false, selection: [] }); }; var activeTbarColor = this.props.muiTheme.palette.accent2Color; var toolbar = React.createElement( 'div', { style: { padding: 10, height: 56, backgroundColor: this.state.select ? activeTbarColor : '#fafafa', display: 'flex', alignItems: 'center', transition: DOMUtils.getBeziersTransition() } }, mode === "selector" && item._parent && React.createElement(IconButton, { iconClassName: 'mdi mdi-chevron-left', onTouchTap: function () { _this.props.onFolderClicked(item._parent); } }), mode === 'book' && total > 0 && item.actions && item.actions.multiple && React.createElement(Checkbox, { style: { width: 'initial', marginLeft: this.state.select ? 7 : 14 }, checked: this.state.select, onCheck: toggleSelect }), React.createElement( 'div', { style: { flex: 1, fontSize: 20, color: this.state.select ? 'white' : 'rgba(0,0,0,0.87)' } }, item.label ), mode === 'book' && item.actions && item.actions.create && !this.state.select && React.createElement(FlatButton, { secondary: true, label: getMessage(item.actions.create), onTouchTap: createAction }), mode === 'book' && item.actions && item.actions.remove && this.state.select && React.createElement(RaisedButton, { secondary: true, label: getMessage(item.actions.remove), disabled: !this.state.selection.length, onTouchTap: deleteAction }), enableSearch && React.createElement(_SearchForm2['default'], { searchLabel: this.props.searchLabel, onSearch: this.props.onSearch, style: { flex: 1, minWidth: 200 } }) ); // PARENT NODE if (item._parent && mode === 'book' && item._parent._parent) { elements.push(React.createElement(ListItem, { key: '__parent__', primaryText: "..", onTouchTap: function (e) { e.stopPropagation();_this.props.onFolderClicked(item._parent); }, leftAvatar: React.createElement(Avatar, { icon: React.createElement(FontIcon, { className: 'mdi mdi-arrow-up' }) }) })); if (total) { elements.push(React.createElement(Divider, { inset: true, key: 'parent-divider' })); } } // ITEMS items.forEach((function (item, index) { var _this2 = this; if (item.subheader) { elements.push(React.createElement( Subheader, null, item.subheader )); return; } var fontIcon = React.createElement(_avatarUserAvatar2['default'], { avatarSize: 36, pydio: this.props.pydio || pydio, userId: item.id, userLabel: item.label, avatar: item.avatar, icon: item.icon, avatarOnly: true, useDefaultAvatar: true }); var rightIconButton = undefined; var touchTap = function touchTap(e) { e.stopPropagation();_this2.props.onItemClicked(item); }; if (folders.indexOf(item) > -1 && this.props.onFolderClicked) { touchTap = function (e) { e.stopPropagation();_this2.props.onFolderClicked(item); }; if (mode === 'selector' && !item._notSelectable) { rightIconButton = React.createElement(IconButton, { iconClassName: "mdi mdi-account-multiple-plus", tooltip: "Select this group", tooltipPosition: 'bottom-left', onTouchTap: function () { _this2.props.onItemClicked(item); } }); } } else if (mode === 'inner' && this.props.onDeleteAction) { rightIconButton = React.createElement(IconButton, { iconClassName: "mdi mdi-delete", tooltip: getMessage(257), tooltipPosition: 'bottom-left', iconStyle: { color: 'rgba(0,0,0,0.13)', hoverColor: 'rgba(0,0,0,0.53)' }, onTouchTap: function () { _this2.props.onDeleteAction(_this2.props.item, [item]); } }); } var select = function select(e, checked) { if (checked) { _this2.setState({ selection: [].concat(_this2.state.selection, [item]) }); } else { var stateSel = _this2.state.selection; var selection = [].concat(stateSel.slice(0, stateSel.indexOf(item)), stateSel.slice(stateSel.indexOf(item) + 1)); _this2.setState({ selection: selection }); } }; elements.push(React.createElement(ListItem, { key: item.id, primaryText: item.label, onTouchTap: touchTap, disabled: mode === 'inner', leftAvatar: !this.state.select && fontIcon, rightIconButton: rightIconButton, leftCheckbox: this.state.select && React.createElement(Checkbox, { checked: this.state.selection.indexOf(item) > -1, onCheck: select }) })); if (mode !== 'inner' && index < total - 1) { elements.push(React.createElement(Divider, { inset: true, key: item.id + '-divider' })); } }).bind(this)); var emptyState = undefined; if (!elements.length) { var emptyStateProps = { style: { backgroundColor: 'rgb(250, 250, 250)' }, iconClassName: 'mdi mdi-account-off', primaryTextId: this.props.emptyStatePrimaryText || getMessage(629), secondaryTextId: mode === 'book' ? this.props.emptyStateSecondaryText || null : null }; if (mode === 'book' && item.actions && item.actions.create) { emptyStateProps = _extends({}, emptyStateProps, { actionLabelId: getMessage(item.actions.create), actionCallback: createAction }); } emptyState = React.createElement(_viewsEmptyStateView2['default'], emptyStateProps); } return React.createElement( 'div', { style: { flex: 1, flexDirection: 'column', display: 'flex' }, onTouchTap: this.props.onTouchTap }, mode !== 'inner' && /*(!emptyState || mode !== 'book') &&*/!this.props.noToolbar && toolbar, !emptyState && !loading && React.createElement( List, { style: { flex: 1, overflowY: mode !== 'inner' ? 'auto' : 'initial' } }, this.props.subHeader && React.createElement( Subheader, null, this.props.subHeader ), elements ), loading && React.createElement(Loader, { style: { flex: 1 } }), !loading && emptyState ); }; return UsersList; })(React.Component); UsersList.propTypes = { item: React.PropTypes.object, onCreateAction: React.PropTypes.func, onDeleteAction: React.PropTypes.func, onItemClicked: React.PropTypes.func, onFolderClicked: React.PropTypes.func, mode: React.PropTypes.oneOf(['book', 'selector', 'inner']) }; exports['default'] = UsersList = PydioContextConsumer(UsersList); exports['default'] = UsersList = muiThemeable()(UsersList); exports['default'] = UsersList; module.exports = exports['default']; },{"../../views/EmptyStateView":49,"../avatar/UserAvatar":46,"./AlphaPaginator":35,"./SearchForm":39,"material-ui":"material-ui","material-ui/styles":"material-ui/styles","pydio":"pydio"}],44:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var _addressbookAddressBook = require('../addressbook/AddressBook'); var _addressbookAddressBook2 = _interopRequireDefault(_addressbookAddressBook); var React = require('react'); var _require = require('pydio/http/users-api'); var UsersApi = _require.UsersApi; var ResourcesManager = require('pydio/http/resources-manager'); var _require2 = require('material-ui'); var IconButton = _require2.IconButton; var Popover = _require2.Popover; var _require3 = require('material-ui/styles'); var muiThemeable = _require3.muiThemeable; var _require$requireLib = require('pydio').requireLib('boot'); var PydioContextConsumer = _require$requireLib.PydioContextConsumer; var AsyncComponent = _require$requireLib.AsyncComponent; var ActionsPanel = (function (_React$Component) { _inherits(ActionsPanel, _React$Component); function ActionsPanel(props, context) { _classCallCheck(this, ActionsPanel); _React$Component.call(this, props, context); this.state = { showPicker: false, pickerAnchor: null, showMailer: false, mailerAnchor: null }; } ActionsPanel.prototype.onTeamSelected = function onTeamSelected(item) { this.setState({ showPicker: false }); if (item.getType() === 'group' && item.getId().indexOf('/AJXP_TEAM/') === 0) { UsersApi.addUserToTeam(item.getId().replace('/AJXP_TEAM/', ''), this.props.userId, this.props.reloadAction); } }; ActionsPanel.prototype.onUserSelected = function onUserSelected(item) { this.setState({ showPicker: false }); UsersApi.addUserToTeam(this.props.team.id, item.getId(), this.props.reloadAction); }; ActionsPanel.prototype.openPicker = function openPicker(event) { this.setState({ showPicker: true, pickerAnchor: event.currentTarget }); }; ActionsPanel.prototype.openMailer = function openMailer(event) { var _this = this; var target = event.currentTarget; ResourcesManager.loadClassesAndApply(['PydioMailer'], function () { _this.setState({ mailerLibLoaded: true }, function () { _this.setState({ showMailer: true, mailerAnchor: target }); }); }); }; ActionsPanel.prototype.componentDidUpdate = function componentDidUpdate(prevProps, prevState) { if (!this.props.lockOnSubPopoverOpen) return; if ((this.state.showPicker || this.state.showMailer) && !(prevState.showPicker || prevState.showMailer)) { this.props.lockOnSubPopoverOpen(true); } else if (!(this.state.showPicker || this.state.showMailer) && (prevState.showPicker || prevState.showMailer)) { this.props.lockOnSubPopoverOpen(false); } }; ActionsPanel.prototype.render = function render() { var _this2 = this; var _props = this.props; var getMessage = _props.getMessage; var muiTheme = _props.muiTheme; var team = _props.team; var user = _props.user; var userEditable = _props.userEditable; var styles = { button: { backgroundColor: muiTheme.palette.accent2Color, borderRadius: '50%', margin: '0 4px', width: 44, height: 44, padding: 10 }, icon: { color: 'white' } }; var mailer = undefined, usermails = {}; var actions = []; if (user && user.hasEmail) { actions.push({ key: 'message', label: getMessage(598), icon: 'email', callback: this.openMailer.bind(this) }); usermails[this.props.user.id] = PydioUsers.User.fromObject(this.props.user); } if (team) { actions.push({ key: 'users', label: getMessage(599), icon: 'account-multiple-plus', callback: this.openPicker.bind(this) }); } else { actions.push({ key: 'teams', label: getMessage(573), icon: 'account-multiple-plus', callback: this.openPicker.bind(this) }); } if (userEditable) { actions.push({ key: 'edit', label: this.props.team ? getMessage(580) : getMessage(600), icon: 'pencil', callback: this.props.onEditAction }); actions.push({ key: 'delete', label: this.props.team ? getMessage(570) : getMessage(582), icon: 'delete', callback: this.props.onDeleteAction }); } return React.createElement( 'div', { style: { textAlign: 'center', marginBottom: 16 } }, actions.map(function (a) { return React.createElement(IconButton, { key: a.key, style: styles.button, iconStyle: styles.icon, tooltip: a.label, iconClassName: "mdi mdi-" + a.icon, onTouchTap: a.callback }); }), React.createElement( Popover, { open: this.state.showPicker, anchorEl: this.state.pickerAnchor, anchorOrigin: { horizontal: 'right', vertical: 'top' }, targetOrigin: { horizontal: 'right', vertical: 'top' }, onRequestClose: function () { _this2.setState({ showPicker: false }); }, useLayerForClickAway: false, style: { zIndex: 2200 } }, React.createElement( 'div', { style: { width: 256, height: 320 } }, React.createElement(_addressbookAddressBook2['default'], { mode: 'selector', pydio: this.props.pydio, loaderStyle: { width: 320, height: 420 }, onItemSelected: this.props.team ? this.onUserSelected.bind(this) : this.onTeamSelected.bind(this), teamsOnly: this.props.team ? false : true, usersOnly: this.props.team ? true : false }) ) ), React.createElement( Popover, { open: this.state.showMailer, anchorEl: this.state.mailerAnchor, anchorOrigin: { horizontal: 'right', vertical: 'top' }, targetOrigin: { horizontal: 'right', vertical: 'top' }, useLayerForClickAway: false, style: { zIndex: 2200 } }, React.createElement( 'div', { style: { width: 256, height: 320 } }, this.state.mailerLibLoaded && React.createElement(AsyncComponent, { namespace: 'PydioMailer', componentName: 'Pane', zDepth: 0, panelTitle: getMessage(598), uniqueUserStyle: true, users: usermails, onDismiss: function () { _this2.setState({ showMailer: false }); }, onFieldFocus: this.props.otherPopoverMouseOver }) ) ) ); }; return ActionsPanel; })(React.Component); ActionsPanel.propTypes = { /** * User data, props must pass at least one of 'user' or 'team' */ user: React.PropTypes.object, /** * Team data, props must pass at least one of 'user' or 'team' */ team: React.PropTypes.object, /** * For users, whether it is editable or not */ userEditable: React.PropTypes.object }; exports['default'] = ActionsPanel = PydioContextConsumer(ActionsPanel); exports['default'] = ActionsPanel = muiThemeable()(ActionsPanel); exports['default'] = ActionsPanel; module.exports = exports['default']; },{"../addressbook/AddressBook":34,"material-ui":"material-ui","material-ui/styles":"material-ui/styles","pydio":"pydio","pydio/http/resources-manager":"pydio/http/resources-manager","pydio/http/users-api":"pydio/http/users-api","react":"react"}],45:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var _addressbookUsersList = require('../addressbook/UsersList'); var _addressbookUsersList2 = _interopRequireDefault(_addressbookUsersList); var _require = require('react'); var Component = _require.Component; var PropTypes = _require.PropTypes; var _require2 = require('material-ui'); var Divider = _require2.Divider; var _require3 = require('pydio/http/users-api'); var UsersApi = _require3.UsersApi; var _require$requireLib = require('pydio').requireLib('boot'); var PydioContextConsumer = _require$requireLib.PydioContextConsumer; /** * Display information about user or team relations */ var GraphPanel = (function (_Component) { _inherits(GraphPanel, _Component); function GraphPanel() { _classCallCheck(this, GraphPanel); _Component.apply(this, arguments); } GraphPanel.prototype.render = function render() { var _props = this.props; var graph = _props.graph; var userLabel = _props.userLabel; var pydio = _props.pydio; var getMessage = _props.getMessage; var elements = []; if (graph.teams && graph.teams.length) { var onDeleteAction = (function (parentItem, team) { var _this = this; UsersApi.removeUserFromTeam(team[0].id, this.props.userId, function (response) { if (response.message) pydio.UI.displayMessage('SUCCESS', response.message); _this.props.reloadAction(); }); }).bind(this); elements.push(React.createElement( 'div', { key: 'teams' }, React.createElement(Divider, null), React.createElement(_addressbookUsersList2['default'], { subHeader: getMessage(581).replace('%s', graph.teams.length), onItemClicked: function () {}, item: { leafs: graph.teams }, mode: 'inner', onDeleteAction: onDeleteAction }) )); } if (graph.source && Object.keys(graph.source).length) { elements.push(React.createElement( 'div', { key: 'source' }, elements.length ? React.createElement(Divider, null) : null, React.createElement( 'div', { style: { padding: 16 } }, getMessage(601).replace('%1', userLabel).replace('%2', Object.keys(graph.source).length) ) )); } if (graph.target && Object.keys(graph.target).length) { elements.push(React.createElement( 'div', { key: 'target' }, elements.length ? React.createElement(Divider, null) : null, React.createElement( 'div', { style: { padding: 16 } }, getMessage(602).replace('%1', userLabel).replace('%2', Object.keys(graph.target).length) ) )); } return React.createElement( 'div', null, elements ); }; return GraphPanel; })(Component); exports['default'] = GraphPanel = PydioContextConsumer(GraphPanel); exports['default'] = GraphPanel; module.exports = exports['default']; },{"../addressbook/UsersList":43,"material-ui":"material-ui","pydio":"pydio","pydio/http/users-api":"pydio/http/users-api","react":"react"}],46:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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 _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var _GraphPanel = require('./GraphPanel'); var _GraphPanel2 = _interopRequireDefault(_GraphPanel); var _ActionsPanel = require('./ActionsPanel'); var _ActionsPanel2 = _interopRequireDefault(_ActionsPanel); var debounce = require('lodash.debounce'); var React = require('react'); var Color = require('color'); var _require = require('material-ui'); var FontIcon = _require.FontIcon; var Popover = _require.Popover; var Paper = _require.Paper; var Avatar = _require.Avatar; var CardTitle = _require.CardTitle; var _require2 = require('material-ui/styles'); var muiThemeable = _require2.muiThemeable; var MetaCacheService = require('pydio/http/meta-cache-service'); var PydioApi = require('pydio/http/api'); /** * Generic component for display a user and her avatar (first letters or photo) */ var UserAvatar = (function (_React$Component) { _inherits(UserAvatar, _React$Component); function UserAvatar(props, context) { _classCallCheck(this, UserAvatar); _React$Component.call(this, props, context); this.state = { user: null, avatar: null, graph: null }; } UserAvatar.prototype.componentDidMount = function componentDidMount() { if (this.props.pydio.user && this.props.pydio.user.id === this.props.userId) { this.loadLocalData(); if (!this._userLoggedObs) { this._userLoggedObs = this.loadLocalData.bind(this); this.props.pydio.observe('user_logged', this._userLoggedObs); } } else if (this.props.userType === 'user') { this.cache = MetaCacheService.getInstance(); this.cache.registerMetaStream('user_public_data', 'EXPIRATION_MANUAL_TRIGGER'); this.cache.registerMetaStream('user_public_data-rich', 'EXPIRATION_MANUAL_TRIGGER'); this.loadPublicData(this.props.userId); } }; UserAvatar.prototype.componentWillReceiveProps = function componentWillReceiveProps(nextProps) { if (!this.props.userId || this.props.userId !== nextProps.userId) { this.setState({ label: nextProps.userId }); } if (this.props.pydio && this.props.pydio.user && this.props.pydio.user.id === nextProps.userId) { this.loadLocalData(); if (!this._userLoggedObs) { this._userLoggedObs = this.loadLocalData.bind(this); this.props.pydio.observe('user_logged', this._userLoggedObs); } } else { if (this._userLoggedObs) { this.props.pydio.stopObserving('user_logged', this._userLoggedObs); } this.cache = MetaCacheService.getInstance(); this.cache.registerMetaStream('user_public_data', 'EXPIRATION_MANUAL_TRIGGER'); this.cache.registerMetaStream('user_public_data-rich', 'EXPIRATION_MANUAL_TRIGGER'); this.loadPublicData(nextProps.userId); } }; UserAvatar.prototype.componentWillUnmount = function componentWillUnmount() { if (this._userLoggedObs) { this.props.pydio.stopObserving('user_logged', this._userLoggedObs); } }; UserAvatar.prototype.loadLocalData = function loadLocalData() { var pydio = this.props.pydio; if (!pydio.user) { this.setState({ label: '', avatar: null }); return; } var userName = pydio.user.getPreference('USER_DISPLAY_NAME') || pydio.user.id; var avatarId = pydio.user.getPreference('avatar'); var avatarUrl = PydioApi.getClient().buildUserAvatarUrl(pydio.user.id, avatarId); this.setState({ label: userName, avatar: avatarUrl }); if (!avatarUrl) { this.loadFromExternalProvider(); } }; UserAvatar.prototype.loadPublicData = function loadPublicData(userId) { var namespace = this.props.richCard ? 'user_public_data-rich' : 'user_public_data'; if (this.cache.hasKey(namespace, userId)) { this.setState(this.cache.getByKey(namespace, userId)); return; } PydioApi.getClient().request({ get_action: 'user_public_data', user_id: userId, graph: this.props.richCard ? 'true' : 'false' }, (function (transport) { var data = transport.responseJSON; if (!data || data.error) { this.cache.setKey(namespace, userId, {}); return; } var user = data.user; var graph = data.graph; var avatarUrl = undefined; var avatarId = user.avatar || null; var label = user.label || userId; if (!user.avatar) { this.loadFromExternalProvider(); } else { avatarUrl = PydioApi.getClient().buildUserAvatarUrl(userId, avatarId); } this.cache.setKey(namespace, userId, { user: user, graph: graph, avatar: avatarUrl }); this.setState({ user: user, graph: graph, avatar: avatarUrl }); }).bind(this)); }; UserAvatar.prototype.loadFromExternalProvider = function loadFromExternalProvider() { if (!this.props.pydio.getPluginConfigs("ajxp_plugin[@id='action.avatar']").get("AVATAR_PROVIDER")) { return; } var namespace = this.props.richCard ? 'user_public_data-rich' : 'user_public_data'; PydioApi.getClient().request({ get_action: 'get_avatar_url', userid: this.props.userId }, (function (transport) { this.setState({ avatar: transport.responseText }); }).bind(this)); }; UserAvatar.prototype.render = function render() { var _this = this; var _state = this.state; var user = _state.user; var avatar = _state.avatar; var graph = _state.graph; var _props = this.props; var pydio = _props.pydio; var userId = _props.userId; var userType = _props.userType; var icon = _props.icon; var style = _props.style; var labelStyle = _props.labelStyle; var avatarStyle = _props.avatarStyle; var avatarSize = _props.avatarSize; var className = _props.className; var avatarClassName = _props.avatarClassName; var labelClassName = _props.labelClassName; var displayLabel = _props.displayLabel; var displayAvatar = _props.displayAvatar; var useDefaultAvatar = _props.useDefaultAvatar; var richCard = _props.richCard; var cardSize = _props.cardSize; var muiTheme = _props.muiTheme; var label = this.state.label; var userTypeLabel = undefined; if (user) { label = user.label; } else if (!label) { label = this.props.userLabel || this.props.userId; } var avatarContent = undefined, avatarColor = undefined, avatarIcon = undefined; if (richCard) { displayAvatar = useDefaultAvatar = displayLabel = true; } if (displayAvatar && !avatar && label && (!displayLabel || useDefaultAvatar)) { var avatarsColor = muiTheme.palette.avatarsColor; if (userType === 'group' || userType === 'team' || userId.indexOf('AJXP_GRP_/') === 0 || userId.indexOf('/AJXP_TEAM/') === 0) { avatarsColor = Color(avatarsColor).darken(0.2).toString(); } var iconClassName = undefined; switch (userType) { case 'group': iconClassName = 'mdi mdi-account-multiple'; userTypeLabel = '289'; break; case 'team': iconClassName = 'mdi mdi-account-multiple-outline'; userTypeLabel = '603'; break; case 'remote': iconClassName = 'mdi mdi-account-network'; userTypeLabel = '604'; break; default: iconClassName = 'mdi mdi-account'; userTypeLabel = user ? user.external ? '589' : '590' : '288'; break; } if (icon) iconClassName = icon; if (userTypeLabel) userTypeLabel = pydio.MessageHash[userTypeLabel]; if (richCard) { avatarIcon = React.createElement(FontIcon, { className: iconClassName, style: { color: avatarsColor } }); avatarColor = '#f5f5f5'; } else { avatarColor = avatarsColor; if (iconClassName) { avatarIcon = React.createElement(FontIcon, { className: iconClassName }); } else { avatarContent = label.split(' ').map(function (word) { return word[0]; }).join('').substring(0, 2); if (avatarContent.length < 2) avatarContent = label.substring(0, 2); } } } var reloadAction = undefined, onEditAction = undefined, onMouseOver = undefined, onMouseOut = undefined, popover = undefined; if (richCard) { (function () { displayAvatar = true; style = _extends({}, style, { flexDirection: 'column' }); avatarSize = cardSize ? cardSize : '100%'; avatarStyle = { borderRadius: 0 }; var localReload = function localReload() { MetaCacheService.getInstance().deleteKey('user_public_data-rich', _this.props.userId); _this.loadPublicData(_this.props.userId); }; reloadAction = function () { localReload(); if (_this.props.reloadAction) _this.props.reloadAction(); }; onEditAction = function () { localReload(); if (_this.props.onEditAction) _this.props.onEditAction(); }; })(); } else if (this.props.richOnHover) { (function () { onMouseOut = function () { if (!_this.lockedBySubPopover) { _this.setState({ showPopover: false }); } }; onMouseOut = debounce(onMouseOut, 350); onMouseOver = function (e) { _this.setState({ showPopover: true, popoverAnchor: e.currentTarget }); onMouseOut.cancel(); }; var onMouseOverInner = function onMouseOverInner(e) { _this.setState({ showPopover: true }); onMouseOut.cancel(); }; var lockOnSubPopoverOpen = function lockOnSubPopoverOpen(status) { _this.lockedBySubPopover = status; onMouseOverInner(); }; popover = React.createElement( Popover, { open: _this.state.showPopover, anchorEl: _this.state.popoverAnchor, onRequestClose: function (reason) { if (reason !== 'clickAway' || !_this.lockedBySubPopover) { _this.setState({ showPopover: false }); } }, anchorOrigin: { horizontal: "left", vertical: "center" }, targetOrigin: { horizontal: "right", vertical: "center" }, useLayerForClickAway: false }, React.createElement( Paper, { zDepth: 2, style: { width: 220, height: 320, overflowY: 'auto' }, onMouseOver: onMouseOverInner, onMouseOut: onMouseOut }, React.createElement(UserAvatar, _extends({}, _this.props, { richCard: true, richOnHover: false, cardSize: 220, lockOnSubPopoverOpen: lockOnSubPopoverOpen })) ) ); })(); } var avatarComponent = React.createElement( Avatar, { src: avatar, icon: avatarIcon, size: avatarSize, style: this.props.avatarOnly ? this.props.style : avatarStyle, backgroundColor: avatarColor }, avatarContent ); if (this.props.avatarOnly) { return avatarComponent; } return React.createElement( 'div', { className: className, style: style, onMouseOver: onMouseOver, onMouseOut: onMouseOut }, displayAvatar && (avatar || avatarContent || avatarIcon) && avatarComponent, displayLabel && !richCard && React.createElement( 'div', { className: labelClassName, style: labelStyle }, label ), displayLabel && richCard && React.createElement(CardTitle, { style: { textAlign: 'center' }, title: label, subtitle: userTypeLabel }), richCard && user && React.createElement(_ActionsPanel2['default'], _extends({}, this.state, this.props, { reloadAction: reloadAction, onEditAction: onEditAction })), graph && React.createElement(_GraphPanel2['default'], _extends({ graph: graph }, this.props, { userLabel: label, reloadAction: reloadAction, onEditAction: onEditAction })), this.props.children, popover ); }; return UserAvatar; })(React.Component); UserAvatar.propTypes = { /** * Id of the user to be loaded */ userId: React.PropTypes.string.isRequired, /** * Pydio instance */ pydio: React.PropTypes.instanceOf(Pydio), /** * Label of the user, if we already have it (otherwise will be loaded) */ userLabel: React.PropTypes.string, /** * Type of user */ userType: React.PropTypes.oneOf(['user', 'group', 'remote', 'team']), /** * Icon to be displayed in avatar */ icon: React.PropTypes.string, /** * Display a rich card or a simple avatar+label chip */ richCard: React.PropTypes.bool, /** * If not rich, display a rich card as popover on mouseover */ richOnHover: React.PropTypes.bool, /** * Add edit action to the card */ userEditable: React.PropTypes.bool, /** * Triggered after successful edition */ onEditAction: React.PropTypes.func, /** * Triggered after deletion */ onDeleteAction: React.PropTypes.func, /** * Triggered if a reload is required */ reloadAction: React.PropTypes.func, /** * Display label element or not */ displayLabel: React.PropTypes.bool, /** * Display avatar element or not */ displayAvatar: React.PropTypes.bool, /** * Display only avatar */ avatarOnly: React.PropTypes.bool, /** * Use default avatar */ useDefaultAvatar: React.PropTypes.bool, /** * Avatar size, 40px by default */ avatarSize: React.PropTypes.number, /** * Add class name to root element */ className: React.PropTypes.string, /** * Add class name to label element */ labelClassName: React.PropTypes.string, /** * Add class name to avatar element */ avatarClassName: React.PropTypes.string, /** * Add style to root element */ style: React.PropTypes.object, /** * Add style to label element */ labelStyle: React.PropTypes.object, /** * Add style to avatar element */ avatarStyle: React.PropTypes.object }; UserAvatar.defaultProps = { displayLabel: true, displayAvatar: true, avatarSize: 40, userType: 'user', className: 'user-avatar-widget', avatarClassName: 'user-avatar', labelClassName: 'user-label' }; exports['default'] = UserAvatar = muiThemeable()(UserAvatar); exports['default'] = UserAvatar; module.exports = exports['default']; },{"./ActionsPanel":44,"./GraphPanel":45,"color":"color","lodash.debounce":"lodash.debounce","material-ui":"material-ui","material-ui/styles":"material-ui/styles","pydio/http/api":"pydio/http/api","pydio/http/meta-cache-service":"pydio/http/meta-cache-service","react":"react"}],47:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ "use strict"; exports.__esModule = true; function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } var FuncUtils = require("pydio/util/func"); var ResourcesManager = require("pydio/http/resources-manager"); /******************************/ /* REACT DND GENERIC COMPONENTS /******************************/ var Types = { NODE_PROVIDER: 'node', SORTABLE_LIST_ITEM: 'sortable-list-item' }; /** * Specifies which props to inject into your component. */ function collect(connect, monitor) { return { connectDragSource: connect.dragSource(), isDragging: monitor.isDragging() }; } function collectDrop(connect, monitor) { return { connectDropTarget: connect.dropTarget(), canDrop: monitor.canDrop(), isOver: monitor.isOver(), isOverCurrent: monitor.isOver({ shallow: true }) }; } var DNDActionParameter = (function () { function DNDActionParameter(source, target, step) { _classCallCheck(this, DNDActionParameter); this._source = source; this._target = target; this._step = step; } DNDActionParameter.prototype.getSource = function getSource() { return this._source; }; DNDActionParameter.prototype.getTarget = function getTarget() { return this._target; }; DNDActionParameter.prototype.getStep = function getStep() { return this._step; }; return DNDActionParameter; })(); DNDActionParameter.STEP_BEGIN_DRAG = 'beginDrag'; DNDActionParameter.STEP_END_DRAG = 'endDrag'; DNDActionParameter.STEP_CAN_DROP = 'canDrop'; DNDActionParameter.STEP_HOVER_DROP = 'hover'; var applyDNDAction = function applyDNDAction(source, target, step) { var Controller = window.pydio.Controller; var dnd = Controller.defaultActions.get("dragndrop"); if (dnd) { var dndAction = Controller.getActionByName(dnd); dndAction.enable(); var params = new DNDActionParameter(source, target, step); var checkModule = dndAction.options.dragndropCheckModule; if (step === DNDActionParameter.STEP_CAN_DROP && checkModule) { if (!FuncUtils.getFunctionByName(checkModule, window)) { ResourcesManager.detectModuleToLoadAndApply(checkModule, function () {}); throw new Error('Cannot find test module, trying to load it'); } FuncUtils.executeFunctionByName(dndAction.options.dragndropCheckModule, window, Controller, params); } else { dndAction.apply(params); } } else { throw new Error('No DND Actions available'); } }; /****************************/ /* REACT DND DRAG/DROP NODES /***************************/ var nodeDragSource = { beginDrag: function beginDrag(props) { // Return the data describing the dragged item return { node: props.node }; }, endDrag: function endDrag(props, monitor, component) { if (!monitor.didDrop()) { return; } var item = monitor.getItem(); var dropResult = monitor.getDropResult(); try { applyDNDAction(item.node, dropResult.node, DNDActionParameter.STEP_END_DRAG); } catch (e) {} } }; var nodeDropTarget = { hover: function hover(props, monitor) {}, canDrop: function canDrop(props, monitor) { var source = monitor.getItem().node; var target = props.node; try { applyDNDAction(source, target, DNDActionParameter.STEP_CAN_DROP); } catch (e) { return false; } return true; }, drop: function drop(props, monitor) { var hasDroppedOnChild = monitor.didDrop(); if (hasDroppedOnChild) { return; } return { node: props.node }; } }; exports.Types = Types; exports.collect = collect; exports.collectDrop = collectDrop; exports.nodeDragSource = nodeDragSource; exports.nodeDropTarget = nodeDropTarget; exports.DNDActionParameter = DNDActionParameter; },{"pydio/http/resources-manager":"pydio/http/resources-manager","pydio/util/func":"pydio/util/func"}],48:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ "use strict"; exports.__esModule = true; exports["default"] = { contextTypes: { messages: React.PropTypes.object, getMessage: React.PropTypes.func } }; module.exports = exports["default"]; },{}],49:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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 _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var _require = require('react'); var Component = _require.Component; var PropTypes = _require.PropTypes; var _require2 = require('material-ui'); var FlatButton = _require2.FlatButton; var FontIcon = _require2.FontIcon; var _require3 = require('material-ui/styles'); var muiThemeable = _require3.muiThemeable; var Color = require('color'); var Pydio = require('pydio'); var _Pydio$requireLib = Pydio.requireLib('boot'); var PydioContextConsumer = _Pydio$requireLib.PydioContextConsumer; var EmptyStateView = (function (_Component) { _inherits(EmptyStateView, _Component); function EmptyStateView(props, context) { _classCallCheck(this, EmptyStateView); _Component.call(this, props, context); } EmptyStateView.prototype.render = function render() { var _props = this.props; var style = _props.style; var iconClassName = _props.iconClassName; var primaryTextId = _props.primaryTextId; var secondaryTextId = _props.secondaryTextId; var actionLabelId = _props.actionLabelId; var actionCallback = _props.actionCallback; var actionStyle = _props.actionStyle; var actionIconClassName = _props.actionIconClassName; var getMessage = _props.getMessage; var mainColor = Color(this.props.muiTheme.palette.primary1Color); var styles = { container: _extends({ display: 'flex', alignItems: 'center', justifyContent: 'center', height: '100%', width: '100%', flex: 1, backgroundColor: mainColor.lightness(97).rgb().toString() }, style), centered: { maxWidth: 280, textAlign: 'center', color: mainColor.fade(0.6).toString() }, icon: { fontSize: 100 }, primaryText: { fontSize: 16, fontWeight: 500 }, secondaryText: { marginTop: 20, fontSize: 13 }, buttonContainer: { marginTop: 100, textAlign: 'center' }, buttonStyle: { color: this.props.muiTheme.palette.accent2Color } }; var buttonIcon = actionIconClassName ? React.createElement(FontIcon, { className: actionIconClassName }) : null; return React.createElement( 'div', { style: styles.container }, React.createElement( 'div', { style: styles.centered }, React.createElement('div', { className: iconClassName, style: styles.icon }), React.createElement( 'div', { style: styles.primaryText }, getMessage(primaryTextId) ), secondaryTextId && React.createElement( 'div', { style: styles.secondaryText }, getMessage(secondaryTextId) ), actionLabelId && actionCallback && React.createElement( 'div', { style: _extends({}, styles.buttonContainer, actionStyle) }, React.createElement(FlatButton, { style: styles.buttonStyle, label: getMessage(actionLabelId), onTouchTap: actionCallback, icon: buttonIcon }) ) ) ); }; return EmptyStateView; })(Component); EmptyStateView.propTypes = { pydio: PropTypes.instanceOf(Pydio).isRequired, iconClassName: PropTypes.string.isRequired, primaryTextId: PropTypes.string.isRequired, secondaryTextId: PropTypes.string, actionLabelId: PropTypes.string, actionCallback: PropTypes.func, actionStyle: PropTypes.object, style: PropTypes.object, getMessage: PropTypes.func }; exports['default'] = EmptyStateView = PydioContextConsumer(EmptyStateView); exports['default'] = EmptyStateView = muiThemeable()(EmptyStateView); exports['default'] = EmptyStateView; module.exports = exports['default']; },{"color":"color","material-ui":"material-ui","material-ui/styles":"material-ui/styles","pydio":"pydio","react":"react"}],50:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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 _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; } var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _materialUi = require('material-ui'); var ModalAppBar = function ModalAppBar(props) { var style = props.style; var titleStyle = props.titleStyle; var iconStyleRight = props.iconStyleRight; var iconStyleLeft = props.iconStyleLeft; var otherProps = _objectWithoutProperties(props, ['style', 'titleStyle', 'iconStyleRight', 'iconStyleLeft']); var styles = { style: _extends({ flexShrink: 0 }, style), titleStyle: _extends({ lineHeight: '56px', height: 56, marginLeft: -8 }, titleStyle), iconStyleRight: _extends({ marginTop: 4 }, iconStyleRight), iconStyleLeft: _extends({ marginTop: 4 }, iconStyleLeft) }; return _react2['default'].createElement(_materialUi.AppBar, _extends({}, otherProps, styles)); }; exports['default'] = ModalAppBar; module.exports = exports['default']; /*borderRadius: '2px 2px 0 0',*/ },{"material-ui":"material-ui","react":"react"}],51:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ /** * Search input building a set of query parameters and calling * the callbacks to display / hide results */ 'use strict'; exports.__esModule = true; exports['default'] = React.createClass({ displayName: 'SearchBox', propTypes: { // Required parameters: React.PropTypes.object.isRequired, queryParameterName: React.PropTypes.string.isRequired, // Other textLabel: React.PropTypes.string, displayResults: React.PropTypes.func, hideResults: React.PropTypes.func, displayResultsState: React.PropTypes.bool, limit: React.PropTypes.number }, getInitialState: function getInitialState() { return { displayResult: this.props.displayResultsState ? true : false }; }, getDefaultProps: function getDefaultProps() { var dm = new PydioDataModel(); dm.setRootNode(new AjxpNode()); return { dataModel: dm }; }, displayResultsState: function displayResultsState() { this.setState({ displayResult: true }); }, hideResultsState: function hideResultsState() { this.setState({ displayResult: false }); this.props.hideResults(); }, onClickSearch: function onClickSearch() { var value = this.refs.query.getValue(); var dm = this.props.dataModel; var params = this.props.parameters; params[this.props.queryParameterName] = value; params['limit'] = this.props.limit || 100; dm.getRootNode().setChildren([]); PydioApi.getClient().request(params, (function (transport) { var remoteNodeProvider = new RemoteNodeProvider({}); remoteNodeProvider.parseNodes(dm.getRootNode(), transport); dm.getRootNode().setLoaded(true); this.displayResultsState(); this.props.displayResults(value, dm); }).bind(this)); }, keyDown: function keyDown(event) { if (event.key == 'Enter') { this.onClickSearch(); } }, render: function render() { return React.createElement( 'div', { className: this.props.className ? this.props.className : '' }, React.createElement( 'div', { style: { paddingTop: 22, float: 'right', opacity: 0.3 } }, React.createElement(ReactMUI.IconButton, { ref: 'button', onClick: this.onClickSearch, iconClassName: 'icon-search', tooltip: 'Search' }) ), React.createElement( 'div', { className: 'searchbox-input-fill', style: { width: 220, float: 'right' } }, React.createElement(ReactMUI.TextField, { ref: 'query', onKeyDown: this.keyDown, floatingLabelText: this.props.textLabel }) ) ); } }); module.exports = exports['default']; },{}],52:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ /** * Get info from Pydio controller an build an * action bar with active actions. * TBC */ 'use strict'; exports.__esModule = true; exports['default'] = React.createClass({ displayName: 'SimpleReactActionBar', propTypes: { dataModel: React.PropTypes.instanceOf(PydioDataModel).isRequired, node: React.PropTypes.instanceOf(AjxpNode).isRequired, actions: React.PropTypes.array }, clickAction: function clickAction(event) { var actionName = event.currentTarget.getAttribute("data-action"); this.props.dataModel.setSelectedNodes([this.props.node]); var a = window.pydio.Controller.getActionByName(actionName); a.fireContextChange(this.props.dataModel, true, window.pydio.user); //a.fireSelectionChange(this.props.dataModel); a.apply([this.props.dataModel]); event.stopPropagation(); event.preventDefault(); }, render: function render() { var actions = this.props.actions.map((function (a) { return React.createElement('div', { key: a.options.name, className: a.options.icon_class + ' material-list-action-inline' || '', title: a.options.title, 'data-action': a.options.name, onClick: this.clickAction }); }).bind(this)); return React.createElement( 'span', null, actions ); } }); module.exports = exports['default']; },{}],53:[function(require,module,exports){ /* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ 'use strict'; exports.__esModule = true; 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; }; var _utilDND = require('../util/DND'); var React = require('react'); var _Pydio$requireLib = Pydio.requireLib('hoc'); var withContextMenu = _Pydio$requireLib.withContextMenu; var ContextMenuWrapper = function ContextMenuWrapper(props) { return React.createElement('div', props); }; ContextMenuWrapper = withContextMenu(ContextMenuWrapper); /** * Tree Node */ var SimpleTreeNode = React.createClass({ displayName: 'SimpleTreeNode', propTypes: { collapse: React.PropTypes.bool, forceExpand: React.PropTypes.bool, childrenOnly: React.PropTypes.bool, depth: React.PropTypes.number, onNodeSelect: React.PropTypes.func, node: React.PropTypes.instanceOf(AjxpNode), dataModel: React.PropTypes.instanceOf(PydioDataModel), forceLabel: React.PropTypes.string, // Optional currently selected detection nodeIsSelected: React.PropTypes.func, // Optional checkboxes checkboxes: React.PropTypes.array, checkboxesValues: React.PropTypes.object, checkboxesComputeStatus: React.PropTypes.func, onCheckboxCheck: React.PropTypes.func }, getDefaultProps: function getDefaultProps() { return { collapse: false, childrenOnly: false, depth: 0, onNodeSelect: function onNodeSelect(node) {} }; }, listenToNode: function listenToNode(node) { this._childrenListener = (function () { if (!this.isMounted()) return; this.setState({ children: this._nodeToChildren(node) }); }).bind(this); this._nodeListener = (function () { if (!this.isMounted()) return; this.forceUpdate(); }).bind(this); node.observe("child_added", this._childrenListener); node.observe("child_removed", this._childrenListener); node.observe("node_replaced", this._nodeListener); }, stopListening: function stopListening(node) { node.stopObserving("child_added", this._childrenListener); node.stopObserving("child_removed", this._childrenListener); node.stopObserving("node_replaced", this._nodeListener); }, componentDidMount: function componentDidMount() { this.listenToNode(this.props.node); }, componentWillUnmount: function componentWillUnmount() { this.stopListening(this.props.node); }, componentWillReceiveProps: function componentWillReceiveProps(nextProps) { var oldNode = this.props.node; var newNode = nextProps.node; if (newNode == oldNode && newNode.getMetadata().get("paginationData")) { var remapedChildren = this.state.children.map(function (c) { c.setParent(newNode);return c; }); var remapedPathes = this.state.children.map(function (c) { return c.getPath(); }); var newChildren = this._nodeToChildren(newNode); newChildren.forEach(function (nc) { if (remapedPathes.indexOf(nc.getPath()) === -1) { remapedChildren.push(nc); } }); this.setState({ children: remapedChildren }); } else { this.setState({ children: this._nodeToChildren(newNode) }); } if (newNode !== oldNode) { this.stopListening(oldNode); this.listenToNode(newNode); } }, getInitialState: function getInitialState() { return { showChildren: !this.props.collapse || this.props.forceExpand, children: this._nodeToChildren(this.props.node) }; }, _nodeToChildren: function _nodeToChildren() { var children = []; this.props.node.getChildren().forEach(function (c) { if (!c.isLeaf() || c.getAjxpMime() === 'ajxp_browsable_archive') children.push(c); }); return children; }, onNodeSelect: function onNodeSelect(ev) { if (this.props.onNodeSelect) { this.props.onNodeSelect(this.props.node); } ev.preventDefault(); ev.stopPropagation(); }, onChildDisplayToggle: function onChildDisplayToggle(ev) { if (this.props.node.getChildren().size) { this.setState({ showChildren: !this.state.showChildren }); } ev.preventDefault(); ev.stopPropagation(); }, nodeIsSelected: function nodeIsSelected(n) { if (this.props.nodeIsSelected) return this.props.nodeIsSelected(n);else return this.props.dataModel.getSelectedNodes().indexOf(n) !== -1; }, render: function render() { var _this = this; var _props = this.props; var node = _props.node; var childrenOnly = _props.childrenOnly; var canDrop = _props.canDrop; var isOverCurrent = _props.isOverCurrent; var checkboxes = _props.checkboxes; var checkboxesComputeStatus = _props.checkboxesComputeStatus; var checkboxesValues = _props.checkboxesValues; var onCheckboxCheck = _props.onCheckboxCheck; var depth = _props.depth; var forceExpand = _props.forceExpand; var selectedItemStyle = _props.selectedItemStyle; var getItemStyle = _props.getItemStyle; var forceLabel = _props.forceLabel; var hasFolderChildrens = this.state.children.length ? true : false; var hasChildren; if (hasFolderChildrens) { hasChildren = React.createElement( 'span', { onClick: this.onChildDisplayToggle }, this.state.showChildren || forceExpand ? React.createElement('span', { className: 'tree-icon icon-angle-down' }) : React.createElement('span', { className: 'tree-icon icon-angle-right' }) ); } else { var cname = "tree-icon icon-angle-right"; if (node.isLoaded()) { cname += " no-folder-children"; } hasChildren = React.createElement('span', { className: cname }); } var isSelected = this.nodeIsSelected(node) ? 'mui-menu-item mui-is-selected' : 'mui-menu-item'; var selfLabel; if (!childrenOnly) { if (canDrop && isOverCurrent) { isSelected += ' droppable-active'; } var boxes; if (checkboxes) { var values = {}, inherited = false, disabled = {}, additionalClassName = ''; if (checkboxesComputeStatus) { var status = checkboxesComputeStatus(node); values = status.VALUES; inherited = status.INHERITED; disabled = status.DISABLED; if (status.CLASSNAME) additionalClassName = ' ' + status.CLASSNAME; } else if (checkboxesValues && checkboxesValues[node.getPath()]) { values = checkboxesValues[node.getPath()]; } var valueClasses = []; boxes = checkboxes.map((function (c) { var selected = values[c] !== undefined ? values[c] : false; var click = (function (event, value) { onCheckboxCheck(node, c, value); }).bind(this); if (selected) valueClasses.push(c); return React.createElement(ReactMUI.Checkbox, { name: c, key: c + "-" + (selected ? "true" : "false"), checked: selected, onCheck: click, disabled: disabled[c], className: "cbox-" + c }); }).bind(this)); isSelected += inherited ? " inherited " : ""; isSelected += valueClasses.length ? " checkbox-values-" + valueClasses.join('-') : " checkbox-values-empty"; boxes = React.createElement( 'div', { className: "tree-checkboxes" + additionalClassName }, boxes ); } var itemStyle = { paddingLeft: depth * 20 }; if (this.nodeIsSelected(node) && selectedItemStyle) { itemStyle = _extends({}, itemStyle, selectedItemStyle); } if (getItemStyle) { itemStyle = _extends({}, itemStyle, getItemStyle(node)); } var icon = 'mdi mdi-folder'; var ajxpMime = node.getAjxpMime(); if (ajxpMime === 'ajxp_browsable_archive') { icon = 'mdi mdi-archive'; } else if (ajxpMime === 'ajxp_recycle') { icon = 'mdi mdi-delete'; } selfLabel = React.createElement( ContextMenuWrapper, { node: node, className: 'tree-item ' + isSelected + (boxes ? ' has-checkboxes' : ''), style: itemStyle }, React.createElement( 'div', { className: 'tree-item-label', onClick: this.onNodeSelect, title: node.getLabel(), 'data-id': node.getPath() }, hasChildren, React.createElement('span', { className: "tree-icon " + icon }), forceLabel ? forceLabel : node.getLabel() ), boxes ); } var children = []; var connector = function connector(instance) { return instance; }; var draggable = false; if (window.ReactDND && this.props.connectDropTarget && this.props.connectDragSource) { (function () { var connectDragSource = _this.props.connectDragSource; var connectDropTarget = _this.props.connectDropTarget; connector = function (instance) { connectDragSource(ReactDOM.findDOMNode(instance)); connectDropTarget(ReactDOM.findDOMNode(instance)); }; draggable = true; })(); } if (this.state.showChildren || forceExpand) { children = this.state.children.map((function (child) { var props = _extends({}, this.props, { forceLabel: null, childrenOnly: false, key: child.getPath(), node: child, depth: depth + 1 }); return React.createElement(draggable ? DragDropTreeNode : SimpleTreeNode, props); }).bind(this)); } return React.createElement( 'li', { ref: connector, className: "treenode" + node.getPath().replace(/\//g, '_') }, selfLabel, React.createElement( 'ul', null, children ) ); } }); var DragDropTreeNode; if (window.ReactDND) { DragDropTreeNode = ReactDND.flow(ReactDND.DragSource(_utilDND.Types.NODE_PROVIDER, _utilDND.nodeDragSource, _utilDND.collect), ReactDND.DropTarget(_utilDND.Types.NODE_PROVIDER, _utilDND.nodeDropTarget, _utilDND.collectDrop))(SimpleTreeNode); } else { DragDropTreeNode = SimpleTreeNode; } /** * Simple openable / loadable tree taking AjxpNode as inputs */ var DNDTreeView = React.createClass({ displayName: 'DNDTreeView', propTypes: { showRoot: React.PropTypes.bool, rootLabel: React.PropTypes.string, onNodeSelect: React.PropTypes.func, node: React.PropTypes.instanceOf(AjxpNode).isRequired, dataModel: React.PropTypes.instanceOf(PydioDataModel).isRequired, selectable: React.PropTypes.bool, selectableMultiple: React.PropTypes.bool, initialSelectionModel: React.PropTypes.array, onSelectionChange: React.PropTypes.func, forceExpand: React.PropTypes.bool, // Optional currently selected detection nodeIsSelected: React.PropTypes.func, // Optional checkboxes checkboxes: React.PropTypes.array, checkboxesValues: React.PropTypes.object, checkboxesComputeStatus: React.PropTypes.func, onCheckboxCheck: React.PropTypes.func }, getDefaultProps: function getDefaultProps() { return { showRoot: true, onNodeSelect: this.onNodeSelect }; }, onNodeSelect: function onNodeSelect(node) { if (this.props.onNodeSelect) { this.props.onNodeSelect(node); } else { this.props.dataModel.setSelectedNodes([node]); } }, render: function render() { return React.createElement( 'ul', { className: this.props.className }, React.createElement(DragDropTreeNode, { childrenOnly: !this.props.showRoot, forceExpand: this.props.forceExpand, node: this.props.node ? this.props.node : this.props.dataModel.getRootNode(), dataModel: this.props.dataModel, onNodeSelect: this.onNodeSelect, nodeIsSelected: this.props.nodeIsSelected, forceLabel: this.props.rootLabel, checkboxes: this.props.checkboxes, checkboxesValues: this.props.checkboxesValues, checkboxesComputeStatus: this.props.checkboxesComputeStatus, onCheckboxCheck: this.props.onCheckboxCheck, selectedItemStyle: this.props.selectedItemStyle, getItemStyle: this.props.getItemStyle }) ); } }); var TreeView = React.createClass({ displayName: 'TreeView', propTypes: { showRoot: React.PropTypes.bool, rootLabel: React.PropTypes.string, onNodeSelect: React.PropTypes.func, node: React.PropTypes.instanceOf(AjxpNode).isRequired, dataModel: React.PropTypes.instanceOf(PydioDataModel).isRequired, selectable: React.PropTypes.bool, selectableMultiple: React.PropTypes.bool, initialSelectionModel: React.PropTypes.array, onSelectionChange: React.PropTypes.func, forceExpand: React.PropTypes.bool, // Optional currently selected detection nodeIsSelected: React.PropTypes.func, // Optional checkboxes checkboxes: React.PropTypes.array, checkboxesValues: React.PropTypes.object, checkboxesComputeStatus: React.PropTypes.func, onCheckboxCheck: React.PropTypes.func }, getDefaultProps: function getDefaultProps() { return { showRoot: true, onNodeSelect: this.onNodeSelect }; }, onNodeSelect: function onNodeSelect(node) { if (this.props.onNodeSelect) { this.props.onNodeSelect(node); } else { this.props.dataModel.setSelectedNodes([node]); } }, render: function render() { return React.createElement( 'ul', { className: this.props.className }, React.createElement(SimpleTreeNode, { childrenOnly: !this.props.showRoot, forceExpand: this.props.forceExpand, node: this.props.node ? this.props.node : this.props.dataModel.getRootNode(), dataModel: this.props.dataModel, onNodeSelect: this.onNodeSelect, nodeIsSelected: this.props.nodeIsSelected, forceLabel: this.props.rootLabel, checkboxes: this.props.checkboxes, checkboxesValues: this.props.checkboxesValues, checkboxesComputeStatus: this.props.checkboxesComputeStatus, onCheckboxCheck: this.props.onCheckboxCheck, selectedItemStyle: this.props.selectedItemStyle, getItemStyle: this.props.getItemStyle }) ); } }); var FoldersTree = React.createClass({ displayName: 'FoldersTree', propTypes: { pydio: React.PropTypes.instanceOf(Pydio).isRequired, dataModel: React.PropTypes.instanceOf(PydioDataModel).isRequired, className: React.PropTypes.string, onNodeSelected: React.PropTypes.func, draggable: React.PropTypes.bool }, nodeObserver: function nodeObserver() { var r = this.props.dataModel.getRootNode(); if (!r.isLoaded()) { r.observeOnce("loaded", (function () { this.forceUpdate(); }).bind(this)); } else { this.forceUpdate(); } }, componentDidMount: function componentDidMount() { var dm = this.props.dataModel; this._dmObs = this.nodeObserver; dm.observe("context_changed", this._dmObs); dm.observe("root_node_changed", this._dmObs); this.nodeObserver(); }, componentWillUnmount: function componentWillUnmount() { if (this._dmObs) { var dm = this.props.dataModel; dm.stopObserving("context_changed", this._dmObs); dm.stopObserving("root_node_changed", this._dmObs); } }, treeNodeSelected: function treeNodeSelected(n) { if (this.props.onNodeSelected) { this.props.onNodeSelected(n); } else { this.props.dataModel.requireContextChange(n); } }, nodeIsSelected: function nodeIsSelected(n) { return n === this.props.dataModel.getContextNode(); }, render: function render() { if (this.props.draggable) { return React.createElement(PydioComponents.DNDTreeView, { onNodeSelect: this.treeNodeSelected, nodeIsSelected: this.nodeIsSelected, dataModel: this.props.dataModel, node: this.props.dataModel.getRootNode(), showRoot: this.props.showRoot ? true : false, selectedItemStyle: this.props.selectedItemStyle, getItemStyle: this.props.getItemStyle, className: "folders-tree" + (this.props.className ? ' ' + this.props.className : '') }); } else { return React.createElement(PydioComponents.TreeView, { onNodeSelect: this.treeNodeSelected, nodeIsSelected: this.nodeIsSelected, dataModel: this.props.dataModel, node: this.props.dataModel.getRootNode(), selectedItemStyle: this.props.selectedItemStyle, getItemStyle: this.props.getItemStyle, showRoot: this.props.showRoot ? true : false, className: "folders-tree" + (this.props.className ? ' ' + this.props.className : '') }); } } }); exports.TreeView = TreeView; exports.DNDTreeView = DNDTreeView; exports.FoldersTree = FoldersTree; },{"../util/DND":47,"react":"react"}]},{},[12])(12) }); //# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","node_modules/react-scrollbar/dist/scrollArea.js","res/build/ui/Components/dynamic-grid/DynamicGrid.js","res/build/ui/Components/dynamic-grid/GridBuilder.js","res/build/ui/Components/dynamic-grid/GridItemMixin.js","res/build/ui/Components/dynamic-grid/Store.js","res/build/ui/Components/dynamic-grid/asGridItem.js","res/build/ui/Components/editor/PaperEditor.js","res/build/ui/Components/editor/ReactEditorOpener.js","res/build/ui/Components/elements/ClipboardTextField.js","res/build/ui/Components/elements/LabelWithTip.js","res/build/ui/Components/elements/SimpleFigureBadge.js","res/build/ui/Components/index.js","res/build/ui/Components/list/ConfigurableListEntry.js","res/build/ui/Components/list/InlineEditor.js","res/build/ui/Components/list/ListEntry.js","res/build/ui/Components/list/ListEntryNodeListenerMixin.js","res/build/ui/Components/list/ListPaginator.js","res/build/ui/Components/list/NodeListCustomProvider.js","res/build/ui/Components/list/SimpleList.js","res/build/ui/Components/list/SortColumns.js","res/build/ui/Components/list/SortableList.js","res/build/ui/Components/list/TableListEntry.js","res/build/ui/Components/list/TableListHeader.js","res/build/ui/Components/menu/ButtonMenu.js","res/build/ui/Components/menu/ContextMenu.js","res/build/ui/Components/menu/IconButtonMenu.js","res/build/ui/Components/menu/IconButtonPopover.js","res/build/ui/Components/menu/MenuItemsConsumer.js","res/build/ui/Components/menu/PopupMenu.js","res/build/ui/Components/menu/Toolbar.js","res/build/ui/Components/menu/Utils.js","res/build/ui/Components/users/TeamCreationForm.js","res/build/ui/Components/users/UsersCompleter.js","res/build/ui/Components/users/addressbook/AddressBook.js","res/build/ui/Components/users/addressbook/AlphaPaginator.js","res/build/ui/Components/users/addressbook/Loaders.js","res/build/ui/Components/users/addressbook/NestedListItem.js","res/build/ui/Components/users/addressbook/RightPanelCard.js","res/build/ui/Components/users/addressbook/SearchForm.js","res/build/ui/Components/users/addressbook/SearchPanel.js","res/build/ui/Components/users/addressbook/TeamCard.js","res/build/ui/Components/users/addressbook/UserCard.js","res/build/ui/Components/users/addressbook/UsersList.js","res/build/ui/Components/users/avatar/ActionsPanel.js","res/build/ui/Components/users/avatar/GraphPanel.js","res/build/ui/Components/users/avatar/UserAvatar.js","res/build/ui/Components/util/DND.js","res/build/ui/Components/util/MessagesConsumerMixin.js","res/build/ui/Components/views/EmptyStateView.js","res/build/ui/Components/views/ModalAppBar.js","res/build/ui/Components/views/SearchBox.js","res/build/ui/Components/views/SimpleReactActionBar.js","res/build/ui/Components/views/TreeView.js"],"names":[],"mappings":"AAAA;ACAA;AACA;;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACzTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACxMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC9FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC3IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5KA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1HA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3OA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC/IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC/yCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1HA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/OA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACrIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACvWA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpoBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5QA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5OA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7HA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1eA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","!function(e,t){\"object\"==typeof exports&&\"object\"==typeof module?module.exports=t(require(\"react\")):\"function\"==typeof define&&define.amd?define([\"react\"],t):\"object\"==typeof exports?exports.ScrollArea=t(require(\"react\")):e.ScrollArea=t(e.React)}(this,function(e){return function(e){function t(o){if(n[o])return n[o].exports;var r=n[o]={exports:{},id:o,loaded:!1};return e[o].call(r.exports,r,r.exports,t),r.loaded=!0,r.exports}var n={};return t.m=e,t.c=n,t.p=\"\",t(0)}([function(e,t,n){\"use strict\";function o(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,\"__esModule\",{value:!0}),n(31);var r=n(13),i=o(r);t.default=i.default},function(t,n){t.exports=e},function(e,t,n){e.exports=n(19)()},function(e,t){\"use strict\";function n(e){var t={};for(var n in e)Object.prototype.hasOwnProperty.call(e,n)&&(t[n]=\"number\"==typeof e[n]?e[n]:e[n].val);return t}t.__esModule=!0,t.default=n,e.exports=t.default},function(e,t,n){(function(t){(function(){var n,o,r;\"undefined\"!=typeof performance&&null!==performance&&performance.now?e.exports=function(){return performance.now()}:\"undefined\"!=typeof t&&null!==t&&t.hrtime?(e.exports=function(){return(n()-r)/1e6},o=t.hrtime,n=function(){var e;return e=o(),1e9*e[0]+e[1]},r=n()):Date.now?(e.exports=function(){return Date.now()-r},r=Date.now()):(e.exports=function(){return(new Date).getTime()-r},r=(new Date).getTime())}).call(this)}).call(t,n(10))},function(e,t,n){(function(t){for(var o=n(23),r=\"undefined\"==typeof window?t:window,i=[\"moz\",\"webkit\"],a=\"AnimationFrame\",l=r[\"request\"+a],s=r[\"cancel\"+a]||r[\"cancelRequest\"+a],u=0;!l&&u<i.length;u++)l=r[i[u]+\"Request\"+a],s=r[i[u]+\"Cancel\"+a]||r[i[u]+\"CancelRequest\"+a];if(!l||!s){var c=0,f=0,p=[],d=1e3/60;l=function(e){if(0===p.length){var t=o(),n=Math.max(0,d-(t-c));c=n+t,setTimeout(function(){var e=p.slice(0);p.length=0;for(var t=0;t<e.length;t++)if(!e[t].cancelled)try{e[t].callback(c)}catch(e){setTimeout(function(){throw e},0)}},Math.round(n))}return p.push({handle:++f,callback:e,cancelled:!1}),f},s=function(e){for(var t=0;t<p.length;t++)p[t].handle===e&&(p[t].cancelled=!0)}}e.exports=function(e){return l.call(r,e)},e.exports.cancel=function(){s.apply(r,arguments)},e.exports.polyfill=function(e){e||(e=r),e.requestAnimationFrame=l,e.cancelAnimationFrame=s}}).call(t,function(){return this}())},function(e,t){\"use strict\";function n(e){var t={};for(var n in e)Object.prototype.hasOwnProperty.call(e,n)&&(t[n]=0);return t}t.__esModule=!0,t.default=n,e.exports=t.default},function(e,t){\"use strict\";function n(e,t,n){for(var o in t)if(Object.prototype.hasOwnProperty.call(t,o)){if(0!==n[o])return!1;var r=\"number\"==typeof t[o]?t[o]:t[o].val;if(e[o]!==r)return!1}return!0}t.__esModule=!0,t.default=n,e.exports=t.default},function(e,t){\"use strict\";function n(e,t,n,r,i,a,l){var s=-i*(t-r),u=-a*n,c=s+u,f=n+c*e,p=t+f*e;return Math.abs(f)<l&&Math.abs(p-r)<l?(o[0]=r,o[1]=0,o):(o[0]=p,o[1]=f,o)}t.__esModule=!0,t.default=n;var o=[0,0];e.exports=t.default},function(e,t,n){\"use strict\";function o(e){return e&&e.__esModule?e:{default:e}}function r(e){return p?f.default.findDOMNode(e):e}function i(){d||p||(d=!0,console.error(\"With React 0.14 and later versions, you no longer need to wrap <ScrollArea> child into a function.\"))}function a(){!d&&p&&(d=!0,console.error(\"With React 0.13, you need to wrap <ScrollArea> child into a function.\"))}function l(e){return e<0?0:e}function s(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:function(e){return e},n={};for(var o in e)e.hasOwnProperty(o)&&(n[o]=t(e[o]));return n}function u(e){var t=e.version;if(\"string\"!=typeof t)return!0;var n=t.split(\".\"),o=parseInt(n[0],10),r=parseInt(n[1],10);return 0===o&&13===r}Object.defineProperty(t,\"__esModule\",{value:!0}),t.findDOMNode=r,t.warnAboutFunctionChild=i,t.warnAboutElementChild=a,t.positiveOrZero=l,t.modifyObjValues=s,t.isReact13=u;var c=n(1),f=o(c),p=u(f.default),d=!1},function(e,t){function n(){throw new Error(\"setTimeout has not been defined\")}function o(){throw new Error(\"clearTimeout has not been defined\")}function r(e){if(c===setTimeout)return setTimeout(e,0);if((c===n||!c)&&setTimeout)return c=setTimeout,setTimeout(e,0);try{return c(e,0)}catch(t){try{return c.call(null,e,0)}catch(t){return c.call(this,e,0)}}}function i(e){if(f===clearTimeout)return clearTimeout(e);if((f===o||!f)&&clearTimeout)return f=clearTimeout,clearTimeout(e);try{return f(e)}catch(t){try{return f.call(null,e)}catch(t){return f.call(this,e)}}}function a(){y&&d&&(y=!1,d.length?h=d.concat(h):v=-1,h.length&&l())}function l(){if(!y){var e=r(a);y=!0;for(var t=h.length;t;){for(d=h,h=[];++v<t;)d&&d[v].run();v=-1,t=h.length}d=null,y=!1,i(e)}}function s(e,t){this.fun=e,this.array=t}function u(){}var c,f,p=e.exports={};!function(){try{c=\"function\"==typeof setTimeout?setTimeout:n}catch(e){c=n}try{f=\"function\"==typeof clearTimeout?clearTimeout:o}catch(e){f=o}}();var d,h=[],y=!1,v=-1;p.nextTick=function(e){var t=new Array(arguments.length-1);if(arguments.length>1)for(var n=1;n<arguments.length;n++)t[n-1]=arguments[n];h.push(new s(e,t)),1!==h.length||y||r(l)},s.prototype.run=function(){this.fun.apply(null,this.array)},p.title=\"browser\",p.browser=!0,p.env={},p.argv=[],p.version=\"\",p.versions={},p.on=u,p.addListener=u,p.once=u,p.off=u,p.removeListener=u,p.removeAllListeners=u,p.emit=u,p.binding=function(e){throw new Error(\"process.binding is not supported\")},p.cwd=function(){return\"/\"},p.chdir=function(e){throw new Error(\"process.chdir is not supported\")},p.umask=function(){return 0}},function(e,t){\"use strict\";t.__esModule=!0,t.default={noWobble:{stiffness:170,damping:26},gentle:{stiffness:120,damping:14},wobbly:{stiffness:180,damping:12},stiff:{stiffness:210,damping:20}},e.exports=t.default},function(e,t,n){\"use strict\";function o(e){return e&&e.__esModule?e.default:e}t.__esModule=!0;var r=n(24);t.Motion=o(r);var i=n(25);t.StaggeredMotion=o(i);var a=n(26);t.TransitionMotion=o(a);var l=n(29);t.spring=o(l);var s=n(11);t.presets=o(s);var u=n(3);t.stripStyle=o(u);var c=n(28);t.reorderKeys=o(c)},function(e,t,n){\"use strict\";function o(e){return e&&e.__esModule?e:{default:e}}function r(e,t){if(!(e instanceof t))throw new TypeError(\"Cannot call a class as a function\")}function i(e,t){if(!e)throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");return!t||\"object\"!=typeof t&&\"function\"!=typeof t?e:t}function a(e,t){if(\"function\"!=typeof t&&null!==t)throw new TypeError(\"Super expression must either be null or a function, not \"+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}Object.defineProperty(t,\"__esModule\",{value:!0});var l=\"function\"==typeof Symbol&&\"symbol\"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&\"function\"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?\"symbol\":typeof e},s=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var o in n)Object.prototype.hasOwnProperty.call(n,o)&&(e[o]=n[o])}return e},u=function(){function e(e,t){for(var n=0;n<t.length;n++){var o=t[n];o.enumerable=o.enumerable||!1,o.configurable=!0,\"value\"in o&&(o.writable=!0),Object.defineProperty(e,o.key,o)}}return function(t,n,o){return n&&e(t.prototype,n),o&&e(t,o),t}}(),c=n(1),f=o(c),p=n(2),d=o(p),h=n(18),y=o(h),v=n(12),m=n(9),b=n(14),S=o(b),g={wheel:\"wheel\",api:\"api\",touch:\"touch\",touchEnd:\"touchEnd\",mousemove:\"mousemove\",keyPress:\"keypress\"},w=function(e){function t(e){r(this,t);var n=i(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e));return n.state={topPosition:0,leftPosition:0,realHeight:0,containerHeight:0,realWidth:0,containerWidth:0},n.scrollArea={refresh:function(){n.setSizesToState()},scrollTop:function(){n.scrollTop()},scrollBottom:function(){n.scrollBottom()},scrollYTo:function(e){n.scrollYTo(e)},scrollLeft:function(){n.scrollLeft()},scrollRight:function(){n.scrollRight()},scrollXTo:function(e){n.scrollXTo(e)}},n.evntsPreviousValues={clientX:0,clientY:0,deltaX:0,deltaY:0},n.bindedHandleWindowResize=n.handleWindowResize.bind(n),n}return a(t,e),u(t,[{key:\"getChildContext\",value:function(){return{scrollArea:this.scrollArea}}},{key:\"componentDidMount\",value:function(){this.props.contentWindow&&this.props.contentWindow.addEventListener(\"resize\",this.bindedHandleWindowResize),this.lineHeightPx=(0,y.default)((0,m.findDOMNode)(this.content)),this.setSizesToState()}},{key:\"componentWillUnmount\",value:function(){this.props.contentWindow&&this.props.contentWindow.removeEventListener(\"resize\",this.bindedHandleWindowResize)}},{key:\"componentDidUpdate\",value:function(){this.setSizesToState()}},{key:\"render\",value:function(){var e=this,t=this.props,n=t.children,o=t.className,r=t.contentClassName,i=t.ownerDocument,a=this.props.smoothScrolling&&(this.state.eventType===g.wheel||this.state.eventType===g.api||this.state.eventType===g.touchEnd||this.state.eventType===g.keyPress),l=this.canScrollY()?f.default.createElement(S.default,{ownerDocument:i,realSize:this.state.realHeight,containerSize:this.state.containerHeight,position:this.state.topPosition,onMove:this.handleScrollbarMove.bind(this),onPositionChange:this.handleScrollbarYPositionChange.bind(this),containerStyle:this.props.verticalContainerStyle,scrollbarStyle:this.props.verticalScrollbarStyle,smoothScrolling:a,minScrollSize:this.props.minScrollSize,onFocus:this.focusContent.bind(this),type:\"vertical\"}):null,u=this.canScrollX()?f.default.createElement(S.default,{ownerDocument:i,realSize:this.state.realWidth,containerSize:this.state.containerWidth,position:this.state.leftPosition,onMove:this.handleScrollbarMove.bind(this),onPositionChange:this.handleScrollbarXPositionChange.bind(this),containerStyle:this.props.horizontalContainerStyle,scrollbarStyle:this.props.horizontalScrollbarStyle,smoothScrolling:a,minScrollSize:this.props.minScrollSize,onFocus:this.focusContent.bind(this),type:\"horizontal\"}):null;\"function\"==typeof n?((0,m.warnAboutFunctionChild)(),n=n()):(0,m.warnAboutElementChild)();var c=\"scrollarea \"+(o||\"\"),p=\"scrollarea-content \"+(r||\"\"),d={marginTop:-this.state.topPosition,marginLeft:-this.state.leftPosition},h=a?(0,m.modifyObjValues)(d,function(e){return(0,v.spring)(e)}):d;return f.default.createElement(v.Motion,{style:h},function(t){return f.default.createElement(\"div\",{ref:function(t){return e.wrapper=t},className:c,style:e.props.style,onWheel:e.handleWheel.bind(e)},f.default.createElement(\"div\",{ref:function(t){return e.content=t},style:s({},e.props.contentStyle,t),className:p,onTouchStart:e.handleTouchStart.bind(e),onTouchMove:e.handleTouchMove.bind(e),onTouchEnd:e.handleTouchEnd.bind(e),onKeyDown:e.handleKeyDown.bind(e),tabIndex:e.props.focusableTabIndex},n),l,u)})}},{key:\"setStateFromEvent\",value:function(e,t){this.props.onScroll&&this.props.onScroll(e),this.setState(s({},e,{eventType:t}))}},{key:\"handleTouchStart\",value:function(e){var t=e.touches;if(1===t.length){var n=t[0],o=n.clientX,r=n.clientY;this.eventPreviousValues=s({},this.eventPreviousValues,{clientY:r,clientX:o,timestamp:Date.now()})}}},{key:\"handleTouchMove\",value:function(e){this.canScroll()&&(e.preventDefault(),e.stopPropagation());var t=e.touches;if(1===t.length){var n=t[0],o=n.clientX,r=n.clientY,i=this.eventPreviousValues.clientY-r,a=this.eventPreviousValues.clientX-o;this.eventPreviousValues=s({},this.eventPreviousValues,{deltaY:i,deltaX:a,clientY:r,clientX:o,timestamp:Date.now()}),this.setStateFromEvent(this.composeNewState(-a,-i))}}},{key:\"handleTouchEnd\",value:function(e){var t=this.eventPreviousValues,n=t.deltaX,o=t.deltaY,r=t.timestamp;\"undefined\"==typeof n&&(n=0),\"undefined\"==typeof o&&(o=0),Date.now()-r<200&&this.setStateFromEvent(this.composeNewState(10*-n,10*-o),g.touchEnd),this.eventPreviousValues=s({},this.eventPreviousValues,{deltaY:0,deltaX:0})}},{key:\"handleScrollbarMove\",value:function(e,t){this.setStateFromEvent(this.composeNewState(t,e))}},{key:\"handleScrollbarXPositionChange\",value:function(e){this.scrollXTo(e)}},{key:\"handleScrollbarYPositionChange\",value:function(e){this.scrollYTo(e)}},{key:\"handleWheel\",value:function(e){var t=e.deltaY,n=e.deltaX;if(this.props.swapWheelAxes){var o=[n,t];t=o[0],n=o[1]}1===e.deltaMode&&(t*=this.lineHeightPx,n*=this.lineHeightPx),t*=this.props.speed,n*=this.props.speed;var r=this.composeNewState(-n,-t);(r.topPosition&&this.state.topPosition!==r.topPosition||r.leftPosition&&this.state.leftPosition!==r.leftPosition||this.props.stopScrollPropagation)&&(e.preventDefault(),e.stopPropagation()),this.setStateFromEvent(r,g.wheel),this.focusContent()}},{key:\"handleKeyDown\",value:function(e){if(\"input\"!==e.target.tagName.toLowerCase()&&\"textarea\"!==e.target.tagName.toLowerCase()&&!e.target.isContentEditable){var t=0,n=0,o=this.lineHeightPx?this.lineHeightPx:10;switch(e.keyCode){case 33:t=this.state.containerHeight-o;break;case 34:t=-this.state.containerHeight+o;break;case 37:n=o;break;case 38:t=o;break;case 39:n=-o;break;case 40:t=-o}if(0!==t||0!==n){var r=this.composeNewState(n,t);e.preventDefault(),e.stopPropagation(),this.setStateFromEvent(r,g.keyPress)}}}},{key:\"handleWindowResize\",value:function(){var e=this.computeSizes();e=this.getModifiedPositionsIfNeeded(e),this.setStateFromEvent(e)}},{key:\"composeNewState\",value:function(e,t){var n=this.computeSizes();return this.canScrollY(n)?n.topPosition=this.computeTopPosition(t,n):n.topPosition=0,this.canScrollX(n)&&(n.leftPosition=this.computeLeftPosition(e,n)),n}},{key:\"computeTopPosition\",value:function(e,t){var n=this.state.topPosition-e;return this.normalizeTopPosition(n,t)}},{key:\"computeLeftPosition\",value:function(e,t){var n=this.state.leftPosition-e;return this.normalizeLeftPosition(n,t)}},{key:\"normalizeTopPosition\",value:function(e,t){return e>t.realHeight-t.containerHeight&&(e=t.realHeight-t.containerHeight),e<0&&(e=0),e}},{key:\"normalizeLeftPosition\",value:function(e,t){return e>t.realWidth-t.containerWidth?e=t.realWidth-t.containerWidth:e<0&&(e=0),e}},{key:\"computeSizes\",value:function(){var e=this.content.offsetHeight,t=this.wrapper.offsetHeight,n=this.content.offsetWidth,o=this.wrapper.offsetWidth;return{realHeight:e,containerHeight:t,realWidth:n,containerWidth:o}}},{key:\"setSizesToState\",value:function(){var e=this.computeSizes();e.realHeight===this.state.realHeight&&e.realWidth===this.state.realWidth||this.setStateFromEvent(this.getModifiedPositionsIfNeeded(e))}},{key:\"scrollTop\",value:function(){this.scrollYTo(0)}},{key:\"scrollBottom\",value:function(){this.scrollYTo(this.state.realHeight-this.state.containerHeight)}},{key:\"scrollLeft\",value:function(){this.scrollXTo(0)}},{key:\"scrollRight\",value:function(){this.scrollXTo(this.state.realWidth-this.state.containerWidth)}},{key:\"scrollYTo\",value:function(e){if(this.canScrollY()){var t=this.normalizeTopPosition(e,this.computeSizes());this.setStateFromEvent({topPosition:t},g.api)}}},{key:\"scrollXTo\",value:function(e){if(this.canScrollX()){var t=this.normalizeLeftPosition(e,this.computeSizes());this.setStateFromEvent({leftPosition:t},g.api)}}},{key:\"canScrollY\",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.state,t=e.realHeight>e.containerHeight;return t&&this.props.vertical}},{key:\"canScrollX\",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.state,t=e.realWidth>e.containerWidth;return t&&this.props.horizontal}},{key:\"canScroll\",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.state;return this.canScrollY(e)||this.canScrollX(e)}},{key:\"getModifiedPositionsIfNeeded\",value:function(e){var t=e.realHeight-e.containerHeight;this.state.topPosition>=t&&(e.topPosition=this.canScrollY(e)?(0,m.positiveOrZero)(t):0);var n=e.realWidth-e.containerWidth;return this.state.leftPosition>=n&&(e.leftPosition=this.canScrollX(e)?(0,m.positiveOrZero)(n):0),e}},{key:\"focusContent\",value:function(){this.content&&(0,m.findDOMNode)(this.content).focus()}}]),t}(f.default.Component);t.default=w,w.childContextTypes={scrollArea:d.default.object},w.propTypes={className:d.default.string,style:d.default.object,speed:d.default.number,contentClassName:d.default.string,contentStyle:d.default.object,vertical:d.default.bool,verticalContainerStyle:d.default.object,verticalScrollbarStyle:d.default.object,horizontal:d.default.bool,horizontalContainerStyle:d.default.object,horizontalScrollbarStyle:d.default.object,onScroll:d.default.func,contentWindow:d.default.any,ownerDocument:d.default.any,smoothScrolling:d.default.bool,minScrollSize:d.default.number,swapWheelAxes:d.default.bool,stopScrollPropagation:d.default.bool,focusableTabIndex:d.default.number},w.defaultProps={speed:1,vertical:!0,horizontal:!0,smoothScrolling:!1,swapWheelAxes:!1,contentWindow:\"object\"===(\"undefined\"==typeof window?\"undefined\":l(window))?window:void 0,ownerDocument:\"object\"===(\"undefined\"==typeof document?\"undefined\":l(document))?document:void 0,focusableTabIndex:1}},function(e,t,n){\"use strict\";function o(e){return e&&e.__esModule?e:{default:e}}function r(e,t){if(!(e instanceof t))throw new TypeError(\"Cannot call a class as a function\")}function i(e,t){if(!e)throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");return!t||\"object\"!=typeof t&&\"function\"!=typeof t?e:t}function a(e,t){if(\"function\"!=typeof t&&null!==t)throw new TypeError(\"Super expression must either be null or a function, not \"+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}Object.defineProperty(t,\"__esModule\",{value:!0});var l=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var o in n)Object.prototype.hasOwnProperty.call(n,o)&&(e[o]=n[o])}return e},s=function(){function e(e,t){for(var n=0;n<t.length;n++){var o=t[n];o.enumerable=o.enumerable||!1,o.configurable=!0,\"value\"in o&&(o.writable=!0),Object.defineProperty(e,o.key,o)}}return function(t,n,o){return n&&e(t.prototype,n),o&&e(t,o),t}}(),u=n(1),c=o(u),f=n(2),p=o(f),d=n(12),h=n(9),y=function(e){function t(e){r(this,t);var n=i(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e)),o=n.calculateState(e);return n.state={position:o.position,scrollSize:o.scrollSize,isDragging:!1,lastClientPosition:0},\"vertical\"===e.type?n.bindedHandleMouseMove=n.handleMouseMoveForVertical.bind(n):n.bindedHandleMouseMove=n.handleMouseMoveForHorizontal.bind(n),n.bindedHandleMouseUp=n.handleMouseUp.bind(n),n}return a(t,e),s(t,[{key:\"componentDidMount\",value:function(){this.props.ownerDocument&&(this.props.ownerDocument.addEventListener(\"mousemove\",this.bindedHandleMouseMove),this.props.ownerDocument.addEventListener(\"mouseup\",this.bindedHandleMouseUp))}},{key:\"componentWillReceiveProps\",value:function(e){this.setState(this.calculateState(e))}},{key:\"componentWillUnmount\",value:function(){this.props.ownerDocument&&(this.props.ownerDocument.removeEventListener(\"mousemove\",this.bindedHandleMouseMove),this.props.ownerDocument.removeEventListener(\"mouseup\",this.bindedHandleMouseUp))}},{key:\"calculateFractionalPosition\",value:function(e,t,n){var o=e-t;return 1-(o-n)/o}},{key:\"calculateState\",value:function(e){var t=this.calculateFractionalPosition(e.realSize,e.containerSize,e.position),n=e.containerSize*e.containerSize/e.realSize,o=n<e.minScrollSize?e.minScrollSize:n,r=(e.containerSize-o)*t;return{scrollSize:o,position:Math.round(r)}}},{key:\"render\",value:function(){var e=this,t=this.props,n=t.smoothScrolling,o=t.isDragging,r=t.type,i=t.scrollbarStyle,a=t.containerStyle,s=\"horizontal\"===r,u=\"vertical\"===r,f=this.createScrollStyles(),p=n?(0,h.modifyObjValues)(f,function(e){return(0,d.spring)(e)}):f,y=\"scrollbar-container \"+(o?\"active\":\"\")+\" \"+(s?\"horizontal\":\"\")+\" \"+(u?\"vertical\":\"\");return c.default.createElement(d.Motion,{style:p},function(t){return c.default.createElement(\"div\",{className:y,style:a,onMouseDown:e.handleScrollBarContainerClick.bind(e),ref:function(t){return e.scrollbarContainer=t}},c.default.createElement(\"div\",{className:\"scrollbar\",style:l({},i,t),onMouseDown:e.handleMouseDown.bind(e)}))})}},{key:\"handleScrollBarContainerClick\",value:function(e){e.preventDefault();var t=this.computeMultiplier(),n=this.isVertical()?e.clientY:e.clientX,o=this.scrollbarContainer.getBoundingClientRect(),r=o.top,i=o.left,a=this.isVertical()?r:i,l=n-a,s=this.props.containerSize*this.props.containerSize/this.props.realSize;this.setState({isDragging:!0,lastClientPosition:n}),this.props.onPositionChange((l-s/2)/t)}},{key:\"handleMouseMoveForHorizontal\",value:function(e){var t=this.computeMultiplier();if(this.state.isDragging){e.preventDefault();var n=this.state.lastClientPosition-e.clientX;this.setState({lastClientPosition:e.clientX}),this.props.onMove(0,n/t)}}},{key:\"handleMouseMoveForVertical\",value:function(e){var t=this.computeMultiplier();if(this.state.isDragging){e.preventDefault();var n=this.state.lastClientPosition-e.clientY;this.setState({lastClientPosition:e.clientY}),this.props.onMove(n/t,0)}}},{key:\"handleMouseDown\",value:function(e){e.preventDefault(),e.stopPropagation();var t=this.isVertical()?e.clientY:e.clientX;this.setState({isDragging:!0,lastClientPosition:t}),this.props.onFocus()}},{key:\"handleMouseUp\",value:function(e){this.state.isDragging&&(e.preventDefault(),this.setState({isDragging:!1}))}},{key:\"createScrollStyles\",value:function(){return\"vertical\"===this.props.type?{height:this.state.scrollSize,marginTop:this.state.position}:{width:this.state.scrollSize,marginLeft:this.state.position}}},{key:\"computeMultiplier\",value:function(){return this.props.containerSize/this.props.realSize}},{key:\"isVertical\",value:function(){return\"vertical\"===this.props.type}}]),t}(c.default.Component);y.propTypes={onMove:p.default.func,onPositionChange:p.default.func,onFocus:p.default.func,realSize:p.default.number,containerSize:p.default.number,position:p.default.number,containerStyle:p.default.object,scrollbarStyle:p.default.object,type:p.default.oneOf([\"vertical\",\"horizontal\"]),ownerDocument:p.default.any,smoothScrolling:p.default.bool,minScrollSize:p.default.number},y.defaultProps={type:\"vertical\",smoothScrolling:!1},t.default=y},function(e,t){var n=function(e,t,n){return n=window.getComputedStyle,(n?n(e):e.currentStyle)[t.replace(/-(\\w)/gi,function(e,t){return t.toUpperCase()})]};e.exports=n},function(e,t,n){t=e.exports=n(17)(),t.push([e.id,\".scrollarea-content{margin:0;padding:0;overflow:hidden;position:relative}.scrollarea-content:focus{outline:0}.scrollarea{position:relative;overflow:hidden}.scrollarea .scrollbar-container{position:absolute;background:none;opacity:.1;z-index:9999;-webkit-transition:all .4s;transition:all .4s}.scrollarea .scrollbar-container.horizontal{width:100%;height:10px;left:0;bottom:0}.scrollarea .scrollbar-container.horizontal .scrollbar{width:20px;height:8px;background:#000;margin-top:1px}.scrollarea .scrollbar-container.vertical{width:10px;height:100%;right:0;top:0}.scrollarea .scrollbar-container.vertical .scrollbar{width:8px;height:20px;background:#000;margin-left:1px}.scrollarea .scrollbar-container.active,.scrollarea .scrollbar-container:hover{background:gray;opacity:.6!important}.scrollarea:hover .scrollbar-container{opacity:.3}\",\"\"])},function(e,t){e.exports=function(){var e=[];return e.toString=function(){for(var e=[],t=0;t<this.length;t++){var n=this[t];n[2]?e.push(\"@media \"+n[2]+\"{\"+n[1]+\"}\"):e.push(n[1])}return e.join(\"\")},e.i=function(t,n){\"string\"==typeof t&&(t=[[null,t,\"\"]]);for(var o={},r=0;r<this.length;r++){var i=this[r][0];\"number\"==typeof i&&(o[i]=!0)}for(r=0;r<t.length;r++){var a=t[r];\"number\"==typeof a[0]&&o[a[0]]||(n&&!a[2]?a[2]=n:n&&(a[2]=\"(\"+a[2]+\") and (\"+n+\")\"),e.push(a))}},e}},function(e,t,n){function o(e){var t=r(e,\"line-height\"),n=parseFloat(t,10);if(t===n+\"\"){var o=e.style.lineHeight;e.style.lineHeight=t+\"em\",t=r(e,\"line-height\"),n=parseFloat(t,10),o?e.style.lineHeight=o:delete e.style.lineHeight}if(t.indexOf(\"pt\")!==-1?(n*=4,n/=3):t.indexOf(\"mm\")!==-1?(n*=96,n/=25.4):t.indexOf(\"cm\")!==-1?(n*=96,n/=2.54):t.indexOf(\"in\")!==-1?n*=96:t.indexOf(\"pc\")!==-1&&(n*=16),n=Math.round(n),\"normal\"===t){var i=e.nodeName,a=document.createElement(i);a.innerHTML=\"&nbsp;\";var l=r(e,\"font-size\");a.style.fontSize=l;var s=document.body;s.appendChild(a);var u=a.offsetHeight;n=u,s.removeChild(a)}return n}var r=n(15);e.exports=o},function(e,t,n){\"use strict\";var o=n(21),r=n(22),i=n(20);e.exports=function(){function e(e,t,n,o,a,l){l!==i&&r(!1,\"Calling PropTypes validators directly is not supported by the `prop-types` package. Use PropTypes.checkPropTypes() to call them. Read more at http://fb.me/use-check-prop-types\")}function t(){return e}e.isRequired=e;var n={array:e,bool:e,func:e,number:e,object:e,string:e,symbol:e,any:e,arrayOf:t,element:e,instanceOf:t,node:e,objectOf:t,oneOf:t,oneOfType:t,shape:t,exact:t};return n.checkPropTypes=o,n.PropTypes=n,n}},function(e,t){\"use strict\";var n=\"SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED\";e.exports=n},function(e,t){\"use strict\";function n(e){return function(){return e}}var o=function(){};o.thatReturns=n,o.thatReturnsFalse=n(!1),o.thatReturnsTrue=n(!0),o.thatReturnsNull=n(null),o.thatReturnsThis=function(){return this},o.thatReturnsArgument=function(e){return e},e.exports=o},function(e,t,n){\"use strict\";function o(e,t,n,o,i,a,l,s){if(r(t),!e){var u;if(void 0===t)u=new Error(\"Minified exception occurred; use the non-minified dev environment for the full error message and additional helpful warnings.\");else{var c=[n,o,i,a,l,s],f=0;u=new Error(t.replace(/%s/g,function(){return c[f++]})),u.name=\"Invariant Violation\"}throw u.framesToPop=1,u}}var r=function(e){};e.exports=o},function(e,t,n){(function(t){(function(){var n,o,r,i,a,l;\"undefined\"!=typeof performance&&null!==performance&&performance.now?e.exports=function(){return performance.now()}:\"undefined\"!=typeof t&&null!==t&&t.hrtime?(e.exports=function(){return(n()-a)/1e6},o=t.hrtime,n=function(){var e;return e=o(),1e9*e[0]+e[1]},i=n(),l=1e9*t.uptime(),a=i-l):Date.now?(e.exports=function(){return Date.now()-r},r=Date.now()):(e.exports=function(){return(new Date).getTime()-r},r=(new Date).getTime())}).call(this)}).call(t,n(10))},function(e,t,n){\"use strict\";function o(e){return e&&e.__esModule?e:{default:e}}function r(e,t){if(!(e instanceof t))throw new TypeError(\"Cannot call a class as a function\")}function i(e,t){if(\"function\"!=typeof t&&null!==t)throw new TypeError(\"Super expression must either be null or a function, not \"+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}t.__esModule=!0;var a=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var o in n)Object.prototype.hasOwnProperty.call(n,o)&&(e[o]=n[o])}return e},l=function(){function e(e,t){for(var n=0;n<t.length;n++){var o=t[n];o.enumerable=o.enumerable||!1,o.configurable=!0,\"value\"in o&&(o.writable=!0),Object.defineProperty(e,o.key,o)}}return function(t,n,o){return n&&e(t.prototype,n),o&&e(t,o),t}}(),s=n(6),u=o(s),c=n(3),f=o(c),p=n(8),d=o(p),h=n(4),y=o(h),v=n(5),m=o(v),b=n(7),S=o(b),g=n(1),w=o(g),P=n(2),T=o(P),k=1e3/60,O=function(e){function t(n){var o=this;r(this,t),e.call(this,n),this.wasAnimating=!1,this.animationID=null,this.prevTime=0,this.accumulatedTime=0,this.unreadPropStyle=null,this.clearUnreadPropStyle=function(e){var t=!1,n=o.state,r=n.currentStyle,i=n.currentVelocity,l=n.lastIdealStyle,s=n.lastIdealVelocity;for(var u in e)if(Object.prototype.hasOwnProperty.call(e,u)){var c=e[u];\"number\"==typeof c&&(t||(t=!0,r=a({},r),i=a({},i),l=a({},l),s=a({},s)),r[u]=c,i[u]=0,l[u]=c,s[u]=0)}t&&o.setState({currentStyle:r,currentVelocity:i,lastIdealStyle:l,lastIdealVelocity:s})},this.startAnimationIfNecessary=function(){o.animationID=m.default(function(e){var t=o.props.style;if(S.default(o.state.currentStyle,t,o.state.currentVelocity))return o.wasAnimating&&o.props.onRest&&o.props.onRest(),o.animationID=null,o.wasAnimating=!1,void(o.accumulatedTime=0);o.wasAnimating=!0;var n=e||y.default(),r=n-o.prevTime;if(o.prevTime=n,o.accumulatedTime=o.accumulatedTime+r,o.accumulatedTime>10*k&&(o.accumulatedTime=0),0===o.accumulatedTime)return o.animationID=null,void o.startAnimationIfNecessary();var i=(o.accumulatedTime-Math.floor(o.accumulatedTime/k)*k)/k,a=Math.floor(o.accumulatedTime/k),l={},s={},u={},c={};for(var f in t)if(Object.prototype.hasOwnProperty.call(t,f)){var p=t[f];if(\"number\"==typeof p)u[f]=p,c[f]=0,l[f]=p,s[f]=0;else{for(var h=o.state.lastIdealStyle[f],v=o.state.lastIdealVelocity[f],m=0;m<a;m++){var b=d.default(k/1e3,h,v,p.val,p.stiffness,p.damping,p.precision);h=b[0],v=b[1]}var g=d.default(k/1e3,h,v,p.val,p.stiffness,p.damping,p.precision),w=g[0],P=g[1];u[f]=h+(w-h)*i,c[f]=v+(P-v)*i,l[f]=h,s[f]=v}}o.animationID=null,o.accumulatedTime-=a*k,o.setState({currentStyle:u,currentVelocity:c,lastIdealStyle:l,lastIdealVelocity:s}),o.unreadPropStyle=null,o.startAnimationIfNecessary()})},this.state=this.defaultState()}return i(t,e),l(t,null,[{key:\"propTypes\",value:{defaultStyle:T.default.objectOf(T.default.number),style:T.default.objectOf(T.default.oneOfType([T.default.number,T.default.object])).isRequired,children:T.default.func.isRequired,onRest:T.default.func},enumerable:!0}]),t.prototype.defaultState=function(){var e=this.props,t=e.defaultStyle,n=e.style,o=t||f.default(n),r=u.default(o);return{currentStyle:o,currentVelocity:r,lastIdealStyle:o,lastIdealVelocity:r}},t.prototype.componentDidMount=function(){this.prevTime=y.default(),this.startAnimationIfNecessary()},t.prototype.componentWillReceiveProps=function(e){null!=this.unreadPropStyle&&this.clearUnreadPropStyle(this.unreadPropStyle),this.unreadPropStyle=e.style,null==this.animationID&&(this.prevTime=y.default(),this.startAnimationIfNecessary())},t.prototype.componentWillUnmount=function(){null!=this.animationID&&(m.default.cancel(this.animationID),this.animationID=null)},t.prototype.render=function(){var e=this.props.children(this.state.currentStyle);return e&&w.default.Children.only(e)},t}(w.default.Component);t.default=O,e.exports=t.default},function(e,t,n){\"use strict\";function o(e){return e&&e.__esModule?e:{default:e}}function r(e,t){if(!(e instanceof t))throw new TypeError(\"Cannot call a class as a function\")}function i(e,t){if(\"function\"!=typeof t&&null!==t)throw new TypeError(\"Super expression must either be null or a function, not \"+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}function a(e,t,n){for(var o=0;o<e.length;o++)if(!g.default(e[o],t[o],n[o]))return!1;return!0}t.__esModule=!0;var l=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var o in n)Object.prototype.hasOwnProperty.call(n,o)&&(e[o]=n[o])}return e},s=function(){function e(e,t){for(var n=0;n<t.length;n++){var o=t[n];o.enumerable=o.enumerable||!1,o.configurable=!0,\"value\"in o&&(o.writable=!0),Object.defineProperty(e,o.key,o)}}return function(t,n,o){return n&&e(t.prototype,n),o&&e(t,o),t}}(),u=n(6),c=o(u),f=n(3),p=o(f),d=n(8),h=o(d),y=n(4),v=o(y),m=n(5),b=o(m),S=n(7),g=o(S),w=n(1),P=o(w),T=n(2),k=o(T),O=1e3/60,M=function(e){function t(n){var o=this;r(this,t),e.call(this,n),this.animationID=null,this.prevTime=0,this.accumulatedTime=0,this.unreadPropStyles=null,this.clearUnreadPropStyle=function(e){for(var t=o.state,n=t.currentStyles,r=t.currentVelocities,i=t.lastIdealStyles,a=t.lastIdealVelocities,s=!1,u=0;u<e.length;u++){var c=e[u],f=!1;for(var p in c)if(Object.prototype.hasOwnProperty.call(c,p)){var d=c[p];\"number\"==typeof d&&(f||(f=!0,s=!0,n[u]=l({},n[u]),r[u]=l({},r[u]),i[u]=l({},i[u]),a[u]=l({},a[u])),n[u][p]=d,r[u][p]=0,i[u][p]=d,a[u][p]=0)}}s&&o.setState({currentStyles:n,currentVelocities:r,lastIdealStyles:i,lastIdealVelocities:a})},this.startAnimationIfNecessary=function(){o.animationID=b.default(function(e){\nvar t=o.props.styles(o.state.lastIdealStyles);if(a(o.state.currentStyles,t,o.state.currentVelocities))return o.animationID=null,void(o.accumulatedTime=0);var n=e||v.default(),r=n-o.prevTime;if(o.prevTime=n,o.accumulatedTime=o.accumulatedTime+r,o.accumulatedTime>10*O&&(o.accumulatedTime=0),0===o.accumulatedTime)return o.animationID=null,void o.startAnimationIfNecessary();for(var i=(o.accumulatedTime-Math.floor(o.accumulatedTime/O)*O)/O,l=Math.floor(o.accumulatedTime/O),s=[],u=[],c=[],f=[],p=0;p<t.length;p++){var d=t[p],y={},m={},b={},S={};for(var g in d)if(Object.prototype.hasOwnProperty.call(d,g)){var w=d[g];if(\"number\"==typeof w)y[g]=w,m[g]=0,b[g]=w,S[g]=0;else{for(var P=o.state.lastIdealStyles[p][g],T=o.state.lastIdealVelocities[p][g],k=0;k<l;k++){var M=h.default(O/1e3,P,T,w.val,w.stiffness,w.damping,w.precision);P=M[0],T=M[1]}var x=h.default(O/1e3,P,T,w.val,w.stiffness,w.damping,w.precision),I=x[0],D=x[1];y[g]=P+(I-P)*i,m[g]=T+(D-T)*i,b[g]=P,S[g]=T}}c[p]=y,f[p]=m,s[p]=b,u[p]=S}o.animationID=null,o.accumulatedTime-=l*O,o.setState({currentStyles:c,currentVelocities:f,lastIdealStyles:s,lastIdealVelocities:u}),o.unreadPropStyles=null,o.startAnimationIfNecessary()})},this.state=this.defaultState()}return i(t,e),s(t,null,[{key:\"propTypes\",value:{defaultStyles:k.default.arrayOf(k.default.objectOf(k.default.number)),styles:k.default.func.isRequired,children:k.default.func.isRequired},enumerable:!0}]),t.prototype.defaultState=function(){var e=this.props,t=e.defaultStyles,n=e.styles,o=t||n().map(p.default),r=o.map(function(e){return c.default(e)});return{currentStyles:o,currentVelocities:r,lastIdealStyles:o,lastIdealVelocities:r}},t.prototype.componentDidMount=function(){this.prevTime=v.default(),this.startAnimationIfNecessary()},t.prototype.componentWillReceiveProps=function(e){null!=this.unreadPropStyles&&this.clearUnreadPropStyle(this.unreadPropStyles),this.unreadPropStyles=e.styles(this.state.lastIdealStyles),null==this.animationID&&(this.prevTime=v.default(),this.startAnimationIfNecessary())},t.prototype.componentWillUnmount=function(){null!=this.animationID&&(b.default.cancel(this.animationID),this.animationID=null)},t.prototype.render=function(){var e=this.props.children(this.state.currentStyles);return e&&P.default.Children.only(e)},t}(P.default.Component);t.default=M,e.exports=t.default},function(e,t,n){\"use strict\";function o(e){return e&&e.__esModule?e:{default:e}}function r(e,t){if(!(e instanceof t))throw new TypeError(\"Cannot call a class as a function\")}function i(e,t){if(\"function\"!=typeof t&&null!==t)throw new TypeError(\"Super expression must either be null or a function, not \"+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}function a(e,t,n){var o=t;return null==o?e.map(function(e,t){return{key:e.key,data:e.data,style:n[t]}}):e.map(function(e,t){for(var r=0;r<o.length;r++)if(o[r].key===e.key)return{key:o[r].key,data:o[r].data,style:n[t]};return{key:e.key,data:e.data,style:n[t]}})}function l(e,t,n,o){if(o.length!==t.length)return!1;for(var r=0;r<o.length;r++)if(o[r].key!==t[r].key)return!1;for(var r=0;r<o.length;r++)if(!k.default(e[r],t[r].style,n[r]))return!1;return!0}function s(e,t,n,o,r,i,a,l,s){for(var u=b.default(o,r,function(e,o){var r=t(o);return null==r?(n({key:o.key,data:o.data}),null):k.default(i[e],r,a[e])?(n({key:o.key,data:o.data}),null):{key:o.key,data:o.data,style:r}}),c=[],f=[],d=[],h=[],y=0;y<u.length;y++){for(var v=u[y],m=null,S=0;S<o.length;S++)if(o[S].key===v.key){m=S;break}if(null==m){var g=e(v);c[y]=g,d[y]=g;var w=p.default(v.style);f[y]=w,h[y]=w}else c[y]=i[m],d[y]=l[m],f[y]=a[m],h[y]=s[m]}return[u,c,f,d,h]}t.__esModule=!0;var u=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var o in n)Object.prototype.hasOwnProperty.call(n,o)&&(e[o]=n[o])}return e},c=function(){function e(e,t){for(var n=0;n<t.length;n++){var o=t[n];o.enumerable=o.enumerable||!1,o.configurable=!0,\"value\"in o&&(o.writable=!0),Object.defineProperty(e,o.key,o)}}return function(t,n,o){return n&&e(t.prototype,n),o&&e(t,o),t}}(),f=n(6),p=o(f),d=n(3),h=o(d),y=n(8),v=o(y),m=n(27),b=o(m),S=n(4),g=o(S),w=n(5),P=o(w),T=n(7),k=o(T),O=n(1),M=o(O),x=n(2),I=o(x),D=1e3/60,_=function(e){function t(n){var o=this;r(this,t),e.call(this,n),this.unmounting=!1,this.animationID=null,this.prevTime=0,this.accumulatedTime=0,this.unreadPropStyles=null,this.clearUnreadPropStyle=function(e){for(var t=s(o.props.willEnter,o.props.willLeave,o.props.didLeave,o.state.mergedPropsStyles,e,o.state.currentStyles,o.state.currentVelocities,o.state.lastIdealStyles,o.state.lastIdealVelocities),n=t[0],r=t[1],i=t[2],a=t[3],l=t[4],c=0;c<e.length;c++){var f=e[c].style,p=!1;for(var d in f)if(Object.prototype.hasOwnProperty.call(f,d)){var h=f[d];\"number\"==typeof h&&(p||(p=!0,r[c]=u({},r[c]),i[c]=u({},i[c]),a[c]=u({},a[c]),l[c]=u({},l[c]),n[c]={key:n[c].key,data:n[c].data,style:u({},n[c].style)}),r[c][d]=h,i[c][d]=0,a[c][d]=h,l[c][d]=0,n[c].style[d]=h)}}o.setState({currentStyles:r,currentVelocities:i,mergedPropsStyles:n,lastIdealStyles:a,lastIdealVelocities:l})},this.startAnimationIfNecessary=function(){o.unmounting||(o.animationID=P.default(function(e){if(!o.unmounting){var t=o.props.styles,n=\"function\"==typeof t?t(a(o.state.mergedPropsStyles,o.unreadPropStyles,o.state.lastIdealStyles)):t;if(l(o.state.currentStyles,n,o.state.currentVelocities,o.state.mergedPropsStyles))return o.animationID=null,void(o.accumulatedTime=0);var r=e||g.default(),i=r-o.prevTime;if(o.prevTime=r,o.accumulatedTime=o.accumulatedTime+i,o.accumulatedTime>10*D&&(o.accumulatedTime=0),0===o.accumulatedTime)return o.animationID=null,void o.startAnimationIfNecessary();for(var u=(o.accumulatedTime-Math.floor(o.accumulatedTime/D)*D)/D,c=Math.floor(o.accumulatedTime/D),f=s(o.props.willEnter,o.props.willLeave,o.props.didLeave,o.state.mergedPropsStyles,n,o.state.currentStyles,o.state.currentVelocities,o.state.lastIdealStyles,o.state.lastIdealVelocities),p=f[0],d=f[1],h=f[2],y=f[3],m=f[4],b=0;b<p.length;b++){var S=p[b].style,w={},P={},T={},k={};for(var O in S)if(Object.prototype.hasOwnProperty.call(S,O)){var M=S[O];if(\"number\"==typeof M)w[O]=M,P[O]=0,T[O]=M,k[O]=0;else{for(var x=y[b][O],I=m[b][O],_=0;_<c;_++){var j=v.default(D/1e3,x,I,M.val,M.stiffness,M.damping,M.precision);x=j[0],I=j[1]}var C=v.default(D/1e3,x,I,M.val,M.stiffness,M.damping,M.precision),z=C[0],E=C[1];w[O]=x+(z-x)*u,P[O]=I+(E-I)*u,T[O]=x,k[O]=I}}y[b]=T,m[b]=k,d[b]=w,h[b]=P}o.animationID=null,o.accumulatedTime-=c*D,o.setState({currentStyles:d,currentVelocities:h,lastIdealStyles:y,lastIdealVelocities:m,mergedPropsStyles:p}),o.unreadPropStyles=null,o.startAnimationIfNecessary()}}))},this.state=this.defaultState()}return i(t,e),c(t,null,[{key:\"propTypes\",value:{defaultStyles:I.default.arrayOf(I.default.shape({key:I.default.string.isRequired,data:I.default.any,style:I.default.objectOf(I.default.number).isRequired})),styles:I.default.oneOfType([I.default.func,I.default.arrayOf(I.default.shape({key:I.default.string.isRequired,data:I.default.any,style:I.default.objectOf(I.default.oneOfType([I.default.number,I.default.object])).isRequired}))]).isRequired,children:I.default.func.isRequired,willEnter:I.default.func,willLeave:I.default.func,didLeave:I.default.func},enumerable:!0},{key:\"defaultProps\",value:{willEnter:function(e){return h.default(e.style)},willLeave:function(){return null},didLeave:function(){}},enumerable:!0}]),t.prototype.defaultState=function(){var e=this.props,t=e.defaultStyles,n=e.styles,o=e.willEnter,r=e.willLeave,i=e.didLeave,a=\"function\"==typeof n?n(t):n,l=void 0;l=null==t?a:t.map(function(e){for(var t=0;t<a.length;t++)if(a[t].key===e.key)return a[t];return e});var u=null==t?a.map(function(e){return h.default(e.style)}):t.map(function(e){return h.default(e.style)}),c=null==t?a.map(function(e){return p.default(e.style)}):t.map(function(e){return p.default(e.style)}),f=s(o,r,i,l,a,u,c,u,c),d=f[0],y=f[1],v=f[2],m=f[3],b=f[4];return{currentStyles:y,currentVelocities:v,lastIdealStyles:m,lastIdealVelocities:b,mergedPropsStyles:d}},t.prototype.componentDidMount=function(){this.prevTime=g.default(),this.startAnimationIfNecessary()},t.prototype.componentWillReceiveProps=function(e){this.unreadPropStyles&&this.clearUnreadPropStyle(this.unreadPropStyles);var t=e.styles;\"function\"==typeof t?this.unreadPropStyles=t(a(this.state.mergedPropsStyles,this.unreadPropStyles,this.state.lastIdealStyles)):this.unreadPropStyles=t,null==this.animationID&&(this.prevTime=g.default(),this.startAnimationIfNecessary())},t.prototype.componentWillUnmount=function(){this.unmounting=!0,null!=this.animationID&&(P.default.cancel(this.animationID),this.animationID=null)},t.prototype.render=function(){var e=a(this.state.mergedPropsStyles,this.unreadPropStyles,this.state.currentStyles),t=this.props.children(e);return t&&M.default.Children.only(t)},t}(M.default.Component);t.default=_,e.exports=t.default},function(e,t){\"use strict\";function n(e,t,n){for(var o={},r=0;r<e.length;r++)o[e[r].key]=r;for(var i={},r=0;r<t.length;r++)i[t[r].key]=r;for(var a=[],r=0;r<t.length;r++)a[r]=t[r];for(var r=0;r<e.length;r++)if(!Object.prototype.hasOwnProperty.call(i,e[r].key)){var l=n(r,e[r]);null!=l&&a.push(l)}return a.sort(function(e,n){var r=i[e.key],a=i[n.key],l=o[e.key],s=o[n.key];if(null!=r&&null!=a)return i[e.key]-i[n.key];if(null!=l&&null!=s)return o[e.key]-o[n.key];if(null!=r){for(var u=0;u<t.length;u++){var c=t[u].key;if(Object.prototype.hasOwnProperty.call(o,c)){if(r<i[c]&&s>o[c])return-1;if(r>i[c]&&s<o[c])return 1}}return 1}for(var u=0;u<t.length;u++){var c=t[u].key;if(Object.prototype.hasOwnProperty.call(o,c)){if(a<i[c]&&l>o[c])return 1;if(a>i[c]&&l<o[c])return-1}}return-1})}t.__esModule=!0,t.default=n,e.exports=t.default},function(e,t,n){\"use strict\";function o(){}t.__esModule=!0,t.default=o;e.exports=t.default},function(e,t,n){\"use strict\";function o(e){return e&&e.__esModule?e:{default:e}}function r(e,t){return i({},s,t,{val:e})}t.__esModule=!0;var i=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var o in n)Object.prototype.hasOwnProperty.call(n,o)&&(e[o]=n[o])}return e};t.default=r;var a=n(11),l=o(a),s=i({},l.default.noWobble,{precision:.01});e.exports=t.default},function(e,t,n){function o(e,t){for(var n=0;n<e.length;n++){var o=e[n],r=d[o.id];if(r){r.refs++;for(var i=0;i<r.parts.length;i++)r.parts[i](o.parts[i]);for(;i<o.parts.length;i++)r.parts.push(u(o.parts[i],t))}else{for(var a=[],i=0;i<o.parts.length;i++)a.push(u(o.parts[i],t));d[o.id]={id:o.id,refs:1,parts:a}}}}function r(e){for(var t=[],n={},o=0;o<e.length;o++){var r=e[o],i=r[0],a=r[1],l=r[2],s=r[3],u={css:a,media:l,sourceMap:s};n[i]?n[i].parts.push(u):t.push(n[i]={id:i,parts:[u]})}return t}function i(e,t){var n=v(),o=S[S.length-1];if(\"top\"===e.insertAt)o?o.nextSibling?n.insertBefore(t,o.nextSibling):n.appendChild(t):n.insertBefore(t,n.firstChild),S.push(t);else{if(\"bottom\"!==e.insertAt)throw new Error(\"Invalid value for parameter 'insertAt'. Must be 'top' or 'bottom'.\");n.appendChild(t)}}function a(e){e.parentNode.removeChild(e);var t=S.indexOf(e);t>=0&&S.splice(t,1)}function l(e){var t=document.createElement(\"style\");return t.type=\"text/css\",i(e,t),t}function s(e){var t=document.createElement(\"link\");return t.rel=\"stylesheet\",i(e,t),t}function u(e,t){var n,o,r;if(t.singleton){var i=b++;n=m||(m=l(t)),o=c.bind(null,n,i,!1),r=c.bind(null,n,i,!0)}else e.sourceMap&&\"function\"==typeof URL&&\"function\"==typeof URL.createObjectURL&&\"function\"==typeof URL.revokeObjectURL&&\"function\"==typeof Blob&&\"function\"==typeof btoa?(n=s(t),o=p.bind(null,n),r=function(){a(n),n.href&&URL.revokeObjectURL(n.href)}):(n=l(t),o=f.bind(null,n),r=function(){a(n)});return o(e),function(t){if(t){if(t.css===e.css&&t.media===e.media&&t.sourceMap===e.sourceMap)return;o(e=t)}else r()}}function c(e,t,n,o){var r=n?\"\":o.css;if(e.styleSheet)e.styleSheet.cssText=g(t,r);else{var i=document.createTextNode(r),a=e.childNodes;a[t]&&e.removeChild(a[t]),a.length?e.insertBefore(i,a[t]):e.appendChild(i)}}function f(e,t){var n=t.css,o=t.media;if(o&&e.setAttribute(\"media\",o),e.styleSheet)e.styleSheet.cssText=n;else{for(;e.firstChild;)e.removeChild(e.firstChild);e.appendChild(document.createTextNode(n))}}function p(e,t){var n=t.css,o=t.sourceMap;o&&(n+=\"\\n/*# sourceMappingURL=data:application/json;base64,\"+btoa(unescape(encodeURIComponent(JSON.stringify(o))))+\" */\");var r=new Blob([n],{type:\"text/css\"}),i=e.href;e.href=URL.createObjectURL(r),i&&URL.revokeObjectURL(i)}var d={},h=function(e){var t;return function(){return\"undefined\"==typeof t&&(t=e.apply(this,arguments)),t}},y=h(function(){return/msie [6-9]\\b/.test(window.navigator.userAgent.toLowerCase())}),v=h(function(){return document.head||document.getElementsByTagName(\"head\")[0]}),m=null,b=0,S=[];e.exports=function(e,t){t=t||{},\"undefined\"==typeof t.singleton&&(t.singleton=y()),\"undefined\"==typeof t.insertAt&&(t.insertAt=\"bottom\");var n=r(e);return o(n,t),function(e){for(var i=[],a=0;a<n.length;a++){var l=n[a],s=d[l.id];s.refs--,i.push(s)}if(e){var u=r(e);o(u,t)}for(var a=0;a<i.length;a++){var s=i[a];if(0===s.refs){for(var c=0;c<s.parts.length;c++)s.parts[c]();delete d[s.id]}}}};var g=function(){var e=[];return function(t,n){return e[t]=n,e.filter(Boolean).join(\"\\n\")}}()},function(e,t,n){var o=n(16);\"string\"==typeof o&&(o=[[e.id,o,\"\"]]);n(30)(o,{});o.locals&&(e.exports=o.locals)}])});","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nvar _Store = require('./Store');\n\nvar _Store2 = _interopRequireDefault(_Store);\n\nvar _GridBuilder = require('./GridBuilder');\n\nvar _GridBuilder2 = _interopRequireDefault(_GridBuilder);\n\n/**\n * Automatic layout for presenting draggable cards to users. Used for user and admin dashboard.\n */\nvar React = require('react');\nvar Pydio = require('pydio');\n\nvar _require = require('react-grid-layout');\n\nvar Responsive = _require.Responsive;\nvar WidthProvider = _require.WidthProvider;\n\nvar _Pydio$requireLib = Pydio.requireLib('boot');\n\nvar PydioContextConsumer = _Pydio$requireLib.PydioContextConsumer;\nvar CardsGrid = React.createClass({\n    displayName: 'CardsGrid',\n\n    /**\n     * Save layouts in the users preference.\n     *\n     * @param {object} allLayouts Responsive layouts passed for saving\n     */\n    saveFullLayouts: function saveFullLayouts(allLayouts) {\n        var savedPref = this.props.store.getUserPreference('Layout');\n        // Compare JSON versions to avoid saving unnecessary changes\n        if (savedPref && this.previousLayout && this.previousLayout == JSON.stringify(allLayouts)) {\n            return;\n        }\n        this.previousLayout = JSON.stringify(allLayouts);\n        this.props.store.saveUserPreference('Layout', allLayouts);\n    },\n\n    onLayoutChange: function onLayoutChange(currentLayout, allLayouts) {\n        if (this._blockLayoutSave) return;\n        this.saveFullLayouts(allLayouts);\n    },\n\n    componentWillUnmount: function componentWillUnmount() {\n        this.props.store.stopObserving(\"cards\", this._storeObserver);\n    },\n\n    componentWillReceiveProps: function componentWillReceiveProps(nextProps) {\n        if (this.props && nextProps.editMode !== this.props.editMode) {\n            Object.keys(this.refs).forEach((function (k) {\n                this.refs[k].toggleEditMode(nextProps.editMode);\n            }).bind(this));\n        }\n    },\n\n    shouldComponentUpdate: function shouldComponentUpdate(nextProps, nextState) {\n        return this._forceUpdate || false;\n    },\n\n    getInitialState: function getInitialState() {\n        this._storeObserver = (function (e) {\n            var _this = this;\n\n            this._forceUpdate = true;\n            this.setState({\n                cards: this.props.store.getCards()\n            }, function () {\n                _this._forceUpdate = false;\n            });\n        }).bind(this);\n        this.props.store.observe(\"cards\", this._storeObserver);\n        return { cards: this.props.store.getCards() };\n    },\n\n    removeCard: function removeCard(itemKey) {\n        this.props.removeCard(itemKey);\n    },\n\n    buildCards: function buildCards(cards) {\n\n        var index = 0;\n        var layouts = { lg: [], md: [], sm: [], xs: [], xxs: [] };\n        var items = [];\n        var additionalNamespaces = [];\n        var rand = Math.random();\n        var savedLayouts = this.props.store.getUserPreference('Layout');\n        var buildLayout = function buildLayout(classObject, itemKey, item, x, y) {\n            var layout = classObject.getGridLayout(x, y);\n            layout['handle'] = 'h4';\n            if (item['gridHandle']) {\n                layout['handle'] = item['gridHandle'];\n            }\n            layout['i'] = itemKey;\n            return layout;\n        };\n        cards.map((function (item) {\n\n            var parts = item.componentClass.split(\".\");\n            var classNS = parts[0];\n            var className = parts[1];\n            var classObject;\n            if (global[classNS] && global[classNS][className]) {\n                classObject = global[classNS][className];\n            } else {\n                if (!global[classNS]) {\n                    additionalNamespaces.push(classNS);\n                }\n                return;\n            }\n            var props = _extends({}, item.props);\n            var itemKey = props['key'] = item['id'] || 'item_' + index;\n            props.ref = itemKey;\n            props.pydio = this.props.pydio;\n            props.onCloseAction = (function () {\n                this.removeCard(itemKey);\n            }).bind(this);\n            props.preferencesProvider = this.props.store;\n            var defaultX = 0,\n                defaultY = 0;\n            if (item.defaultPosition) {\n                defaultX = item.defaultPosition.x;\n                defaultY = item.defaultPosition.y;\n            }\n            var defaultLayout = buildLayout(classObject, itemKey, item, defaultX, defaultY);\n\n            for (var breakpoint in layouts) {\n                if (!layouts.hasOwnProperty(breakpoint)) continue;\n                var breakLayout = layouts[breakpoint];\n                // Find corresponding element in preference\n                var existing;\n                if (savedLayouts && savedLayouts[breakpoint]) {\n                    savedLayouts[breakpoint].map(function (gridData) {\n                        if (gridData['i'] == itemKey && gridData['h'] == defaultLayout['h']) {\n                            existing = gridData;\n                        }\n                    });\n                }\n                if (existing) {\n                    breakLayout.push(existing);\n                } else if (item.defaultLayouts && item.defaultLayouts[breakpoint]) {\n                    var crtLayout = buildLayout(classObject, itemKey, item, item.defaultLayouts[breakpoint].x, item.defaultLayouts[breakpoint].y);\n                    breakLayout.push(crtLayout);\n                } else {\n                    breakLayout.push(defaultLayout);\n                }\n            }\n            index++;\n            items.push(React.createElement(classObject, props));\n        }).bind(this));\n\n        if (additionalNamespaces.length) {\n            this._blockLayoutSave = true;\n            ResourcesManager.loadClassesAndApply(additionalNamespaces, (function () {\n                this.setState({ additionalNamespacesLoaded: additionalNamespaces }, (function () {\n                    this._blockLayoutSave = false;\n                }).bind(this));\n            }).bind(this));\n        }\n        return { cards: items, layouts: layouts };\n    },\n\n    render: function render() {\n        var _buildCards = this.buildCards(this.state.cards);\n\n        var cards = _buildCards.cards;\n        var layouts = _buildCards.layouts;\n\n        var ResponsiveGridLayout = WidthProvider(Responsive);\n        return React.createElement(\n            ResponsiveGridLayout,\n            {\n                className: 'dashboard-layout',\n                cols: this.props.cols || { lg: 10, md: 8, sm: 8, xs: 4, xxs: 2 },\n                layouts: layouts,\n                rowHeight: 5,\n                onLayoutChange: this.onLayoutChange,\n                isDraggable: !this.props.disableDrag,\n                style: this.props.style,\n                autoSize: false\n            },\n            cards\n        );\n    }\n\n});\n\nvar DynamicGrid = React.createClass({\n    displayName: 'DynamicGrid',\n\n    propTypes: {\n        storeNamespace: React.PropTypes.string.isRequired,\n        builderNamespaces: React.PropTypes.array,\n        defaultCards: React.PropTypes.array,\n        pydio: React.PropTypes.instanceOf(Pydio),\n        disableDrag: React.PropTypes.bool\n    },\n\n    removeCard: function removeCard(cardId) {\n\n        this.state.store.removeCard(cardId);\n    },\n\n    addCard: function addCard(cardDefinition) {\n\n        this.state.store.addCard(cardDefinition);\n    },\n\n    resetCardsAndLayout: function resetCardsAndLayout() {\n        this.state.store.saveUserPreference('Layout', null);\n        this.state.store.setCards(this.props.defaultCards);\n    },\n\n    getInitialState: function getInitialState() {\n        var store = new _Store2['default'](this.props.storeNamespace, this.props.defaultCards, this.props.pydio);\n        return {\n            editMode: false,\n            store: store\n        };\n    },\n\n    toggleEditMode: function toggleEditMode() {\n        this.setState({ editMode: !this.state.editMode });\n    },\n\n    render: function render() {\n        var _this2 = this;\n\n        var monitorWidgetEditing = (function (status) {\n            this.setState({ widgetEditing: status });\n        }).bind(this);\n\n        var builder = undefined;\n        if (this.props.builderNamespaces && this.state.editMode) {\n            builder = React.createElement(_GridBuilder2['default'], {\n                className: 'admin-helper-panel',\n                namespaces: this.props.builderNamespaces,\n                onCreateCard: this.addCard,\n                onResetLayout: this.resetCardsAndLayout,\n                onEditStatusChange: monitorWidgetEditing,\n                getMessage: function (id) {\n                    var ns = arguments.length <= 1 || arguments[1] === undefined ? 'ajxp_admin' : arguments[1];\n                    return _this2.props.getMessage(id, ns);\n                }\n            });\n        }\n        var propStyle = this.props.style || {};\n        var rglStyle = this.props.rglStyle || {};\n        return React.createElement(\n            'div',\n            { style: _extends({}, this.props.style, { width: '100%', flex: '1' }), className: this.state.editMode ? \"builder-open\" : \"\" },\n            React.createElement(\n                'div',\n                { style: { position: 'absolute', bottom: 30, right: 18, zIndex: 11 } },\n                React.createElement(MaterialUI.FloatingActionButton, {\n                    tooltip: this.props.getMessage('home.49'),\n                    onClick: this.toggleEditMode,\n                    iconClassName: this.state.editMode ? \"icon-ok\" : \"mdi mdi-pencil\",\n                    mini: this.state.editMode,\n                    disabled: this.state.editMode && this.state.widgetEditing\n                })\n            ),\n            builder,\n            React.createElement(\n                'div',\n                { className: 'home-dashboard', style: { height: '100%' } },\n                React.createElement(CardsGrid, {\n                    disableDrag: this.props.disableDrag,\n                    cols: this.props.cols,\n                    store: this.state.store,\n                    style: rglStyle,\n                    pydio: this.props.pydio,\n                    editMode: this.state.editMode,\n                    removeCard: this.removeCard\n                })\n            )\n        );\n    }\n\n});\n\nexports['default'] = DynamicGrid = PydioContextConsumer(DynamicGrid);\nexports['default'] = DynamicGrid;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nvar React = require('react');\nvar Pydio = require('pydio');\n\nvar _Pydio$requireLib = Pydio.requireLib('boot');\n\nvar PydioContextConsumer = _Pydio$requireLib.PydioContextConsumer;\nvar AsyncComponent = _Pydio$requireLib.AsyncComponent;\n\nvar GridBuilder = React.createClass({\n    displayName: 'GridBuilder',\n\n    propTypes: {\n        namespaces: React.PropTypes.array,\n        onCreateCard: React.PropTypes.func,\n        onEditStatusChange: React.PropTypes.func\n    },\n\n    getInitialState: function getInitialState() {\n        return {\n            selectedIndex: 0,\n            availableWidgets: this.listAvailableWidgets()\n        };\n    },\n\n    listAvailableWidgets: function listAvailableWidgets() {\n        var secondPass = arguments.length <= 0 || arguments[0] === undefined ? false : arguments[0];\n\n        var widgets = [];\n        var additionalNamespaces = [];\n        this.props.namespaces.map(function (ns) {\n            if (!global[ns]) {\n                additionalNamespaces.push(ns);\n                return;\n            }\n            for (var k in global[ns]) {\n                if (global[ns].hasOwnProperty(k)) {\n                    var widgetClass = global[ns][k];\n                    if (widgetClass.hasBuilderFields && widgetClass.hasBuilderFields()) {\n                        widgets.push({ reactClass: widgetClass, fullName: ns + '.' + widgetClass.displayName });\n                    }\n                }\n            }\n        });\n        if (additionalNamespaces.length && !secondPass) {\n            ResourcesManager.loadClassesAndApply(additionalNamespaces, (function () {\n                this.setState({\n                    availableWidgets: this.listAvailableWidgets(true)\n                });\n            }).bind(this));\n        }\n        return widgets;\n    },\n\n    onDropDownChange: function onDropDownChange(event, index, item) {\n        var defaultValues = {};\n        if (index != 0) {\n            item.payload['reactClass'].getBuilderFields().map(function (f) {\n                if (f['default']) defaultValues[f.name] = f['default'];\n            });\n        }\n        if (this.props.onEditStatusChange) {\n            this.props.onEditStatusChange(index != 0);\n        }\n        this.setState({\n            selectedIndex: index,\n            selectedWidget: item.payload,\n            currentFormValues: defaultValues\n        });\n    },\n\n    cancel: function cancel() {\n        if (this.props.onEditStatusChange) {\n            this.props.onEditStatusChange(false);\n        }\n        this.setState({ selectedIndex: 0 });\n    },\n\n    onFormValueChange: function onFormValueChange(newValues) {\n        this.setState({ currentFormValues: newValues });\n    },\n\n    onFormSubmit: function onFormSubmit() {\n        var values = this.state.currentFormValues;\n        var selectedWidget = this.state.selectedWidget;\n        var title = values.title ? values.title : values.legend;\n        if (!title) title = this.state.selectedWidget['reactClass'].builderDisplayName;\n        this.props.onCreateCard({\n            componentClass: selectedWidget.fullName,\n            title: title,\n            props: values\n        });\n        this.cancel();\n    },\n\n    resetLayout: function resetLayout() {\n        if (window.confirm(this.props.getMessage('home.51'))) {\n            this.props.onResetLayout();\n        }\n    },\n\n    render: function render() {\n        var getMessage = this.props.getMessage;\n\n        var selectorItems = [{ payload: 0, text: getMessage('home.50') }].concat(this.state.availableWidgets.map(function (w, index) {\n            return { payload: w, text: w['reactClass'].builderDisplayName };\n        }));\n\n        var selector = React.createElement(ReactMUI.DropDownMenu, {\n            menuItems: selectorItems,\n            onChange: this.onDropDownChange,\n            selectedIndex: this.state.selectedIndex,\n            autoWidth: false,\n            className: 'widget-type-selector'\n        });\n\n        var form, add;\n        if (this.state.selectedIndex != 0) {\n            var fields = this.state.selectedWidget['reactClass'].getBuilderFields();\n            var defaultValues = {};\n            fields.map(function (f) {\n                if (f['default']) defaultValues[f.name] = f['default'];\n            });\n            if (this.state.currentFormValues) {\n                defaultValues = LangUtils.mergeObjectsRecursive(defaultValues, this.state.currentFormValues);\n            }\n            form = React.createElement(AsyncComponent, {\n                namespace: 'PydioForm',\n                componentName: 'FormPanel',\n                parameters: fields,\n                depth: -1,\n                values: defaultValues,\n                onChange: this.onFormValueChange\n            });\n            add = React.createElement(\n                'div',\n                { style: { textAlign: 'center', paddingBottom: 100 } },\n                React.createElement(ReactMUI.RaisedButton, { label: getMessage('home.52'), onClick: this.onFormSubmit }),\n                ' ',\n                React.createElement(ReactMUI.RaisedButton, { label: getMessage('54', ''), onClick: this.cancel })\n            );\n        }\n\n        return React.createElement(\n            ReactMUI.Paper,\n            _extends({}, this.props, {\n                zDepth: 3 }),\n            React.createElement(\n                'h3',\n                null,\n                getMessage('home.53')\n            ),\n            React.createElement(\n                'div',\n                { className: 'legend' },\n                getMessage('home.54'),\n                React.createElement('br', null),\n                getMessage('home.55')\n            ),\n            selector,\n            form,\n            add,\n            React.createElement(\n                'div',\n                { style: { position: 'absolute', bottom: 30, left: 10 } },\n                React.createElement(ReactMUI.FlatButton, { disabled: this.state.selectedIndex != 0, label: getMessage('home.56'), secondary: true, onClick: this.resetLayout })\n            )\n        );\n    }\n\n});\n\nexports['default'] = GridBuilder = PydioContextConsumer(GridBuilder);\nexports['default'] = GridBuilder;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nexports['default'] = {\n\n    propTypes: {\n        showCloseAction: React.PropTypes.bool,\n        onCloseAction: React.PropTypes.func\n    },\n\n    focusItem: function focusItem() {\n        this.setState({ focus: true });\n    },\n\n    blurItem: function blurItem() {\n        this.setState({ focus: false });\n    },\n\n    mergeStyleWithFocus: function mergeStyleWithFocus() {\n        return _extends({}, this.props.style, { zIndex: this.state.focus ? 1 : null });\n    },\n\n    getInitialSate: function getInitialSate() {\n        return { focus: false, showCloseAction: false };\n    },\n\n    toggleEditMode: function toggleEditMode() {\n        var value = arguments.length <= 0 || arguments[0] === undefined ? undefined : arguments[0];\n\n        if (value === undefined) {\n            this.setState({ showCloseAction: !(this.state && this.state.showCloseAction) });\n        } else {\n            this.setState({ showCloseAction: value });\n        }\n    },\n\n    getCloseButton: function getCloseButton() {\n        if (this.state && this.state.showCloseAction) {\n            var closeAction = this.props.onCloseAction || function () {};\n            var overlayStyle = {\n                position: 'absolute',\n                backgroundColor: 'rgba(0,0,0,0.53)',\n                zIndex: 10,\n                top: 0,\n                left: 0,\n                bottom: 0,\n                right: 0,\n                display: 'flex',\n                alignItems: 'center',\n                justifyContent: 'center'\n            };\n            return React.createElement(\n                'div',\n                { style: overlayStyle },\n                React.createElement(MaterialUI.FlatButton, {\n                    label: pydio.MessageHash['ajxp_admin.home.48'],\n                    className: 'card-close-button',\n                    onTouchTap: closeAction,\n                    style: { color: 'white' }\n                })\n            );\n        } else {\n            return null;\n        }\n    },\n\n    statics: {\n        getGridLayout: function getGridLayout(x, y) {\n            return {\n                x: x || 0,\n                y: y || 0,\n                w: this.gridWidth || 4,\n                h: this.gridHeight || 12,\n                isResizable: false\n            };\n        },\n        hasBuilderFields: function hasBuilderFields() {\n            return this.builderFields ? true : false;\n        },\n        getBuilderFields: function getBuilderFields() {\n            return this.builderFields;\n        }\n    }\n\n};\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Store = (function (_Observable) {\n    _inherits(Store, _Observable);\n\n    /**\n     * Init a card store\n     * @param prefNamespace Namespace for getting/setting user preferences\n     * @param defaultCards Array of cards to be displayed by default\n     */\n\n    function Store(prefNamespace, defaultCards, pydioObject) {\n        _classCallCheck(this, Store);\n\n        _Observable.call(this);\n        this._namespace = prefNamespace;\n        this._pydio = pydioObject;\n        this._cards = this.getUserPreference(\"Cards\");\n        if (!this._cards) {\n            this._cards = defaultCards;\n        }\n    }\n\n    Store.prototype.getUserPreference = function getUserPreference(prefName) {\n        var prefKey = this._namespace + prefName;\n        var guiPrefs = this._pydio.user.getPreference('gui_preferences', true);\n        if (guiPrefs && guiPrefs[prefKey]) {\n            return guiPrefs[prefKey];\n        } else {\n            return null;\n        }\n    };\n\n    Store.prototype.saveUserPreference = function saveUserPreference(prefName, prefValue) {\n        var prefKey = this._namespace + prefName;\n        var guiPrefs = this._pydio.user.getPreference('gui_preferences', true);\n        if (!guiPrefs) guiPrefs = {};\n        guiPrefs[prefKey] = prefValue;\n        this._pydio.user.setPreference('gui_preferences', guiPrefs, true);\n        this._pydio.user.savePreference('gui_preferences');\n    };\n\n    Store.prototype.saveCards = function saveCards(cards) {\n        this.saveUserPreference('Cards', cards);\n    };\n\n    Store.prototype.resetCards = function resetCards() {\n        this.saveUserPreference('Cards', null);\n    };\n\n    Store.prototype.setCards = function setCards(newCards) {\n        this._cards = newCards;\n        this.notify(\"cards\", this._cards);\n        this.saveCards(newCards);\n    };\n\n    Store.prototype.getCards = function getCards() {\n        return this._cards;\n    };\n\n    Store.prototype.removeCard = function removeCard(cardId) {\n        var index = -1;\n        var currentCards = this.getCards();\n        currentCards.map(function (card, arrayIndex) {\n            if (card.id == cardId) index = arrayIndex;\n        });\n        if (index == -1) {\n            console.warn('Card ID not found, this is strange.', cardId);\n            return;\n        }\n        var newCards;\n        if (index == 0) newCards = currentCards.slice(1);else if (index == currentCards.length - 1) newCards = currentCards.slice(0, -1);else newCards = currentCards.slice(0, index).concat(currentCards.slice(index + 1));\n        this.setCards(newCards);\n    };\n\n    Store.prototype.createCardId = function createCardId(cardDefinition) {\n        var randomize = arguments.length <= 1 || arguments[1] === undefined ? false : arguments[1];\n\n        var id = LangUtils.computeStringSlug(cardDefinition['title']);\n        if (randomize) {\n            id += '-' + Math.round(Math.random() * 100 + 10);\n        }\n        var alreadyExists = false;\n        this._cards.map((function (card) {\n            if (card.id == id) alreadyExists = true;\n        }).bind(this));\n        if (alreadyExists) {\n            id = this.createCardId(cardDefinition, true);\n        }\n        return id;\n    };\n\n    Store.prototype.addCard = function addCard(cardDefinition) {\n        //console.log(cardDefinition);\n\n        cardDefinition['id'] = this.createCardId(cardDefinition);\n        this.setCards(this._cards.concat([cardDefinition]));\n    };\n\n    return Store;\n})(Observable);\n\nexports['default'] = Store;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _require = require('react');\n\nvar Component = _require.Component;\nvar PropTypes = _require.PropTypes;\n\nvar _require2 = require('material-ui');\n\nvar FlatButton = _require2.FlatButton;\n\nvar _require3 = require('material-ui/styles');\n\nvar muiThemeable = _require3.muiThemeable;\n\nexports['default'] = function (PydioComponent, displayName) {\n    var gridDimension = arguments.length <= 2 || arguments[2] === undefined ? { gridWidth: 4, gridHeight: 12 } : arguments[2];\n    var builderFields = arguments.length <= 3 || arguments[3] === undefined ? undefined : arguments[3];\n\n    var originalDisplayName = PydioComponent.displayName || PydioComponent.name;\n    PydioComponent = muiThemeable()(PydioComponent);\n\n    var GridItem = (function (_Component) {\n        _inherits(GridItem, _Component);\n\n        function GridItem(props, context) {\n            _classCallCheck(this, GridItem);\n\n            _Component.call(this, props, context);\n            this.state = { focus: false, showCloseAction: false };\n        }\n\n        GridItem.prototype.focusItem = function focusItem() {\n            this.setState({ focus: true });\n        };\n\n        GridItem.prototype.blurItem = function blurItem() {\n            this.setState({ focus: false });\n        };\n\n        GridItem.prototype.mergeStyleWithFocus = function mergeStyleWithFocus() {\n            return _extends({}, this.props.style, { zIndex: this.state.focus ? 1 : null });\n        };\n\n        GridItem.prototype.toggleEditMode = function toggleEditMode() {\n            var value = arguments.length <= 0 || arguments[0] === undefined ? undefined : arguments[0];\n\n            if (value === undefined) {\n                this.setState({ showCloseAction: !(this.state && this.state.showCloseAction) });\n            } else {\n                this.setState({ showCloseAction: value });\n            }\n        };\n\n        GridItem.prototype.getCloseButton = function getCloseButton() {\n            var closeAction = this.props.onCloseAction || function () {};\n            var overlayStyle = {\n                position: 'absolute',\n                backgroundColor: 'rgba(0,0,0,0.53)',\n                zIndex: 10,\n                top: 0,\n                left: 0,\n                bottom: 0,\n                right: 0,\n                display: 'flex',\n                alignItems: 'center',\n                justifyContent: 'center'\n            };\n            return React.createElement(\n                'div',\n                { style: overlayStyle },\n                React.createElement(FlatButton, {\n                    label: this.props.pydio.MessageHash['ajxp_admin.home.48'],\n                    className: 'card-close-button',\n                    onTouchTap: closeAction,\n                    style: { color: 'white' }\n                })\n            );\n        };\n\n        GridItem.prototype.render = function render() {\n            var props = _extends({}, this.props, {\n                style: this.mergeStyleWithFocus(),\n                closeButton: this.state.showCloseAction ? this.getCloseButton() : null,\n                onFocusItem: this.focusItem.bind(this),\n                onBlurItem: this.blurItem.bind(this)\n            });\n            return React.createElement(PydioComponent, props);\n        };\n\n        return GridItem;\n    })(Component);\n\n    GridItem.propTypes = {\n        onCloseAction: PropTypes.func\n    };\n\n    GridItem.displayName = originalDisplayName;\n    GridItem.builderDisplayName = displayName;\n\n    GridItem.getGridLayout = function (x, y) {\n        return {\n            x: x || 0,\n            y: y || 0,\n            w: gridDimension.gridWidth || 4,\n            h: gridDimension.gridHeight || 12,\n            isResizable: false\n        };\n    };\n\n    GridItem.hasBuilderFields = function () {\n        return builderFields !== undefined;\n    };\n    GridItem.getBuilderFields = function () {\n        return builderFields;\n    };\n\n    return GridItem;\n};\n\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n/**\n * Two columns layout used for Workspaces and Plugins editors\n */\n'use strict';\n\nexports.__esModule = true;\nvar PaperEditorLayout = React.createClass({\n    displayName: 'PaperEditorLayout',\n\n    propTypes: {\n        title: React.PropTypes.any,\n        titleActionBar: React.PropTypes.any,\n        leftNav: React.PropTypes.any,\n        contentFill: React.PropTypes.bool,\n        className: React.PropTypes.string\n    },\n\n    toggleMenu: function toggleMenu() {\n        var crtLeftOpen = this.state && this.state.forceLeftOpen;\n        this.setState({ forceLeftOpen: !crtLeftOpen });\n    },\n\n    render: function render() {\n        return React.createElement(\n            'div',\n            { className: \"paper-editor-content layout-fill vertical-layout\" + (this.props.className ? ' ' + this.props.className : '') },\n            React.createElement(\n                'div',\n                { className: 'paper-editor-title' },\n                React.createElement(\n                    'h2',\n                    null,\n                    this.props.title,\n                    ' ',\n                    React.createElement(\n                        'div',\n                        { className: 'left-picker-toggle' },\n                        React.createElement(ReactMUI.IconButton, { iconClassName: 'icon-caret-down', onClick: this.toggleMenu })\n                    )\n                ),\n                React.createElement(\n                    'div',\n                    { className: 'title-bar' },\n                    this.props.titleActionBar\n                )\n            ),\n            React.createElement(\n                'div',\n                { className: 'layout-fill main-layout-nav-to-stack' },\n                React.createElement(\n                    'div',\n                    { className: \"paper-editor-left\" + (this.state && this.state.forceLeftOpen ? ' picker-open' : ''), onClick: this.toggleMenu },\n                    this.props.leftNav\n                ),\n                React.createElement(\n                    'div',\n                    { className: \"layout-fill paper-editor-right\" + (this.props.contentFill ? ' vertical-layout' : ''), style: this.props.contentFill ? {} : { overflowY: 'auto' } },\n                    this.props.children\n                )\n            )\n        );\n    }\n});\n/**\n * Navigation subheader used by PaperEditorLayout\n */\nvar PaperEditorNavHeader = React.createClass({\n    displayName: 'PaperEditorNavHeader',\n\n    propTypes: {\n        label: React.PropTypes.string\n    },\n\n    render: function render() {\n\n        return React.createElement(\n            'div',\n            { className: 'mui-subheader' },\n            this.props.children,\n            this.props.label\n        );\n    }\n\n});\n/**\n * Navigation entry used by PaperEditorLayout.\n */\nvar PaperEditorNavEntry = React.createClass({\n    displayName: 'PaperEditorNavEntry',\n\n    propTypes: {\n        keyName: React.PropTypes.string.isRequired,\n        onClick: React.PropTypes.func.isRequired,\n        label: React.PropTypes.string,\n        selectedKey: React.PropTypes.string,\n        isLast: React.PropTypes.bool,\n        // Drop Down Data\n        dropDown: React.PropTypes.bool,\n        dropDownData: React.PropTypes.object,\n        dropDownChange: React.PropTypes.func,\n        dropDownDefaultItems: React.PropTypes.array\n    },\n\n    onClick: function onClick() {\n        this.props.onClick(this.props.keyName);\n    },\n\n    captureDropDownClick: function captureDropDownClick() {\n        if (this.preventClick) {\n            this.preventClick = false;\n            return;\n        }\n        this.props.onClick(this.props.keyName);\n    },\n\n    dropDownChange: function dropDownChange(event, index, item) {\n        this.preventClick = true;\n        this.props.dropDownChange(item);\n    },\n\n    render: function render() {\n\n        if (!this.props.dropDown || !this.props.dropDownData) {\n            return React.createElement(\n                'div',\n                {\n                    className: 'menu-entry' + (this.props.keyName == this.props.selectedKey ? ' menu-entry-selected' : '') + (this.props.isLast ? ' last' : ''),\n                    onClick: this.onClick },\n                this.props.children,\n                this.props.label\n            );\n        }\n\n        // dropDown & dropDownData are loaded\n        var menuItemsTpl = [{ text: this.props.label, payload: '-1' }];\n        if (this.props.dropDownDefaultItems) {\n            menuItemsTpl = menuItemsTpl.concat(this.props.dropDownDefaultItems);\n        }\n        this.props.dropDownData.forEach(function (v, k) {\n            menuItemsTpl.push({ text: v.label, payload: v });\n        });\n        return React.createElement(\n            'div',\n            { onClick: this.captureDropDownClick, className: 'menu-entry-dropdown' + (this.props.keyName == this.props.selectedKey ? ' menu-entry-selected' : '') + (this.props.isLast ? ' last' : '') },\n            React.createElement(ReactMUI.DropDownMenu, {\n                menuItems: menuItemsTpl,\n                className: 'dropdown-full-width',\n                style: { width: 256 },\n                autoWidth: false,\n                onChange: this.dropDownChange\n            })\n        );\n    }\n});\n\nexports.PaperEditorLayout = PaperEditorLayout;\nexports.PaperEditorNavEntry = PaperEditorNavEntry;\nexports.PaperEditorNavHeader = PaperEditorNavHeader;\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n\"use strict\";\n\nexports.__esModule = true;\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar propTypes = {\n    node: React.PropTypes.instanceOf(AjxpNode).isRequired,\n    registry: React.PropTypes.instanceOf(Registry).isRequired,\n    editorData: React.PropTypes.object.isRequired,\n    icon: React.PropTypes.bool\n};\n\nvar defaultProps = {\n    icon: false\n};\n\nvar ReactEditorOpener = (function (_React$Component) {\n    _inherits(ReactEditorOpener, _React$Component);\n\n    function ReactEditorOpener(props) {\n        _classCallCheck(this, ReactEditorOpener);\n\n        _React$Component.call(this, props);\n\n        var node = props.node;\n        var editorData = props.editorData;\n\n        this.state = {\n            ready: false\n        };\n    }\n\n    ReactEditorOpener.prototype.componentDidMount = function componentDidMount() {\n        var _this = this;\n\n        var _props = this.props;\n        var editorData = _props.editorData;\n        var registry = _props.registry;\n\n        registry.loadEditorResources(editorData.resourcesManager, function () {\n            return _this.setState({ ready: true });\n        });\n    };\n\n    ReactEditorOpener.prototype.render = function render() {\n        var editorData = this.props.editorData;\n        var ready = this.state.ready;\n\n        if (!ready) return null;\n\n        var EditorClass = null;\n        if (!(EditorClass = FuncUtils.getFunctionByName(editorData.editorClass, window))) {\n            return React.createElement(\n                \"div\",\n                null,\n                \"Cannot find editor component (\" + editorData.editorClass + \")!\"\n            );\n        }\n\n        // Getting HOC of the class\n        return React.createElement(EditorClass.Editor, this.props);\n    };\n\n    return ReactEditorOpener;\n})(React.Component);\n\nReactEditorOpener.propTypes = propTypes;\nReactEditorOpener.defaultProps = defaultProps;\n\nexports[\"default\"] = ReactEditorOpener;\nmodule.exports = exports[\"default\"];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nexports['default'] = React.createClass({\n    displayName: 'ClipboardTextField',\n\n    propTypes: {\n        floatingLabelText: React.PropTypes.string,\n\n        inputValue: React.PropTypes.string,\n        inputClassName: React.PropTypes.string,\n        getMessage: React.PropTypes.func,\n        inputCopyMessage: React.PropTypes.string\n    },\n\n    getInitialState: function getInitialState() {\n        return { copyMessage: null };\n    },\n\n    componentDidMount: function componentDidMount() {\n        this.attachClipboard();\n    },\n    componentDidUpdate: function componentDidUpdate() {\n        this.attachClipboard();\n    },\n\n    attachClipboard: function attachClipboard() {\n        if (this._clip) {\n            this._clip.destroy();\n        }\n        if (!this.refs['copy-button']) {\n            return;\n        }\n        this._clip = new Clipboard(this.refs['copy-button'], {\n            text: (function (trigger) {\n                return this.props.inputValue;\n            }).bind(this)\n        });\n        this._clip.on('success', (function () {\n            this.setState({ copyMessage: this.props.getMessage(this.props.inputCopyMessage || '192') }, this.clearCopyMessage);\n        }).bind(this));\n        this._clip.on('error', (function () {\n            var copyMessage;\n            if (global.navigator.platform.indexOf(\"Mac\") === 0) {\n                copyMessage = this.props.getMessage('144');\n            } else {\n                copyMessage = this.props.getMessage('143');\n            }\n            this.refs['input'].focus();\n            this.setState({ copyMessage: copyMessage }, this.clearCopyMessage);\n        }).bind(this));\n    },\n\n    clearCopyMessage: function clearCopyMessage() {\n        global.setTimeout((function () {\n            this.setState({ copyMessage: '' });\n        }).bind(this), 3000);\n    },\n\n    render: function render() {\n\n        var select = function select(e) {\n            e.currentTarget.select();\n        };\n\n        var copyMessage = null;\n        if (this.state.copyMessage) {\n            var setHtml = (function () {\n                return { __html: this.state.copyMessage };\n            }).bind(this);\n            copyMessage = React.createElement('div', { style: { color: 'rgba(0,0,0,0.23)' }, className: 'copy-message', dangerouslySetInnerHTML: setHtml() });\n        }\n\n        var buttonStyle = _extends({\n            position: 'absolute',\n            right: -8,\n            bottom: 13,\n            fontSize: 15,\n            color: this.props.buttonColor || 'rgba(0, 150, 136, 0.52)',\n            height: 26,\n            width: 26,\n            lineHeight: '28px',\n            textAlign: 'center',\n            cursor: 'pointer',\n            borderRadius: '50%'\n        }, this.props.buttonStyle);\n\n        return React.createElement(\n            'div',\n            null,\n            React.createElement(\n                'div',\n                { style: { position: 'relative' } },\n                React.createElement(MaterialUI.TextField, {\n                    fullWidth: true,\n                    ref: 'input',\n                    floatingLabelText: this.props.floatingLabelText,\n                    floatingLabelStyle: { whiteSpace: 'nowrap' },\n                    underlineShow: this.props.underlineShow,\n                    defaultValue: this.props.inputValue,\n                    className: this.props.inputClassName,\n                    multiLine: this.props.multiLine,\n                    rows: this.props.rows,\n                    rowsMax: this.props.rowsMax,\n                    readOnly: true,\n                    onClick: select,\n                    style: { marginTop: -10, width: '92%', fontSize: 14 }\n                }),\n                React.createElement('span', { ref: 'copy-button', style: buttonStyle, title: this.props.getMessage('191'), className: 'copy-button mdi mdi-content-copy' })\n            ),\n            copyMessage\n        );\n    }\n\n});\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\nexports['default'] = React.createClass({\n    displayName: 'LabelWithTip',\n\n    propTypes: {\n        label: React.PropTypes.string,\n        labelElement: React.PropTypes.object,\n        tooltip: React.PropTypes.string,\n        tooltipClassName: React.PropTypes.string,\n        className: React.PropTypes.string,\n        style: React.PropTypes.object\n    },\n\n    getInitialState: function getInitialState() {\n        return { show: false };\n    },\n\n    show: function show() {\n        this.setState({ show: true });\n    },\n    hide: function hide() {\n        this.setState({ show: false });\n    },\n\n    render: function render() {\n        if (this.props.tooltip) {\n            var tooltipStyle = {};\n            if (this.props.label || this.props.labelElement) {\n                if (this.state.show) {\n                    tooltipStyle = { bottom: -10, top: 'inherit' };\n                }\n            } else {\n                tooltipStyle = { position: 'relative' };\n            }\n            var label = undefined;\n            if (this.props.label) {\n                label = React.createElement(\n                    'span',\n                    { className: 'ellipsis-label' },\n                    this.props.label\n                );\n            } else if (this.props.labelElement) {\n                label = this.props.labelElement;\n            }\n            var style = this.props.style || { position: 'relative' };\n\n            return React.createElement(\n                'span',\n                { onMouseEnter: this.show, onMouseLeave: this.hide, style: style, className: this.props.className },\n                label,\n                this.props.children,\n                React.createElement(ReactMUI.Tooltip, { label: this.props.tooltip, style: tooltipStyle, className: this.props.tooltipClassName, show: this.state.show })\n            );\n        } else {\n            if (this.props.label) {\n                return React.createElement(\n                    'span',\n                    null,\n                    this.props.label\n                );\n            } else if (this.props.labelElement) {\n                return this.props.labelElement;\n            } else {\n                return React.createElement(\n                    'span',\n                    null,\n                    this.props.children\n                );\n            }\n        }\n    }\n\n});\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n/**\n * Simple MuiPaper with a figure and a legend\n */\n'use strict';\n\nexports.__esModule = true;\nexports['default'] = React.createClass({\n    displayName: 'SimpleFigureBadge',\n\n    propTypes: {\n        colorIndicator: React.PropTypes.string,\n        figure: React.PropTypes.number.isRequired,\n        legend: React.PropTypes.string\n    },\n\n    getDefaultProps: function getDefaultProps() {\n        return {\n            colorIndicator: ''\n        };\n    },\n\n    render: function render() {\n        return React.createElement(\n            ReactMUI.Paper,\n            { style: { display: 'inline-block', marginLeft: 16 } },\n            React.createElement(\n                'div',\n                { className: 'figure-badge', style: this.props.colorIndicator ? { borderLeftColor: this.props.colorIndicator } : {} },\n                React.createElement(\n                    'div',\n                    { className: 'figure' },\n                    this.props.figure\n                ),\n                React.createElement(\n                    'div',\n                    { className: 'legend' },\n                    this.props.legend\n                )\n            )\n        );\n    }\n});\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nvar _listSortableList = require('./list/SortableList');\n\nvar _listSortableList2 = _interopRequireDefault(_listSortableList);\n\nvar _listSimpleList = require('./list/SimpleList');\n\nvar _listSimpleList2 = _interopRequireDefault(_listSimpleList);\n\nvar _listNodeListCustomProvider = require('./list/NodeListCustomProvider');\n\nvar _listNodeListCustomProvider2 = _interopRequireDefault(_listNodeListCustomProvider);\n\nvar _listListEntry = require('./list/ListEntry');\n\nvar _listListPaginator = require('./list/ListPaginator');\n\nvar _listListPaginator2 = _interopRequireDefault(_listListPaginator);\n\nvar _viewsTreeView = require('./views/TreeView');\n\nvar _elementsLabelWithTip = require('./elements/LabelWithTip');\n\nvar _elementsLabelWithTip2 = _interopRequireDefault(_elementsLabelWithTip);\n\nvar _elementsSimpleFigureBadge = require('./elements/SimpleFigureBadge');\n\nvar _elementsSimpleFigureBadge2 = _interopRequireDefault(_elementsSimpleFigureBadge);\n\nvar _viewsSearchBox = require('./views/SearchBox');\n\nvar _viewsSearchBox2 = _interopRequireDefault(_viewsSearchBox);\n\nvar _elementsClipboardTextField = require('./elements/ClipboardTextField');\n\nvar _elementsClipboardTextField2 = _interopRequireDefault(_elementsClipboardTextField);\n\nvar _viewsEmptyStateView = require('./views/EmptyStateView');\n\nvar _viewsEmptyStateView2 = _interopRequireDefault(_viewsEmptyStateView);\n\nvar _viewsModalAppBar = require('./views/ModalAppBar');\n\nvar _viewsModalAppBar2 = _interopRequireDefault(_viewsModalAppBar);\n\nvar _editorReactEditorOpener = require('./editor/ReactEditorOpener');\n\nvar _editorReactEditorOpener2 = _interopRequireDefault(_editorReactEditorOpener);\n\nvar _editorPaperEditor = require('./editor/PaperEditor');\n\nvar _dynamicGridDynamicGrid = require('./dynamic-grid/DynamicGrid');\n\nvar _dynamicGridDynamicGrid2 = _interopRequireDefault(_dynamicGridDynamicGrid);\n\nvar _dynamicGridStore = require('./dynamic-grid/Store');\n\nvar _dynamicGridStore2 = _interopRequireDefault(_dynamicGridStore);\n\nvar _dynamicGridGridItemMixin = require('./dynamic-grid/GridItemMixin');\n\nvar _dynamicGridGridItemMixin2 = _interopRequireDefault(_dynamicGridGridItemMixin);\n\nvar _dynamicGridAsGridItem = require('./dynamic-grid/asGridItem');\n\nvar _dynamicGridAsGridItem2 = _interopRequireDefault(_dynamicGridAsGridItem);\n\nvar _utilDND = require('./util/DND');\n\nvar _usersAvatarUserAvatar = require('./users/avatar/UserAvatar');\n\nvar _usersAvatarUserAvatar2 = _interopRequireDefault(_usersAvatarUserAvatar);\n\nvar _usersUsersCompleter = require('./users/UsersCompleter');\n\nvar _usersUsersCompleter2 = _interopRequireDefault(_usersUsersCompleter);\n\nvar _usersTeamCreationForm = require('./users/TeamCreationForm');\n\nvar _usersTeamCreationForm2 = _interopRequireDefault(_usersTeamCreationForm);\n\nvar _menuButtonMenu = require('./menu/ButtonMenu');\n\nvar _menuButtonMenu2 = _interopRequireDefault(_menuButtonMenu);\n\nvar _menuContextMenu = require('./menu/ContextMenu');\n\nvar _menuContextMenu2 = _interopRequireDefault(_menuContextMenu);\n\nvar _menuIconButtonMenu = require('./menu/IconButtonMenu');\n\nvar _menuIconButtonMenu2 = _interopRequireDefault(_menuIconButtonMenu);\n\nvar _menuToolbar = require('./menu/Toolbar');\n\nvar _menuToolbar2 = _interopRequireDefault(_menuToolbar);\n\nvar _usersAddressbookAddressBook = require('./users/addressbook/AddressBook');\n\nvar _usersAddressbookAddressBook2 = _interopRequireDefault(_usersAddressbookAddressBook);\n\nvar PydioComponents = {\n\n    SortableList: _listSortableList2['default'],\n    SimpleList: _listSimpleList2['default'],\n    NodeListCustomProvider: _listNodeListCustomProvider2['default'],\n    ListEntry: _listListEntry.ListEntry,\n    ListPaginator: _listListPaginator2['default'],\n\n    TreeView: _viewsTreeView.TreeView,\n    DNDTreeView: _viewsTreeView.DNDTreeView,\n    FoldersTree: _viewsTreeView.FoldersTree,\n    ClipboardTextField: _elementsClipboardTextField2['default'],\n    LabelWithTip: _elementsLabelWithTip2['default'],\n    EmptyStateView: _viewsEmptyStateView2['default'],\n    SimpleFigureBadge: _elementsSimpleFigureBadge2['default'],\n    SearchBox: _viewsSearchBox2['default'],\n    ModalAppBar: _viewsModalAppBar2['default'],\n\n    ReactEditorOpener: _editorReactEditorOpener2['default'],\n    PaperEditorLayout: _editorPaperEditor.PaperEditorLayout,\n    PaperEditorNavEntry: _editorPaperEditor.PaperEditorNavEntry,\n    PaperEditorNavHeader: _editorPaperEditor.PaperEditorNavHeader,\n\n    DynamicGrid: _dynamicGridDynamicGrid2['default'],\n    DynamicGridItemMixin: _dynamicGridGridItemMixin2['default'],\n    asGridItem: _dynamicGridAsGridItem2['default'],\n    DynamicGridStore: _dynamicGridStore2['default'],\n\n    DND: {\n        Types: _utilDND.Types, collect: _utilDND.collect, collectDrop: _utilDND.collectDrop, nodeDragSource: _utilDND.nodeDragSource, nodeDropTarget: _utilDND.nodeDropTarget, DNDActionParameter: _utilDND.DNDActionParameter\n    },\n    DNDActionParameter: _utilDND.DNDActionParameter,\n\n    UserAvatar: _usersAvatarUserAvatar2['default'],\n    UsersCompleter: _usersUsersCompleter2['default'],\n    TeamCreationForm: _usersTeamCreationForm2['default'],\n    AddressBook: _usersAddressbookAddressBook2['default'],\n\n    ContextMenu: _menuContextMenu2['default'],\n    Toolbar: _menuToolbar2['default'],\n    ButtonMenu: _menuButtonMenu2['default'],\n    IconButtonMenu: _menuIconButtonMenu2['default']\n};\n\nexports['default'] = PydioComponents;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _ListEntryNodeListenerMixin = require('./ListEntryNodeListenerMixin');\n\nvar _ListEntryNodeListenerMixin2 = _interopRequireDefault(_ListEntryNodeListenerMixin);\n\nvar _InlineEditor = require('./InlineEditor');\n\nvar _InlineEditor2 = _interopRequireDefault(_InlineEditor);\n\nvar _ListEntry = require('./ListEntry');\n\nvar _materialUi = require('material-ui');\n\n/**\n * Callback based material list entry with custom icon render, firstLine, secondLine, etc.\n */\nexports['default'] = _react2['default'].createClass({\n    displayName: 'ConfigurableListEntry',\n\n    mixins: [_ListEntryNodeListenerMixin2['default']],\n\n    propTypes: {\n        node: _react2['default'].PropTypes.instanceOf(AjxpNode),\n        // SEE ALSO ListEntry PROPS\n        renderIcon: _react2['default'].PropTypes.func,\n        renderFirstLine: _react2['default'].PropTypes.func,\n        renderSecondLine: _react2['default'].PropTypes.func,\n        renderThirdLine: _react2['default'].PropTypes.func,\n        renderActions: _react2['default'].PropTypes.func,\n        style: _react2['default'].PropTypes.object\n    },\n\n    render: function render() {\n        var _this = this;\n\n        var icon = undefined,\n            firstLine = undefined,\n            secondLine = undefined,\n            thirdLine = undefined,\n            style = this.props.style || {};\n        if (this.props.renderIcon) {\n            icon = this.props.renderIcon(this.props.node, this.props);\n        } else {\n            var node = this.props.node;\n            var iconClass = node.getMetadata().get(\"icon_class\") ? node.getMetadata().get(\"icon_class\") : node.isLeaf() ? \"icon-file-alt\" : \"icon-folder-close\";\n            icon = _react2['default'].createElement(_materialUi.FontIcon, { className: iconClass });\n        }\n\n        if (this.props.renderFirstLine) {\n            firstLine = this.props.renderFirstLine(this.props.node);\n        } else {\n            firstLine = this.props.node.getLabel();\n        }\n        if (this.state && this.state.inlineEdition) {\n            firstLine = _react2['default'].createElement(\n                'span',\n                null,\n                _react2['default'].createElement(_InlineEditor2['default'], {\n                    node: this.props.node,\n                    onClose: function () {\n                        _this.setState({ inlineEdition: false });\n                    },\n                    callback: this.state.inlineEditionCallback\n                }),\n                firstLine\n            );\n            style.position = 'relative';\n        }\n        if (this.props.renderSecondLine) {\n            secondLine = this.props.renderSecondLine(this.props.node);\n        }\n        if (this.props.renderThirdLine) {\n            thirdLine = this.props.renderThirdLine(this.props.node);\n        }\n        var actions = this.props.actions;\n        if (this.props.renderActions) {\n            actions = this.props.renderActions(this.props.node);\n        }\n\n        return _react2['default'].createElement(_ListEntry.DragDropListEntry, _extends({}, this.props, {\n            iconCell: icon,\n            firstLine: firstLine,\n            secondLine: secondLine,\n            thirdLine: thirdLine,\n            actions: actions,\n            style: style\n        }));\n    }\n\n});\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\nvar React = require('react');\nvar Pydio = require('pydio');\nvar AjxpNode = require('pydio/model/node');\n\nvar _Pydio$requireLib = Pydio.requireLib('boot');\n\nvar PydioContextConsumer = _Pydio$requireLib.PydioContextConsumer;\n\nvar _require = require('material-ui');\n\nvar Paper = _require.Paper;\nvar TextField = _require.TextField;\nvar FlatButton = _require.FlatButton;\n\nvar InlineEditor = React.createClass({\n    displayName: 'InlineEditor',\n\n    propTypes: {\n        node: React.PropTypes.instanceOf(AjxpNode),\n        callback: React.PropTypes.func,\n        onClose: React.PropTypes.func,\n        detached: React.PropTypes.bool\n    },\n\n    submit: function submit() {\n        if (!this.state || !this.state.value || this.state.value === this.props.node.getLabel()) {\n            this.setState({ errorString: 'Please use a different value for renaming!' });\n            this.props.getPydio().displayMessage('ERROR', 'Please use a different value for renaming!');\n        } else {\n            this.props.callback(this.state.value);\n            this.props.onClose();\n        }\n    },\n\n    componentDidMount: function componentDidMount() {\n        this.refs.text.focus();\n    },\n\n    catchClicks: function catchClicks(e) {\n        e.stopPropagation();\n    },\n\n    onKeyDown: function onKeyDown(e) {\n        if (e.key === 'Enter') {\n            this.submit();\n        }\n        this.setState({ errorString: '' });\n        e.stopPropagation();\n    },\n\n    render: function render() {\n        var _this = this;\n\n        return React.createElement(\n            Paper,\n            { className: \"inline-editor\" + (this.props.detached ? \" detached\" : \"\"), style: { padding: 8 }, zDepth: 2 },\n            React.createElement(TextField, {\n                ref: 'text',\n                defaultValue: this.props.node.getLabel(),\n                onChange: function (e, value) {\n                    _this.setState({ value: value });\n                },\n                onClick: this['catch'], onDoubleClick: this.catchClicks,\n                tabIndex: '0', onKeyDown: this.onKeyDown,\n                errorText: this.state ? this.state.errorString : null\n            }),\n            React.createElement(\n                'div',\n                { style: { textAlign: 'right', paddingTop: 8 } },\n                React.createElement(FlatButton, { label: 'Cancel', onClick: this.props.onClose }),\n                React.createElement(FlatButton, { label: 'Submit', onClick: this.submit })\n            )\n        );\n    }\n\n});\n\nexports['default'] = InlineEditor = PydioContextConsumer(InlineEditor);\n\nexports['default'] = InlineEditor;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _reactDom = require('react-dom');\n\nvar _reactDom2 = _interopRequireDefault(_reactDom);\n\nvar _utilDND = require('../util/DND');\n\nvar _reactDnd = require('react-dnd');\n\nvar _materialUi = require('material-ui');\n\nvar _materialUiStyles = require('material-ui/styles');\n\nvar _color = require('color');\n\nvar _color2 = _interopRequireDefault(_color);\n\n/**\n * Material List Entry\n */\n\nvar ListEntry = (function (_React$Component) {\n    _inherits(ListEntry, _React$Component);\n\n    function ListEntry() {\n        _classCallCheck(this, ListEntry);\n\n        _React$Component.apply(this, arguments);\n    }\n\n    ListEntry.prototype.onClick = function onClick(event) {\n        if (this.props.showSelector) {\n            if (this.props.selectorDisabled) return;\n            this.props.onSelect(this.props.node, event);\n            event.stopPropagation();\n            event.preventDefault();\n        } else if (this.props.onClick) {\n            this.props.onClick(this.props.node, event);\n        }\n    };\n\n    ListEntry.prototype.onDoubleClick = function onDoubleClick(event) {\n        if (this.props.onDoubleClick) {\n            this.props.onDoubleClick(this.props.node, event);\n        }\n    };\n\n    ListEntry.prototype.render = function render() {\n        var _this = this;\n\n        var selector = undefined,\n            icon = undefined,\n            additionalClassName = undefined;\n\n        var _props = this.props;\n        var node = _props.node;\n        var showSelector = _props.showSelector;\n        var selected = _props.selected;\n        var selectorDisabled = _props.selectorDisabled;\n        var firstLine = _props.firstLine;\n        var secondLine = _props.secondLine;\n        var thirdLine = _props.thirdLine;\n        var style = _props.style;\n        var actions = _props.actions;\n        var iconCell = _props.iconCell;\n        var mainIcon = _props.mainIcon;\n        var className = _props.className;\n        var canDrop = _props.canDrop;\n        var isOver = _props.isOver;\n        var connectDragSource = _props.connectDragSource;\n        var connectDropTarget = _props.connectDropTarget;\n\n        var mainClasses = ['material-list-entry', 'material-list-entry-' + (thirdLine ? 3 : secondLine ? 2 : 1) + '-lines'];\n        if (className) mainClasses.push(className);\n\n        if (showSelector) {\n            selector = React.createElement(\n                'div',\n                { className: 'material-list-selector' },\n                React.createElement(_materialUi.Checkbox, { checked: selected, ref: 'selector', disabled: selectorDisabled })\n            );\n        }\n\n        if (iconCell) {\n            icon = this.props.iconCell;\n        } else if (this.props.mainIcon) {\n            icon = React.createElement(_materialUi.FontIcon, { className: \"mui-font-icon \" + this.props.mainIcon, style: { fontSize: 18 /*, color: \"#FFFFFF\"*/ } });\n        }\n\n        if (canDrop && isOver) {\n            mainClasses.push('droppable-active');\n        }\n\n        if (node) {\n            mainClasses.push('listentry' + node.getPath().replace(/\\//g, '_'));\n            mainClasses.push('ajxp_node_' + (node.isLeaf() ? 'leaf' : 'collection'));\n            if (node.getAjxpMime()) {\n                mainClasses.push('ajxp_mime_' + node.getAjxpMime());\n            }\n        }\n\n        var additionalStyle = {\n            /*transition:'background-color 250ms cubic-bezier(0.23, 1, 0.32, 1) 0ms, color 250ms cubic-bezier(0.23, 1, 0.32, 1) 0ms'*/\n        };\n        if (this.state && this.state.hover && !this.props.noHover) {\n            additionalStyle = _extends({}, additionalStyle, {\n                backgroundColor: 'rgba(0,0,0,0.05)',\n                borderBottom: '1px solid transparent'\n            });\n        }\n        if (selected) {\n            var selectionColor = this.props.muiTheme.palette.accent2Color;\n            var selectionColorDark = _color2['default'](selectionColor).dark();\n            additionalStyle = _extends({}, additionalStyle, {\n                backgroundColor: selectionColor,\n                color: selectionColorDark ? 'white' : 'rgba(0,0,0,.87)'\n            });\n            mainClasses.push('selected');\n            mainClasses.push('selected-' + (selectionColorDark ? 'dark' : 'light'));\n        }\n\n        return React.createElement(\n            ContextMenuWrapper,\n            _extends({}, this.props, {\n                ref: function (instance) {\n                    var node = _reactDom2['default'].findDOMNode(instance);\n                    if (typeof connectDropTarget === 'function') connectDropTarget(node);\n                    if (typeof connectDragSource === 'function') connectDragSource(node);\n                },\n                onClick: this.onClick.bind(this),\n                onDoubleClick: showSelector ? null : this.onDoubleClick.bind(this),\n                className: mainClasses.join(' '),\n                onMouseOver: function () {\n                    _this.setState({ hover: true });\n                },\n                onMouseOut: function () {\n                    _this.setState({ hover: false });\n                },\n                style: _extends({}, style, additionalStyle) }),\n            selector,\n            React.createElement(\n                'div',\n                { className: \"material-list-icon\" + (mainIcon || iconCell ? \"\" : \" material-list-icon-none\") },\n                icon\n            ),\n            React.createElement(\n                'div',\n                { className: 'material-list-text' },\n                React.createElement(\n                    'div',\n                    { key: 'line-1', className: 'material-list-line-1' },\n                    firstLine\n                ),\n                React.createElement(\n                    'div',\n                    { key: 'line-2', className: 'material-list-line-2' },\n                    secondLine\n                ),\n                React.createElement(\n                    'div',\n                    { key: 'line-3', className: 'material-list-line-3' },\n                    thirdLine\n                )\n            ),\n            React.createElement(\n                'div',\n                { className: 'material-list-actions' },\n                actions\n            )\n        );\n    };\n\n    return ListEntry;\n})(React.Component);\n\nvar ContextMenuWrapper = function ContextMenuWrapper(props) {\n    return React.createElement('div', props);\n};\nContextMenuWrapper = PydioHOCs.withContextMenu(ContextMenuWrapper);\n\nListEntry.propTypes = {\n    showSelector: React.PropTypes.bool,\n    selected: React.PropTypes.bool,\n    selectorDisabled: React.PropTypes.bool,\n    onSelect: React.PropTypes.func,\n    onClick: React.PropTypes.func,\n    iconCell: React.PropTypes.element,\n    mainIcon: React.PropTypes.string,\n    firstLine: React.PropTypes.node,\n    secondLine: React.PropTypes.node,\n    thirdLine: React.PropTypes.node,\n    actions: React.PropTypes.element,\n    activeDroppable: React.PropTypes.bool,\n    className: React.PropTypes.string,\n    style: React.PropTypes.object,\n    noHover: React.PropTypes.bool\n};\n\nexports.ListEntry = ListEntry = _materialUiStyles.muiThemeable()(ListEntry);\n\nvar DragDropListEntry = _reactDnd.flow(_reactDnd.DragSource(_utilDND.Types.NODE_PROVIDER, _utilDND.nodeDragSource, _utilDND.collect), _reactDnd.DropTarget(_utilDND.Types.NODE_PROVIDER, _utilDND.nodeDropTarget, _utilDND.collectDrop))(ListEntry);\n\nexports.DragDropListEntry = DragDropListEntry;\nexports.ListEntry = ListEntry;\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n\"use strict\";\n\nexports.__esModule = true;\nexports[\"default\"] = {\n\n    attach: function attach(node) {\n        this._nodeListener = (function () {\n            if (!this.isMounted()) {\n                this.detach(node);\n                return;\n            }\n            this.forceUpdate();\n        }).bind(this);\n        this._actionListener = (function (eventMemo) {\n            if (!this.isMounted()) {\n                this.detach(node);\n                return;\n            }\n            if (eventMemo && eventMemo.type === 'prompt-rename' && eventMemo.callback) {\n                this.setState({ inlineEdition: true, inlineEditionCallback: eventMemo.callback });\n            }\n            return true;\n        }).bind(this);\n        node.observe(\"node_replaced\", this._nodeListener);\n        node.observe(\"node_action\", this._actionListener);\n    },\n\n    detach: function detach(node) {\n        if (this._nodeListener) {\n            node.stopObserving(\"node_replaced\", this._nodeListener);\n            node.stopObserving(\"node_action\", this._actionListener);\n        }\n    },\n\n    componentDidMount: function componentDidMount() {\n        this.attach(this.props.node);\n    },\n\n    componentWillUnmount: function componentWillUnmount() {\n        this.detach(this.props.node);\n    }\n\n};\nmodule.exports = exports[\"default\"];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n\"use strict\";\n\nexports.__esModule = true;\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { \"default\": obj }; }\n\nvar _utilMessagesConsumerMixin = require('../util/MessagesConsumerMixin');\n\nvar _utilMessagesConsumerMixin2 = _interopRequireDefault(_utilMessagesConsumerMixin);\n\n/**\n * Pagination component reading metadata \"paginationData\" from current node.\n */\nexports[\"default\"] = React.createClass({\n    displayName: \"ListPaginator\",\n\n    mixins: [_utilMessagesConsumerMixin2[\"default\"]],\n\n    propTypes: {\n        dataModel: React.PropTypes.instanceOf(PydioDataModel).isRequired,\n        node: React.PropTypes.instanceOf(AjxpNode)\n    },\n\n    componentDidMount: function componentDidMount() {\n        var _this = this;\n\n        if (!this.props.node) {\n            (function () {\n                var dm = _this.props.dataModel;\n                _this._dmObserver = (function () {\n                    this.setState({ node: dm.getContextNode() });\n                }).bind(_this);\n                dm.observe(\"context_changed\", _this._dmObserver);\n                _this.setState({ node: dm.getContextNode() });\n            })();\n        }\n    },\n\n    componentWillUnmount: function componentWillUnmount() {\n        if (this._dmObserver) {\n            this.props.dataModel.stopObserving(\"context_changed\", this._dmObserver);\n        }\n    },\n\n    getInitialState: function getInitialState() {\n        return { node: this.props.node };\n    },\n\n    changePage: function changePage(event) {\n        this.state.node.getMetadata().get(\"paginationData\").set(\"new_page\", event.currentTarget.getAttribute('data-page'));\n        this.props.dataModel.requireContextChange(this.state.node);\n    },\n\n    onMenuChange: function onMenuChange(event, index, item) {\n        this.state.node.getMetadata().get(\"paginationData\").set(\"new_page\", item.payload);\n        this.props.dataModel.requireContextChange(this.state.node);\n    },\n\n    render: function render() {\n        if (!this.state.node || !this.state.node.getMetadata().get(\"paginationData\")) {\n            return null;\n        }\n        var pData = this.state.node.getMetadata().get(\"paginationData\");\n        var current = parseInt(pData.get(\"current\"));\n        var total = parseInt(pData.get(\"total\"));\n        var pages = [],\n            next,\n            last,\n            previous,\n            first;\n        var pageWord = this.context.getMessage ? this.context.getMessage('331', '') : this.props.getMessage('331', '');\n        for (var i = 1; i <= total; i++) {\n            pages.push({ payload: i, text: pageWord + ' ' + i + (i == current ? ' / ' + total : '') });\n        }\n        if (pages.length <= 1) {\n            return null;\n        }\n        var sep = undefined;\n        if (this.props.toolbarDisplay) {\n            if (current > 1) previous = React.createElement(\n                \"span\",\n                { className: \"toolbars-button-menu\" },\n                React.createElement(ReactMUI.IconButton, { onClick: this.changePage, \"data-page\": current - 1, iconClassName: \"icon-caret-left\" })\n            );\n            if (current < total) next = React.createElement(\n                \"span\",\n                { className: \"toolbars-button-menu\" },\n                React.createElement(ReactMUI.IconButton, { onClick: this.changePage, \"data-page\": current + 1, iconClassName: \"icon-caret-right\" })\n            );\n        } else {\n            if (current > 1) previous = React.createElement(ReactMUI.FontIcon, { onClick: this.changePage, \"data-page\": current - 1, className: \"icon-angle-left\" });\n            if (current < total) next = React.createElement(ReactMUI.FontIcon, { onClick: this.changePage, \"data-page\": current + 1, className: \"icon-angle-right\" });\n            sep = React.createElement(\n                \"span\",\n                { className: \"mui-toolbar-separator\" },\n                \" \"\n            );\n        }\n        return React.createElement(\n            \"span\",\n            { id: this.props.id, style: this.props.style },\n            first,\n            previous,\n            React.createElement(ReactMUI.DropDownMenu, { onChange: this.onMenuChange, menuItems: pages, selectedIndex: current - 1 }),\n            next,\n            last,\n            sep\n        );\n    }\n\n});\nmodule.exports = exports[\"default\"];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n\"use strict\";\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { \"default\": obj }; }\n\nvar _SimpleList = require('./SimpleList');\n\nvar _SimpleList2 = _interopRequireDefault(_SimpleList);\n\n/**\n * Simple to use list component encapsulated with its own query mechanism\n * using a set of properties for the remote node provider.\n */\nexports[\"default\"] = React.createClass({\n    displayName: \"NodeListCustomProvider\",\n\n    propTypes: {\n        nodeProviderProperties: React.PropTypes.object,\n        presetDataModel: React.PropTypes.instanceOf(PydioDataModel),\n        autoRefresh: React.PropTypes.number,\n        actionBarGroups: React.PropTypes.array,\n        heightAutoWithMax: React.PropTypes.number,\n        elementHeight: React.PropTypes.number.isRequired,\n        nodeClicked: React.PropTypes.func,\n        reloadOnServerMessage: React.PropTypes.string,\n        entryRenderAsCard: React.PropTypes.func\n    },\n\n    reload: function reload() {\n        if (this.refs.list && this.isMounted()) {\n            this.refs.list.reload();\n        }\n    },\n\n    componentWillUnmount: function componentWillUnmount() {\n        if (this._smObs) {\n            this.props.pydio.stopObserving(\"server_message\", this._smObs);\n            this.props.pydio.stopObserving(\"server_message:\" + this.props.reloadOnServerMessage, this.reload);\n        }\n    },\n\n    componentWillReceiveProps: function componentWillReceiveProps(nextProps) {\n        if (this.props.nodeProviderProperties && this.props.nodeProviderProperties !== nextProps.nodeProviderProperties) {\n            var _state = this.state;\n            var dataModel = _state.dataModel;\n            var node = _state.node;\n\n            var provider = new RemoteNodeProvider(nextProps.nodeProviderProperties);\n            dataModel.setAjxpNodeProvider(provider);\n            node.updateProvider(provider);\n            this.setState({ dataModel: dataModel, node: node });\n        } else if (this.props.presetDataModel !== nextProps.presetDataModel) {\n            this.setState({\n                dataModel: nextProps.presetDataModel,\n                node: nextProps.presetDataModel.getRootNode()\n            });\n        }\n    },\n\n    getInitialState: function getInitialState() {\n\n        var dataModel = undefined;\n        if (this.props.presetDataModel) {\n            dataModel = this.props.presetDataModel;\n        } else {\n            dataModel = PydioDataModel.RemoteDataModelFactory(this.props.nodeProviderProperties);\n        }\n        var rootNode = dataModel.getRootNode();\n        if (this.props.nodeClicked) {\n            // leaf\n            this.openEditor = (function (node) {\n                this.props.nodeClicked(node);\n                return false;\n            }).bind(this);\n            // dir\n            dataModel.observe(\"selection_changed\", (function (event) {\n                var selectedNodes = event.memo.getSelectedNodes();\n                if (selectedNodes.length) {\n                    this.props.nodeClicked(selectedNodes[0]);\n                    event.memo.setSelectedNodes([]);\n                }\n            }).bind(this));\n        }\n        if (this.props.reloadOnServerMessage && this.props.pydio) {\n            this._smObs = (function (event) {\n                if (XMLUtils.XPathSelectSingleNode(event, this.props.reloadOnServerMessage)) this.reload();\n            }).bind(this);\n            this.props.pydio.observe(\"server_message\", this._smObs);\n            this.props.pydio.observe(\"server_message:\" + this.props.reloadOnServerMessage, this.reload);\n        }\n        return { node: rootNode, dataModel: dataModel };\n    },\n\n    render: function render() {\n        var legend;\n        if (this.props.legend) {\n            legend = React.createElement(\n                \"div\",\n                { className: \"subtitle\" },\n                this.props.legend\n            );\n        }\n        return React.createElement(\n            \"div\",\n            { className: this.props.heightAutoWithMax ? \"\" : \"layout-fill vertical-layout\" },\n            React.createElement(_SimpleList2[\"default\"], _extends({}, this.props, {\n                openEditor: this.openEditor,\n                ref: \"list\",\n                style: Object.assign({ height: '100%' }, this.props.style || {}),\n                node: this.state.node,\n                dataModel: this.state.dataModel,\n                actionBarGroups: this.props.actionBarGroups,\n                skipParentNavigation: true,\n                observeNodeReload: true\n            }))\n        );\n    }\n\n});\nmodule.exports = exports[\"default\"];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nvar _reactScrollbar = require('react-scrollbar');\n\nvar _reactScrollbar2 = _interopRequireDefault(_reactScrollbar);\n\nvar _utilMessagesConsumerMixin = require('../util/MessagesConsumerMixin');\n\nvar _utilMessagesConsumerMixin2 = _interopRequireDefault(_utilMessagesConsumerMixin);\n\nvar _ListEntry = require('./ListEntry');\n\nvar _TableListEntry = require('./TableListEntry');\n\nvar _TableListEntry2 = _interopRequireDefault(_TableListEntry);\n\nvar _TableListHeader = require('./TableListHeader');\n\nvar _TableListHeader2 = _interopRequireDefault(_TableListHeader);\n\nvar _ConfigurableListEntry = require('./ConfigurableListEntry');\n\nvar _ConfigurableListEntry2 = _interopRequireDefault(_ConfigurableListEntry);\n\nvar _SortColumns = require('./SortColumns');\n\nvar _SortColumns2 = _interopRequireDefault(_SortColumns);\n\nvar _ListPaginator = require('./ListPaginator');\n\nvar _ListPaginator2 = _interopRequireDefault(_ListPaginator);\n\nvar _viewsSimpleReactActionBar = require('../views/SimpleReactActionBar');\n\nvar _viewsSimpleReactActionBar2 = _interopRequireDefault(_viewsSimpleReactActionBar);\n\nvar _InlineEditor = require('./InlineEditor');\n\nvar _InlineEditor2 = _interopRequireDefault(_InlineEditor);\n\nvar _viewsEmptyStateView = require('../views/EmptyStateView');\n\nvar _viewsEmptyStateView2 = _interopRequireDefault(_viewsEmptyStateView);\n\nvar React = require('react');\nvar Infinite = require('react-infinite');\n\nvar DOMUtils = require('pydio/util/dom');\nvar LangUtils = require('pydio/util/lang');\nvar PydioDataModel = require('pydio/model/data-model');\nvar PeriodicalExecuter = require('pydio/util/periodical-executer');\n\n/**\n * Generic List component, using Infinite for cell virtualization, pagination, various\n * displays, etc... It provides many hooks for rendering cells on-demand.\n */\nvar SimpleList = React.createClass({\n    displayName: 'SimpleList',\n\n    mixins: [_utilMessagesConsumerMixin2['default']],\n\n    propTypes: {\n        infiniteSliceCount: React.PropTypes.number,\n        filterNodes: React.PropTypes.func,\n        customToolbar: React.PropTypes.object,\n        tableKeys: React.PropTypes.object,\n        autoRefresh: React.PropTypes.number,\n        reloadAtCursor: React.PropTypes.bool,\n        clearSelectionOnReload: React.PropTypes.bool,\n        heightAutoWithMax: React.PropTypes.number,\n        containerHeight: React.PropTypes.number,\n        observeNodeReload: React.PropTypes.bool,\n        defaultGroupBy: React.PropTypes.string,\n        defaultGroupByLabel: React.PropTypes.string,\n        defaultSortingInfo: React.PropTypes.object,\n\n        skipParentNavigation: React.PropTypes.bool,\n        skipInternalDataModel: React.PropTypes.bool,\n        delayInitialLoad: React.PropTypes.number,\n\n        entryEnableSelector: React.PropTypes.func,\n        renderCustomEntry: React.PropTypes.func,\n        entryRenderIcon: React.PropTypes.func,\n        entryRenderActions: React.PropTypes.func,\n        entryRenderFirstLine: React.PropTypes.func,\n        entryRenderSecondLine: React.PropTypes.func,\n        entryRenderThirdLine: React.PropTypes.func,\n        entryHandleClicks: React.PropTypes.func,\n        hideToolbar: React.PropTypes.bool,\n        computeActionsForNode: React.PropTypes.bool,\n        multipleActions: React.PropTypes.array,\n\n        openEditor: React.PropTypes.func,\n        openCollection: React.PropTypes.func,\n\n        elementStyle: React.PropTypes.object,\n        passScrollingStateToChildren: React.PropTypes.bool,\n        elementHeight: React.PropTypes.oneOfType([React.PropTypes.number, React.PropTypes.object]).isRequired\n\n    },\n\n    statics: {\n        HEIGHT_ONE_LINE: 50,\n        HEIGHT_TWO_LINES: 73,\n        CLICK_TYPE_SIMPLE: 'simple',\n        CLICK_TYPE_DOUBLE: 'double',\n        PARENT_FOLDER_ICON: 'mdi mdi-chevron-left'\n    },\n\n    getDefaultProps: function getDefaultProps() {\n        return { infiniteSliceCount: 30, clearSelectionOnReload: true };\n    },\n\n    clickRow: function clickRow(gridRow, event) {\n        var node = undefined;\n        if (gridRow.props) {\n            node = gridRow.props.data.node;\n        } else {\n            node = gridRow;\n        }\n        if (this.props.entryHandleClicks) {\n            this.props.entryHandleClicks(node, SimpleList.CLICK_TYPE_SIMPLE, event);\n            return;\n        }\n        if (node.isLeaf() && this.props.openEditor) {\n            if (this.props.openEditor(node) === false) {\n                return;\n            }\n            var uniqueSelection = new Map();\n            uniqueSelection.set(node, true);\n            this.setState({ selection: uniqueSelection }, this.rebuildLoadedElements);\n        } else if (!node.isLeaf()) {\n            if (this.props.openCollection) {\n                this.props.openCollection(node);\n            } else {\n                this.props.dataModel.setSelectedNodes([node]);\n            }\n        }\n    },\n\n    doubleClickRow: function doubleClickRow(gridRow, event) {\n        var node = undefined;\n        if (gridRow.props) {\n            node = gridRow.props.data.node;\n        } else {\n            node = gridRow;\n        }\n        if (this.props.entryHandleClicks) {\n            this.props.entryHandleClicks(node, SimpleList.CLICK_TYPE_DOUBLE, event);\n        }\n    },\n\n    onColumnSort: function onColumnSort(column) {\n        var stateSetCallback = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1];\n\n        var pagination = this.props.node.getMetadata().get('paginationData');\n        if (pagination && pagination.get('total') > 1 && pagination.get('remote_order')) {\n\n            var dir = 'asc';\n            if (this.props.node.getMetadata().get('paginationData').get('currentOrderDir')) {\n                dir = this.props.node.getMetadata().get('paginationData').get('currentOrderDir') === 'asc' ? 'desc' : 'asc';\n            }\n            var orderData = new Map();\n            orderData.set('order_column', column['remoteSortAttribute'] ? column.remoteSortAttribute : column.name);\n            orderData.set('order_direction', dir);\n            this.props.node.getMetadata().set(\"remote_order\", orderData);\n            this.props.dataModel.requireContextChange(this.props.node, true);\n        } else {\n\n            var att = column['sortAttribute'] ? column['sortAttribute'] : column.name;\n            var sortingInfo = undefined;\n            var _state$sortingInfo = this.state.sortingInfo;\n            var attribute = _state$sortingInfo.attribute;\n            var direction = _state$sortingInfo.direction;\n\n            if (attribute === att && direction) {\n                if (direction === 'asc') {\n                    // Switch direction\n                    sortingInfo = { attribute: att, sortType: column.sortType, direction: 'desc' };\n                } else {\n                    // Reset sorting\n                    sortingInfo = this.props.defaultSortingInfo || {};\n                }\n            } else {\n                sortingInfo = { attribute: att, sortType: column.sortType, direction: 'asc' };\n            }\n            this.setState({ sortingInfo: sortingInfo }, (function () {\n                this.rebuildLoadedElements();\n                if (stateSetCallback) {\n                    stateSetCallback();\n                }\n            }).bind(this));\n        }\n    },\n\n    computeSelectionFromCurrentPlusTargetNode: function computeSelectionFromCurrentPlusTargetNode(currentSelection, targetNode) {\n\n        var currentIndexStart = undefined,\n            currentIndexEnd = undefined,\n            nodeBefore = false;\n        if (!this.indexedElements) {\n            return [];\n        }\n        var firstSelected = currentSelection[0];\n        var lastSelected = currentSelection[currentSelection.length - 1];\n        var newSelection = [];\n        for (var i = 0; i < this.indexedElements.length; i++) {\n            if (currentIndexStart !== undefined) {\n                newSelection.push(this.indexedElements[i].node);\n            }\n            if (this.indexedElements[i].node === targetNode) {\n                if (currentIndexStart !== undefined && currentIndexEnd === undefined) {\n                    currentIndexEnd = i;\n                    break;\n                }\n                currentIndexStart = i;\n                nodeBefore = true;\n                newSelection.push(this.indexedElements[i].node);\n            }\n            if (this.indexedElements[i].node === firstSelected && currentIndexStart === undefined) {\n                currentIndexStart = i;\n                newSelection.push(this.indexedElements[i].node);\n            }\n            if (this.indexedElements[i].node === lastSelected && nodeBefore) {\n                currentIndexEnd = i;\n                break;\n            }\n        }\n        return newSelection;\n    },\n\n    onKeyDown: function onKeyDown(e) {\n        var currentIndexStart = undefined,\n            currentIndexEnd = undefined;\n        var contextHolder = window.pydio.getContextHolder();\n        var elementsPerLine = this.props.elementsPerLine || 1;\n        var shiftKey = e.shiftKey;\n        var key = e.key;\n\n        if (contextHolder.isEmpty() || !this.indexedElements) {\n            return;\n        }\n        var downKeys = ['ArrowDown', 'ArrowRight', 'PageDown', 'End'];\n\n        var position = shiftKey && downKeys.indexOf(key) > -1 ? 'first' : 'last';\n        var currentSelection = contextHolder.getSelectedNodes();\n\n        var firstSelected = currentSelection[0];\n        var lastSelected = currentSelection[currentSelection.length - 1];\n\n        if (key === 'Enter') {\n            this.doubleClickRow(firstSelected);\n            return;\n        }\n        if (key === 'Delete' && global.pydio.Controller.fireActionByKey('key_delete')) {\n            return;\n        }\n\n        for (var i = 0; i < this.indexedElements.length; i++) {\n            if (this.indexedElements[i].node === firstSelected) {\n                currentIndexStart = i;\n            }\n            if (this.indexedElements[i].node === lastSelected) {\n                currentIndexEnd = i;\n                break;\n            }\n        }\n        var selectionIndex = undefined;\n        var maxIndex = this.indexedElements.length - 1;\n        var increment = key === 'PageDown' || key === 'PageUp' ? 10 : 1;\n        if (key === 'ArrowDown' || key === 'PageDown') {\n            selectionIndex = Math.min(currentIndexEnd + elementsPerLine * increment, maxIndex);\n        } else if (key === 'ArrowUp' || key === 'PageUp') {\n            selectionIndex = Math.max(currentIndexStart - elementsPerLine * increment, 0);\n        } else if (key === 'Home') {\n            selectionIndex = 0;\n        } else if (key === 'End') {\n            selectionIndex = maxIndex;\n        }\n        if (elementsPerLine > 1) {\n            if (key === 'ArrowRight') {\n                selectionIndex = currentIndexEnd + 1;\n            } else if (key === 'ArrowLeft') {\n                selectionIndex = currentIndexStart - 1;\n            }\n        }\n\n        if (shiftKey && selectionIndex !== undefined) {\n            var min = Math.min(currentIndexStart, currentIndexEnd, selectionIndex);\n            var max = Math.max(currentIndexStart, currentIndexEnd, selectionIndex);\n            if (min !== max) {\n                var selection = [];\n                for (var i = min; i < max + 1; i++) {\n                    if (this.indexedElements[i]) selection.push(this.indexedElements[i].node);\n                }\n                contextHolder.setSelectedNodes(selection);\n            }\n        } else if (this.indexedElements[selectionIndex] && this.indexedElements[selectionIndex].node) {\n            contextHolder.setSelectedNodes([this.indexedElements[selectionIndex].node]);\n        }\n    },\n\n    getInitialState: function getInitialState() {\n        this.actionsCache = { multiple: new Map() };\n        if (!this.props.skipInternalDataModel) {\n            this.dm = new PydioDataModel();\n            this.dm.setRootNode(this.props.dataModel.getContextNode());\n            this.dm.setContextNode(this.props.dataModel.getContextNode());\n        } else {\n            this.dm = this.props.dataModel;\n        }\n        var sortingInfo = this.props.defaultSortingInfo || null;\n        var state = {\n            loaded: this.props.node.isLoaded(),\n            loading: !this.props.node.isLoaded(),\n            showSelector: false,\n            elements: this.props.node.isLoaded() ? this.buildElements(sortingInfo, 0, this.props.infiniteSliceCount) : [],\n            containerHeight: this.props.containerHeight ? this.props.containerHeight : this.props.heightAutoWithMax ? 0 : 500,\n            sortingInfo: sortingInfo\n        };\n        if (this.props.elementHeight instanceof Object) {\n            state.elementHeight = this.computeElementHeightResponsive();\n        }\n        state.infiniteLoadBeginBottomOffset = 200;\n        return state;\n    },\n\n    componentWillReceiveProps: function componentWillReceiveProps(nextProps) {\n        var _this = this;\n\n        this.indexedElements = null;\n        var currentLength = Math.max(this.state.elements.length, nextProps.infiniteSliceCount);\n        var sortingInfo = this.state.sortingInfo || nextProps.defaultSortingInfo || null;\n        this.setState({\n            loaded: nextProps.node.isLoaded(),\n            loading: !nextProps.node.isLoaded(),\n            showSelector: false,\n            elements: nextProps.node.isLoaded() ? this.buildElements(sortingInfo, 0, currentLength, nextProps.node) : [],\n            infiniteLoadBeginBottomOffset: 200,\n            sortingInfo: sortingInfo\n        }, function () {\n            if (nextProps.node.isLoaded()) _this.updateInfiniteContainerHeight();\n        });\n        if (!nextProps.autoRefresh && this.refreshInterval) {\n            window.clearInterval(this.refreshInterval);\n            this.refreshInterval = null;\n        } else if (nextProps.autoRefresh && !this.refreshInterval) {\n            this.refreshInterval = window.setInterval(this.reload, nextProps.autoRefresh);\n        }\n        this.patchInfiniteGrid(nextProps.elementsPerLine);\n        if (this.props.node && nextProps.node !== this.props.node) {\n            this.observeNodeChildren(this.props.node, true);\n        }\n        if (this._manualScrollPe) {\n            this._manualScrollPe.stop();\n            this._manualScrollPe = null;\n        }\n    },\n\n    observeNodeChildren: function observeNodeChildren(node) {\n        var stop = arguments.length <= 1 || arguments[1] === undefined ? false : arguments[1];\n\n        if (stop && !this._childrenObserver) return;\n\n        if (!this._childrenObserver) {\n            this._childrenObserver = (function () {\n                this.indexedElements = null;\n                this.rebuildLoadedElements();\n            }).bind(this);\n        }\n        if (!this._childrenActionsObserver) {\n            this._childrenActionsObserver = (function (eventMemo) {\n                if (eventMemo.type === 'prompt-rename') {\n                    this.setState({ inlineEditionForNode: eventMemo.child, inlineEditionCallback: eventMemo.callback });\n                }\n            }).bind(this);\n        }\n        if (stop) {\n            node.stopObserving(\"child_added\", this._childrenObserver);\n            node.stopObserving(\"child_removed\", this._childrenObserver);\n            node.stopObserving(\"child_node_action\", this._childrenActionsObserver);\n        } else {\n            node.observe(\"child_added\", this._childrenObserver);\n            node.observe(\"child_removed\", this._childrenObserver);\n            node.observe(\"child_node_action\", this._childrenActionsObserver);\n        }\n    },\n\n    _loadNodeIfNotLoaded: function _loadNodeIfNotLoaded() {\n        var node = this.props.node;\n\n        if (!node.isLoaded()) {\n            node.observeOnce(\"loaded\", (function () {\n                if (!this.isMounted()) return;\n                if (this.props.node === node) {\n                    this.observeNodeChildren(node);\n                    this.setState({\n                        loaded: true,\n                        loading: false,\n                        elements: this.buildElements(this.state.sortingInfo, 0, this.props.infiniteSliceCount)\n                    });\n                }\n                if (this.props.heightAutoWithMax) {\n                    this.updateInfiniteContainerHeight();\n                }\n            }).bind(this));\n            node.load();\n        } else {\n            this.observeNodeChildren(node);\n        }\n    },\n\n    _loadingListener: function _loadingListener() {\n        this.observeNodeChildren(this.props.node, true);\n        this.setState({ loaded: false, loading: true });\n        this.indexedElements = null;\n    },\n    _loadedListener: function _loadedListener() {\n        var currentLength = Math.max(this.state.elements.length, this.props.infiniteSliceCount);\n        this.setState({\n            loading: false,\n            elements: this.buildElements(this.state.sortingInfo, 0, currentLength, this.props.node)\n        });\n        if (this.props.heightAutoWithMax) {\n            this.updateInfiniteContainerHeight();\n        }\n        this.observeNodeChildren(this.props.node);\n    },\n\n    reload: function reload() {\n        if (this.props.reloadAtCursor && this._currentCursor) {\n            this.loadStartingAtCursor();\n            return;\n        }\n        if (this.props.clearSelectionOnReload) {\n            this.props.dataModel.setSelectedNodes([]);\n        }\n        this._loadingListener();\n        this.props.node.observeOnce(\"loaded\", this._loadedListener);\n        this.props.node.reload();\n    },\n\n    loadStartingAtCursor: function loadStartingAtCursor() {\n        this._loadingListener();\n        var node = this.props.node;\n        var cachedChildren = node.getChildren();\n        var newChildren = [];\n        node.observeOnce(\"loaded\", (function () {\n            var reorderedChildren = new Map();\n            newChildren.map(function (c) {\n                reorderedChildren.set(c.getPath(), c);\n            });\n            cachedChildren.forEach(function (c) {\n                reorderedChildren.set(c.getPath(), c);\n            });\n            node._children = reorderedChildren;\n            this._loadedListener();\n        }).bind(this));\n        node.setLoaded(false);\n        node.observe(\"child_added\", function (newChild) {\n            newChildren.push(node._children.get(newChild));\n        });\n        this.props.node.load(null, { cursor: this._currentCursor });\n    },\n\n    wireReloadListeners: function wireReloadListeners() {\n        this.wrappedLoading = this._loadingListener;\n        this.wrappedLoaded = this._loadedListener;\n        this.props.node.observe(\"loading\", this.wrappedLoading);\n        this.props.node.observe(\"loaded\", this.wrappedLoaded);\n    },\n    stopReloadListeners: function stopReloadListeners() {\n        this.props.node.stopObserving(\"loading\", this.wrappedLoading);\n        this.props.node.stopObserving(\"loaded\", this.wrappedLoaded);\n    },\n\n    toggleSelector: function toggleSelector() {\n        // Force rebuild elements\n        this.setState({\n            showSelector: !this.state.showSelector,\n            selection: new Map()\n        }, this.rebuildLoadedElements);\n    },\n\n    toggleSelection: function toggleSelection(node) {\n        var selection = this.state.selection || new Map();\n        if (selection.get(node)) selection['delete'](node);else selection.set(node, true);\n        if (this.refs.all_selector) this.refs.all_selector.setChecked(false);\n        this.setState({\n            selection: selection\n        }, this.rebuildLoadedElements);\n    },\n\n    selectAll: function selectAll() {\n        var _this2 = this;\n\n        if (this.refs.all_selector && !this.refs.all_selector.isChecked()) {\n            this.setState({ selection: new Map() }, this.rebuildLoadedElements);\n        } else {\n            (function () {\n                var selection = new Map();\n                _this2.props.node.getChildren().forEach((function (child) {\n                    if (this.props.filterNodes && !this.props.filterNodes(child)) {\n                        return;\n                    }\n                    if (child.isLeaf()) {\n                        selection.set(child, true);\n                    }\n                }).bind(_this2));\n                if (_this2.refs.all_selector) _this2.refs.all_selector.setChecked(true);\n                _this2.setState({ selection: selection }, _this2.rebuildLoadedElements);\n            })();\n        }\n    },\n\n    applyMultipleAction: function applyMultipleAction(ev) {\n        if (!this.state.selection || !this.state.selection.size) {\n            return;\n        }\n        var actionName = ev.currentTarget.getAttribute('data-action');\n        var dm = this.dm || new PydioDataModel();\n        dm.setContextNode(this.props.node);\n        var selNodes = [];\n        this.state.selection.forEach(function (v, node) {\n            selNodes.push(node);\n        });\n        dm.setSelectedNodes(selNodes);\n        var a = this.props.pydio.Controller.getActionByName(actionName);\n        a.fireContextChange(dm, true, this.props.pydio.user);\n        a.apply([dm]);\n\n        ev.stopPropagation();\n        ev.preventDefault();\n    },\n\n    getActionsForNode: function getActionsForNode(dm, node) {\n        if (!this.props.computeActionsForNode) {\n            return [];\n        }\n        var cacheKey = node.isLeaf() ? 'file-' + node.getAjxpMime() : 'folder';\n        var selectionType = node.isLeaf() ? 'file' : 'dir';\n        var nodeActions = [];\n        if (this.actionsCache[cacheKey]) {\n            nodeActions = this.actionsCache[cacheKey];\n        } else {\n            dm.setSelectedNodes([node]);\n            window.pydio.Controller.actions.forEach((function (a) {\n                a.fireContextChange(dm, true, window.pydio.user);\n                if (a.context.selection && a.context.actionBar && a.selectionContext[selectionType] && !a.deny && a.options.icon_class && (!this.props.actionBarGroups || this.props.actionBarGroups.indexOf(a.context.actionBarGroup) !== -1) && (!a.selectionContext.allowedMimes.length || a.selectionContext.allowedMimes.indexOf(node.getAjxpMime()) !== -1)) {\n                    nodeActions.push(a);\n                    if (node.isLeaf() && a.selectionContext.unique === false) {\n                        this.actionsCache.multiple.set(a.options.name, a);\n                    }\n                }\n            }).bind(this));\n            this.actionsCache[cacheKey] = nodeActions;\n        }\n        return nodeActions;\n    },\n\n    updateInfiniteContainerHeight: function updateInfiniteContainerHeight() {\n        var retries = arguments.length <= 0 || arguments[0] === undefined ? false : arguments[0];\n\n        if (this.props.containerHeight) {\n            return this.props.containerHeight;\n        }\n        if (!this.refs.infiniteParent) {\n            return;\n        }\n        var containerHeight = this.refs.infiniteParent.clientHeight;\n        if (this.props.heightAutoWithMax) {\n            var number = this.indexedElements ? this.indexedElements.length : this.props.node.getChildren().size;\n            var elementHeight = this.state.elementHeight ? this.state.elementHeight : this.props.elementHeight;\n            containerHeight = Math.min(number * elementHeight, this.props.heightAutoWithMax);\n        }\n        if (!containerHeight && !retries) {\n            global.setTimeout((function () {\n                this.updateInfiniteContainerHeight(true);\n            }).bind(this), 50);\n        }\n        this.setState({ containerHeight: containerHeight });\n    },\n\n    computeElementHeightResponsive: function computeElementHeightResponsive() {\n        var breaks = this.props.elementHeight;\n        if (!(breaks instanceof Object)) {\n            breaks = {\n                \"min-width:480px\": this.props.elementHeight,\n                \"max-width:480px\": Object.keys(this.props.tableKeys).length * 24 + 33\n            };\n        }\n        if (window.matchMedia) {\n            for (var k in breaks) {\n                if (breaks.hasOwnProperty(k) && window.matchMedia('(' + k + ')').matches) {\n                    return breaks[k];\n                }\n            }\n        } else {\n            var width = DOMUtils.getViewportWidth();\n            if (width < 480) return breaks[\"max-width:480px\"];else return breaks[\"max-width:480px\"];\n        }\n        return 50;\n    },\n\n    updateElementHeightResponsive: function updateElementHeightResponsive() {\n        var newH = this.computeElementHeightResponsive();\n        if (!this.state || !this.state.elementHeight || this.state.elementHeight != newH) {\n            this.setState({ elementHeight: newH }, (function () {\n                if (this.props.heightAutoWithMax) {\n                    this.updateInfiniteContainerHeight();\n                }\n            }).bind(this));\n        }\n    },\n\n    patchInfiniteGrid: function patchInfiniteGrid(els) {\n        if (this.refs.infinite && els > 1) {\n            this.refs.infinite.state.infiniteComputer.__proto__.getDisplayIndexStart = function (windowTop) {\n                return els * Math.floor(windowTop / this.heightData / els);\n            };\n            this.refs.infinite.state.infiniteComputer.__proto__.getDisplayIndexEnd = function (windowBottom) {\n                return els * Math.ceil(windowBottom / this.heightData / els);\n            };\n        }\n    },\n\n    componentDidMount: function componentDidMount() {\n        var _this3 = this;\n\n        if (this.props.delayInitialLoad) {\n            setTimeout(function () {\n                _this3._loadNodeIfNotLoaded();\n            }, this.props.delayInitialLoad);\n        } else {\n            this._loadNodeIfNotLoaded();\n        }\n        this.patchInfiniteGrid(this.props.elementsPerLine);\n        if (this.refs.infiniteParent) {\n            this.updateInfiniteContainerHeight();\n            if (!this.props.heightAutoWithMax && !this.props.externalResize) {\n                if (window.addEventListener) {\n                    window.addEventListener('resize', this.updateInfiniteContainerHeight);\n                } else {\n                    window.attachEvent('onresize', this.updateInfiniteContainerHeight);\n                }\n            }\n        }\n        if (this.props.autoRefresh) {\n            this.refreshInterval = window.setInterval(this.reload, this.props.autoRefresh);\n        }\n        if (this.props.observeNodeReload) {\n            this.wireReloadListeners();\n        }\n        if (this.props.elementHeight instanceof Object || this.props.tableKeys) {\n            if (window.addEventListener) {\n                window.addEventListener('resize', this.updateElementHeightResponsive);\n            } else {\n                window.attachEvent('onresize', this.updateElementHeightResponsive);\n            }\n            this.updateElementHeightResponsive();\n        }\n        this.props.dataModel.observe('selection_changed', (function () {\n            var _this4 = this;\n\n            if (!this.isMounted()) return;\n            var selection = new Map();\n            var selectedNodes = this.props.dataModel.getSelectedNodes();\n            selectedNodes.map(function (n) {\n                selection.set(n, true);\n            });\n            this.setState({ selection: selection }, function () {\n                _this4.rebuildLoadedElements();\n                if (selectedNodes.length === 1) {\n                    _this4.scrollToView(selectedNodes[0]);\n                }\n            });\n        }).bind(this));\n    },\n\n    componentWillUnmount: function componentWillUnmount() {\n        if (!this.props.heightAutoWithMax) {\n            if (window.removeEventListener) {\n                window.removeEventListener('resize', this.updateInfiniteContainerHeight);\n            } else {\n                window.detachEvent('onresize', this.updateInfiniteContainerHeight);\n            }\n        }\n        if (this.props.elementHeight instanceof Object || this.props.tableKeys) {\n            if (window.removeEventListener) {\n                window.removeEventListener('resize', this.updateElementHeightResponsive);\n            } else {\n                window.detachEvent('resize', this.updateElementHeightResponsive);\n            }\n        }\n        if (this.refreshInterval) {\n            window.clearInterval(this.refreshInterval);\n        }\n        if (this.props.observeNodeReload) {\n            this.stopReloadListeners();\n        }\n        if (this.props.node) {\n            this.observeNodeChildren(this.props.node, true);\n        }\n    },\n\n    componentDidUpdate: function componentDidUpdate(prevProps, prevState) {\n        if (prevProps.node && this.props.node && prevProps.node.getPath() === this.props.node.getPath()) {\n            return;\n        }\n        this._loadNodeIfNotLoaded();\n    },\n\n    onScroll: function onScroll(scrollTop) {\n\n        if (!this.props.passScrollingStateToChildren) {\n            return;\n        }\n        // Maintains a series of timeouts to set this.state.isScrolling\n        // to be true when the element is scrolling.\n\n        if (this.state.scrollTimeout) {\n            clearTimeout(this.state.scrollTimeout);\n        }\n\n        var that = this,\n            scrollTimeout = setTimeout(function () {\n            that.setState({\n                isScrolling: false,\n                scrollTimeout: undefined\n            });\n        }, 150);\n\n        this.setState({\n            isScrolling: true,\n            scrollTimeout: scrollTimeout\n        });\n    },\n\n    scrollToLast: function scrollToLast() {\n        if (this.indexedElements && this.indexedElements[this.indexedElements.length - 1].node) {\n            this.scrollToView(this.indexedElements[this.indexedElements.length - 1].node);\n        }\n    },\n\n    scrollToView: function scrollToView(node) {\n        var _this5 = this;\n\n        if (!this.indexedElements || !this.refs.infinite || !this.refs.infinite.scrollable) return;\n        var scrollable = this.refs.infinite.scrollable;\n        var visibleFrame = {\n            top: scrollable.scrollTop + this.props.elementHeight / 2,\n            bottom: scrollable.scrollTop + this.state.containerHeight - this.props.elementHeight / 2\n        };\n        var realMaxScrollTop = this.indexedElements.length * this.props.elementHeight - this.state.containerHeight;\n\n        var position = -1;\n        this.indexedElements.forEach(function (e, k) {\n            if (e.node && e.node === node) position = k;\n        });\n        if (position === -1) return;\n        var elementHeight = this.props.elementHeight;\n        var scrollTarget = position * elementHeight;\n\n        if (scrollTarget > visibleFrame.top && scrollTarget < visibleFrame.bottom) {\n            // already visible;\n            return;\n        } else if (scrollTarget >= visibleFrame.bottom) {\n            scrollTarget -= this.state.containerHeight - elementHeight * 2;\n        }\n        scrollTarget = Math.min(scrollTarget, realMaxScrollTop);\n        scrollable.scrollTop = scrollTarget;\n        if (this._manualScrollPe) this._manualScrollPe.stop();\n        if (scrollable.scrollHeight < scrollTarget) {\n            this._manualScrollPe = new PeriodicalExecuter(function () {\n                scrollable.scrollTop = scrollTarget;\n                if (scrollable.scrollHeight >= scrollTarget) {\n                    _this5._manualScrollPe.stop();\n                    _this5._manualScrollPe = null;\n                }\n            }, .25);\n        }\n    },\n\n    buildElementsFromNodeEntries: function buildElementsFromNodeEntries(nodeEntries, showSelector) {\n\n        var components = [],\n            index = 0;\n        var nodeEntriesLength = nodeEntries.length;\n        nodeEntries.forEach((function (entry) {\n            var data = undefined;\n            if (entry.parent) {\n                data = {\n                    node: entry.node,\n                    key: entry.node.getPath(),\n                    id: entry.node.getPath(),\n                    mainIcon: SimpleList.PARENT_FOLDER_ICON,\n                    firstLine: \"..\",\n                    className: \"list-parent-node\",\n                    secondLine: this.context.getMessage('react.1'),\n                    onClick: this.clickRow,\n                    onDoubleClick: this.doubleClickRow,\n                    showSelector: false,\n                    selectorDisabled: true,\n                    noHover: false\n                };\n                if (this.props.entryRenderParentIcon && !this.props.tableKeys) {\n                    data['iconCell'] = this.props.entryRenderParentIcon(entry.node, entry);\n                } else {\n                    data['mainIcon'] = SimpleList.PARENT_FOLDER_ICON;\n                }\n                if (this.props.elementStyle) {\n                    data['style'] = this.props.elementStyle;\n                }\n                if (this.props.passScrollingStateToChildren) {\n                    data['parentIsScrolling'] = this.state.isScrolling;\n                }\n                components.push(React.createElement(_ListEntry.ListEntry, data));\n            } else if (entry.groupHeader) {\n                var id = entry.groupHeader,\n                    firstLine = entry.groupHeaderLabel;\n                if (this.props.entryRenderGroupHeader) {\n                    firstLine = this.props.entryRenderGroupHeader(id, firstLine);\n                }\n                data = {\n                    node: null,\n                    key: entry.groupHeader,\n                    id: id,\n                    mainIcon: null,\n                    firstLine: firstLine,\n                    className: 'list-group-header',\n                    onClick: null,\n                    showSelector: false,\n                    selectorDisabled: true,\n                    noHover: true\n                };\n                if (this.props.passScrollingStateToChildren) {\n                    data['parentIsScrolling'] = this.state.isScrolling;\n                }\n                components.push(React.createElement(_ListEntry.ListEntry, data));\n            } else {\n                data = {\n                    node: entry.node,\n                    onClick: this.clickRow,\n                    onDoubleClick: this.doubleClickRow,\n                    onSelect: this.toggleSelection,\n                    key: entry.node.getPath(),\n                    id: entry.node.getPath(),\n                    renderIcon: this.props.entryRenderIcon,\n                    renderFirstLine: this.props.entryRenderFirstLine,\n                    renderSecondLine: this.props.entryRenderSecondLine,\n                    renderThirdLine: this.props.entryRenderThirdLine,\n                    renderActions: this.props.entryRenderActions,\n                    showSelector: showSelector,\n                    selected: this.state && this.state.selection ? this.state.selection.get(entry.node) : false,\n                    actions: React.createElement(_viewsSimpleReactActionBar2['default'], { node: entry.node, actions: entry.actions, dataModel: this.dm }),\n                    selectorDisabled: !(this.props.entryEnableSelector ? this.props.entryEnableSelector(entry.node) : entry.node.isLeaf())\n                };\n                data['isFirst'] = index === 0;\n                data['isLast'] = index === nodeEntriesLength - 1;\n                index++;\n                if (this.props.elementStyle) {\n                    data['style'] = this.props.elementStyle;\n                }\n                if (this.props.passScrollingStateToChildren) {\n                    data['parentIsScrolling'] = this.state.isScrolling;\n                }\n                if (this.props.renderCustomEntry) {\n\n                    components.push(this.props.renderCustomEntry(data));\n                } else if (this.props.tableKeys) {\n\n                    if (this.props.defaultGroupBy) {\n                        data['tableKeys'] = LangUtils.deepCopy(this.props.tableKeys);\n                        delete data['tableKeys'][this.props.defaultGroupBy];\n                    } else {\n                        data['tableKeys'] = this.props.tableKeys;\n                    }\n                    components.push(React.createElement(_TableListEntry2['default'], data));\n                } else {\n\n                    components.push(React.createElement(_ConfigurableListEntry2['default'], data));\n                }\n            }\n        }).bind(this));\n\n        return components;\n    },\n\n    buildElements: function buildElements(sortingInfo, start, end, node, showSelector) {\n        var _this6 = this;\n\n        var theNode = this.props.node;\n        if (node) theNode = node;\n        var theShowSelector = this.state && this.state.showSelector;\n        if (showSelector !== undefined) theShowSelector = showSelector;\n\n        if (!this.indexedElements || this.indexedElements.length !== theNode.getChildren().size) {\n            (function () {\n                _this6.indexedElements = [];\n                var groupBy = undefined,\n                    groupByLabel = undefined,\n                    groups = undefined,\n                    groupKeys = undefined,\n                    groupLabels = undefined;\n                if (_this6.props.defaultGroupBy) {\n                    groupBy = _this6.props.defaultGroupBy;\n                    groupByLabel = _this6.props.groupByLabel || false;\n                    groups = {}, groupKeys = [], groupLabels = {};\n                }\n\n                if (!_this6.props.skipParentNavigation && theNode.getParent() && (_this6.props.dataModel.getContextNode() !== theNode || _this6.props.skipInternalDataModel)) {\n                    _this6.indexedElements.push({ node: theNode.getParent(), parent: true, actions: null });\n                }\n\n                theNode.getChildren().forEach((function (child) {\n                    if (child.getMetadata().has('cursor')) {\n                        var childCursor = parseInt(child.getMetadata().get('cursor'));\n                        this._currentCursor = Math.max(this._currentCursor ? this._currentCursor : 0, childCursor);\n                    }\n                    if (this.props.filterNodes && !this.props.filterNodes(child)) {\n                        return;\n                    }\n                    var nodeActions = this.getActionsForNode(this.dm, child);\n                    if (groupBy) {\n                        var groupValue = child.getMetadata().get(groupBy) || 'N/A';\n                        if (!groups[groupValue]) {\n                            groups[groupValue] = [];\n                            groupKeys.push(groupValue);\n                        }\n                        if (groupByLabel && child.getMetadata().has(groupByLabel) && !groupLabels[groupValue]) {\n                            groupLabels[groupValue] = child.getMetadata().get(groupByLabel);\n                        }\n                        groups[groupValue].push({ node: child, parent: false, actions: nodeActions });\n                    } else {\n                        this.indexedElements.push({ node: child, parent: false, actions: nodeActions });\n                    }\n                }).bind(_this6));\n\n                if (groupBy) {\n                    groupKeys = groupKeys.sort();\n                    groupKeys.map((function (k) {\n                        var label = k;\n                        if (groupLabels[k]) {\n                            label = groupLabels[k];\n                        } else if (this.props.renderGroupLabels) {\n                            label = this.props.renderGroupLabels(groupBy, k);\n                        }\n                        this.indexedElements.push({\n                            node: null,\n                            groupHeader: k,\n                            groupHeaderLabel: label,\n                            parent: false,\n                            actions: null\n                        });\n                        this.indexedElements = this.indexedElements.concat(groups[k]);\n                    }).bind(_this6));\n                }\n            })();\n        }\n\n        if (sortingInfo && !this.remoteSortingInfo()) {\n            (function () {\n                var attribute = sortingInfo.attribute;\n                var direction = sortingInfo.direction;\n                var sortType = sortingInfo.sortType;\n\n                var sortFunction = undefined;\n                if (sortType === 'file-natural') {\n                    sortFunction = function (a, b) {\n                        if (a.parent) {\n                            return -1;\n                        }\n                        if (b.parent) {\n                            return 1;\n                        }\n                        var nodeA = a.node;\n                        var nodeB = b.node;\n                        // Recycle always last\n                        if (nodeA.isRecycle()) return 1;\n                        if (nodeB.isRecycle()) return -1;\n                        // Folders first\n                        var aLeaf = nodeA.isLeaf();\n                        var bLeaf = nodeB.isLeaf();\n                        var res = aLeaf && !bLeaf ? 1 : !aLeaf && bLeaf ? -1 : 0;\n                        if (res !== 0) return res;\n                        res = nodeA.getLabel().localeCompare(nodeB.getLabel());\n                        return res;\n                    };\n                } else {\n                    sortFunction = function (a, b) {\n                        if (a.parent) {\n                            return -1;\n                        }\n                        var aMeta = a.node.getMetadata().get(attribute) || \"\";\n                        var bMeta = b.node.getMetadata().get(attribute) || \"\";\n                        var res = undefined;\n                        if (sortType === 'number') {\n                            aMeta = parseFloat(aMeta);\n                            bMeta = parseFloat(bMeta);\n                            res = direction === 'asc' ? aMeta - bMeta : bMeta - aMeta;\n                        } else if (sortType === 'string') {\n                            res = direction === 'asc' ? aMeta.localeCompare(bMeta) : bMeta.localeCompare(aMeta);\n                        }\n                        if (res === 0) {\n                            // Resort by label to make it stable\n                            var labComp = a.node.getLabel().localeCompare(b.node.getLabel());\n                            res = direction === 'asc' ? labComp : -labComp;\n                        }\n                        return res;\n                    };\n                }\n                _this6.indexedElements.sort(sortFunction);\n            })();\n        }\n\n        if (this.props.elementPerLine > 1) {\n            end = end * this.props.elementPerLine;\n            start = start * this.props.elementPerLine;\n        }\n        return this.indexedElements.slice(start, end);\n    },\n\n    rebuildLoadedElements: function rebuildLoadedElements() {\n        var newElements = this.buildElements(this.state.sortingInfo, 0, Math.max(this.state.elements.length, this.props.infiniteSliceCount));\n        var infiniteLoadBeginBottomOffset = newElements.length ? 200 : 0;\n        this.setState({\n            elements: newElements,\n            infiniteLoadBeginBottomOffset: infiniteLoadBeginBottomOffset\n        });\n        this.updateInfiniteContainerHeight();\n    },\n\n    handleInfiniteLoad: function handleInfiniteLoad() {\n        var elemLength = this.state.elements.length;\n        var newElements = this.buildElements(this.state.sortingInfo, elemLength, elemLength + this.props.infiniteSliceCount);\n        var infiniteLoadBeginBottomOffset = newElements.length ? 200 : 0;\n        this.setState({\n            isInfiniteLoading: false,\n            elements: this.state.elements.concat(newElements),\n            infiniteLoadBeginBottomOffset: infiniteLoadBeginBottomOffset\n        });\n    },\n\n    /**\n     * Extract remote sorting info from current node metadata\n     */\n    remoteSortingInfo: function remoteSortingInfo() {\n        var meta = this.props.node.getMetadata().get('paginationData');\n        if (meta && meta.get('total') > 1 && meta.has('remote_order')) {\n            var col = meta.get('currentOrderCol');\n            var dir = meta.get('currentOrderDir');\n            if (col && dir) {\n                return {\n                    remote: true,\n                    attribute: col,\n                    direction: dir\n                };\n            }\n        }\n        return null;\n    },\n\n    renderToolbar: function renderToolbar() {\n        var _this7 = this;\n\n        var rightButtons = [React.createElement(ReactMUI.FontIcon, {\n            key: 1,\n            tooltip: 'Reload',\n            className: \"icon-refresh\" + (this.state.loading ? \" rotating\" : \"\"),\n            onClick: this.reload\n        })];\n        var i = 2;\n        if (this.props.sortKeys) {\n\n            var sortingInfo = undefined,\n                remoteSortingInfo = this.remoteSortingInfo();\n            if (remoteSortingInfo) {\n                sortingInfo = remoteSortingInfo;\n            } else {\n                sortingInfo = this.state ? this.state.sortingInfo : null;\n            }\n            rightButtons.push(React.createElement(_SortColumns2['default'], {\n                key: i,\n                displayMode: 'menu',\n                tableKeys: this.props.sortKeys,\n                columnClicked: this.onColumnSort,\n                sortingInfo: sortingInfo\n            }));\n            i++;\n        }\n        if (this.props.additionalActions) {\n            rightButtons.push(this.props.additionalActions);\n        }\n\n        var leftToolbar = undefined,\n            paginator = undefined;\n        if (this.props.node.getMetadata().get(\"paginationData\") && this.props.node.getMetadata().get(\"paginationData\").get('total') > 1) {\n            paginator = React.createElement(_ListPaginator2['default'], { dataModel: this.dm, node: this.props.node });\n        }\n\n        if (this.props.listTitle) {\n            leftToolbar = React.createElement(\n                ReactMUI.ToolbarGroup,\n                { key: 0, float: 'left' },\n                React.createElement(\n                    'div',\n                    { className: 'list-title' },\n                    this.props.listTitle\n                )\n            );\n        }\n\n        if (this.props.searchResultData) {\n\n            leftToolbar = React.createElement(\n                ReactMUI.ToolbarGroup,\n                { key: 0, float: 'left' },\n                React.createElement(\n                    'h2',\n                    { className: 'search-results-title' },\n                    this.context.getMessage('react.3').replace('%s', this.props.searchResultData.term)\n                )\n            );\n            rightButtons = React.createElement(ReactMUI.RaisedButton, { key: 1, label: this.context.getMessage('react.4'), primary: true, onClick: this.props.searchResultData.toggleState });\n        } else if (this.actionsCache.multiple.size || this.props.multipleActions) {\n            var bulkLabel = this.context.getMessage('react.2');\n            if (this.state.selection && this.state.showSelector) {\n                bulkLabel += \" (\" + this.state.selection.size + \")\";\n            }\n            leftToolbar = React.createElement(\n                ReactMUI.ToolbarGroup,\n                { key: 0, float: 'left', className: 'hide-on-vertical-layout' },\n                React.createElement(ReactMUI.Checkbox, { ref: 'all_selector', onClick: this.selectAll }),\n                React.createElement(ReactMUI.FlatButton, { label: bulkLabel, onClick: this.toggleSelector })\n            );\n\n            if (this.state.showSelector) {\n                (function () {\n                    rightButtons = [];\n                    var index = 0;\n                    var actions = _this7.props.multipleActions || _this7.actionsCache.multiple;\n                    actions.forEach((function (a) {\n                        rightButtons.push(React.createElement(ReactMUI.RaisedButton, {\n                            key: index,\n                            label: a.options.text,\n                            'data-action': a.options.name,\n                            onClick: this.applyMultipleAction,\n                            primary: true }));\n                    }).bind(_this7));\n                    rightButtons = React.createElement(\n                        'span',\n                        null,\n                        rightButtons\n                    );\n                })();\n            }\n        }\n\n        return React.createElement(\n            ReactMUI.Toolbar,\n            null,\n            leftToolbar,\n            React.createElement(\n                ReactMUI.ToolbarGroup,\n                { key: 1, float: 'right' },\n                paginator,\n                rightButtons\n            )\n        );\n    },\n\n    render: function render() {\n        var _this8 = this;\n\n        var containerClasses = \"material-list vertical-layout layout-fill\";\n        if (this.props.className) {\n            containerClasses += \" \" + this.props.className;\n        }\n        if (this.state.showSelector) {\n            containerClasses += \" list-show-selectors\";\n        }\n        if (this.props.tableKeys) {\n            containerClasses += \" table-mode\";\n        }\n        var toolbar = undefined;\n        if (this.props.tableKeys) {\n            var tableKeys = undefined;\n            if (this.props.defaultGroupBy) {\n                tableKeys = LangUtils.deepCopy(this.props.tableKeys);\n                delete tableKeys[this.props.defaultGroupBy];\n            } else {\n                tableKeys = this.props.tableKeys;\n            }\n            var sortingInfo = undefined,\n                remoteSortingInfo = this.remoteSortingInfo();\n            if (remoteSortingInfo) {\n                sortingInfo = remoteSortingInfo;\n            } else {\n                sortingInfo = this.state ? this.state.sortingInfo : null;\n            }\n            toolbar = React.createElement(_TableListHeader2['default'], {\n                tableKeys: tableKeys,\n                loading: this.state.loading,\n                reload: this.reload,\n                ref: 'loading_indicator',\n                dm: this.props.dataModel,\n                node: this.props.node,\n                additionalActions: this.props.additionalActions,\n                onHeaderClick: this.onColumnSort,\n                sortingInfo: sortingInfo\n            });\n        } else {\n            toolbar = this.props.customToolbar ? this.props.customToolbar : !this.props.hideToolbar ? this.renderToolbar() : null;\n        }\n\n        var inlineEditor = undefined;\n        if (this.state.inlineEditionForNode) {\n            inlineEditor = React.createElement(_InlineEditor2['default'], {\n                detached: true,\n                node: this.state.inlineEditionForNode,\n                callback: this.state.inlineEditionCallback,\n                onClose: function () {\n                    _this8.setState({ inlineEditionForNode: null });\n                }\n            });\n        }\n\n        var emptyState = undefined;\n        var _props = this.props;\n        var emptyStateProps = _props.emptyStateProps;\n        var node = _props.node;\n\n        if (emptyStateProps && this.props.node.isLoaded() && !this.props.node.isLoading() && (!this.state.elements.length || this.state.elements.length === 1 && this.state.elements[0].parent)) {\n\n            var actionProps = {};\n            if (this.state.elements.length === 1 && this.state.elements[0].parent) {\n                (function () {\n                    var parentNode = _this8.state.elements[0].node;\n                    actionProps = {\n                        actionLabelId: 'react.1',\n                        actionIconClassName: SimpleList.PARENT_FOLDER_ICON,\n                        actionCallback: function actionCallback(e) {\n                            if (_this8.props.entryHandleClicks) {\n                                _this8.props.entryHandleClicks(parentNode, SimpleList.CLICK_TYPE_DOUBLE, e);\n                            }\n                        }\n                    };\n                })();\n            }\n            emptyState = React.createElement(_viewsEmptyStateView2['default'], _extends({}, emptyStateProps, actionProps));\n        } else if (emptyStateProps && emptyStateProps.checkEmptyState && emptyStateProps.checkEmptyState(this.props.node)) {\n\n            emptyState = React.createElement(_viewsEmptyStateView2['default'], emptyStateProps);\n        }\n\n        var elements = this.buildElementsFromNodeEntries(this.state.elements, this.state.showSelector);\n\n        return React.createElement(\n            'div',\n            { className: containerClasses, onContextMenu: this.contextMenuResponder, tabIndex: '0', onKeyDown: this.onKeyDown, style: this.props.style },\n            toolbar,\n            inlineEditor,\n            React.createElement(\n                'div',\n                { className: this.props.heightAutoWithMax ? \"infinite-parent-smooth-height\" : emptyState ? \"layout-fill vertical_layout\" : \"layout-fill\", ref: 'infiniteParent' },\n                !emptyState && !this.props.verticalScroller && React.createElement(\n                    Infinite,\n                    {\n                        elementHeight: this.state.elementHeight ? this.state.elementHeight : this.props.elementHeight,\n                        containerHeight: this.state.containerHeight ? this.state.containerHeight : 1,\n                        infiniteLoadBeginEdgeOffset: this.state.infiniteLoadBeginBottomOffset,\n                        onInfiniteLoad: this.handleInfiniteLoad,\n                        handleScroll: this.onScroll,\n                        ref: 'infinite'\n                    },\n                    elements\n                ),\n                !emptyState && this.props.verticalScroller && React.createElement(\n                    _reactScrollbar2['default'],\n                    {\n                        speed: 0.8,\n                        horizontalScroll: false,\n                        style: { height: this.state.containerHeight },\n                        verticalScrollbarStyle: { borderRadius: 10, width: 6 },\n                        verticalContainerStyle: { width: 8 }\n                    },\n                    React.createElement(\n                        'div',\n                        null,\n                        elements\n                    )\n                ),\n                emptyState\n            )\n        );\n    }\n\n});\n\nexports['default'] = SimpleList;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nvar _menuIconButtonMenu = require('../menu/IconButtonMenu');\n\nvar _menuIconButtonMenu2 = _interopRequireDefault(_menuIconButtonMenu);\n\nvar React = require('react');\nvar Pydio = require('pydio');\n\nvar _Pydio$requireLib = Pydio.requireLib('boot');\n\nvar PydioContextConsumer = _Pydio$requireLib.PydioContextConsumer;\n\nvar _require = require('material-ui-legacy');\n\nvar ToolbarGroup = _require.ToolbarGroup;\n\nvar SortColumns = React.createClass({\n    displayName: 'SortColumns',\n\n    propTypes: {\n        tableKeys: React.PropTypes.object.isRequired,\n        columnClicked: React.PropTypes.func,\n        sortingInfo: React.PropTypes.object,\n        displayMode: React.PropTypes.string\n    },\n\n    onMenuClicked: function onMenuClicked(object) {\n        this.props.columnClicked(object.payload);\n    },\n\n    onHeaderClick: function onHeaderClick(key, callback) {\n        var data = this.props.tableKeys[key];\n        if (data && data['sortType'] && this.props.columnClicked) {\n            data['name'] = key;\n            this.props.columnClicked(data, callback);\n        }\n    },\n\n    getColumnsItems: function getColumnsItems(displayMode) {\n        var _this = this;\n\n        var controller = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1];\n\n        var items = [];\n        var _callback = function _callback() {\n            if (controller) {\n                controller.notify('actions_refreshed');\n            }\n        };\n\n        var _loop = function (key) {\n            if (!_this.props.tableKeys.hasOwnProperty(key)) return 'continue';\n            var data = _this.props.tableKeys[key];\n            var style = data['width'] ? { width: data['width'] } : null;\n            var icon = undefined;\n            var className = 'cell header_cell cell-' + key;\n            if (data['sortType']) {\n                className += ' sortable';\n                if (_this.props.sortingInfo && (_this.props.sortingInfo.attribute === key || _this.props.sortingInfo.attribute === data['sortAttribute'] || _this.props.sortingInfo.attribute === data['remoteSortAttribute'])) {\n                    icon = _this.props.sortingInfo.direction === 'asc' ? 'mdi mdi-arrow-up' : 'mdi mdi-arrow-down';\n                    className += ' active-sort-' + _this.props.sortingInfo.direction;\n                }\n            }\n            if (displayMode === 'menu') {\n                data['name'] = key;\n                items.push({\n                    payload: data,\n                    text: data['label'],\n                    iconClassName: icon\n                });\n            } else if (displayMode === 'menu_data') {\n                items.push({\n                    name: data['label'],\n                    callback: function callback() {\n                        _this.onHeaderClick(key, _callback);\n                    },\n                    icon_class: icon || '__INSET__'\n                });\n            } else {\n                items.push(React.createElement(\n                    'span',\n                    {\n                        key: key,\n                        className: className,\n                        style: style,\n                        onClick: function () {\n                            _this.onHeaderClick(key, _callback);\n                        }\n                    },\n                    data['label']\n                ));\n            }\n        };\n\n        for (var key in this.props.tableKeys) {\n            var _ret = _loop(key);\n\n            if (_ret === 'continue') continue;\n        }\n        return items;\n    },\n\n    buildSortingMenuItems: function buildSortingMenuItems(controller) {\n        return this.getColumnsItems('menu_data', controller);\n    },\n\n    componentDidMount: function componentDidMount() {\n\n        var sortAction = new Action({\n            name: 'sort_action',\n            icon_class: 'mdi mdi-sort-descending',\n            text_id: 450,\n            title_id: 450,\n            text: this.props.getMessage(450),\n            title: this.props.getMessage(450),\n            hasAccessKey: false,\n            subMenu: true,\n            subMenuUpdateImage: true\n        }, {\n            selection: false,\n            dir: true,\n            actionBar: true,\n            actionBarGroup: 'display_toolbar',\n            contextMenu: false,\n            infoPanel: false\n        }, {}, {}, {\n            dynamicBuilder: this.buildSortingMenuItems\n        });\n        var buttons = new Map();\n        buttons.set('sort_action', sortAction);\n        this.props.pydio.getController().updateGuiActions(buttons);\n    },\n\n    componentWillUnmount: function componentWillUnmount() {\n        this.props.pydio.getController().deleteFromGuiActions('sort_action');\n    },\n\n    render: function render() {\n        if (this.props.displayMode === 'menu') {\n            return React.createElement(_menuIconButtonMenu2['default'], { buttonTitle: 'Sort by...', buttonClassName: 'mdi mdi-sort-descending', menuItems: this.getColumnsItems('menu', this.props.pydio.getController()), onMenuClicked: this.onMenuClicked });\n        } else {\n            return React.createElement(\n                ToolbarGroup,\n                { float: 'left' },\n                this.getColumnsItems('header', this.props.pydio.getController())\n            );\n        }\n    }\n});\n\nexports['default'] = SortColumns = PydioContextConsumer(SortColumns);\nexports['default'] = SortColumns;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n\"use strict\";\n\nexports.__esModule = true;\n\nvar _utilDND = require('../util/DND');\n\n/***************************/\n/* REACT DND SORTABLE LIST\n /**************************/\n/**\n * Specifies the drag source contract.\n * Only `beginDrag` function is required.\n */\nvar sortableItemSource = {\n    beginDrag: function beginDrag(props) {\n        // Return the data describing the dragged item\n        return { id: props.id };\n    },\n    endDrag: function endDrag(props) {\n        props.endSwitching();\n    }\n};\n\nvar sortableItemTarget = {\n\n    hover: function hover(props, monitor) {\n        var draggedId = monitor.getItem().id;\n        if (draggedId !== props.id) {\n            props.switchItems(draggedId, props.id);\n        }\n    }\n\n};\n\nvar sortableItem = React.createClass({\n    displayName: \"sortableItem\",\n\n    propTypes: {\n        connectDragSource: React.PropTypes.func.isRequired,\n        connectDropTarget: React.PropTypes.func.isRequired,\n        isDragging: React.PropTypes.bool.isRequired,\n        id: React.PropTypes.any.isRequired,\n        label: React.PropTypes.string.isRequired,\n        switchItems: React.PropTypes.func.isRequired,\n        removable: React.PropTypes.bool,\n        onRemove: React.PropTypes.func\n    },\n\n    removeClicked: function removeClicked() {\n        this.props.onRemove(this.props.id);\n    },\n\n    render: function render() {\n        // Your component receives its own props as usual\n        var id = this.props.id;\n\n        // These two props are injected by React DnD,\n        // as defined by your `collect` function above:\n        var isDragging = this.props.isDragging;\n        var connectDragSource = this.props.connectDragSource;\n        var connectDropTarget = this.props.connectDropTarget;\n\n        var remove;\n        if (this.props.removable) {\n            remove = React.createElement(\"span\", { className: \"button mdi mdi-close\", onClick: this.removeClicked });\n        }\n        return React.createElement(\n            ReactMUI.Paper,\n            {\n                ref: function (instance) {\n                    connectDropTarget(ReactDOM.findDOMNode(instance));\n                    connectDragSource(ReactDOM.findDOMNode(instance));\n                },\n                zDepth: 1,\n                style: { opacity: isDragging ? 0 : 1 }\n            },\n            React.createElement(\n                \"div\",\n                { className: this.props.className },\n                this.props.label,\n                remove\n            )\n        );\n    }\n});\n\nvar NonDraggableListItem = React.createClass({\n    displayName: \"NonDraggableListItem\",\n\n    render: function render() {\n        var remove;\n        if (this.props.removable) {\n            remove = React.createElement(\"span\", { className: \"button mdi mdi-close\", onClick: this.removeClicked });\n        }\n        return React.createElement(\n            ReactMUI.Paper,\n            { zDepth: 1 },\n            React.createElement(\n                \"div\",\n                { className: this.props.className },\n                this.props.label,\n                remove\n            )\n        );\n    }\n});\n\nvar DraggableListItem;\nif (window.ReactDND) {\n    DraggableListItem = ReactDND.flow(ReactDND.DragSource(_utilDND.Types.SORTABLE_LIST_ITEM, sortableItemSource, _utilDND.collect), ReactDND.DropTarget(_utilDND.Types.SORTABLE_LIST_ITEM, sortableItemTarget, _utilDND.collectDrop))(sortableItem);\n} else {\n    DraggableListItem = NonDraggableListItem;\n}\n\nvar SortableList = React.createClass({\n    displayName: \"SortableList\",\n\n    propTypes: {\n        values: React.PropTypes.array.isRequired,\n        onOrderUpdated: React.PropTypes.func,\n        removable: React.PropTypes.bool,\n        onRemove: React.PropTypes.func,\n        className: React.PropTypes.string,\n        itemClassName: React.PropTypes.string\n    },\n\n    getInitialState: function getInitialState() {\n        return { values: this.props.values };\n    },\n    componentWillReceiveProps: function componentWillReceiveProps(props) {\n        this.setState({ values: props.values, switchData: null });\n    },\n\n    findItemIndex: function findItemIndex(itemId, data) {\n        for (var i = 0; i < data.length; i++) {\n            if (data[i]['payload'] == itemId) {\n                return i;\n            }\n        }\n    },\n\n    switchItems: function switchItems(oldId, newId) {\n        var oldIndex = this.findItemIndex(oldId, this.state.values);\n        var oldItem = this.state.values[oldIndex];\n        var newIndex = this.findItemIndex(newId, this.state.values);\n        var newItem = this.state.values[newIndex];\n\n        var currentValues = this.state.values.slice();\n        currentValues[oldIndex] = newItem;\n        currentValues[newIndex] = oldItem;\n\n        // Check that it did not come back to original state\n        var oldPrevious = this.findItemIndex(oldId, this.props.values);\n        var newPrevious = this.findItemIndex(newId, this.props.values);\n        if (oldPrevious == newIndex && newPrevious == oldIndex) {\n            this.setState({ values: currentValues, switchData: null });\n            //console.log(\"no more moves\");\n        } else {\n                this.setState({ values: currentValues, switchData: { oldId: oldId, newId: newId } });\n                //console.log({oldId:oldIndex, newId:newIndex});\n            }\n    },\n\n    endSwitching: function endSwitching() {\n        if (this.state.switchData) {\n            // Check that it did not come back to original state\n            if (this.props.onOrderUpdated) {\n                this.props.onOrderUpdated(this.state.switchData.oldId, this.state.switchData.newId, this.state.values);\n            }\n        }\n        this.setState({ switchData: null });\n    },\n\n    render: function render() {\n        var switchItems = this.switchItems;\n        return React.createElement(\n            \"div\",\n            { className: this.props.className },\n            this.state.values.map((function (item) {\n                return React.createElement(DraggableListItem, {\n                    id: item.payload,\n                    key: item.payload,\n                    label: item.text,\n                    switchItems: switchItems,\n                    endSwitching: this.endSwitching,\n                    removable: this.props.removable,\n                    onRemove: this.props.onRemove,\n                    className: this.props.itemClassName\n                });\n            }).bind(this))\n        );\n    }\n});\n\nexports[\"default\"] = SortableList;\nmodule.exports = exports[\"default\"];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nvar _ListEntryNodeListenerMixin = require('./ListEntryNodeListenerMixin');\n\nvar _ListEntryNodeListenerMixin2 = _interopRequireDefault(_ListEntryNodeListenerMixin);\n\nvar _ListEntry = require('./ListEntry');\n\nvar _InlineEditor = require('./InlineEditor');\n\nvar _InlineEditor2 = _interopRequireDefault(_InlineEditor);\n\n/**\n * Specific list entry rendered as a table row. Not a real table, CSS used.\n */\nexports['default'] = React.createClass({\n    displayName: 'TableListEntry',\n\n    mixins: [_ListEntryNodeListenerMixin2['default']],\n\n    propTypes: {\n        node: React.PropTypes.instanceOf(AjxpNode),\n        tableKeys: React.PropTypes.object.isRequired,\n        renderActions: React.PropTypes.func\n        // See also ListEntry nodes\n    },\n\n    render: function render() {\n        var _this = this;\n\n        var actions = this.props.actions;\n        if (this.props.renderActions) {\n            actions = this.props.renderActions(this.props.node);\n        }\n\n        var cells = [];\n        var firstKey = true;\n        var meta = this.props.node.getMetadata();\n        for (var key in this.props.tableKeys) {\n            if (!this.props.tableKeys.hasOwnProperty(key)) continue;\n\n            var data = this.props.tableKeys[key];\n            var style = data['width'] ? { width: data['width'] } : null;\n            var value = undefined,\n                rawValue = undefined;\n            if (data.renderCell) {\n                data['name'] = key;\n                value = data.renderCell(this.props.node, data);\n            } else if (key === 'ajxp_modiftime' && meta.get('ajxp_relativetime')) {\n                value = meta.get('ajxp_relativetime');\n            } else {\n                value = meta.get(key);\n            }\n            rawValue = meta.get(key);\n            var inlineEditor = undefined;\n            if (this.state && this.state.inlineEdition && firstKey) {\n                inlineEditor = React.createElement(_InlineEditor2['default'], {\n                    node: this.props.node,\n                    onClose: function () {\n                        _this.setState({ inlineEdition: false });\n                    },\n                    callback: this.state.inlineEditionCallback\n                });\n                var _style = this.props.style || {};\n                _style.position = 'relative';\n                this.props.style = _style;\n            }\n            cells.push(React.createElement(\n                'span',\n                { key: key, className: 'cell cell-' + key, title: rawValue, style: style, 'data-label': data['label'] },\n                inlineEditor,\n                value\n            ));\n            firstKey = false;\n        }\n\n        return React.createElement(_ListEntry.DragDropListEntry, _extends({}, this.props, {\n            iconCell: null,\n            firstLine: cells,\n            actions: actions\n        }));\n    }\n\n});\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nvar _utilMessagesConsumerMixin = require('../util/MessagesConsumerMixin');\n\nvar _utilMessagesConsumerMixin2 = _interopRequireDefault(_utilMessagesConsumerMixin);\n\nvar _SortColumns = require('./SortColumns');\n\nvar _SortColumns2 = _interopRequireDefault(_SortColumns);\n\nvar _ListPaginator = require('./ListPaginator');\n\nvar _ListPaginator2 = _interopRequireDefault(_ListPaginator);\n\n/**\n * Specific header for Table layout, reading metadata from node and using keys\n */\nexports['default'] = React.createClass({\n    displayName: 'TableListHeader',\n\n    mixins: [_utilMessagesConsumerMixin2['default']],\n\n    propTypes: {\n        tableKeys: React.PropTypes.object.isRequired,\n        loading: React.PropTypes.bool,\n        reload: React.PropTypes.func,\n        dm: React.PropTypes.instanceOf(PydioDataModel),\n        node: React.PropTypes.instanceOf(AjxpNode),\n        onHeaderClick: React.PropTypes.func,\n        sortingInfo: React.PropTypes.object\n    },\n\n    render: function render() {\n        var headers = undefined,\n            paginator = undefined;\n        if (this.props.node.getMetadata().get(\"paginationData\") && this.props.node.getMetadata().get(\"paginationData\").get('total') > 1) {\n            paginator = React.createElement(_ListPaginator2['default'], { dataModel: this.props.dm, node: this.props.node });\n        }\n        return React.createElement(\n            ReactMUI.Toolbar,\n            { className: 'toolbarTableHeader' },\n            React.createElement(_SortColumns2['default'], _extends({ displayMode: 'tableHeader' }, this.props, { columnClicked: this.props.onHeaderClick })),\n            React.createElement(\n                ReactMUI.ToolbarGroup,\n                { float: 'right' },\n                paginator,\n                React.createElement(ReactMUI.FontIcon, {\n                    key: 1,\n                    tooltip: this.context.getMessage('149', ''),\n                    className: \"icon-refresh\" + (this.props.loading ? \" rotating\" : \"\"),\n                    onClick: this.props.reload\n                }),\n                this.props.additionalActions\n            )\n        );\n    }\n});\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nvar _Utils = require('./Utils');\n\nvar _Utils2 = _interopRequireDefault(_Utils);\n\nvar _MenuItemsConsumer = require('./MenuItemsConsumer');\n\nvar _MenuItemsConsumer2 = _interopRequireDefault(_MenuItemsConsumer);\n\nvar React = require('react');\nvar ReactDOM = require('react-dom');\n\nvar _require = require('material-ui');\n\nvar Menu = _require.Menu;\n\nvar Controller = require('pydio/model/controller');\n\nvar ButtonMenu = React.createClass({\n    displayName: 'ButtonMenu',\n\n    propTypes: {\n        buttonTitle: React.PropTypes.oneOfType([React.PropTypes.string, React.PropTypes.object]).isRequired,\n        menuItems: React.PropTypes.array.isRequired,\n        className: React.PropTypes.string,\n        raised: React.PropTypes.bool,\n        direction: React.PropTypes.oneOf(['left', 'right'])\n    },\n\n    componentDidMount: function componentDidMount() {\n        var _this = this;\n\n        if (this.props.openOnEvent) {\n            this.props.pydio.observe(this.props.openOnEvent, function () {\n                _this.showMenu();\n            });\n        }\n    },\n\n    getInitialState: function getInitialState() {\n        return { showMenu: false };\n    },\n\n    showMenu: function showMenu(event) {\n        var anchor = undefined;\n        if (event) {\n            anchor = event.currentTarget;\n        } else {\n            anchor = this._buttonDOM;\n        }\n        this.setState({\n            showMenu: true,\n            anchor: anchor\n        });\n    },\n\n    menuClicked: function menuClicked(event, index, object) {\n        //object.payload();\n        this.setState({ showMenu: false });\n    },\n\n    render: function render() {\n        var _this2 = this;\n\n        var label = React.createElement(\n            'span',\n            null,\n            this.props.buttonTitle,\n            ' ',\n            React.createElement('span', { className: 'icon-caret-down' })\n        );\n        var button = undefined;\n        var props = {\n            primary: this.props.primary,\n            secondary: this.props.secondary,\n            disabled: this.props.disabeld,\n            label: label,\n            onTouchTap: this.showMenu,\n            onClick: function onClick(e) {\n                return e.stopPropagation();\n            }\n        };\n        var menuItems = this.props.menuItems;\n        var _state = this.state;\n        var showMenu = _state.showMenu;\n        var anchor = _state.anchor;\n\n        if (menuItems.length) {\n            if (this.props.raised) {\n                button = React.createElement(MaterialUI.RaisedButton, _extends({}, props, { style: this.props.buttonStyle, labelStyle: this.props.buttonLabelStyle, ref: function (b) {\n                        _this2._buttonDOM = ReactDOM.findDOMNode(b);\n                    } }));\n            } else {\n                button = React.createElement(MaterialUI.FlatButton, _extends({}, props, { style: this.props.buttonStyle, labelStyle: this.props.buttonLabelStyle, ref: function (b) {\n                        _this2._buttonDOM = ReactDOM.findDOMNode(b);\n                    } }));\n            }\n        }\n        return React.createElement(\n            'span',\n            { id: this.props.id, className: this.props.className },\n            button,\n            React.createElement(\n                MaterialUI.Popover,\n                {\n                    className: 'menuPopover',\n                    open: showMenu,\n                    anchorEl: anchor,\n                    anchorOrigin: { horizontal: this.props.direction || 'left', vertical: 'bottom' },\n                    targetOrigin: { horizontal: this.props.direction || 'left', vertical: 'top' },\n                    onRequestClose: function () {\n                        _this2.setState({ showMenu: false });\n                    },\n                    style: { marginTop: 1 },\n                    useLayerForClickAway: false\n                },\n                _Utils2['default'].itemsToMenu(menuItems, this.menuClicked)\n            )\n        );\n    }\n\n});\n\nexports['default'] = _MenuItemsConsumer2['default'](ButtonMenu);\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _pydioModelContextMenu = require('pydio/model/context-menu');\n\nvar _pydioModelContextMenu2 = _interopRequireDefault(_pydioModelContextMenu);\n\nvar _Utils = require('./Utils');\n\nvar _Utils2 = _interopRequireDefault(_Utils);\n\nvar _PopupMenu = require('./PopupMenu');\n\nvar _PopupMenu2 = _interopRequireDefault(_PopupMenu);\n\nvar _require = require('react');\n\nvar Component = _require.Component;\n\nvar dims = {\n    MENU_ITEM_HEIGHT: 32, //48 if not display:compact\n    MENU_SEP_HEIGHT: 16,\n    MENU_VERTICAL_PADDING: 8,\n    MENU_WIDTH: 250,\n    OFFSET_VERTICAL: 8,\n    OFFSET_HORIZONTAL: 8\n};\n\nvar ContextMenu = (function (_Component) {\n    _inherits(ContextMenu, _Component);\n\n    function ContextMenu() {\n        _classCallCheck(this, ContextMenu);\n\n        _Component.apply(this, arguments);\n    }\n\n    ContextMenu.prototype.modelOpen = function modelOpen(node) {\n        var position = _pydioModelContextMenu2['default'].getInstance().getPosition();\n        var items = undefined;\n        if (node) {\n            var dm = pydio.getContextHolder();\n            if (dm.getSelectedNodes().indexOf(node) !== -1) {\n                this.openMenu('selectionContext', position);\n            } else {\n                pydio.observeOnce(\"actions_refreshed\", (function (dataModel) {\n                    this.openMenu('selectionContext', position);\n                }).bind(this));\n                dm.setSelectedNodes([node]);\n            }\n        } else {\n            this.openMenu('genericContext', position);\n        }\n    };\n\n    ContextMenu.prototype.openMenu = function openMenu(context, position) {\n        var items = this.computeMenuItems(context);\n        this._items = items;\n        var mobile = this.props.pydio.UI.MOBILE_EXTENSIONS;\n        if (!mobile) {\n            position = this.computeVisiblePosition(position, items);\n            this.refs['menu'].showMenu({\n                top: position.y,\n                left: position.x\n            }, items);\n        } else {\n            this.refs['menu'].showMenu({\n                bottom: 0,\n                left: 0,\n                right: 0,\n                height: 200,\n                zIndex: 10000,\n                overflowY: 'auto'\n            }, items);\n        }\n    };\n\n    ContextMenu.prototype.computeMenuItems = function computeMenuItems(context) {\n        var actions = this.props.pydio.Controller.getContextActions(context, ['inline', 'info_panel', 'info_panel_share']);\n        return _Utils2['default'].pydioActionsToItems(actions);\n    };\n\n    ContextMenu.prototype.computeVisiblePosition = function computeVisiblePosition(position, items) {\n        var menuHeight = dims.MENU_VERTICAL_PADDING * 2;\n        items.map(function (it) {\n            if (it.separator) menuHeight += dims.MENU_SEP_HEIGHT;else menuHeight += dims.MENU_ITEM_HEIGHT;\n        });\n        var menuWidth = dims.MENU_WIDTH;\n        var windowW = Math.max(document.documentElement.clientWidth, window.innerWidth || 0);\n        var windowH = Math.max(document.documentElement.clientHeight, window.innerHeight || 0);\n        if (position.x + menuWidth > windowW) {\n            position.x = Math.max(position.x - menuWidth, 10) - dims.OFFSET_HORIZONTAL;\n        } else {\n            position.x += dims.OFFSET_HORIZONTAL;\n        }\n        if (position.y + menuHeight > windowH) {\n            position.y = Math.max(position.y - menuHeight, 10) - dims.OFFSET_VERTICAL;\n        } else {\n            position.y += dims.OFFSET_VERTICAL;\n        }\n        return position;\n    };\n\n    ContextMenu.prototype.componentDidMount = function componentDidMount() {\n        this._modelOpen = this.modelOpen.bind(this);\n        _pydioModelContextMenu2['default'].getInstance().observe(\"open\", this._modelOpen);\n    };\n\n    ContextMenu.prototype.componentWillUnmount = function componentWillUnmount() {\n        _pydioModelContextMenu2['default'].getInstance().stopObserving(\"open\", this._modelOpen);\n    };\n\n    ContextMenu.prototype.render = function render() {\n        var mobile = this.props.pydio.UI.MOBILE_EXTENSIONS;\n        return React.createElement(_PopupMenu2['default'], {\n            ref: 'menu',\n            menuItems: this._items || [],\n            onMenuClosed: this.props.onMenuClosed,\n            menuProps: mobile ? { width: 600, autoWidth: false, desktop: false } : {},\n            zDepth: mobile ? 2 : 1\n        });\n    };\n\n    return ContextMenu;\n})(Component);\n\nexports['default'] = ContextMenu;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _Utils = require('./Utils');\n\nvar _Utils2 = _interopRequireDefault(_Utils);\n\nvar _MenuItemsConsumer = require('./MenuItemsConsumer');\n\nvar _MenuItemsConsumer2 = _interopRequireDefault(_MenuItemsConsumer);\n\nvar React = require('react');\n\nvar _require = require('material-ui');\n\nvar IconButton = _require.IconButton;\nvar Popover = _require.Popover;\n\nvar IconButtonMenu = (function (_React$Component) {\n    _inherits(IconButtonMenu, _React$Component);\n\n    function IconButtonMenu(props, context) {\n        _classCallCheck(this, IconButtonMenu);\n\n        _React$Component.call(this, props, context);\n        this.state = { showMenu: false };\n    }\n\n    IconButtonMenu.prototype.showMenu = function showMenu(event) {\n        this.setState({\n            showMenu: true,\n            anchor: event.currentTarget\n        });\n    };\n\n    IconButtonMenu.prototype.closeMenu = function closeMenu(event, index, menuItem) {\n        this.setState({ showMenu: false });\n    };\n\n    IconButtonMenu.prototype.render = function render() {\n        var _this = this;\n\n        return React.createElement(\n            'span',\n            { className: \"toolbars-button-menu \" + (this.props.className ? this.props.className : '') },\n            React.createElement(IconButton, {\n                ref: 'menuButton',\n                tooltip: this.props.buttonTitle,\n                iconClassName: this.props.buttonClassName,\n                onTouchTap: this.showMenu.bind(this),\n                iconStyle: this.props.buttonStyle\n            }),\n            React.createElement(\n                Popover,\n                {\n                    open: this.state.showMenu,\n                    anchorEl: this.state.anchor,\n                    anchorOrigin: { horizontal: this.props.popoverDirection || 'right', vertical: this.props.popoverTargetPosition || 'bottom' },\n                    targetOrigin: { horizontal: this.props.popoverDirection || 'right', vertical: 'top' },\n                    onRequestClose: function () {\n                        _this.setState({ showMenu: false });\n                    },\n                    useLayerForClickAway: false\n                },\n                _Utils2['default'].itemsToMenu(this.props.menuItems, this.closeMenu.bind(this), false, this.props.menuProps || undefined)\n            )\n        );\n    };\n\n    return IconButtonMenu;\n})(React.Component);\n\nIconButtonMenu.propTypes = {\n    buttonTitle: React.PropTypes.string.isRequired,\n    buttonClassName: React.PropTypes.string.isRequired,\n    className: React.PropTypes.string,\n    popoverDirection: React.PropTypes.oneOf(['right', 'left']),\n    popoverPosition: React.PropTypes.oneOf(['top', 'bottom']),\n    menuProps: React.PropTypes.object,\n    menuItems: React.PropTypes.array.isRequired\n};\n\nexports['default'] = _MenuItemsConsumer2['default'](IconButtonMenu);\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar React = require('react');\n\nvar _require = require('material-ui');\n\nvar IconButton = _require.IconButton;\nvar Popover = _require.Popover;\n\nvar IconButtonPopover = (function (_React$Component) {\n    _inherits(IconButtonPopover, _React$Component);\n\n    function IconButtonPopover(props, context) {\n        _classCallCheck(this, IconButtonPopover);\n\n        _React$Component.call(this, props, context);\n        this.state = { showPopover: false };\n    }\n\n    IconButtonPopover.prototype.showPopover = function showPopover(event) {\n        this.setState({\n            showPopover: true,\n            anchor: event.currentTarget\n        });\n    };\n\n    IconButtonPopover.prototype.render = function render() {\n        var _this = this;\n\n        return React.createElement(\n            'span',\n            { className: \"toolbars-button-menu \" + (this.props.className ? this.props.className : '') },\n            React.createElement(IconButton, {\n                ref: 'menuButton',\n                tooltip: this.props.buttonTitle,\n                iconClassName: this.props.buttonClassName,\n                onTouchTap: this.showPopover.bind(this),\n                iconStyle: this.props.buttonStyle\n            }),\n            React.createElement(\n                Popover,\n                {\n                    open: this.state.showPopover,\n                    anchorEl: this.state.anchor,\n                    anchorOrigin: { horizontal: this.props.direction || 'right', vertical: 'bottom' },\n                    targetOrigin: { horizontal: this.props.direction || 'right', vertical: 'top' },\n                    onRequestClose: function () {\n                        _this.setState({ showPopover: false });\n                    },\n                    useLayerForClickAway: false\n                },\n                this.props.popoverContent\n            )\n        );\n    };\n\n    return IconButtonPopover;\n})(React.Component);\n\nIconButtonPopover.propTypes = {\n    buttonTitle: React.PropTypes.string.isRequired,\n    buttonClassName: React.PropTypes.string.isRequired,\n    className: React.PropTypes.string,\n    direction: React.PropTypes.oneOf(['right', 'left']),\n    popoverContent: React.PropTypes.object.isRequired\n};\n\nexports['default'] = IconButtonPopover;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _Utils = require('./Utils');\n\nvar _Utils2 = _interopRequireDefault(_Utils);\n\nvar React = require('react');\nvar Controller = require('pydio/model/controller');\n\nexports['default'] = function (Component) {\n    var Wrapped = (function (_React$Component) {\n        _inherits(Wrapped, _React$Component);\n\n        function Wrapped(props, context) {\n            _classCallCheck(this, Wrapped);\n\n            _React$Component.call(this, props, context);\n            this.state = {\n                menuItems: this.props.menuItems || []\n            };\n        }\n\n        Wrapped.prototype.componentDidMount = function componentDidMount() {\n            var _this = this;\n\n            if (this.props.controller && !this.props.menuItems) {\n                this._observer = function () {\n                    var actions = _this.props.controller.getContextActions('genericContext', null, _this.props.toolbars);\n                    var menuItems = _Utils2['default'].pydioActionsToItems(actions);\n                    _this.setState({ menuItems: menuItems });\n                };\n                if (this.props.controller === this.props.pydio.Controller) {\n                    this.props.pydio.observe(\"actions_refreshed\", this._observer);\n                } else {\n                    this.props.controller.observe(\"actions_refreshed\", this._observer);\n                }\n                this._observer();\n            }\n        };\n\n        Wrapped.prototype.componentWillUnmount = function componentWillUnmount() {\n            if (this._observer) {\n                if (this.props.controller === this.props.pydio.Controller) {\n                    this.props.pydio.stopObserving(\"actions_refreshed\", this._observer);\n                } else {\n                    this.props.controller.stopObserving(\"actions_refreshed\", this._observer);\n                }\n            }\n        };\n\n        Wrapped.prototype.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n            if (nextProps.menuItems && nextProps.menuItems !== this.props.menuItems) {\n                this.setState({ menuItems: nextProps.menuItems });\n            }\n        };\n\n        Wrapped.prototype.render = function render() {\n            return React.createElement(Component, _extends({}, this.props, { menuItems: this.state.menuItems }));\n        };\n\n        return Wrapped;\n    })(React.Component);\n\n    Wrapped.propTypes = {\n        menuItems: React.PropTypes.array,\n        toolbars: React.PropTypes.array,\n        controller: React.PropTypes.instanceOf(Controller),\n        pydio: React.PropTypes.instanceOf(Pydio)\n    };\n\n    return Wrapped;\n};\n\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nvar _Utils = require('./Utils');\n\nvar _Utils2 = _interopRequireDefault(_Utils);\n\nvar React = require('react');\nvar ReactDOM = require('react-dom');\n\nvar _require = require('material-ui');\n\nvar Menu = _require.Menu;\nvar Paper = _require.Paper;\nexports['default'] = React.createClass({\n    displayName: 'PopupMenu',\n\n    propTypes: {\n        menuItems: React.PropTypes.array.isRequired,\n        onExternalClickCheckElements: React.PropTypes.func,\n        className: React.PropTypes.string,\n        style: React.PropTypes.object,\n        onMenuClosed: React.PropTypes.func\n    },\n\n    getInitialState: function getInitialState() {\n        return { showMenu: false, menuItems: this.props.menuItems };\n    },\n    showMenu: function showMenu() {\n        var style = arguments.length <= 0 || arguments[0] === undefined ? null : arguments[0];\n        var menuItems = arguments.length <= 1 || arguments[1] === undefined ? null : arguments[1];\n\n        this.setState({\n            showMenu: true,\n            style: style,\n            menuItems: menuItems ? menuItems : this.state.menuItems\n        });\n    },\n    hideMenu: function hideMenu(event) {\n        if (!event) {\n            this.setState({ showMenu: false });\n            if (this.props.onMenuClosed) this.props.onMenuClosed();\n            return;\n        }\n        // Firefox trigger a click event when you mouse up on contextmenu event\n        if (typeof event !== 'undefined' && event.button === 2 && event.type !== 'contextmenu') {\n            return;\n        }\n        var node = ReactDOM.findDOMNode(this.refs.menuContainer);\n        if (node.contains(event.target) || node === event.target) {\n            return;\n        }\n\n        this.setState({ showMenu: false });\n        if (this.props.onMenuClosed) this.props.onMenuClosed();\n    },\n    componentDidMount: function componentDidMount() {\n        this._observer = this.hideMenu;\n    },\n    componentWillUnmount: function componentWillUnmount() {\n        document.removeEventListener('click', this._observer, false);\n    },\n    componentWillReceiveProps: function componentWillReceiveProps(nextProps) {\n        if (nextProps.menuItems) {\n            this.setState({ menuItems: nextProps.menuItems });\n        }\n    },\n    componentDidUpdate: function componentDidUpdate(prevProps, nextProps) {\n        if (this.state.showMenu) {\n            document.addEventListener('click', this._observer, false);\n        } else {\n            document.removeEventListener('click', this._observer, false);\n        }\n    },\n\n    menuClicked: function menuClicked(event, index, menuItem) {\n        this.hideMenu();\n    },\n\n    render: function render() {\n\n        var style = this.state.style || {};\n        style = _extends({}, style, { zIndex: 1000 });\n        var menu = _Utils2['default'].itemsToMenu(this.state.menuItems, this.menuClicked, false, _extends({ desktop: true, display: 'right', width: 250 }, this.props.menuProps));\n        if (this.state.showMenu) {\n            return React.createElement(\n                Paper,\n                { zDepth: this.props.zDepth || 1, ref: 'menuContainer', className: 'menu-positioner', style: style },\n                menu\n            );\n        } else {\n            return null;\n        }\n    }\n\n});\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nvar _Utils = require('./Utils');\n\nvar _Utils2 = _interopRequireDefault(_Utils);\n\nvar _IconButtonMenu = require('./IconButtonMenu');\n\nvar _IconButtonMenu2 = _interopRequireDefault(_IconButtonMenu);\n\nvar _ButtonMenu = require('./ButtonMenu');\n\nvar _ButtonMenu2 = _interopRequireDefault(_ButtonMenu);\n\nvar _IconButtonPopover = require('./IconButtonPopover');\n\nvar _IconButtonPopover2 = _interopRequireDefault(_IconButtonPopover);\n\n(function (global) {\n    exports['default'] = React.createClass({\n        displayName: 'Toolbar',\n\n        propTypes: {\n            toolbars: React.PropTypes.array,\n            groupOtherList: React.PropTypes.array,\n            renderingType: React.PropTypes.string,\n            controller: React.PropTypes.instanceOf(Controller),\n            toolbarStyle: React.PropTypes.object,\n            buttonStyle: React.PropTypes.object\n        },\n\n        componentDidMount: function componentDidMount() {\n            this._observer = (function () {\n                if (!this.isMounted()) return;\n                this.setState({\n                    groups: this.props.controller.getToolbarsActions(this.props.toolbars, this.props.groupOtherList)\n                });\n            }).bind(this);\n            if (this.props.controller === pydio.Controller) {\n                pydio.observe(\"actions_refreshed\", this._observer);\n            } else {\n                this.props.controller.observe(\"actions_refreshed\", this._observer);\n            }\n        },\n\n        componentWillUnmount: function componentWillUnmount() {\n            if (this.props.controller === pydio.Controller) {\n                pydio.stopObserving(\"actions_refreshed\", this._observer);\n            } else {\n                this.props.controller.stopObserving(\"actions_refreshed\", this._observer);\n            }\n        },\n\n        componentWillReceiveProps: function componentWillReceiveProps(nextProps) {\n            if (nextProps.toolbars !== this.props.toolbars) {\n                this.setState({\n                    groups: this.props.controller.getToolbarsActions(nextProps.toolbars, nextProps.groupOtherList)\n                });\n            }\n        },\n\n        getInitialState: function getInitialState() {\n            return {\n                groups: this.props.controller.getToolbarsActions(this.props.toolbars, this.props.groupOtherList)\n            };\n        },\n\n        getDefaultProps: function getDefaultProps() {\n            return {\n                controller: global.pydio.Controller,\n                renderingType: 'button',\n                groupOtherList: []\n            };\n        },\n\n        render: function render() {\n            var groups = this.state.groups;\n            var actions = [];\n            var _props = this.props;\n            var toolbars = _props.toolbars;\n            var renderingType = _props.renderingType;\n            var groupOtherList = _props.groupOtherList;\n            var buttonStyle = _props.buttonStyle;\n            var tooltipPosition = _props.tooltipPosition;\n            var controller = _props.controller;\n\n            var allToolbars = [].concat(toolbars);\n            if (groupOtherList.length) {\n                allToolbars = allToolbars.concat(['MORE_ACTION']);\n            }\n            allToolbars.map(function (barName) {\n                if (!groups.has(barName)) return;\n                groups.get(barName).map(function (action) {\n                    if (action.deny) return;\n                    var menuItems = undefined,\n                        popoverContent = undefined,\n                        menuTitle = undefined,\n                        menuIcon = undefined;\n                    var actionName = action.options.name;\n\n                    menuTitle = action.options.text;\n                    menuIcon = action.options.icon_class;\n\n                    if (barName === 'MORE_ACTION') {\n                        (function () {\n                            var subItems = action.subMenuItems.dynamicItems;\n                            var items = [];\n                            subItems.map(function (obj) {\n                                if (obj.separator) {\n                                    items.push(obj);\n                                } else if (obj.actionId && !obj.actionId.deny) {\n                                    items.push(obj.actionId.getMenuData());\n                                }\n                            });\n                            menuItems = _Utils2['default'].pydioActionsToItems(items);\n                        })();\n                    } else if (action.subMenuItems.staticItems) {\n                        menuItems = _Utils2['default'].pydioActionsToItems(action.subMenuItems.staticItems);\n                    } else if (action.subMenuItems.dynamicBuilder) {\n                        menuItems = _Utils2['default'].pydioActionsToItems(action.subMenuItems.dynamicBuilder(controller));\n                    } else if (action.subMenuItems.popoverContent) {\n                        popoverContent = action.subMenuItems.popoverContent;\n                    } else {}\n                    var id = 'action-' + action.options.name;\n                    if (renderingType === 'button-icon') {\n                        menuTitle = React.createElement(\n                            'span',\n                            { className: 'button-icon' },\n                            React.createElement('span', { className: \"button-icon-icon \" + menuIcon }),\n                            React.createElement(\n                                'span',\n                                { className: 'button-icon-label' },\n                                menuTitle\n                            )\n                        );\n                    }\n                    if (menuItems) {\n                        if (renderingType === 'button' || renderingType === 'button-icon') {\n                            actions.push(React.createElement(_ButtonMenu2['default'], {\n                                key: actionName,\n                                className: id,\n                                buttonTitle: menuTitle,\n                                menuItems: menuItems,\n                                buttonLabelStyle: buttonStyle\n                            }));\n                        } else {\n                            actions.push(React.createElement(_IconButtonMenu2['default'], {\n                                key: actionName,\n                                className: id,\n                                onMenuClicked: function (object) {\n                                    object.payload();\n                                },\n                                buttonClassName: menuIcon,\n                                buttonTitle: menuTitle,\n                                menuItems: menuItems,\n                                buttonStyle: buttonStyle\n                            }));\n                        }\n                    } else if (popoverContent) {\n                        actions.push(React.createElement(_IconButtonPopover2['default'], {\n                            key: actionName,\n                            className: id,\n                            buttonClassName: menuIcon,\n                            buttonTitle: menuTitle,\n                            buttonStyle: buttonStyle,\n                            popoverContent: popoverContent\n                        }));\n                    } else {\n                        var click = function click(synthEvent) {\n                            action.apply();\n                        };\n                        if (renderingType === 'button-icon') {\n                            actions.push(React.createElement(ReactMUI.FlatButton, {\n                                key: actionName,\n                                className: id,\n                                onTouchTap: click,\n                                label: menuTitle,\n                                labelStyle: buttonStyle\n                            }));\n                        } else if (renderingType === 'button') {\n                            actions.push(React.createElement(MaterialUI.FlatButton, {\n                                key: actionName,\n                                className: id,\n                                onTouchTap: click,\n                                label: menuTitle,\n                                labelStyle: buttonStyle\n                            }));\n                        } else {\n                            actions.push(React.createElement(MaterialUI.IconButton, {\n                                key: actionName,\n                                iconClassName: menuIcon + ' ' + id,\n                                iconStyle: buttonStyle,\n                                onTouchTap: click,\n                                tooltip: menuTitle,\n                                tooltipPosition: tooltipPosition\n                            }));\n                        }\n                    }\n                });\n            });\n            var cName = this.props.className ? this.props.className : '';\n            cName += ' ' + 'toolbar';\n            if (!actions.length) {\n                cName += ' empty-toolbar';\n            }\n            return React.createElement(\n                'div',\n                { className: cName, style: this.props.toolbarStyle, id: this.props.id },\n                actions\n            );\n        }\n\n    });\n})(window);\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nvar _require = require('material-ui');\n\nvar Divider = _require.Divider;\nvar Menu = _require.Menu;\nvar MenuItem = _require.MenuItem;\nvar FontIcon = _require.FontIcon;\n\nfunction pydioActionsToItems() {\n    var actions = arguments.length <= 0 || arguments[0] === undefined ? [] : arguments[0];\n\n    var items = [];\n    var lastIsSeparator = false;\n    actions.map((function (action, index) {\n        if (action.separator) {\n            if (lastIsSeparator) return;\n            items.push(action);\n            lastIsSeparator = true;\n            return;\n        }\n        lastIsSeparator = false;\n        var label = action.raw_name ? action.raw_name : action.name;\n        var iconClass = action.icon_class;\n        var payload = undefined;\n        if (action.subMenu) {\n            var subItems = action.subMenuBeforeShow ? pydioActionsToItems(action.subMenuBeforeShow()) : action.subMenu;\n            items.push({\n                text: label,\n                iconClassName: iconClass,\n                subItems: subItems\n            });\n        } else {\n            items.push({\n                text: label,\n                iconClassName: iconClass,\n                payload: action.callback\n            });\n        }\n    }).bind(this));\n    if (lastIsSeparator) {\n        items = items.slice(0, items.length - 1);\n    }\n    if (items.length && items[0] && items[0].separator) {\n        items.shift();\n    }\n    return items;\n}\n\nfunction itemsToMenu(items, closeMenuCallback) {\n    var subItemsOnly = arguments.length <= 2 || arguments[2] === undefined ? false : arguments[2];\n    var menuProps = arguments.length <= 3 || arguments[3] === undefined ? {} : arguments[3];\n\n    menuProps = _extends({\n        display: 'normal',\n        width: 216,\n        desktop: true,\n        autoWidth: false\n    }, menuProps);\n\n    var menuItems = items.map(function (item, index) {\n\n        if (item.separator) return React.createElement(Divider, { key: \"divider\" + index });\n\n        var subItems = undefined,\n            payload = undefined;\n        if (item.subItems) {\n            subItems = itemsToMenu(item.subItems, closeMenuCallback, true);\n        } else if (item.payload) {\n            payload = function () {\n                item.payload();\n                closeMenuCallback();\n            };\n        }\n\n        var leftIcon = undefined,\n            rightIcon = undefined;\n        var iconClassName = item.iconClassName;var inset = false;\n        if (iconClassName === '__INSET__') {\n            iconClassName = '';\n            inset = true;\n        }\n\n        if (menuProps.display === 'normal') {\n            leftIcon = iconClassName ? React.createElement(FontIcon, { className: item.iconClassName + ' menu-icons', style: { fontSize: 16, padding: 5 } }) : null;\n        } else if (menuProps.display === 'right') {\n            rightIcon = iconClassName ? React.createElement(FontIcon, { className: item.iconClassName + ' menu-icons', style: { fontSize: 16, padding: 5 } }) : null;\n        }\n        rightIcon = subItems && subItems.length ? React.createElement(FontIcon, { className: 'mdi mdi-menu-right menu-icons' }) : rightIcon;\n\n        return React.createElement(MenuItem, {\n            key: item.text,\n            primaryText: item.text,\n            insetChildren: inset,\n            leftIcon: leftIcon,\n            rightIcon: rightIcon,\n            onTouchTap: payload,\n            menuItems: subItems\n        });\n    });\n\n    if (subItemsOnly) {\n        return menuItems;\n    } else {\n        return React.createElement(\n            Menu,\n            menuProps,\n            menuItems\n        );\n    }\n}\n\nexports['default'] = { pydioActionsToItems: pydioActionsToItems, itemsToMenu: itemsToMenu };\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _require = require('react');\n\nvar Component = _require.Component;\nvar PropTypes = _require.PropTypes;\n\nvar _require2 = require('material-ui');\n\nvar TextField = _require2.TextField;\nvar FlatButton = _require2.FlatButton;\n\nvar _require$requireLib = require('pydio').requireLib('boot');\n\nvar PydioContextConsumer = _require$requireLib.PydioContextConsumer;\n\n/**\n * Simple form for creating a team\n */\n\nvar TeamCreationForm = (function (_Component) {\n    _inherits(TeamCreationForm, _Component);\n\n    TeamCreationForm.updateTeamUsers = function updateTeamUsers(team, operation, users, callback) {\n        var teamId = team.id.replace('/AJXP_TEAM/', '');\n        var clearUserCache = function clearUserCache(uId) {\n            MetaCacheService.getInstance().deleteKey('user_public_data-rich', uId);\n        };\n        if (operation === 'add') {\n            users.forEach(function (user) {\n                var userId = user.getId ? user.getId() : user.id;\n                PydioUsers.Client.addUserToTeam(teamId, userId, callback);\n                clearUserCache(userId);\n            });\n        } else if (operation === 'delete') {\n            users.forEach(function (user) {\n                var userId = user.getId ? user.getId() : user.id;\n                PydioUsers.Client.removeUserFromTeam(teamId, userId, callback);\n                clearUserCache(userId);\n            });\n        } else if (operation === 'create') {\n            PydioUsers.Client.saveSelectionAsTeam(teamId, users, callback);\n            users.forEach(function (user) {\n                clearUserCache(user.getId ? user.getId() : user.id);\n            });\n        }\n    };\n\n    function TeamCreationForm(props, context) {\n        _classCallCheck(this, TeamCreationForm);\n\n        _Component.call(this, props, context);\n        this.state = { value: '' };\n    }\n\n    TeamCreationForm.prototype.onChange = function onChange(e, value) {\n        this.setState({ value: value });\n    };\n\n    TeamCreationForm.prototype.submitCreationForm = function submitCreationForm() {\n        var value = this.state.value;\n        TeamCreationForm.updateTeamUsers({ id: value }, 'create', [], this.props.onTeamCreated);\n    };\n\n    TeamCreationForm.prototype.render = function render() {\n        var getMessage = this.props.getMessage;\n\n        return React.createElement(\n            'div',\n            { style: { padding: 20 } },\n            React.createElement(\n                'div',\n                null,\n                getMessage(591)\n            ),\n            React.createElement(TextField, { floatingLabelText: getMessage(578), value: this.state.value, onChange: this.onChange.bind(this), fullWidth: true }),\n            React.createElement(\n                'div',\n                null,\n                React.createElement(\n                    'div',\n                    { style: { textAlign: 'right', paddingTop: 10 } },\n                    React.createElement(FlatButton, { label: getMessage(49), onTouchTap: this.props.onCancel.bind(this) }),\n                    React.createElement(FlatButton, { label: getMessage(579), secondary: true, onTouchTap: this.submitCreationForm.bind(this) })\n                )\n            )\n        );\n    };\n\n    return TeamCreationForm;\n})(Component);\n\nTeamCreationForm.propTypes = {\n    /**\n     * Callback triggered after team creation succeeded\n     */\n    onTeamCreated: PropTypes.func.isRequired,\n    /**\n     * Request modal close\n     */\n    onCancel: PropTypes.func.isRequired\n};\n\nexports['default'] = TeamCreationForm = PydioContextConsumer(TeamCreationForm);\n\nexports['default'] = TeamCreationForm;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n'use strict';\n\nexports.__esModule = true;\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nvar _addressbookAddressBook = require('./addressbook/AddressBook');\n\nvar _addressbookAddressBook2 = _interopRequireDefault(_addressbookAddressBook);\n\nvar _require$requireLib = require('pydio/http/resources-manager').requireLib('boot');\n\nvar AsyncComponent = _require$requireLib.AsyncComponent;\n\nvar _require = require('material-ui');\n\nvar TextField = _require.TextField;\nvar AutoComplete = _require.AutoComplete;\nvar RefreshIndicator = _require.RefreshIndicator;\nvar IconButton = _require.IconButton;\nvar Popover = _require.Popover;\n\nvar React = require('react');\nvar FuncUtils = require('pydio/util/func');\n\n/**\n * Ready to use autocomplete field that will load users/groups/roles from\n * the server (using user_list_authorized_users API).\n * Used for sharing, addressbooks, send email, etc.\n *\n * Can also open a \"selector-style\" adress book.\n */\nvar UsersLoader = React.createClass({\n    displayName: 'UsersLoader',\n\n    propTypes: {\n\n        /**\n         * Method called to render a commponent, taking a UserObject as input\n         */\n        renderSuggestion: React.PropTypes.func.isRequired,\n        /**\n         * Callback when a value is finally selected\n         */\n        onValueSelected: React.PropTypes.func.isRequired,\n        /**\n         * Floating Label Text displayed on the field\n         */\n        fieldLabel: React.PropTypes.string.isRequired,\n        /**\n         * Array of values to ignore\n         */\n        excludes: React.PropTypes.array.isRequired,\n        /**\n         * Display only users, no groups nor roles\n         */\n        usersOnly: React.PropTypes.bool,\n        /**\n         * Display users from local directory and/or from remote.\n         */\n        usersFrom: React.PropTypes.oneOf(['local', 'remote', 'any']),\n        /**\n         * Do not propose a \"Create user\" option\n         */\n        existingOnly: React.PropTypes.bool,\n        /**\n         * Allow free typing\n         */\n        freeValueAllowed: React.PropTypes.bool,\n        /**\n         * Will be passed to the root component\n         */\n        className: React.PropTypes.string\n    },\n\n    getInitialState: function getInitialState() {\n        return {\n            dataSource: [],\n            loading: false,\n            searchText: '',\n            minChars: parseInt(global.pydio.getPluginConfigs(\"core.conf\").get(\"USERS_LIST_COMPLETE_MIN_CHARS\"))\n        };\n    },\n\n    /**\n     * Loads values from server\n     * @param {string} input Currently searched text\n     * @param {Function} callback Called with the values\n     */\n    suggestionLoader: function suggestionLoader(input, callback) {\n        var excludes = this.props.excludes;\n        var disallowTemporary = this.props.existingOnly && !this.props.freeValueAllowed;\n        this.setState({ loading: this.state.loading + 1 });\n        PydioUsers.Client.authorizedUsersStartingWith(input, (function (users) {\n            this.setState({ loading: this.state.loading - 1 });\n            if (disallowTemporary) {\n                users = users.filter(function (user) {\n                    return !user.getTemporary();\n                });\n            }\n            if (excludes && excludes.length) {\n                users = users.filter(function (user) {\n                    return excludes.indexOf(user.getId()) == -1;\n                });\n            }\n            callback(users);\n        }).bind(this), this.props.usersOnly, this.props.existingOnly);\n    },\n\n    /**\n     * Called when the field is updated\n     * @param value\n     */\n    textFieldUpdate: function textFieldUpdate(value) {\n\n        this.setState({ searchText: value });\n        if (this.state.minChars && value && value.length < this.state.minChars) {\n            return;\n        }\n        this.loadBuffered(value, 350);\n    },\n\n    getPendingSearchText: function getPendingSearchText() {\n        return this.state.searchText || false;\n    },\n\n    /**\n     * Debounced call for rendering search\n     * @param value {string}\n     * @param timeout {int}\n     */\n    loadBuffered: function loadBuffered(value, timeout) {\n\n        if (!value && this._emptyValueList) {\n            this.setState({ dataSource: this._emptyValueList });\n            return;\n        }\n        FuncUtils.bufferCallback('remote_users_search', timeout, (function () {\n            this.setState({ loading: true });\n            this.suggestionLoader(value, (function (users) {\n                var crtValueFound = false;\n                var values = users.map((function (userObject) {\n                    var component = React.createElement(\n                        MaterialUI.MenuItem,\n                        null,\n                        this.props.renderSuggestion(userObject)\n                    );\n                    return {\n                        userObject: userObject,\n                        text: userObject.getExtendedLabel(),\n                        value: component\n                    };\n                }).bind(this));\n                if (!value) {\n                    this._emptyValueList = values;\n                }\n                this.setState({ dataSource: values, loading: false });\n            }).bind(this));\n        }).bind(this));\n    },\n\n    /**\n     * Called when user selects a value from the list\n     * @param value\n     * @param index\n     */\n    onCompleterRequest: function onCompleterRequest(value, index) {\n\n        if (index === -1) {\n            this.state.dataSource.map(function (entry) {\n                if (entry.text === value) {\n                    value = entry;\n                }\n            });\n            if (value && !value.userObject && this.props.freeValueAllowed) {\n                var fake = new PydioUsers.User(value, value, 'user', null, null, true);\n                this.props.onValueSelected(fake);\n                this.setState({ searchText: '', dataSource: [] });\n                return;\n            }\n        }\n        if (value && value.userObject) {\n            var object = value.userObject;\n            if (object.getTemporary()) {\n                if (this.props.freeValueAllowed) {\n                    this.props.onValueSelected(object);\n                } else {\n                    this.setState({ createUser: object.getLabel() });\n                }\n            } else {\n                this.props.onValueSelected(object);\n            }\n            this.setState({ searchText: '', dataSource: [] });\n        }\n    },\n\n    /**\n     * Triggers onValueSelected props callback\n     * @param {Pydio.User} newUser\n     */\n    onUserCreated: function onUserCreated(newUser) {\n        this.props.onValueSelected(newUser);\n        this.setState({ createUser: null });\n    },\n\n    /**\n     * Close user creation form\n     */\n    onCreationCancelled: function onCreationCancelled() {\n        this.setState({ createUser: null });\n    },\n\n    /**\n     * Open address book inside a Popover\n     * @param event\n     */\n    openAddressBook: function openAddressBook(event) {\n        this.setState({\n            addressBookOpen: true,\n            addressBookAnchor: event.currentTarget\n        });\n    },\n\n    /**\n     * Close address book popover\n     */\n    closeAddressBook: function closeAddressBook() {\n        this.setState({ addressBookOpen: false });\n    },\n\n    /**\n     * Triggered when user clicks on an entry from adress book.\n     * @param item\n     */\n    onAddressBookItemSelected: function onAddressBookItemSelected(item) {\n        this.props.onValueSelected(item);\n    },\n\n    render: function render() {\n        var _this = this;\n\n        var _state = this.state;\n        var dataSource = _state.dataSource;\n        var createUser = _state.createUser;\n\n        var containerStyle = { position: 'relative', overflow: 'visible' };\n\n        /*\n        if(createUser){\n             return (\n                <div style={containerStyle}>\n                    <div style={{position: 'absolute', top: 73, left: 0, right: 0, zIndex: 10}}>\n                        <AsyncComponent\n                            namespace={\"PydioForm\"}\n                            componentName={\"UserCreationForm\"}\n                             newUserName={this.state.createUser}\n                            onUserCreated={this.onUserCreated}\n                            onCancel={this.onCreationCancelled}\n                            pydio={this.props.pydio}\n                        />\n                    </div>\n                </div>\n            );\n         }\n        */\n\n        return React.createElement(\n            'div',\n            { style: containerStyle, ref: function (el) {\n                    _this._popoverAnchor = el;\n                } },\n            !createUser && React.createElement(AutoComplete, {\n                filter: MaterialUI.AutoComplete.noFilter,\n                dataSource: dataSource,\n                searchText: this.state.searchText,\n                onUpdateInput: this.textFieldUpdate,\n                className: this.props.className,\n                openOnFocus: true,\n                floatingLabelText: this.props.fieldLabel,\n                underlineShow: !this.props.underlineHide,\n                fullWidth: true,\n                onNewRequest: this.onCompleterRequest,\n                listStyle: { maxHeight: 350, overflowY: 'auto' },\n                onFocus: function () {\n                    _this.loadBuffered(_this.state.searchText, 100);\n                }\n            }),\n            createUser && React.createElement(TextField, {\n                floatingLabelText: this.props.fieldLabel,\n                value: global.pydio.MessageHash[485] + ' (' + this.state.createUser + ')',\n                disabled: true,\n                fullWidth: true,\n                underlineShow: !this.props.underlineHide\n            }),\n            !createUser && React.createElement(\n                'div',\n                { style: { position: 'absolute', right: 4, bottom: 14, height: 20, width: 20 } },\n                React.createElement(RefreshIndicator, {\n                    size: 20,\n                    left: 0,\n                    top: 0,\n                    status: this.state.loading ? 'loading' : 'hide'\n                })\n            ),\n            this.props.showAddressBook && !createUser && React.createElement(_addressbookAddressBook2['default'], {\n                mode: 'popover',\n                pydio: this.props.pydio,\n                loaderStyle: { width: 320, height: 420 },\n                onItemSelected: this.onAddressBookItemSelected,\n                usersFrom: this.props.usersFrom,\n                disableSearch: true\n            }),\n            React.createElement(\n                Popover,\n                {\n                    open: createUser,\n                    anchorEl: this._popoverAnchor,\n                    anchorOrigin: { horizontal: 'left', vertical: 'bottom' },\n                    targetOrigin: { horizontal: 'left', vertical: 'top' },\n                    onRequestClose: this.onCreationCancelled,\n                    canAutoPosition: false\n                },\n                createUser && React.createElement(AsyncComponent, {\n                    namespace: \"PydioForm\",\n                    componentName: \"UserCreationForm\",\n\n                    style: { width: 350, height: 320 },\n                    newUserName: this.state.createUser,\n                    onUserCreated: this.onUserCreated,\n                    onCancel: this.onCreationCancelled,\n                    pydio: this.props.pydio\n                })\n            )\n        );\n    }\n\n});\n\nexports['default'] = UsersLoader;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nvar _NestedListItem = require('./NestedListItem');\n\nvar _NestedListItem2 = _interopRequireDefault(_NestedListItem);\n\nvar _UsersList = require('./UsersList');\n\nvar _UsersList2 = _interopRequireDefault(_UsersList);\n\nvar _RightPanelCard = require('./RightPanelCard');\n\nvar _RightPanelCard2 = _interopRequireDefault(_RightPanelCard);\n\nvar _SearchPanel = require('./SearchPanel');\n\nvar _SearchPanel2 = _interopRequireDefault(_SearchPanel);\n\nvar _Loaders = require('./Loaders');\n\nvar _Loaders2 = _interopRequireDefault(_Loaders);\n\nvar _TeamCreationForm = require('../TeamCreationForm');\n\nvar _TeamCreationForm2 = _interopRequireDefault(_TeamCreationForm);\n\nvar React = require('react');\nvar Pydio = require('pydio');\n\nvar _Pydio$requireLib = Pydio.requireLib('boot');\n\nvar AsyncComponent = _Pydio$requireLib.AsyncComponent;\nvar PydioContextConsumer = _Pydio$requireLib.PydioContextConsumer;\n\nvar _require = require('material-ui');\n\nvar Popover = _require.Popover;\nvar IconButton = _require.IconButton;\n\nvar _require2 = require('material-ui/styles');\n\nvar muiThemeable = _require2.muiThemeable;\nvar colors = _require2.colors;\n\n/**\n * High level component to browse users, groups and teams, either in a large format (mode='book') or a more compact\n * format (mode='selector'|'popover').\n * Address book allows to create external users, teams, and also to browse trusted server directories if Federated Sharing\n * is active.\n */\nvar AddressBook = React.createClass({\n    displayName: 'AddressBook',\n\n    propTypes: {\n        /**\n         * Main instance of pydio\n         */\n        pydio: React.PropTypes.instanceOf(Pydio),\n        /**\n         * Display mode, either large (book) or small picker ('selector', 'popover').\n         */\n        mode: React.PropTypes.oneOf(['book', 'selector', 'popover']).isRequired,\n        /**\n         * Callback triggered in 'selector' mode whenever an item is clicked.\n         */\n        onItemSelected: React.PropTypes.func,\n        /**\n         * Display users only, no teams or groups\n         */\n        usersOnly: React.PropTypes.bool,\n        /**\n         * Choose various user sources, either the local directory or remote ( = trusted ) servers.\n         */\n        usersFrom: React.PropTypes.oneOf(['local', 'remote', 'any']),\n        /**\n         * Disable the search engine\n         */\n        disableSearch: React.PropTypes.bool,\n        /**\n         * Theme object passed by muiThemeable() wrapper\n         */\n        muiTheme: React.PropTypes.object,\n        /**\n         * Will be passed to the Popover object\n         */\n        popoverStyle: React.PropTypes.object,\n        /**\n         * Used as a button to open the selector in a popover\n         */\n        popoverButton: React.PropTypes.object,\n        /**\n         * Will be passed to the Popover container object\n         */\n        popoverContainerStyle: React.PropTypes.object,\n        /**\n         * Will be passed to the Popover Icon Button.\n         */\n        popoverIconButtonStyle: React.PropTypes.object\n    },\n\n    getDefaultProps: function getDefaultProps() {\n        return {\n            mode: 'book',\n            usersOnly: false,\n            usersFrom: 'any',\n            teamsOnly: false,\n            disableSearch: false\n        };\n    },\n\n    getInitialState: function getInitialState() {\n        var _this = this;\n\n        var _props = this.props;\n        var pydio = _props.pydio;\n        var mode = _props.mode;\n        var usersOnly = _props.usersOnly;\n        var usersFrom = _props.usersFrom;\n        var teamsOnly = _props.teamsOnly;\n        var disableSearch = _props.disableSearch;\n\n        var getMessage = function getMessage(id) {\n            return _this.props.getMessage(id, '');\n        };\n        var confConfigs = pydio.getPluginConfigs('core.conf');\n\n        var root = undefined;\n        if (teamsOnly) {\n            root = {\n                id: 'teams',\n                label: getMessage(568),\n                childrenLoader: _Loaders2['default'].loadTeams,\n                _parent: null,\n                _notSelectable: true,\n                actions: {\n                    type: 'teams',\n                    create: '+ ' + getMessage(569),\n                    remove: getMessage(570),\n                    multiple: true\n                }\n            };\n            return {\n                root: root,\n                selectedItem: root,\n                loading: false,\n                rightPaneItem: null\n            };\n        }\n\n        root = {\n            id: 'root',\n            label: getMessage(592),\n            type: 'root',\n            collections: []\n        };\n        if (usersFrom !== 'remote') {\n            if (confConfigs.get('USER_CREATE_USERS')) {\n                root.collections.push({\n                    id: 'ext',\n                    label: getMessage(593),\n                    //icon:'mdi mdi-account-network',\n                    itemsLoader: _Loaders2['default'].loadExternalUsers,\n                    _parent: root,\n                    _notSelectable: true,\n                    actions: {\n                        type: 'users',\n                        create: '+ ' + getMessage(484),\n                        remove: getMessage(582),\n                        multiple: true\n                    }\n                });\n            }\n            if (!usersOnly) {\n                root.collections.push({\n                    id: 'teams',\n                    label: getMessage(568),\n                    //icon: 'mdi mdi-account-multiple',\n                    childrenLoader: _Loaders2['default'].loadTeams,\n                    _parent: root,\n                    _notSelectable: true,\n                    actions: {\n                        type: 'teams',\n                        create: '+ ' + getMessage(569),\n                        remove: getMessage(570),\n                        multiple: true\n                    }\n                });\n            }\n            if (confConfigs.get('ALLOW_CROSSUSERS_SHARING')) {\n                var groupOrUsers = confConfigs.get('ADDRESSBOOK_GROUP_OR_USERS');\n                if (groupOrUsers && groupOrUsers.group_switch_value) groupOrUsers = groupOrUsers.group_switch_value;else groupOrUsers = 'both';\n\n                if (groupOrUsers === 'search') {\n                    if (!disableSearch) {\n                        root.collections.push({\n                            id: 'search',\n                            label: getMessage(583),\n                            //icon:'mdi mdi-account-search',\n                            type: 'search',\n                            _parent: root,\n                            _notSelectable: true\n                        });\n                    }\n                } else {\n                    root.collections.push({\n                        id: 'AJXP_GRP_/',\n                        label: getMessage(584),\n                        //icon:'mdi mdi-account-box',\n                        childrenLoader: groupOrUsers === 'both' || groupOrUsers === 'groups' ? _Loaders2['default'].loadGroups : null,\n                        itemsLoader: groupOrUsers === 'both' || groupOrUsers === 'users' ? _Loaders2['default'].loadGroupUsers : null,\n                        _parent: root,\n                        _notSelectable: true\n                    });\n                }\n            }\n        }\n\n        var ocsRemotes = pydio.getPluginConfigs('core.ocs').get('TRUSTED_SERVERS');\n        if (ocsRemotes && !usersOnly && usersFrom !== 'local') {\n            var remotes = JSON.parse(ocsRemotes);\n            var remotesNodes = {\n                id: 'remotes',\n                label: getMessage(594),\n                //icon:'mdi mdi-server',\n                collections: [],\n                _parent: root,\n                _notSelectable: true\n            };\n            for (var k in remotes) {\n                if (!remotes.hasOwnProperty(k)) continue;\n                remotesNodes.collections.push({\n                    id: k,\n                    label: remotes[k],\n                    icon: 'mdi mdi-server-network',\n                    type: 'remote',\n                    _parent: remotesNodes,\n                    _notSelectable: true\n                });\n            }\n            if (remotesNodes.collections.length) {\n                root.collections.push(remotesNodes);\n            }\n        }\n\n        return {\n            root: root,\n            selectedItem: mode === 'selector' ? root : root.collections[0],\n            loading: false,\n            rightPaneItem: null\n        };\n    },\n\n    componentDidMount: function componentDidMount() {\n        this.state.selectedItem && this.onFolderClicked(this.state.selectedItem);\n    },\n\n    onFolderClicked: function onFolderClicked(item) {\n        var _this2 = this;\n\n        var callback = arguments.length <= 1 || arguments[1] === undefined ? undefined : arguments[1];\n\n        // Special case for teams\n        if (item.type === 'group' && item.id.indexOf('/AJXP_TEAM/') === 0) {\n            this.onUserListItemClicked(item);\n            return;\n        }\n        this.setState({ loading: true });\n\n        _Loaders2['default'].childrenAsPromise(item, false).then(function (children) {\n            _Loaders2['default'].childrenAsPromise(item, true).then(function (children) {\n                _this2.setState({ selectedItem: item, loading: false }, callback);\n            });\n        });\n    },\n\n    onUserListItemClicked: function onUserListItemClicked(item) {\n        if (this.props.onItemSelected) {\n            var uObject = new PydioUsers.User(item.id, item.label, item.type, item.group, item.avatar, item.temporary, item.external);\n            if (item.trusted_server_id) {\n                uObject.trustedServerId = item.trusted_server_id;\n                uObject.trustedServerLabel = item.trusted_server_label;\n            }\n            this.props.onItemSelected(uObject);\n        } else {\n            this.setState({ rightPaneItem: item });\n        }\n    },\n\n    onCreateAction: function onCreateAction(item) {\n        this.setState({ createDialogItem: item });\n    },\n\n    closeCreateDialogAndReload: function closeCreateDialogAndReload() {\n        this.setState({ createDialogItem: null });\n        this.reloadCurrentNode();\n    },\n\n    onCardUpdateAction: function onCardUpdateAction(item) {\n        if (item._parent && item._parent === this.state.selectedItem) {\n            this.reloadCurrentNode();\n        }\n    },\n\n    onDeleteAction: function onDeleteAction(parentItem, selection) {\n        if (!confirm(this.props.getMessage(278))) {\n            return;\n        }\n        switch (parentItem.actions.type) {\n            case 'users':\n                selection.forEach((function (user) {\n                    if (this.state.rightPaneItem === user) this.setState({ rightPaneItem: null });\n                    PydioUsers.Client.deleteUser(user.id, this.reloadCurrentNode.bind(this));\n                }).bind(this));\n                break;\n            case 'teams':\n                selection.forEach((function (team) {\n                    if (this.state.rightPaneItem === team) this.setState({ rightPaneItem: null });\n                    PydioUsers.Client.deleteTeam(team.id.replace('/AJXP_TEAM/', ''), this.reloadCurrentNode.bind(this));\n                }).bind(this));\n                break;\n            case 'team':\n                _TeamCreationForm2['default'].updateTeamUsers(parentItem, 'delete', selection, this.reloadCurrentNode.bind(this));\n                break;\n            default:\n                break;\n        }\n    },\n\n    openPopover: function openPopover(event) {\n        this.setState({\n            popoverOpen: true,\n            popoverAnchor: event.currentTarget\n        });\n    },\n\n    closePopover: function closePopover() {\n        this.setState({ popoverOpen: false });\n    },\n\n    reloadCurrentNode: function reloadCurrentNode() {\n        var _this3 = this;\n\n        this.state.selectedItem.leafLoaded = false;\n        this.state.selectedItem.collectionsLoaded = false;\n        this.onFolderClicked(this.state.selectedItem, function () {\n            if (_this3.state.rightPaneItem) {\n                (function () {\n                    var rPaneId = _this3.state.rightPaneItem.id;\n                    var foundItem = null;\n                    var leafs = _this3.state.selectedItem.leafs || [];\n                    var collections = _this3.state.selectedItem.collections || [];\n                    [].concat(leafs, collections).forEach(function (leaf) {\n                        if (leaf.id === rPaneId) foundItem = leaf;\n                    });\n                    _this3.setState({ rightPaneItem: foundItem });\n                })();\n            }\n        });\n    },\n\n    reloadCurrentAtPage: function reloadCurrentAtPage(letterOrRange) {\n        this.state.selectedItem.leafLoaded = false;\n        this.state.selectedItem.collectionsLoaded = false;\n        if (letterOrRange === -1) {\n            this.state.selectedItem.currentParams = null;\n        } else if (letterOrRange.indexOf('-') !== -1) {\n            this.state.selectedItem.range = letterOrRange;\n        } else {\n            this.state.selectedItem.range = null;\n            this.state.selectedItem.currentParams = { alpha_pages: 'true', value: letterOrRange };\n        }\n        this.onFolderClicked(this.state.selectedItem);\n    },\n\n    reloadCurrentWithSearch: function reloadCurrentWithSearch(value) {\n        if (!value) {\n            this.reloadCurrentAtPage(-1);\n            return;\n        }\n        this.state.selectedItem.leafLoaded = false;\n        this.state.selectedItem.collectionsLoaded = false;\n        this.state.selectedItem.currentParams = { has_search: true, value: value, existing_only: true };\n        this.onFolderClicked(this.state.selectedItem);\n    },\n\n    render: function render() {\n        var _this4 = this;\n\n        var _props2 = this.props;\n        var mode = _props2.mode;\n        var muiTheme = _props2.muiTheme;\n        var getMessage = _props2.getMessage;\n\n        if (mode === 'popover') {\n\n            var popoverStyle = this.props.popoverStyle || {};\n            var popoverContainerStyle = this.props.popoverContainerStyle || {};\n            var iconButtonStyle = this.props.popoverIconButtonStyle || {};\n            var iconButton = React.createElement(IconButton, {\n                style: _extends({ position: 'absolute', padding: 15, zIndex: 100, right: 0, top: 25, display: this.state.loading ? 'none' : 'initial' }, iconButtonStyle),\n                iconStyle: { fontSize: 19, color: 'rgba(0,0,0,0.6)' },\n                iconClassName: 'mdi mdi-book-open-variant',\n                onTouchTap: this.openPopover\n            });\n            if (this.props.popoverButton) {\n                iconButton = React.createElement(this.props.popoverButton.type, _extends({}, this.props.popoverButton.props, { onTouchTap: this.openPopover }));\n            }\n            return React.createElement(\n                'span',\n                null,\n                iconButton,\n                React.createElement(\n                    Popover,\n                    {\n                        open: this.state.popoverOpen,\n                        anchorEl: this.state.popoverAnchor,\n                        anchorOrigin: { horizontal: 'right', vertical: 'top' },\n                        targetOrigin: { horizontal: 'left', vertical: 'top' },\n                        onRequestClose: this.closePopover,\n                        style: _extends({ marginLeft: 20 }, popoverStyle),\n                        zDepth: 2\n                    },\n                    React.createElement(\n                        'div',\n                        { style: _extends({ width: 320, height: 420 }, popoverContainerStyle) },\n                        React.createElement(AddressBook, _extends({}, this.props, { mode: 'selector' }))\n                    )\n                )\n            );\n        }\n\n        var _state = this.state;\n        var selectedItem = _state.selectedItem;\n        var root = _state.root;\n        var rightPaneItem = _state.rightPaneItem;\n        var createDialogItem = _state.createDialogItem;\n\n        var leftColumnStyle = {\n            backgroundColor: colors.grey100,\n            width: 256,\n            overflowY: 'auto',\n            overflowX: 'hidden'\n        };\n        var centerComponent = undefined,\n            rightPanel = undefined,\n            leftPanel = undefined;\n\n        if (selectedItem.id === 'search') {\n\n            centerComponent = React.createElement(_SearchPanel2['default'], {\n                item: selectedItem,\n                title: getMessage(583, ''),\n                searchLabel: getMessage(595, ''),\n                onItemClicked: this.onUserListItemClicked,\n                onFolderClicked: this.onFolderClicked,\n                mode: mode\n            });\n        } else if (selectedItem.type === 'remote') {\n\n            centerComponent = React.createElement(_SearchPanel2['default'], {\n                item: selectedItem,\n                params: { trusted_server_id: selectedItem.id },\n                searchLabel: getMessage(595, ''),\n                title: getMessage(596, '').replace('%s', selectedItem.label),\n                onItemClicked: this.onUserListItemClicked,\n                onFolderClicked: this.onFolderClicked,\n                mode: mode\n            });\n        } else {\n\n            var emptyStatePrimary = undefined;\n            var emptyStateSecondary = undefined;\n            var otherProps = {};\n            if (selectedItem.id === 'teams') {\n                emptyStatePrimary = getMessage(571, '');\n                emptyStateSecondary = getMessage(572, '');\n            } else if (selectedItem.id === 'ext') {\n                emptyStatePrimary = getMessage(585, '');\n                emptyStateSecondary = getMessage(586, '');\n            } else if (selectedItem.id.indexOf('AJXP_GRP_/') === 0) {\n                otherProps = {\n                    showSubheaders: true,\n                    paginatorType: !(selectedItem.currentParams && selectedItem.currentParams.has_search) && 'alpha',\n                    paginatorCallback: this.reloadCurrentAtPage.bind(this),\n                    enableSearch: !this.props.disableSearch,\n                    searchLabel: getMessage(595, ''),\n                    onSearch: this.reloadCurrentWithSearch.bind(this)\n                };\n            }\n\n            centerComponent = React.createElement(_UsersList2['default'], _extends({\n                item: selectedItem,\n                onItemClicked: this.onUserListItemClicked,\n                onFolderClicked: this.onFolderClicked,\n                onCreateAction: this.onCreateAction,\n                onDeleteAction: this.onDeleteAction,\n                loading: this.state.loading,\n                mode: mode,\n                emptyStatePrimaryText: emptyStatePrimary,\n                emptyStateSecondaryText: emptyStateSecondary,\n                onTouchTap: this.state.rightPaneItem ? function () {\n                    _this4.setState({ rightPaneItem: null });\n                } : null\n            }, otherProps));\n        }\n        var rightPanelStyle = _extends({}, leftColumnStyle, { transformOrigin: 'right', backgroundColor: 'white' });\n        if (!rightPaneItem) {\n            rightPanelStyle = _extends({}, rightPanelStyle, { transform: 'translateX(256px)', width: 0 });\n        }\n        rightPanel = React.createElement(_RightPanelCard2['default'], {\n            pydio: this.props.pydio,\n            onRequestClose: function () {\n                _this4.setState({ rightPaneItem: null });\n            },\n            style: rightPanelStyle,\n            onCreateAction: this.onCreateAction,\n            onDeleteAction: this.onDeleteAction,\n            onUpdateAction: this.onCardUpdateAction,\n            item: rightPaneItem });\n        if (mode === 'book') {\n            leftPanel = React.createElement(\n                MaterialUI.Paper,\n                { zDepth: 0, style: _extends({}, leftColumnStyle, { zIndex: 2 }) },\n                React.createElement(\n                    MaterialUI.List,\n                    null,\n                    root.collections.map((function (e) {\n                        return React.createElement(_NestedListItem2['default'], {\n                            key: e.id,\n                            selected: selectedItem.id,\n                            nestedLevel: 0,\n                            entry: e,\n                            onTouchTap: this.onFolderClicked\n                        });\n                    }).bind(this))\n                )\n            );\n        }\n\n        var dialogTitle = undefined,\n            dialogContent = undefined;\n        if (createDialogItem) {\n            if (createDialogItem.actions.type === 'users') {\n                dialogTitle = getMessage(484, '');\n                dialogContent = React.createElement(\n                    'div',\n                    { style: { height: 500 } },\n                    React.createElement(AsyncComponent, {\n                        namespace: 'PydioForm',\n                        componentName: 'UserCreationForm',\n                        zDepth: 0,\n                        style: { height: 500 },\n                        newUserName: \"\",\n                        onUserCreated: this.closeCreateDialogAndReload,\n                        onCancel: function () {\n                            _this4.setState({ createDialogItem: null });\n                        },\n                        pydio: this.props.pydio\n                    })\n                );\n            } else if (createDialogItem.actions.type === 'teams') {\n                dialogTitle = getMessage(569, '');\n                dialogContent = React.createElement(_TeamCreationForm2['default'], {\n                    onTeamCreated: this.closeCreateDialogAndReload,\n                    onCancel: function () {\n                        _this4.setState({ createDialogItem: null });\n                    }\n                });\n            } else if (createDialogItem.actions.type === 'team') {\n                var selectUser = function selectUser(item) {\n                    _TeamCreationForm2['default'].updateTeamUsers(createDialogItem, 'add', [item], _this4.reloadCurrentNode.bind(_this4));\n                };\n                dialogTitle = null;\n                dialogContent = React.createElement(AddressBook, {\n                    pydio: this.props.pydio,\n                    mode: 'selector',\n                    usersOnly: true,\n                    disableSearch: true,\n                    onItemSelected: selectUser\n                });\n            }\n        }\n\n        var style = this.props.style || {};\n        return React.createElement(\n            'div',\n            { style: _extends({ display: 'flex', height: mode === 'selector' ? 420 : 450 }, style) },\n            leftPanel,\n            centerComponent,\n            rightPanel,\n            React.createElement(\n                MaterialUI.Dialog,\n                {\n                    contentStyle: { width: 380, minWidth: 380, maxWidth: 380, padding: 0 },\n                    bodyStyle: { padding: 0 },\n                    title: React.createElement(\n                        'div',\n                        { style: { padding: 20 } },\n                        dialogTitle\n                    ),\n                    actions: null,\n                    modal: false,\n                    open: createDialogItem ? true : false,\n                    onRequestClose: function () {\n                        _this4.setState({ createDialogItem: null });\n                    }\n                },\n                dialogContent\n            )\n        );\n    }\n\n});\n\nexports['default'] = AddressBook = PydioContextConsumer(AddressBook);\nexports['default'] = AddressBook = muiThemeable()(AddressBook);\nexports['default'] = AddressBook;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _react = require('react');\n\nvar _materialUiStyles = require('material-ui/styles');\n\nvar _pydio = require('pydio');\n\nvar _pydio2 = _interopRequireDefault(_pydio);\n\nvar _materialUi = require('material-ui');\n\n/**\n * Alphabet and pages generator to give a first-letter-based pagination\n */\n\nvar _Pydio$requireLib = _pydio2['default'].requireLib('boot');\n\nvar PydioContextConsumer = _Pydio$requireLib.PydioContextConsumer;\n\nvar AlphaPaginator = (function (_Component) {\n    _inherits(AlphaPaginator, _Component);\n\n    function AlphaPaginator() {\n        _classCallCheck(this, AlphaPaginator);\n\n        _Component.apply(this, arguments);\n    }\n\n    AlphaPaginator.prototype.render = function render() {\n\n        var letters = 'abcdefghijklmnopqrstuvwxyz0123456789'.split('');\n        letters = [-1].concat(letters);\n        var _props = this.props;\n        var item = _props.item;\n        var paginatorCallback = _props.paginatorCallback;\n        var style = _props.style;\n        var getMessage = _props.getMessage;\n\n        var paginator = undefined;\n        if (item.pagination) {\n            (function () {\n                var _item$pagination = item.pagination;\n                var start = _item$pagination.start;\n                var end = _item$pagination.end;\n                var max = _item$pagination.max;\n                var interval = _item$pagination.interval;\n\n                var total_pages = Math.ceil(max / interval);\n                var current = Math.ceil(start / interval);\n                var pages = [];\n                for (var i = 0; i < total_pages; i++) {\n                    pages.push(i);\n                }paginator = React.createElement(\n                    _materialUi.SelectField,\n                    { floatingLabelText: getMessage(331), style: { width: 60 }, fullWidth: true, value: current, onChange: function (e, i, v) {\n                            paginatorCallback(v * interval + '-' + (v + 1) * interval);\n                        } },\n                    pages.map(function (p) {\n                        return React.createElement(_materialUi.MenuItem, { value: p, key: p, primaryText: p + 1 });\n                    })\n                );\n            })();\n        }\n\n        var currentPage = item.currentParams && item.currentParams.alpha_pages && item.currentParams.value || -1;\n\n        return React.createElement(\n            'div',\n            { style: _extends({}, style, { display: 'flex', paddingRight: 8, alignItems: 'center' }) },\n            React.createElement(\n                'div',\n                { style: { flex: 1 } },\n                getMessage(249, '')\n            ),\n            paginator,\n            React.createElement(\n                _materialUi.SelectField,\n                { floatingLabelText: getMessage(625), style: { width: 60, marginLeft: 20 }, fullWidth: true, value: currentPage, onChange: function (e, i, v) {\n                        paginatorCallback(v);\n                    } },\n                letters.map(function (l) {\n                    return React.createElement(_materialUi.MenuItem, { value: l, key: l, primaryText: l === -1 ? getMessage(597, '') : l });\n                })\n            )\n        );\n    };\n\n    return AlphaPaginator;\n})(_react.Component);\n\nAlphaPaginator.propTypes = {\n    /**\n     * Currently selected Item\n     */\n    item: _react.PropTypes.object,\n    /**\n     * When a letter is clicked, function(letter)\n     */\n    paginatorCallback: _react.PropTypes.func.isRequired,\n    /**\n     * Main instance of pydio\n     */\n    pydio: _react.PropTypes.instanceOf(_pydio2['default']),\n    /**\n     * Display mode, either large (book) or small picker ('selector', 'popover').\n     */\n    mode: _react.PropTypes.oneOf(['book', 'selector', 'popover']).isRequired\n};\n\nexports['default'] = AlphaPaginator = PydioContextConsumer(AlphaPaginator);\nexports['default'] = AlphaPaginator = _materialUiStyles.muiThemeable()(AlphaPaginator);\n\nexports['default'] = AlphaPaginator;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nvar Loaders = (function () {\n    function Loaders() {\n        _classCallCheck(this, Loaders);\n    }\n\n    Loaders.childrenAsPromise = function childrenAsPromise(item) {\n        var leaf = arguments.length <= 1 || arguments[1] === undefined ? false : arguments[1];\n        var childrenLoader = item.childrenLoader;\n        var itemsLoader = item.itemsLoader;\n        var leafLoaded = item.leafLoaded;\n        var collectionsLoaded = item.collectionsLoaded;\n        var leafs = item.leafs;\n        var collections = item.collections;\n\n        var loader = leaf ? itemsLoader : childrenLoader;\n        var loaded = leaf ? leafLoaded : collectionsLoaded;\n        return new Promise(function (resolve, reject) {\n            if (!loaded && loader) {\n                loader(item, function (newChildren) {\n                    if (leaf) {\n                        item.leafs = newChildren;\n                        item.leafLoaded = true;\n                    } else {\n                        item.collections = newChildren;\n                        item.collectionsLoaded = true;\n                    }\n                    resolve(newChildren);\n                });\n            } else {\n                var res = (leaf ? leafs : collections) || [];\n                resolve(res);\n            }\n        });\n    };\n\n    Loaders.listUsers = function listUsers(params, callback) {\n        var parent = arguments.length <= 2 || arguments[2] === undefined ? null : arguments[2];\n\n        var baseParams = { get_action: 'user_list_authorized_users', format: 'json' };\n        baseParams = _extends({}, baseParams, params);\n        var cb = callback;\n        if (parent) {\n            if (parent.range) {\n                baseParams['range'] = parent.range;\n            }\n            cb = function (children) {\n                callback(children.map(function (c) {\n                    c._parent = parent;return c;\n                }));\n            };\n        }\n        PydioApi.getClient().request(baseParams, function (transport) {\n            cb(transport.responseJSON);\n            var cRange = transport.responseObject.headers.get('Content-Range');\n            var aRange = transport.responseObject.headers.get('Accept-Range');\n            if (cRange && aRange && parent) {\n                var _aRange$split = aRange.split(' ');\n\n                var type = _aRange$split[0];\n                var interval = _aRange$split[1];\n\n                var _cRange$split = cRange.split('/');\n\n                var range = _cRange$split[0];\n                var max = _cRange$split[1];\n\n                var _range$split = range.split('-');\n\n                var start = _range$split[0];\n                var end = _range$split[1];\n\n                parent.pagination = {\n                    start: parseInt(start),\n                    end: parseInt(end),\n                    max: parseInt(max),\n                    interval: parseInt(interval)\n                };\n            }\n        });\n    };\n\n    Loaders.loadTeams = function loadTeams(entry, callback) {\n        var wrapped = function wrapped(children) {\n            children.map(function (child) {\n                child.icon = 'mdi mdi-account-multiple';\n                child.itemsLoader = Loaders.loadTeamUsers;\n                child.actions = {\n                    type: 'team',\n                    create: '573',\n                    remove: '574',\n                    multiple: true\n                };\n                child._notSelectable = true;\n            });\n            callback(children);\n        };\n        Loaders.listUsers({ filter_value: 8 }, wrapped, entry);\n    };\n\n    Loaders.loadGroups = function loadGroups(entry, callback) {\n        var wrapped = function wrapped(children) {\n            children.map(function (child) {\n                child.icon = 'mdi mdi-account-multiple';\n                child.childrenLoader = entry.childrenLoader ? Loaders.loadGroups : null;\n                child.itemsLoader = entry.itemsLoader ? Loaders.loadGroupUsers : null;\n                if (entry.currentParams && entry.currentParams.alpha_pages) {\n                    child.currentParams = _extends({}, entry.currentParams);\n                }\n            });\n            callback(children);\n        };\n        var path = entry.id.replace('AJXP_GRP_', '');\n        var params = { filter_value: 4, group_path: path };\n        if (entry.currentParams && !entry.currentParams.alpha_pages) {\n            params = _extends({}, params, entry.currentParams);\n        }\n        Loaders.listUsers(params, wrapped, entry);\n    };\n\n    Loaders.loadExternalUsers = function loadExternalUsers(entry, callback) {\n        Loaders.listUsers({ filter_value: 2 }, callback, entry);\n    };\n\n    Loaders.loadGroupUsers = function loadGroupUsers(entry, callback) {\n        var path = entry.id.replace('AJXP_GRP_', '');\n        var params = { filter_value: 1, group_path: path };\n        if (entry.currentParams) {\n            params = _extends({}, params, entry.currentParams);\n        }\n        Loaders.listUsers(params, callback, entry);\n    };\n\n    Loaders.loadTeamUsers = function loadTeamUsers(entry, callback) {\n        Loaders.listUsers({ filter_value: 3, group_path: entry.id }, callback, entry);\n    };\n\n    return Loaders;\n})();\n\nexports['default'] = Loaders;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _require = require('react');\n\nvar Component = _require.Component;\nvar PropTypes = _require.PropTypes;\n\n/**\n * Left panel of the address book\n * Display treeview hierarchy of users, teams, groups.\n */\n\nvar NestedListItem = (function (_Component) {\n    _inherits(NestedListItem, _Component);\n\n    function NestedListItem() {\n        _classCallCheck(this, NestedListItem);\n\n        _Component.apply(this, arguments);\n    }\n\n    /**\n     * Triggers this.props.onTouchTap\n     */\n\n    NestedListItem.prototype.onTouchTap = function onTouchTap() {\n        this.props.onTouchTap(this.props.entry);\n    };\n\n    /**\n     * Recursively build other NestedListItem\n     * @param data\n     */\n\n    NestedListItem.prototype.buildNestedItems = function buildNestedItems(data) {\n        return data.map((function (entry) {\n            return React.createElement(NestedListItem, {\n                nestedLevel: this.props.nestedLevel + 1,\n                entry: entry,\n                onTouchTap: this.props.onTouchTap,\n                selected: this.props.selected\n            });\n        }).bind(this));\n    };\n\n    NestedListItem.prototype.render = function render() {\n        var _props$entry = this.props.entry;\n        var id = _props$entry.id;\n        var label = _props$entry.label;\n        var icon = _props$entry.icon;\n        var selected = _props$entry.selected;\n\n        var children = this.props.entry.collections || [];\n        var nested = this.buildNestedItems(children);\n        var fontIcon = undefined;\n        if (icon) {\n            fontIcon = React.createElement(MaterialUI.FontIcon, { className: icon });\n        }\n        return React.createElement(MaterialUI.ListItem, {\n            nestedLevel: this.props.nestedLevel,\n            key: id,\n            primaryText: label,\n            onTouchTap: this.onTouchTap.bind(this),\n            nestedItems: nested,\n            initiallyOpen: true,\n            leftIcon: false && fontIcon,\n            innerDivStyle: { fontWeight: this.props.selected === this.props.entry.id ? 500 : 400 }\n        });\n    };\n\n    return NestedListItem;\n})(Component);\n\nNestedListItem.propTypes = {\n    /**\n     * Keeps track of the current depth level\n     */\n    nestedLevel: PropTypes.number,\n    /**\n     * Currently selected node id\n     */\n    selected: PropTypes.string,\n    /**\n     * Callback triggered when an entry is selected\n     */\n    onTouchTap: PropTypes.func\n};\n\nexports['default'] = NestedListItem;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _TeamCard = require('./TeamCard');\n\nvar _TeamCard2 = _interopRequireDefault(_TeamCard);\n\nvar _UserCard = require('./UserCard');\n\nvar _UserCard2 = _interopRequireDefault(_UserCard);\n\nvar React = require('react');\n\nvar _require = require('material-ui');\n\nvar Paper = _require.Paper;\n\n/**\n * Container for UserCard or TeamCard\n */\n\nvar RightPanelCard = (function (_React$Component) {\n  _inherits(RightPanelCard, _React$Component);\n\n  function RightPanelCard() {\n    _classCallCheck(this, RightPanelCard);\n\n    _React$Component.apply(this, arguments);\n  }\n\n  RightPanelCard.prototype.render = function render() {\n\n    var content = undefined;\n    var item = this.props.item || {};\n    if (item.type === 'user') {\n      content = React.createElement(_UserCard2['default'], this.props);\n    } else if (item.type === 'group' && item.id.indexOf('/AJXP_TEAM/') === 0) {\n      content = React.createElement(_TeamCard2['default'], this.props);\n    }\n\n    return React.createElement(\n      Paper,\n      { zDepth: 2, style: _extends({ position: 'relative' }, this.props.style) },\n      content\n    );\n  };\n\n  return RightPanelCard;\n})(React.Component);\n\nRightPanelCard.propTypes = {\n  /**\n   * Pydio instance\n   */\n  pydio: React.PropTypes.instanceOf(Pydio),\n  /**\n   * Selected item\n   */\n  item: React.PropTypes.object,\n  /**\n   * Applies to root container\n   */\n  style: React.PropTypes.object,\n  /**\n   * Forwarded to child\n   */\n  onRequestClose: React.PropTypes.func,\n  /**\n   * Forwarded to child\n   */\n  onDeleteAction: React.PropTypes.func,\n  /**\n   * Forwarded to child\n   */\n  onUpdateAction: React.PropTypes.func\n};\n\nexports['default'] = RightPanelCard;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _require = require('react');\n\nvar Component = _require.Component;\nvar PropTypes = _require.PropTypes;\n\n/**\n * Ready to use Form + Result List for search users\n */\n\nvar SearchForm = (function (_Component) {\n    _inherits(SearchForm, _Component);\n\n    function SearchForm(props, context) {\n        _classCallCheck(this, SearchForm);\n\n        _Component.call(this, props.context);\n        this.state = { value: '' };\n    }\n\n    SearchForm.prototype.search = function search() {\n        this.props.onSearch(this.state.value);\n    };\n\n    SearchForm.prototype.onChange = function onChange(event, value) {\n        this.setState({ value: value });\n        FuncUtils.bufferCallback('search_users_list', 300, this.search.bind(this));\n    };\n\n    SearchForm.prototype.render = function render() {\n\n        return React.createElement(\n            'div',\n            { style: _extends({ minWidth: 320 }, this.props.style) },\n            React.createElement(MaterialUI.TextField, {\n                fullWidth: true,\n                value: this.state.value,\n                onChange: this.onChange.bind(this),\n                hintText: this.props.searchLabel\n            })\n        );\n    };\n\n    return SearchForm;\n})(Component);\n\nSearchForm.propTypes = {\n    /**\n     * Label displayed in the search field\n     */\n    searchLabel: PropTypes.string.isRequired,\n    /**\n     * Callback triggered to search\n     */\n    onSearch: PropTypes.func.isRequired,\n    /**\n     * Will be appended to the root element\n     */\n    style: PropTypes.object\n};\n\nexports['default'] = SearchForm;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _SearchForm = require('./SearchForm');\n\nvar _SearchForm2 = _interopRequireDefault(_SearchForm);\n\nvar _UsersList = require('./UsersList');\n\nvar _UsersList2 = _interopRequireDefault(_UsersList);\n\nvar _Loaders = require('./Loaders');\n\nvar _Loaders2 = _interopRequireDefault(_Loaders);\n\n/**\n * Ready to use Form + Result List for search users\n */\n\nvar _require = require('react');\n\nvar Component = _require.Component;\nvar PropTypes = _require.PropTypes;\n\nvar _require$requireLib = require('pydio').requireLib('boot');\n\nvar PydioContextConsumer = _require$requireLib.PydioContextConsumer;\n\nvar SearchPanel = (function (_Component) {\n    _inherits(SearchPanel, _Component);\n\n    function SearchPanel(props, context) {\n        _classCallCheck(this, SearchPanel);\n\n        _Component.call(this, props.context);\n        this.state = { items: [] };\n    }\n\n    SearchPanel.prototype.onSearch = function onSearch(value) {\n        var _this = this;\n\n        if (!value) {\n            this.setState({ items: [] });\n            return;\n        }\n        var params = { value: value, existing_only: 'true' };\n        if (this.props.params) {\n            params = _extends({}, params, this.props.params);\n        }\n        _Loaders2['default'].listUsers(params, function (children) {\n            _this.setState({ items: children });\n        });\n    };\n\n    SearchPanel.prototype.render = function render() {\n        var _this2 = this;\n\n        var _props = this.props;\n        var mode = _props.mode;\n        var item = _props.item;\n        var getMessage = _props.getMessage;\n\n        return React.createElement(\n            'div',\n            { style: { flex: 1, display: 'flex', flexDirection: 'column' } },\n            React.createElement(\n                'div',\n                { style: { padding: 10, height: 56, backgroundColor: this.state.select ? activeTbarColor : '#fafafa', display: 'flex', alignItems: 'center', transition: DOMUtils.getBeziersTransition() } },\n                mode === \"selector\" && item._parent && React.createElement(MaterialUI.IconButton, { iconClassName: 'mdi mdi-chevron-left', onTouchTap: function () {\n                        _this2.props.onFolderClicked(item._parent);\n                    } }),\n                mode === 'book' && React.createElement(\n                    'div',\n                    { style: { fontSize: 20, color: 'rgba(0,0,0,0.87)', flex: 1 } },\n                    this.props.title\n                ),\n                React.createElement(_SearchForm2['default'], { style: mode === 'book' ? { minWidth: 320 } : { flex: 1 }, searchLabel: this.props.searchLabel, onSearch: this.onSearch.bind(this) })\n            ),\n            React.createElement(_UsersList2['default'], {\n                mode: this.props.mode,\n                onItemClicked: this.props.onItemClicked,\n                item: { leafs: this.state.items },\n                noToolbar: true,\n                emptyStatePrimaryText: getMessage(587, ''),\n                emptyStateSecondaryText: getMessage(588, '')\n            })\n        );\n    };\n\n    return SearchPanel;\n})(Component);\n\nSearchPanel.propTypes = {\n    /**\n     * Optional parameters added to listUsers() request\n     */\n    params: PropTypes.object,\n    /**\n     * Label displayed in the toolbar\n     */\n    searchLabel: PropTypes.string,\n    /**\n     * Callback triggered when a search result is clicked\n     */\n    onItemClicked: PropTypes.func,\n    /**\n     * Currently selected item, required for navigation\n     */\n    item: PropTypes.object,\n    /**\n     * Callback triggered if the result is a collection\n     */\n    onFolderClicked: PropTypes.func\n};\n\nexports['default'] = SearchPanel = PydioContextConsumer(SearchPanel);\nexports['default'] = SearchPanel;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _UsersList = require('./UsersList');\n\nvar _UsersList2 = _interopRequireDefault(_UsersList);\n\nvar _Loaders = require('./Loaders');\n\nvar _Loaders2 = _interopRequireDefault(_Loaders);\n\nvar _avatarActionsPanel = require('../avatar/ActionsPanel');\n\nvar _avatarActionsPanel2 = _interopRequireDefault(_avatarActionsPanel);\n\nvar React = require('react');\n\nvar _require = require('material-ui');\n\nvar TextField = _require.TextField;\nvar FlatButton = _require.FlatButton;\nvar CardTitle = _require.CardTitle;\nvar Divider = _require.Divider;\n\nvar _require$requireLib = require('pydio').requireLib('boot');\n\nvar PydioContextConsumer = _require$requireLib.PydioContextConsumer;\n\n/**\n * Display info about a Team inside a popover-able card\n */\n\nvar TeamCard = (function (_React$Component) {\n    _inherits(TeamCard, _React$Component);\n\n    function TeamCard(props, context) {\n        _classCallCheck(this, TeamCard);\n\n        _React$Component.call(this, props, context);\n        this.state = { label: this.props.item.label };\n    }\n\n    /**\n     * Use loader to get team participants\n     * @param item\n     */\n\n    TeamCard.prototype.loadMembers = function loadMembers(item) {\n        var _this = this;\n\n        this.setState({ loading: true });\n        _Loaders2['default'].childrenAsPromise(item, false).then(function (children) {\n            _Loaders2['default'].childrenAsPromise(item, true).then(function (children) {\n                _this.setState({ members: item.leafs, loading: false });\n            });\n        });\n    };\n\n    TeamCard.prototype.componentWillMount = function componentWillMount() {\n        this.loadMembers(this.props.item);\n    };\n\n    TeamCard.prototype.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n        this.loadMembers(nextProps.item);\n        this.setState({ label: nextProps.item.label });\n    };\n\n    TeamCard.prototype.onLabelChange = function onLabelChange(e, value) {\n        this.setState({ label: value });\n    };\n\n    TeamCard.prototype.updateLabel = function updateLabel() {\n        var _this2 = this;\n\n        if (this.state.label !== this.props.item.label) {\n            PydioUsers.Client.updateTeamLabel(this.props.item.id.replace('/AJXP_TEAM/', ''), this.state.label, function () {\n                _this2.props.onUpdateAction(_this2.props.item);\n            });\n        }\n        this.setState({ editMode: false });\n    };\n\n    TeamCard.prototype.render = function render() {\n        var _this3 = this;\n\n        var _props = this.props;\n        var item = _props.item;\n        var onDeleteAction = _props.onDeleteAction;\n        var onCreateAction = _props.onCreateAction;\n        var getMessage = _props.getMessage;\n\n        var editProps = {\n            team: item,\n            userEditable: true,\n            onDeleteAction: function onDeleteAction() {\n                _this3.props.onDeleteAction(item._parent, [item]);\n            },\n            onEditAction: function onEditAction() {\n                _this3.setState({ editMode: !_this3.state.editMode });\n            },\n            reloadAction: function reloadAction() {\n                _this3.props.onUpdateAction(item);\n            }\n        };\n\n        var title = undefined;\n        if (this.state.editMode) {\n            title = React.createElement(\n                'div',\n                { style: { display: 'flex', alignItems: 'center', margin: 16 } },\n                React.createElement(TextField, { style: { flex: 1, fontSize: 24 }, fullWidth: true, disabled: false, underlineShow: false, value: this.state.label, onChange: this.onLabelChange.bind(this) }),\n                React.createElement(FlatButton, { secondary: true, label: getMessage(48), onTouchTap: function () {\n                        _this3.updateLabel();\n                    } })\n            );\n        } else {\n            title = React.createElement(CardTitle, { title: this.state.label, subtitle: item.leafs && item.leafs.length ? getMessage(576).replace('%s', item.leafs.length) : getMessage(577) });\n        }\n        return React.createElement(\n            'div',\n            null,\n            title,\n            React.createElement(_avatarActionsPanel2['default'], _extends({}, this.props, editProps)),\n            React.createElement(Divider, null),\n            React.createElement(_UsersList2['default'], { subHeader: getMessage(575), onItemClicked: function () {}, item: item, mode: 'inner', onDeleteAction: onDeleteAction })\n        );\n    };\n\n    return TeamCard;\n})(React.Component);\n\nTeamCard.propTypes = {\n    /**\n     * Pydio instance\n     */\n    pydio: React.PropTypes.instanceOf(Pydio),\n    /**\n     * Team data object\n     */\n    item: React.PropTypes.object,\n    /**\n     * Applied to root container\n     */\n    style: React.PropTypes.object,\n    /**\n     * Called to dismiss the popover\n     */\n    onRequestClose: React.PropTypes.func,\n    /**\n     * Delete current team\n     */\n    onDeleteAction: React.PropTypes.func,\n    /**\n     * Update current team\n     */\n    onUpdateAction: React.PropTypes.func\n};\n\nexports['default'] = TeamCard = PydioContextConsumer(TeamCard);\n\nexports['default'] = TeamCard;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _avatarUserAvatar = require('../avatar/UserAvatar');\n\nvar _avatarUserAvatar2 = _interopRequireDefault(_avatarUserAvatar);\n\nvar React = require('react');\n\nvar _require$requireLib = require('pydio').requireLib('boot');\n\nvar AsyncComponent = _require$requireLib.AsyncComponent;\n\n/**\n * Card presentation of a user. Relies on the UserAvatar object,\n * plus the PydioForm.UserCreationForm when in edit mode.\n */\n\nvar UserCard = (function (_React$Component) {\n    _inherits(UserCard, _React$Component);\n\n    function UserCard(props, context) {\n        _classCallCheck(this, UserCard);\n\n        _React$Component.call(this, props, context);\n        this.state = { editForm: false };\n    }\n\n    UserCard.prototype.render = function render() {\n        var _this = this;\n\n        var item = this.props.item;\n\n        var editableProps = {},\n            editForm = undefined;\n        if (item._parent && item._parent.id === 'ext') {\n            editableProps = {\n                userEditable: true,\n                onDeleteAction: function onDeleteAction() {\n                    _this.props.onDeleteAction(item._parent, [item]);\n                },\n                onEditAction: function onEditAction() {\n                    _this.setState({ editForm: true });\n                },\n                reloadAction: function reloadAction() {\n                    _this.props.onUpdateAction(item);\n                }\n            };\n        }\n\n        if (this.state.editForm) {\n            editForm = React.createElement(AsyncComponent, {\n                namespace: 'PydioForm',\n                componentName: 'UserCreationForm',\n                pydio: this.props.pydio,\n                zDepth: 0,\n                style: { height: 500 },\n                newUserName: item.id,\n                editMode: true,\n                userData: item,\n                onUserCreated: function () {\n                    _this.props.onUpdateAction(item);_this.setState({ editForm: false });\n                },\n                onCancel: function () {\n                    _this.setState({ editForm: false });\n                }\n            });\n        }\n\n        return React.createElement(\n            'div',\n            null,\n            React.createElement(\n                _avatarUserAvatar2['default'],\n                _extends({\n                    userId: this.props.item.id,\n                    richCard: true,\n                    pydio: this.props.pydio,\n                    cardSize: this.props.style.width\n                }, editableProps),\n                editForm\n            )\n        );\n    };\n\n    return UserCard;\n})(React.Component);\n\nUserCard.propTypes = {\n    /**\n     * Pydio instance\n     */\n    pydio: React.PropTypes.instanceOf(Pydio),\n    /**\n     * Team data object\n     */\n    item: React.PropTypes.object,\n    /**\n     * Applied to root container\n     */\n    style: React.PropTypes.object,\n    /**\n     * Called to dismiss the popover\n     */\n    onRequestClose: React.PropTypes.func,\n    /**\n     * Delete current team\n     */\n    onDeleteAction: React.PropTypes.func,\n    /**\n     * Update current team\n     */\n    onUpdateAction: React.PropTypes.func\n};\n\nexports['default'] = UserCard;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _avatarUserAvatar = require('../avatar/UserAvatar');\n\nvar _avatarUserAvatar2 = _interopRequireDefault(_avatarUserAvatar);\n\nvar _viewsEmptyStateView = require('../../views/EmptyStateView');\n\nvar _viewsEmptyStateView2 = _interopRequireDefault(_viewsEmptyStateView);\n\nvar _AlphaPaginator = require('./AlphaPaginator');\n\nvar _AlphaPaginator2 = _interopRequireDefault(_AlphaPaginator);\n\nvar _SearchForm = require('./SearchForm');\n\nvar _SearchForm2 = _interopRequireDefault(_SearchForm);\n\nvar _require = require('material-ui');\n\nvar IconButton = _require.IconButton;\nvar Checkbox = _require.Checkbox;\nvar FlatButton = _require.FlatButton;\nvar RaisedButton = _require.RaisedButton;\nvar ListItem = _require.ListItem;\nvar FontIcon = _require.FontIcon;\nvar Avatar = _require.Avatar;\nvar Divider = _require.Divider;\nvar Subheader = _require.Subheader;\nvar List = _require.List;\n\nvar _require2 = require('material-ui/styles');\n\nvar muiThemeable = _require2.muiThemeable;\n\nvar _require$requireLib = require('pydio').requireLib('boot');\n\nvar Loader = _require$requireLib.Loader;\nvar PydioContextConsumer = _require$requireLib.PydioContextConsumer;\n\nvar UsersList = (function (_React$Component) {\n    _inherits(UsersList, _React$Component);\n\n    function UsersList(props, context) {\n        _classCallCheck(this, UsersList);\n\n        _React$Component.call(this, props, context);\n        this.state = { select: false, selection: [] };\n    }\n\n    UsersList.prototype.render = function render() {\n        var _this = this;\n\n        var _props = this.props;\n        var item = _props.item;\n        var mode = _props.mode;\n        var paginatorType = _props.paginatorType;\n        var loading = _props.loading;\n        var enableSearch = _props.enableSearch;\n        var showSubheaders = _props.showSubheaders;\n        var getMessage = _props.getMessage;\n\n        var folders = item.collections || [];\n        var leafs = item.leafs || [];\n        var foldersSubHeader = folders.length && (leafs.length || showSubheaders) ? [{ subheader: getMessage('532') }] : [];\n        var usersSubHeader = [];\n        if ((showSubheaders || paginatorType) && leafs.length) {\n            usersSubHeader = [{ subheader: paginatorType ? React.createElement(_AlphaPaginator2['default'], _extends({}, this.props, { style: { lineHeight: '20px', padding: '14px 0' } })) : getMessage('249') }];\n        }\n        var items = [].concat(foldersSubHeader, folders, usersSubHeader, leafs);\n        var total = items.length;\n        var elements = [];\n        var toggleSelect = function toggleSelect() {\n            _this.setState({ select: !_this.state.select, selection: [] });\n        };\n        var createAction = function createAction() {\n            _this.props.onCreateAction(item);\n        };\n        var deleteAction = function deleteAction() {\n            _this.props.onDeleteAction(item, _this.state.selection);_this.setState({ select: false, selection: [] });\n        };\n\n        var activeTbarColor = this.props.muiTheme.palette.accent2Color;\n        var toolbar = React.createElement(\n            'div',\n            { style: { padding: 10, height: 56, backgroundColor: this.state.select ? activeTbarColor : '#fafafa', display: 'flex', alignItems: 'center', transition: DOMUtils.getBeziersTransition() } },\n            mode === \"selector\" && item._parent && React.createElement(IconButton, { iconClassName: 'mdi mdi-chevron-left', onTouchTap: function () {\n                    _this.props.onFolderClicked(item._parent);\n                } }),\n            mode === 'book' && total > 0 && item.actions && item.actions.multiple && React.createElement(Checkbox, { style: { width: 'initial', marginLeft: this.state.select ? 7 : 14 }, checked: this.state.select, onCheck: toggleSelect }),\n            React.createElement(\n                'div',\n                { style: { flex: 1, fontSize: 20, color: this.state.select ? 'white' : 'rgba(0,0,0,0.87)' } },\n                item.label\n            ),\n            mode === 'book' && item.actions && item.actions.create && !this.state.select && React.createElement(FlatButton, { secondary: true, label: getMessage(item.actions.create), onTouchTap: createAction }),\n            mode === 'book' && item.actions && item.actions.remove && this.state.select && React.createElement(RaisedButton, { secondary: true, label: getMessage(item.actions.remove), disabled: !this.state.selection.length, onTouchTap: deleteAction }),\n            enableSearch && React.createElement(_SearchForm2['default'], { searchLabel: this.props.searchLabel, onSearch: this.props.onSearch, style: { flex: 1, minWidth: 200 } })\n        );\n        // PARENT NODE\n        if (item._parent && mode === 'book' && item._parent._parent) {\n            elements.push(React.createElement(ListItem, {\n                key: '__parent__',\n                primaryText: \"..\",\n                onTouchTap: function (e) {\n                    e.stopPropagation();_this.props.onFolderClicked(item._parent);\n                },\n                leftAvatar: React.createElement(Avatar, { icon: React.createElement(FontIcon, { className: 'mdi mdi-arrow-up' }) })\n            }));\n            if (total) {\n                elements.push(React.createElement(Divider, { inset: true, key: 'parent-divider' }));\n            }\n        }\n        // ITEMS\n        items.forEach((function (item, index) {\n            var _this2 = this;\n\n            if (item.subheader) {\n                elements.push(React.createElement(\n                    Subheader,\n                    null,\n                    item.subheader\n                ));\n                return;\n            }\n            var fontIcon = React.createElement(_avatarUserAvatar2['default'], { avatarSize: 36, pydio: this.props.pydio || pydio,\n                userId: item.id,\n                userLabel: item.label,\n                avatar: item.avatar,\n                icon: item.icon,\n                avatarOnly: true,\n                useDefaultAvatar: true\n            });\n            var rightIconButton = undefined;\n            var touchTap = function touchTap(e) {\n                e.stopPropagation();_this2.props.onItemClicked(item);\n            };\n            if (folders.indexOf(item) > -1 && this.props.onFolderClicked) {\n                touchTap = function (e) {\n                    e.stopPropagation();_this2.props.onFolderClicked(item);\n                };\n                if (mode === 'selector' && !item._notSelectable) {\n                    rightIconButton = React.createElement(IconButton, {\n                        iconClassName: \"mdi mdi-account-multiple-plus\",\n                        tooltip: \"Select this group\",\n                        tooltipPosition: 'bottom-left',\n                        onTouchTap: function () {\n                            _this2.props.onItemClicked(item);\n                        }\n                    });\n                }\n            } else if (mode === 'inner' && this.props.onDeleteAction) {\n                rightIconButton = React.createElement(IconButton, {\n                    iconClassName: \"mdi mdi-delete\",\n                    tooltip: getMessage(257),\n                    tooltipPosition: 'bottom-left',\n                    iconStyle: { color: 'rgba(0,0,0,0.13)', hoverColor: 'rgba(0,0,0,0.53)' },\n                    onTouchTap: function () {\n                        _this2.props.onDeleteAction(_this2.props.item, [item]);\n                    }\n                });\n            }\n            var select = function select(e, checked) {\n                if (checked) {\n                    _this2.setState({ selection: [].concat(_this2.state.selection, [item]) });\n                } else {\n                    var stateSel = _this2.state.selection;\n                    var selection = [].concat(stateSel.slice(0, stateSel.indexOf(item)), stateSel.slice(stateSel.indexOf(item) + 1));\n                    _this2.setState({ selection: selection });\n                }\n            };\n            elements.push(React.createElement(ListItem, {\n                key: item.id,\n                primaryText: item.label,\n                onTouchTap: touchTap,\n                disabled: mode === 'inner',\n                leftAvatar: !this.state.select && fontIcon,\n                rightIconButton: rightIconButton,\n                leftCheckbox: this.state.select && React.createElement(Checkbox, { checked: this.state.selection.indexOf(item) > -1, onCheck: select })\n            }));\n            if (mode !== 'inner' && index < total - 1) {\n                elements.push(React.createElement(Divider, { inset: true, key: item.id + '-divider' }));\n            }\n        }).bind(this));\n\n        var emptyState = undefined;\n        if (!elements.length) {\n            var emptyStateProps = {\n                style: { backgroundColor: 'rgb(250, 250, 250)' },\n                iconClassName: 'mdi mdi-account-off',\n                primaryTextId: this.props.emptyStatePrimaryText || getMessage(629),\n                secondaryTextId: mode === 'book' ? this.props.emptyStateSecondaryText || null : null\n            };\n            if (mode === 'book' && item.actions && item.actions.create) {\n                emptyStateProps = _extends({}, emptyStateProps, {\n                    actionLabelId: getMessage(item.actions.create),\n                    actionCallback: createAction\n                });\n            }\n            emptyState = React.createElement(_viewsEmptyStateView2['default'], emptyStateProps);\n        }\n\n        return React.createElement(\n            'div',\n            { style: { flex: 1, flexDirection: 'column', display: 'flex' }, onTouchTap: this.props.onTouchTap },\n            mode !== 'inner' && /*(!emptyState || mode !== 'book') &&*/!this.props.noToolbar && toolbar,\n            !emptyState && !loading && React.createElement(\n                List,\n                { style: { flex: 1, overflowY: mode !== 'inner' ? 'auto' : 'initial' } },\n                this.props.subHeader && React.createElement(\n                    Subheader,\n                    null,\n                    this.props.subHeader\n                ),\n                elements\n            ),\n            loading && React.createElement(Loader, { style: { flex: 1 } }),\n            !loading && emptyState\n        );\n    };\n\n    return UsersList;\n})(React.Component);\n\nUsersList.propTypes = {\n    item: React.PropTypes.object,\n    onCreateAction: React.PropTypes.func,\n    onDeleteAction: React.PropTypes.func,\n    onItemClicked: React.PropTypes.func,\n    onFolderClicked: React.PropTypes.func,\n    mode: React.PropTypes.oneOf(['book', 'selector', 'inner'])\n};\n\nexports['default'] = UsersList = PydioContextConsumer(UsersList);\nexports['default'] = UsersList = muiThemeable()(UsersList);\n\nexports['default'] = UsersList;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _addressbookAddressBook = require('../addressbook/AddressBook');\n\nvar _addressbookAddressBook2 = _interopRequireDefault(_addressbookAddressBook);\n\nvar React = require('react');\n\nvar _require = require('pydio/http/users-api');\n\nvar UsersApi = _require.UsersApi;\n\nvar ResourcesManager = require('pydio/http/resources-manager');\n\nvar _require2 = require('material-ui');\n\nvar IconButton = _require2.IconButton;\nvar Popover = _require2.Popover;\n\nvar _require3 = require('material-ui/styles');\n\nvar muiThemeable = _require3.muiThemeable;\n\nvar _require$requireLib = require('pydio').requireLib('boot');\n\nvar PydioContextConsumer = _require$requireLib.PydioContextConsumer;\nvar AsyncComponent = _require$requireLib.AsyncComponent;\n\nvar ActionsPanel = (function (_React$Component) {\n    _inherits(ActionsPanel, _React$Component);\n\n    function ActionsPanel(props, context) {\n        _classCallCheck(this, ActionsPanel);\n\n        _React$Component.call(this, props, context);\n        this.state = { showPicker: false, pickerAnchor: null, showMailer: false, mailerAnchor: null };\n    }\n\n    ActionsPanel.prototype.onTeamSelected = function onTeamSelected(item) {\n        this.setState({ showPicker: false });\n        if (item.getType() === 'group' && item.getId().indexOf('/AJXP_TEAM/') === 0) {\n            UsersApi.addUserToTeam(item.getId().replace('/AJXP_TEAM/', ''), this.props.userId, this.props.reloadAction);\n        }\n    };\n\n    ActionsPanel.prototype.onUserSelected = function onUserSelected(item) {\n        this.setState({ showPicker: false });\n        UsersApi.addUserToTeam(this.props.team.id, item.getId(), this.props.reloadAction);\n    };\n\n    ActionsPanel.prototype.openPicker = function openPicker(event) {\n        this.setState({ showPicker: true, pickerAnchor: event.currentTarget });\n    };\n\n    ActionsPanel.prototype.openMailer = function openMailer(event) {\n        var _this = this;\n\n        var target = event.currentTarget;\n        ResourcesManager.loadClassesAndApply(['PydioMailer'], function () {\n            _this.setState({ mailerLibLoaded: true }, function () {\n                _this.setState({ showMailer: true, mailerAnchor: target });\n            });\n        });\n    };\n\n    ActionsPanel.prototype.componentDidUpdate = function componentDidUpdate(prevProps, prevState) {\n        if (!this.props.lockOnSubPopoverOpen) return;\n        if ((this.state.showPicker || this.state.showMailer) && !(prevState.showPicker || prevState.showMailer)) {\n            this.props.lockOnSubPopoverOpen(true);\n        } else if (!(this.state.showPicker || this.state.showMailer) && (prevState.showPicker || prevState.showMailer)) {\n            this.props.lockOnSubPopoverOpen(false);\n        }\n    };\n\n    ActionsPanel.prototype.render = function render() {\n        var _this2 = this;\n\n        var _props = this.props;\n        var getMessage = _props.getMessage;\n        var muiTheme = _props.muiTheme;\n        var team = _props.team;\n        var user = _props.user;\n        var userEditable = _props.userEditable;\n\n        var styles = {\n            button: {\n                backgroundColor: muiTheme.palette.accent2Color,\n                borderRadius: '50%',\n                margin: '0 4px',\n                width: 44,\n                height: 44,\n                padding: 10\n            },\n            icon: {\n                color: 'white'\n            }\n        };\n        var mailer = undefined,\n            usermails = {};\n        var actions = [];\n        if (user && user.hasEmail) {\n            actions.push({ key: 'message', label: getMessage(598), icon: 'email', callback: this.openMailer.bind(this) });\n            usermails[this.props.user.id] = PydioUsers.User.fromObject(this.props.user);\n        }\n        if (team) {\n            actions.push({ key: 'users', label: getMessage(599), icon: 'account-multiple-plus', callback: this.openPicker.bind(this) });\n        } else {\n            actions.push({ key: 'teams', label: getMessage(573), icon: 'account-multiple-plus', callback: this.openPicker.bind(this) });\n        }\n        if (userEditable) {\n            actions.push({ key: 'edit', label: this.props.team ? getMessage(580) : getMessage(600), icon: 'pencil', callback: this.props.onEditAction });\n            actions.push({ key: 'delete', label: this.props.team ? getMessage(570) : getMessage(582), icon: 'delete', callback: this.props.onDeleteAction });\n        }\n\n        return React.createElement(\n            'div',\n            { style: { textAlign: 'center', marginBottom: 16 } },\n            actions.map(function (a) {\n                return React.createElement(IconButton, {\n                    key: a.key,\n                    style: styles.button,\n                    iconStyle: styles.icon,\n                    tooltip: a.label,\n                    iconClassName: \"mdi mdi-\" + a.icon,\n                    onTouchTap: a.callback\n                });\n            }),\n            React.createElement(\n                Popover,\n                {\n                    open: this.state.showPicker,\n                    anchorEl: this.state.pickerAnchor,\n                    anchorOrigin: { horizontal: 'right', vertical: 'top' },\n                    targetOrigin: { horizontal: 'right', vertical: 'top' },\n                    onRequestClose: function () {\n                        _this2.setState({ showPicker: false });\n                    },\n                    useLayerForClickAway: false,\n                    style: { zIndex: 2200 }\n                },\n                React.createElement(\n                    'div',\n                    { style: { width: 256, height: 320 } },\n                    React.createElement(_addressbookAddressBook2['default'], {\n                        mode: 'selector',\n                        pydio: this.props.pydio,\n                        loaderStyle: { width: 320, height: 420 },\n                        onItemSelected: this.props.team ? this.onUserSelected.bind(this) : this.onTeamSelected.bind(this),\n                        teamsOnly: this.props.team ? false : true,\n                        usersOnly: this.props.team ? true : false\n                    })\n                )\n            ),\n            React.createElement(\n                Popover,\n                {\n                    open: this.state.showMailer,\n                    anchorEl: this.state.mailerAnchor,\n                    anchorOrigin: { horizontal: 'right', vertical: 'top' },\n                    targetOrigin: { horizontal: 'right', vertical: 'top' },\n                    useLayerForClickAway: false,\n                    style: { zIndex: 2200 }\n                },\n                React.createElement(\n                    'div',\n                    { style: { width: 256, height: 320 } },\n                    this.state.mailerLibLoaded && React.createElement(AsyncComponent, {\n                        namespace: 'PydioMailer',\n                        componentName: 'Pane',\n                        zDepth: 0,\n                        panelTitle: getMessage(598),\n                        uniqueUserStyle: true,\n                        users: usermails,\n                        onDismiss: function () {\n                            _this2.setState({ showMailer: false });\n                        },\n                        onFieldFocus: this.props.otherPopoverMouseOver\n                    })\n                )\n            )\n        );\n    };\n\n    return ActionsPanel;\n})(React.Component);\n\nActionsPanel.propTypes = {\n\n    /**\n     * User data, props must pass at least one of 'user' or 'team'\n     */\n    user: React.PropTypes.object,\n    /**\n     * Team data, props must pass at least one of 'user' or 'team'\n     */\n    team: React.PropTypes.object,\n    /**\n     * For users, whether it is editable or not\n     */\n    userEditable: React.PropTypes.object\n\n};\n\nexports['default'] = ActionsPanel = PydioContextConsumer(ActionsPanel);\nexports['default'] = ActionsPanel = muiThemeable()(ActionsPanel);\n\nexports['default'] = ActionsPanel;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _addressbookUsersList = require('../addressbook/UsersList');\n\nvar _addressbookUsersList2 = _interopRequireDefault(_addressbookUsersList);\n\nvar _require = require('react');\n\nvar Component = _require.Component;\nvar PropTypes = _require.PropTypes;\n\nvar _require2 = require('material-ui');\n\nvar Divider = _require2.Divider;\n\nvar _require3 = require('pydio/http/users-api');\n\nvar UsersApi = _require3.UsersApi;\n\nvar _require$requireLib = require('pydio').requireLib('boot');\n\nvar PydioContextConsumer = _require$requireLib.PydioContextConsumer;\n\n/**\n * Display information about user or team relations\n */\n\nvar GraphPanel = (function (_Component) {\n    _inherits(GraphPanel, _Component);\n\n    function GraphPanel() {\n        _classCallCheck(this, GraphPanel);\n\n        _Component.apply(this, arguments);\n    }\n\n    GraphPanel.prototype.render = function render() {\n        var _props = this.props;\n        var graph = _props.graph;\n        var userLabel = _props.userLabel;\n        var pydio = _props.pydio;\n        var getMessage = _props.getMessage;\n\n        var elements = [];\n        if (graph.teams && graph.teams.length) {\n            var onDeleteAction = (function (parentItem, team) {\n                var _this = this;\n\n                UsersApi.removeUserFromTeam(team[0].id, this.props.userId, function (response) {\n                    if (response.message) pydio.UI.displayMessage('SUCCESS', response.message);\n                    _this.props.reloadAction();\n                });\n            }).bind(this);\n            elements.push(React.createElement(\n                'div',\n                { key: 'teams' },\n                React.createElement(Divider, null),\n                React.createElement(_addressbookUsersList2['default'], { subHeader: getMessage(581).replace('%s', graph.teams.length), onItemClicked: function () {}, item: { leafs: graph.teams }, mode: 'inner', onDeleteAction: onDeleteAction })\n            ));\n        }\n        if (graph.source && Object.keys(graph.source).length) {\n            elements.push(React.createElement(\n                'div',\n                { key: 'source' },\n                elements.length ? React.createElement(Divider, null) : null,\n                React.createElement(\n                    'div',\n                    { style: { padding: 16 } },\n                    getMessage(601).replace('%1', userLabel).replace('%2', Object.keys(graph.source).length)\n                )\n            ));\n        }\n        if (graph.target && Object.keys(graph.target).length) {\n            elements.push(React.createElement(\n                'div',\n                { key: 'target' },\n                elements.length ? React.createElement(Divider, null) : null,\n                React.createElement(\n                    'div',\n                    { style: { padding: 16 } },\n                    getMessage(602).replace('%1', userLabel).replace('%2', Object.keys(graph.target).length)\n                )\n            ));\n        }\n        return React.createElement(\n            'div',\n            null,\n            elements\n        );\n    };\n\n    return GraphPanel;\n})(Component);\n\nexports['default'] = GraphPanel = PydioContextConsumer(GraphPanel);\nexports['default'] = GraphPanel;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _GraphPanel = require('./GraphPanel');\n\nvar _GraphPanel2 = _interopRequireDefault(_GraphPanel);\n\nvar _ActionsPanel = require('./ActionsPanel');\n\nvar _ActionsPanel2 = _interopRequireDefault(_ActionsPanel);\n\nvar debounce = require('lodash.debounce');\nvar React = require('react');\nvar Color = require('color');\n\nvar _require = require('material-ui');\n\nvar FontIcon = _require.FontIcon;\nvar Popover = _require.Popover;\nvar Paper = _require.Paper;\nvar Avatar = _require.Avatar;\nvar CardTitle = _require.CardTitle;\n\nvar _require2 = require('material-ui/styles');\n\nvar muiThemeable = _require2.muiThemeable;\n\nvar MetaCacheService = require('pydio/http/meta-cache-service');\nvar PydioApi = require('pydio/http/api');\n\n/**\n * Generic component for display a user and her avatar (first letters or photo)\n */\n\nvar UserAvatar = (function (_React$Component) {\n    _inherits(UserAvatar, _React$Component);\n\n    function UserAvatar(props, context) {\n        _classCallCheck(this, UserAvatar);\n\n        _React$Component.call(this, props, context);\n        this.state = {\n            user: null,\n            avatar: null,\n            graph: null\n        };\n    }\n\n    UserAvatar.prototype.componentDidMount = function componentDidMount() {\n        if (this.props.pydio.user && this.props.pydio.user.id === this.props.userId) {\n            this.loadLocalData();\n            if (!this._userLoggedObs) {\n                this._userLoggedObs = this.loadLocalData.bind(this);\n                this.props.pydio.observe('user_logged', this._userLoggedObs);\n            }\n        } else if (this.props.userType === 'user') {\n            this.cache = MetaCacheService.getInstance();\n            this.cache.registerMetaStream('user_public_data', 'EXPIRATION_MANUAL_TRIGGER');\n            this.cache.registerMetaStream('user_public_data-rich', 'EXPIRATION_MANUAL_TRIGGER');\n            this.loadPublicData(this.props.userId);\n        }\n    };\n\n    UserAvatar.prototype.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n        if (!this.props.userId || this.props.userId !== nextProps.userId) {\n            this.setState({ label: nextProps.userId });\n        }\n        if (this.props.pydio && this.props.pydio.user && this.props.pydio.user.id === nextProps.userId) {\n            this.loadLocalData();\n            if (!this._userLoggedObs) {\n                this._userLoggedObs = this.loadLocalData.bind(this);\n                this.props.pydio.observe('user_logged', this._userLoggedObs);\n            }\n        } else {\n            if (this._userLoggedObs) {\n                this.props.pydio.stopObserving('user_logged', this._userLoggedObs);\n            }\n            this.cache = MetaCacheService.getInstance();\n            this.cache.registerMetaStream('user_public_data', 'EXPIRATION_MANUAL_TRIGGER');\n            this.cache.registerMetaStream('user_public_data-rich', 'EXPIRATION_MANUAL_TRIGGER');\n            this.loadPublicData(nextProps.userId);\n        }\n    };\n\n    UserAvatar.prototype.componentWillUnmount = function componentWillUnmount() {\n        if (this._userLoggedObs) {\n            this.props.pydio.stopObserving('user_logged', this._userLoggedObs);\n        }\n    };\n\n    UserAvatar.prototype.loadLocalData = function loadLocalData() {\n        var pydio = this.props.pydio;\n\n        if (!pydio.user) {\n            this.setState({ label: '', avatar: null });\n            return;\n        }\n        var userName = pydio.user.getPreference('USER_DISPLAY_NAME') || pydio.user.id;\n        var avatarId = pydio.user.getPreference('avatar');\n        var avatarUrl = PydioApi.getClient().buildUserAvatarUrl(pydio.user.id, avatarId);\n        this.setState({\n            label: userName,\n            avatar: avatarUrl\n        });\n        if (!avatarUrl) {\n            this.loadFromExternalProvider();\n        }\n    };\n\n    UserAvatar.prototype.loadPublicData = function loadPublicData(userId) {\n\n        var namespace = this.props.richCard ? 'user_public_data-rich' : 'user_public_data';\n        if (this.cache.hasKey(namespace, userId)) {\n            this.setState(this.cache.getByKey(namespace, userId));\n            return;\n        }\n        PydioApi.getClient().request({\n            get_action: 'user_public_data',\n            user_id: userId,\n            graph: this.props.richCard ? 'true' : 'false'\n        }, (function (transport) {\n            var data = transport.responseJSON;\n            if (!data || data.error) {\n                this.cache.setKey(namespace, userId, {});\n                return;\n            }\n            var user = data.user;\n            var graph = data.graph;\n\n            var avatarUrl = undefined;\n            var avatarId = user.avatar || null;\n            var label = user.label || userId;\n            if (!user.avatar) {\n                this.loadFromExternalProvider();\n            } else {\n                avatarUrl = PydioApi.getClient().buildUserAvatarUrl(userId, avatarId);\n            }\n            this.cache.setKey(namespace, userId, {\n                user: user,\n                graph: graph,\n                avatar: avatarUrl\n            });\n            this.setState({\n                user: user,\n                graph: graph,\n                avatar: avatarUrl\n            });\n        }).bind(this));\n    };\n\n    UserAvatar.prototype.loadFromExternalProvider = function loadFromExternalProvider() {\n        if (!this.props.pydio.getPluginConfigs(\"ajxp_plugin[@id='action.avatar']\").get(\"AVATAR_PROVIDER\")) {\n            return;\n        }\n        var namespace = this.props.richCard ? 'user_public_data-rich' : 'user_public_data';\n        PydioApi.getClient().request({\n            get_action: 'get_avatar_url',\n            userid: this.props.userId\n        }, (function (transport) {\n            this.setState({ avatar: transport.responseText });\n        }).bind(this));\n    };\n\n    UserAvatar.prototype.render = function render() {\n        var _this = this;\n\n        var _state = this.state;\n        var user = _state.user;\n        var avatar = _state.avatar;\n        var graph = _state.graph;\n        var _props = this.props;\n        var pydio = _props.pydio;\n        var userId = _props.userId;\n        var userType = _props.userType;\n        var icon = _props.icon;\n        var style = _props.style;\n        var labelStyle = _props.labelStyle;\n        var avatarStyle = _props.avatarStyle;\n        var avatarSize = _props.avatarSize;\n        var className = _props.className;\n        var avatarClassName = _props.avatarClassName;\n        var labelClassName = _props.labelClassName;\n        var displayLabel = _props.displayLabel;\n        var displayAvatar = _props.displayAvatar;\n        var useDefaultAvatar = _props.useDefaultAvatar;\n        var richCard = _props.richCard;\n        var cardSize = _props.cardSize;\n        var muiTheme = _props.muiTheme;\n        var label = this.state.label;\n\n        var userTypeLabel = undefined;\n        if (user) {\n            label = user.label;\n        } else if (!label) {\n            label = this.props.userLabel || this.props.userId;\n        }\n\n        var avatarContent = undefined,\n            avatarColor = undefined,\n            avatarIcon = undefined;\n        if (richCard) {\n            displayAvatar = useDefaultAvatar = displayLabel = true;\n        }\n        if (displayAvatar && !avatar && label && (!displayLabel || useDefaultAvatar)) {\n            var avatarsColor = muiTheme.palette.avatarsColor;\n            if (userType === 'group' || userType === 'team' || userId.indexOf('AJXP_GRP_/') === 0 || userId.indexOf('/AJXP_TEAM/') === 0) {\n                avatarsColor = Color(avatarsColor).darken(0.2).toString();\n            }\n            var iconClassName = undefined;\n            switch (userType) {\n                case 'group':\n                    iconClassName = 'mdi mdi-account-multiple';\n                    userTypeLabel = '289';\n                    break;\n                case 'team':\n                    iconClassName = 'mdi mdi-account-multiple-outline';\n                    userTypeLabel = '603';\n                    break;\n                case 'remote':\n                    iconClassName = 'mdi mdi-account-network';\n                    userTypeLabel = '604';\n                    break;\n                default:\n                    iconClassName = 'mdi mdi-account';\n                    userTypeLabel = user ? user.external ? '589' : '590' : '288';\n                    break;\n            }\n            if (icon) iconClassName = icon;\n            if (userTypeLabel) userTypeLabel = pydio.MessageHash[userTypeLabel];\n            if (richCard) {\n                avatarIcon = React.createElement(FontIcon, { className: iconClassName, style: { color: avatarsColor } });\n                avatarColor = '#f5f5f5';\n            } else {\n                avatarColor = avatarsColor;\n                if (iconClassName) {\n                    avatarIcon = React.createElement(FontIcon, { className: iconClassName });\n                } else {\n                    avatarContent = label.split(' ').map(function (word) {\n                        return word[0];\n                    }).join('').substring(0, 2);\n                    if (avatarContent.length < 2) avatarContent = label.substring(0, 2);\n                }\n            }\n        }\n        var reloadAction = undefined,\n            onEditAction = undefined,\n            onMouseOver = undefined,\n            onMouseOut = undefined,\n            popover = undefined;\n        if (richCard) {\n            (function () {\n\n                displayAvatar = true;\n                style = _extends({}, style, { flexDirection: 'column' });\n                avatarSize = cardSize ? cardSize : '100%';\n                avatarStyle = { borderRadius: 0 };\n                var localReload = function localReload() {\n                    MetaCacheService.getInstance().deleteKey('user_public_data-rich', _this.props.userId);\n                    _this.loadPublicData(_this.props.userId);\n                };\n                reloadAction = function () {\n                    localReload();\n                    if (_this.props.reloadAction) _this.props.reloadAction();\n                };\n                onEditAction = function () {\n                    localReload();\n                    if (_this.props.onEditAction) _this.props.onEditAction();\n                };\n            })();\n        } else if (this.props.richOnHover) {\n            (function () {\n\n                onMouseOut = function () {\n                    if (!_this.lockedBySubPopover) {\n                        _this.setState({ showPopover: false });\n                    }\n                };\n                onMouseOut = debounce(onMouseOut, 350);\n                onMouseOver = function (e) {\n                    _this.setState({ showPopover: true, popoverAnchor: e.currentTarget });\n                    onMouseOut.cancel();\n                };\n                var onMouseOverInner = function onMouseOverInner(e) {\n                    _this.setState({ showPopover: true });\n                    onMouseOut.cancel();\n                };\n\n                var lockOnSubPopoverOpen = function lockOnSubPopoverOpen(status) {\n                    _this.lockedBySubPopover = status;\n                    onMouseOverInner();\n                };\n\n                popover = React.createElement(\n                    Popover,\n                    {\n                        open: _this.state.showPopover,\n                        anchorEl: _this.state.popoverAnchor,\n                        onRequestClose: function (reason) {\n                            if (reason !== 'clickAway' || !_this.lockedBySubPopover) {\n                                _this.setState({ showPopover: false });\n                            }\n                        },\n                        anchorOrigin: { horizontal: \"left\", vertical: \"center\" },\n                        targetOrigin: { horizontal: \"right\", vertical: \"center\" },\n                        useLayerForClickAway: false\n                    },\n                    React.createElement(\n                        Paper,\n                        { zDepth: 2, style: { width: 220, height: 320, overflowY: 'auto' }, onMouseOver: onMouseOverInner, onMouseOut: onMouseOut },\n                        React.createElement(UserAvatar, _extends({}, _this.props, { richCard: true, richOnHover: false, cardSize: 220, lockOnSubPopoverOpen: lockOnSubPopoverOpen }))\n                    )\n                );\n            })();\n        }\n\n        var avatarComponent = React.createElement(\n            Avatar,\n            {\n                src: avatar,\n                icon: avatarIcon,\n                size: avatarSize,\n                style: this.props.avatarOnly ? this.props.style : avatarStyle,\n                backgroundColor: avatarColor\n            },\n            avatarContent\n        );\n\n        if (this.props.avatarOnly) {\n            return avatarComponent;\n        }\n\n        return React.createElement(\n            'div',\n            { className: className, style: style, onMouseOver: onMouseOver, onMouseOut: onMouseOut },\n            displayAvatar && (avatar || avatarContent || avatarIcon) && avatarComponent,\n            displayLabel && !richCard && React.createElement(\n                'div',\n                {\n                    className: labelClassName,\n                    style: labelStyle },\n                label\n            ),\n            displayLabel && richCard && React.createElement(CardTitle, { style: { textAlign: 'center' }, title: label, subtitle: userTypeLabel }),\n            richCard && user && React.createElement(_ActionsPanel2['default'], _extends({}, this.state, this.props, { reloadAction: reloadAction, onEditAction: onEditAction })),\n            graph && React.createElement(_GraphPanel2['default'], _extends({ graph: graph }, this.props, { userLabel: label, reloadAction: reloadAction, onEditAction: onEditAction })),\n            this.props.children,\n            popover\n        );\n    };\n\n    return UserAvatar;\n})(React.Component);\n\nUserAvatar.propTypes = {\n    /**\n     * Id of the user to be loaded\n     */\n    userId: React.PropTypes.string.isRequired,\n    /**\n     * Pydio instance\n     */\n    pydio: React.PropTypes.instanceOf(Pydio),\n    /**\n     * Label of the user, if we already have it (otherwise will be loaded)\n     */\n    userLabel: React.PropTypes.string,\n    /**\n     * Type of user\n     */\n    userType: React.PropTypes.oneOf(['user', 'group', 'remote', 'team']),\n    /**\n     * Icon to be displayed in avatar\n     */\n    icon: React.PropTypes.string,\n    /**\n     * Display a rich card or a simple avatar+label chip\n     */\n    richCard: React.PropTypes.bool,\n    /**\n     * If not rich, display a rich card as popover on mouseover\n     */\n    richOnHover: React.PropTypes.bool,\n\n    /**\n     * Add edit action to the card\n     */\n    userEditable: React.PropTypes.bool,\n    /**\n     * Triggered after successful edition\n     */\n    onEditAction: React.PropTypes.func,\n    /**\n     * Triggered after deletion\n     */\n    onDeleteAction: React.PropTypes.func,\n    /**\n     * Triggered if a reload is required\n     */\n    reloadAction: React.PropTypes.func,\n\n    /**\n     * Display label element or not\n     */\n    displayLabel: React.PropTypes.bool,\n    /**\n     * Display avatar element or not\n     */\n    displayAvatar: React.PropTypes.bool,\n    /**\n     * Display only avatar\n     */\n    avatarOnly: React.PropTypes.bool,\n    /**\n     * Use default avatar\n     */\n    useDefaultAvatar: React.PropTypes.bool,\n    /**\n     * Avatar size, 40px by default\n     */\n    avatarSize: React.PropTypes.number,\n\n    /**\n     * Add class name to root element\n     */\n    className: React.PropTypes.string,\n    /**\n     * Add class name to label element\n     */\n    labelClassName: React.PropTypes.string,\n    /**\n     * Add class name to avatar element\n     */\n    avatarClassName: React.PropTypes.string,\n    /**\n     * Add style to root element\n     */\n    style: React.PropTypes.object,\n    /**\n     * Add style to label element\n     */\n    labelStyle: React.PropTypes.object,\n    /**\n     * Add style to avatar element\n     */\n    avatarStyle: React.PropTypes.object\n};\n\nUserAvatar.defaultProps = {\n    displayLabel: true,\n    displayAvatar: true,\n    avatarSize: 40,\n    userType: 'user',\n    className: 'user-avatar-widget',\n    avatarClassName: 'user-avatar',\n    labelClassName: 'user-label'\n};\n\nexports['default'] = UserAvatar = muiThemeable()(UserAvatar);\n\nexports['default'] = UserAvatar;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n\"use strict\";\n\nexports.__esModule = true;\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar FuncUtils = require(\"pydio/util/func\");\nvar ResourcesManager = require(\"pydio/http/resources-manager\");\n\n/******************************/\n/* REACT DND GENERIC COMPONENTS\n /******************************/\nvar Types = {\n    NODE_PROVIDER: 'node',\n    SORTABLE_LIST_ITEM: 'sortable-list-item'\n};\n\n/**\n * Specifies which props to inject into your component.\n */\nfunction collect(connect, monitor) {\n    return {\n        connectDragSource: connect.dragSource(),\n        isDragging: monitor.isDragging()\n    };\n}\n\nfunction collectDrop(connect, monitor) {\n    return {\n        connectDropTarget: connect.dropTarget(),\n        canDrop: monitor.canDrop(),\n        isOver: monitor.isOver(),\n        isOverCurrent: monitor.isOver({ shallow: true })\n    };\n}\n\nvar DNDActionParameter = (function () {\n    function DNDActionParameter(source, target, step) {\n        _classCallCheck(this, DNDActionParameter);\n\n        this._source = source;\n        this._target = target;\n        this._step = step;\n    }\n\n    DNDActionParameter.prototype.getSource = function getSource() {\n        return this._source;\n    };\n\n    DNDActionParameter.prototype.getTarget = function getTarget() {\n        return this._target;\n    };\n\n    DNDActionParameter.prototype.getStep = function getStep() {\n        return this._step;\n    };\n\n    return DNDActionParameter;\n})();\n\nDNDActionParameter.STEP_BEGIN_DRAG = 'beginDrag';\nDNDActionParameter.STEP_END_DRAG = 'endDrag';\nDNDActionParameter.STEP_CAN_DROP = 'canDrop';\nDNDActionParameter.STEP_HOVER_DROP = 'hover';\n\nvar applyDNDAction = function applyDNDAction(source, target, step) {\n    var Controller = window.pydio.Controller;\n\n    var dnd = Controller.defaultActions.get(\"dragndrop\");\n    if (dnd) {\n        var dndAction = Controller.getActionByName(dnd);\n        dndAction.enable();\n        var params = new DNDActionParameter(source, target, step);\n        var checkModule = dndAction.options.dragndropCheckModule;\n        if (step === DNDActionParameter.STEP_CAN_DROP && checkModule) {\n            if (!FuncUtils.getFunctionByName(checkModule, window)) {\n                ResourcesManager.detectModuleToLoadAndApply(checkModule, function () {});\n                throw new Error('Cannot find test module, trying to load it');\n            }\n            FuncUtils.executeFunctionByName(dndAction.options.dragndropCheckModule, window, Controller, params);\n        } else {\n            dndAction.apply(params);\n        }\n    } else {\n        throw new Error('No DND Actions available');\n    }\n};\n\n/****************************/\n/* REACT DND DRAG/DROP NODES\n /***************************/\n\nvar nodeDragSource = {\n    beginDrag: function beginDrag(props) {\n        // Return the data describing the dragged item\n        return { node: props.node };\n    },\n\n    endDrag: function endDrag(props, monitor, component) {\n        if (!monitor.didDrop()) {\n            return;\n        }\n        var item = monitor.getItem();\n        var dropResult = monitor.getDropResult();\n        try {\n            applyDNDAction(item.node, dropResult.node, DNDActionParameter.STEP_END_DRAG);\n        } catch (e) {}\n    }\n};\n\nvar nodeDropTarget = {\n\n    hover: function hover(props, monitor) {},\n\n    canDrop: function canDrop(props, monitor) {\n\n        var source = monitor.getItem().node;\n        var target = props.node;\n\n        try {\n            applyDNDAction(source, target, DNDActionParameter.STEP_CAN_DROP);\n        } catch (e) {\n            return false;\n        }\n        return true;\n    },\n\n    drop: function drop(props, monitor) {\n        var hasDroppedOnChild = monitor.didDrop();\n        if (hasDroppedOnChild) {\n            return;\n        }\n        return { node: props.node };\n    }\n\n};\n\nexports.Types = Types;\nexports.collect = collect;\nexports.collectDrop = collectDrop;\nexports.nodeDragSource = nodeDragSource;\nexports.nodeDropTarget = nodeDropTarget;\nexports.DNDActionParameter = DNDActionParameter;\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n\"use strict\";\n\nexports.__esModule = true;\nexports[\"default\"] = {\n    contextTypes: {\n        messages: React.PropTypes.object,\n        getMessage: React.PropTypes.func\n    }\n};\nmodule.exports = exports[\"default\"];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar _require = require('react');\n\nvar Component = _require.Component;\nvar PropTypes = _require.PropTypes;\n\nvar _require2 = require('material-ui');\n\nvar FlatButton = _require2.FlatButton;\nvar FontIcon = _require2.FontIcon;\n\nvar _require3 = require('material-ui/styles');\n\nvar muiThemeable = _require3.muiThemeable;\n\nvar Color = require('color');\nvar Pydio = require('pydio');\n\nvar _Pydio$requireLib = Pydio.requireLib('boot');\n\nvar PydioContextConsumer = _Pydio$requireLib.PydioContextConsumer;\n\nvar EmptyStateView = (function (_Component) {\n    _inherits(EmptyStateView, _Component);\n\n    function EmptyStateView(props, context) {\n        _classCallCheck(this, EmptyStateView);\n\n        _Component.call(this, props, context);\n    }\n\n    EmptyStateView.prototype.render = function render() {\n        var _props = this.props;\n        var style = _props.style;\n        var iconClassName = _props.iconClassName;\n        var primaryTextId = _props.primaryTextId;\n        var secondaryTextId = _props.secondaryTextId;\n        var actionLabelId = _props.actionLabelId;\n        var actionCallback = _props.actionCallback;\n        var actionStyle = _props.actionStyle;\n        var actionIconClassName = _props.actionIconClassName;\n        var getMessage = _props.getMessage;\n\n        var mainColor = Color(this.props.muiTheme.palette.primary1Color);\n\n        var styles = {\n            container: _extends({\n                display: 'flex',\n                alignItems: 'center',\n                justifyContent: 'center',\n                height: '100%',\n                width: '100%',\n                flex: 1,\n                backgroundColor: mainColor.lightness(97).rgb().toString()\n            }, style),\n            centered: {\n                maxWidth: 280,\n                textAlign: 'center',\n                color: mainColor.fade(0.6).toString()\n            },\n            icon: {\n                fontSize: 100\n            },\n            primaryText: {\n                fontSize: 16,\n                fontWeight: 500\n            },\n            secondaryText: {\n                marginTop: 20,\n                fontSize: 13\n            },\n            buttonContainer: {\n                marginTop: 100,\n                textAlign: 'center'\n            },\n            buttonStyle: {\n                color: this.props.muiTheme.palette.accent2Color\n            }\n        };\n        var buttonIcon = actionIconClassName ? React.createElement(FontIcon, { className: actionIconClassName }) : null;\n        return React.createElement(\n            'div',\n            { style: styles.container },\n            React.createElement(\n                'div',\n                { style: styles.centered },\n                React.createElement('div', { className: iconClassName, style: styles.icon }),\n                React.createElement(\n                    'div',\n                    { style: styles.primaryText },\n                    getMessage(primaryTextId)\n                ),\n                secondaryTextId && React.createElement(\n                    'div',\n                    { style: styles.secondaryText },\n                    getMessage(secondaryTextId)\n                ),\n                actionLabelId && actionCallback && React.createElement(\n                    'div',\n                    { style: _extends({}, styles.buttonContainer, actionStyle) },\n                    React.createElement(FlatButton, { style: styles.buttonStyle, label: getMessage(actionLabelId), onTouchTap: actionCallback, icon: buttonIcon })\n                )\n            )\n        );\n    };\n\n    return EmptyStateView;\n})(Component);\n\nEmptyStateView.propTypes = {\n\n    pydio: PropTypes.instanceOf(Pydio).isRequired,\n    iconClassName: PropTypes.string.isRequired,\n    primaryTextId: PropTypes.string.isRequired,\n\n    secondaryTextId: PropTypes.string,\n    actionLabelId: PropTypes.string,\n    actionCallback: PropTypes.func,\n    actionStyle: PropTypes.object,\n\n    style: PropTypes.object,\n    getMessage: PropTypes.func\n\n};\n\nexports['default'] = EmptyStateView = PydioContextConsumer(EmptyStateView);\nexports['default'] = EmptyStateView = muiThemeable()(EmptyStateView);\n\nexports['default'] = EmptyStateView;\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }\n\nfunction _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _materialUi = require('material-ui');\n\nvar ModalAppBar = function ModalAppBar(props) {\n    var style = props.style;\n    var titleStyle = props.titleStyle;\n    var iconStyleRight = props.iconStyleRight;\n    var iconStyleLeft = props.iconStyleLeft;\n\n    var otherProps = _objectWithoutProperties(props, ['style', 'titleStyle', 'iconStyleRight', 'iconStyleLeft']);\n\n    var styles = {\n        style: _extends({\n            flexShrink: 0\n        }, style),\n        titleStyle: _extends({\n            lineHeight: '56px',\n            height: 56,\n            marginLeft: -8\n        }, titleStyle),\n        iconStyleRight: _extends({\n            marginTop: 4\n        }, iconStyleRight),\n        iconStyleLeft: _extends({\n            marginTop: 4\n        }, iconStyleLeft)\n    };\n\n    return _react2['default'].createElement(_materialUi.AppBar, _extends({}, otherProps, styles));\n};\n\nexports['default'] = ModalAppBar;\nmodule.exports = exports['default'];\n/*borderRadius: '2px 2px 0 0',*/\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n/**\n * Search input building a set of query parameters and calling\n * the callbacks to display / hide results\n */\n'use strict';\n\nexports.__esModule = true;\nexports['default'] = React.createClass({\n    displayName: 'SearchBox',\n\n    propTypes: {\n        // Required\n        parameters: React.PropTypes.object.isRequired,\n        queryParameterName: React.PropTypes.string.isRequired,\n        // Other\n        textLabel: React.PropTypes.string,\n        displayResults: React.PropTypes.func,\n        hideResults: React.PropTypes.func,\n        displayResultsState: React.PropTypes.bool,\n        limit: React.PropTypes.number\n    },\n\n    getInitialState: function getInitialState() {\n        return {\n            displayResult: this.props.displayResultsState ? true : false\n        };\n    },\n\n    getDefaultProps: function getDefaultProps() {\n        var dm = new PydioDataModel();\n        dm.setRootNode(new AjxpNode());\n        return { dataModel: dm };\n    },\n\n    displayResultsState: function displayResultsState() {\n        this.setState({\n            displayResult: true\n        });\n    },\n\n    hideResultsState: function hideResultsState() {\n        this.setState({\n            displayResult: false\n        });\n        this.props.hideResults();\n    },\n\n    onClickSearch: function onClickSearch() {\n        var value = this.refs.query.getValue();\n        var dm = this.props.dataModel;\n        var params = this.props.parameters;\n        params[this.props.queryParameterName] = value;\n        params['limit'] = this.props.limit || 100;\n        dm.getRootNode().setChildren([]);\n        PydioApi.getClient().request(params, (function (transport) {\n            var remoteNodeProvider = new RemoteNodeProvider({});\n            remoteNodeProvider.parseNodes(dm.getRootNode(), transport);\n            dm.getRootNode().setLoaded(true);\n            this.displayResultsState();\n            this.props.displayResults(value, dm);\n        }).bind(this));\n    },\n\n    keyDown: function keyDown(event) {\n        if (event.key == 'Enter') {\n            this.onClickSearch();\n        }\n    },\n\n    render: function render() {\n        return React.createElement(\n            'div',\n            { className: this.props.className ? this.props.className : '' },\n            React.createElement(\n                'div',\n                { style: { paddingTop: 22, float: 'right', opacity: 0.3 } },\n                React.createElement(ReactMUI.IconButton, {\n                    ref: 'button',\n                    onClick: this.onClickSearch,\n                    iconClassName: 'icon-search',\n                    tooltip: 'Search'\n                })\n            ),\n            React.createElement(\n                'div',\n                { className: 'searchbox-input-fill', style: { width: 220, float: 'right' } },\n                React.createElement(ReactMUI.TextField, { ref: 'query', onKeyDown: this.keyDown, floatingLabelText: this.props.textLabel })\n            )\n        );\n    }\n\n});\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n/**\n * Get info from Pydio controller an build an\n * action bar with active actions.\n * TBC\n */\n'use strict';\n\nexports.__esModule = true;\nexports['default'] = React.createClass({\n    displayName: 'SimpleReactActionBar',\n\n    propTypes: {\n        dataModel: React.PropTypes.instanceOf(PydioDataModel).isRequired,\n        node: React.PropTypes.instanceOf(AjxpNode).isRequired,\n        actions: React.PropTypes.array\n    },\n\n    clickAction: function clickAction(event) {\n        var actionName = event.currentTarget.getAttribute(\"data-action\");\n        this.props.dataModel.setSelectedNodes([this.props.node]);\n        var a = window.pydio.Controller.getActionByName(actionName);\n        a.fireContextChange(this.props.dataModel, true, window.pydio.user);\n        //a.fireSelectionChange(this.props.dataModel);\n        a.apply([this.props.dataModel]);\n        event.stopPropagation();\n        event.preventDefault();\n    },\n\n    render: function render() {\n        var actions = this.props.actions.map((function (a) {\n            return React.createElement('div', {\n                key: a.options.name,\n                className: a.options.icon_class + ' material-list-action-inline' || '',\n                title: a.options.title,\n                'data-action': a.options.name,\n                onClick: this.clickAction });\n        }).bind(this));\n        return React.createElement(\n            'span',\n            null,\n            actions\n        );\n    }\n});\nmodule.exports = exports['default'];\n","/*\n * Copyright 2007-2017 Charles du Jeu - Abstrium SAS <team (at) pyd.io>\n * This file is part of Pydio.\n *\n * Pydio is free software: you can redistribute it and/or modify\n * it under the terms of the GNU Affero General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n *\n * Pydio is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n * GNU Affero General Public License for more details.\n *\n * You should have received a copy of the GNU Affero General Public License\n * along with Pydio.  If not, see <http://www.gnu.org/licenses/>.\n *\n * The latest code can be found at <https://pydio.com>.\n */\n\n'use strict';\n\nexports.__esModule = true;\n\nvar _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; };\n\nvar _utilDND = require('../util/DND');\n\nvar React = require('react');\n\nvar _Pydio$requireLib = Pydio.requireLib('hoc');\n\nvar withContextMenu = _Pydio$requireLib.withContextMenu;\n\nvar ContextMenuWrapper = function ContextMenuWrapper(props) {\n    return React.createElement('div', props);\n};\nContextMenuWrapper = withContextMenu(ContextMenuWrapper);\n\n/**\n * Tree Node\n */\nvar SimpleTreeNode = React.createClass({\n    displayName: 'SimpleTreeNode',\n\n    propTypes: {\n        collapse: React.PropTypes.bool,\n        forceExpand: React.PropTypes.bool,\n        childrenOnly: React.PropTypes.bool,\n        depth: React.PropTypes.number,\n        onNodeSelect: React.PropTypes.func,\n        node: React.PropTypes.instanceOf(AjxpNode),\n        dataModel: React.PropTypes.instanceOf(PydioDataModel),\n        forceLabel: React.PropTypes.string,\n        // Optional currently selected detection\n        nodeIsSelected: React.PropTypes.func,\n        // Optional checkboxes\n        checkboxes: React.PropTypes.array,\n        checkboxesValues: React.PropTypes.object,\n        checkboxesComputeStatus: React.PropTypes.func,\n        onCheckboxCheck: React.PropTypes.func\n    },\n\n    getDefaultProps: function getDefaultProps() {\n        return {\n            collapse: false,\n            childrenOnly: false,\n            depth: 0,\n            onNodeSelect: function onNodeSelect(node) {}\n        };\n    },\n\n    listenToNode: function listenToNode(node) {\n        this._childrenListener = (function () {\n            if (!this.isMounted()) return;\n            this.setState({ children: this._nodeToChildren(node) });\n        }).bind(this);\n        this._nodeListener = (function () {\n            if (!this.isMounted()) return;\n            this.forceUpdate();\n        }).bind(this);\n        node.observe(\"child_added\", this._childrenListener);\n        node.observe(\"child_removed\", this._childrenListener);\n        node.observe(\"node_replaced\", this._nodeListener);\n    },\n\n    stopListening: function stopListening(node) {\n        node.stopObserving(\"child_added\", this._childrenListener);\n        node.stopObserving(\"child_removed\", this._childrenListener);\n        node.stopObserving(\"node_replaced\", this._nodeListener);\n    },\n\n    componentDidMount: function componentDidMount() {\n        this.listenToNode(this.props.node);\n    },\n\n    componentWillUnmount: function componentWillUnmount() {\n        this.stopListening(this.props.node);\n    },\n\n    componentWillReceiveProps: function componentWillReceiveProps(nextProps) {\n        var oldNode = this.props.node;\n        var newNode = nextProps.node;\n        if (newNode == oldNode && newNode.getMetadata().get(\"paginationData\")) {\n            var remapedChildren = this.state.children.map(function (c) {\n                c.setParent(newNode);return c;\n            });\n            var remapedPathes = this.state.children.map(function (c) {\n                return c.getPath();\n            });\n            var newChildren = this._nodeToChildren(newNode);\n            newChildren.forEach(function (nc) {\n                if (remapedPathes.indexOf(nc.getPath()) === -1) {\n                    remapedChildren.push(nc);\n                }\n            });\n            this.setState({ children: remapedChildren });\n        } else {\n            this.setState({ children: this._nodeToChildren(newNode) });\n        }\n        if (newNode !== oldNode) {\n            this.stopListening(oldNode);\n            this.listenToNode(newNode);\n        }\n    },\n\n    getInitialState: function getInitialState() {\n        return {\n            showChildren: !this.props.collapse || this.props.forceExpand,\n            children: this._nodeToChildren(this.props.node)\n        };\n    },\n\n    _nodeToChildren: function _nodeToChildren() {\n        var children = [];\n        this.props.node.getChildren().forEach(function (c) {\n            if (!c.isLeaf() || c.getAjxpMime() === 'ajxp_browsable_archive') children.push(c);\n        });\n        return children;\n    },\n\n    onNodeSelect: function onNodeSelect(ev) {\n        if (this.props.onNodeSelect) {\n            this.props.onNodeSelect(this.props.node);\n        }\n        ev.preventDefault();\n        ev.stopPropagation();\n    },\n    onChildDisplayToggle: function onChildDisplayToggle(ev) {\n        if (this.props.node.getChildren().size) {\n            this.setState({ showChildren: !this.state.showChildren });\n        }\n        ev.preventDefault();\n        ev.stopPropagation();\n    },\n    nodeIsSelected: function nodeIsSelected(n) {\n        if (this.props.nodeIsSelected) return this.props.nodeIsSelected(n);else return this.props.dataModel.getSelectedNodes().indexOf(n) !== -1;\n    },\n    render: function render() {\n        var _this = this;\n\n        var _props = this.props;\n        var node = _props.node;\n        var childrenOnly = _props.childrenOnly;\n        var canDrop = _props.canDrop;\n        var isOverCurrent = _props.isOverCurrent;\n        var checkboxes = _props.checkboxes;\n        var checkboxesComputeStatus = _props.checkboxesComputeStatus;\n        var checkboxesValues = _props.checkboxesValues;\n        var onCheckboxCheck = _props.onCheckboxCheck;\n        var depth = _props.depth;\n        var forceExpand = _props.forceExpand;\n        var selectedItemStyle = _props.selectedItemStyle;\n        var getItemStyle = _props.getItemStyle;\n        var forceLabel = _props.forceLabel;\n\n        var hasFolderChildrens = this.state.children.length ? true : false;\n        var hasChildren;\n        if (hasFolderChildrens) {\n            hasChildren = React.createElement(\n                'span',\n                { onClick: this.onChildDisplayToggle },\n                this.state.showChildren || forceExpand ? React.createElement('span', { className: 'tree-icon icon-angle-down' }) : React.createElement('span', { className: 'tree-icon icon-angle-right' })\n            );\n        } else {\n            var cname = \"tree-icon icon-angle-right\";\n            if (node.isLoaded()) {\n                cname += \" no-folder-children\";\n            }\n            hasChildren = React.createElement('span', { className: cname });\n        }\n        var isSelected = this.nodeIsSelected(node) ? 'mui-menu-item mui-is-selected' : 'mui-menu-item';\n        var selfLabel;\n        if (!childrenOnly) {\n            if (canDrop && isOverCurrent) {\n                isSelected += ' droppable-active';\n            }\n            var boxes;\n            if (checkboxes) {\n                var values = {},\n                    inherited = false,\n                    disabled = {},\n                    additionalClassName = '';\n                if (checkboxesComputeStatus) {\n                    var status = checkboxesComputeStatus(node);\n                    values = status.VALUES;\n                    inherited = status.INHERITED;\n                    disabled = status.DISABLED;\n                    if (status.CLASSNAME) additionalClassName = ' ' + status.CLASSNAME;\n                } else if (checkboxesValues && checkboxesValues[node.getPath()]) {\n                    values = checkboxesValues[node.getPath()];\n                }\n                var valueClasses = [];\n                boxes = checkboxes.map((function (c) {\n                    var selected = values[c] !== undefined ? values[c] : false;\n                    var click = (function (event, value) {\n                        onCheckboxCheck(node, c, value);\n                    }).bind(this);\n                    if (selected) valueClasses.push(c);\n                    return React.createElement(ReactMUI.Checkbox, {\n                        name: c,\n                        key: c + \"-\" + (selected ? \"true\" : \"false\"),\n                        checked: selected,\n                        onCheck: click,\n                        disabled: disabled[c],\n                        className: \"cbox-\" + c\n                    });\n                }).bind(this));\n                isSelected += inherited ? \" inherited \" : \"\";\n                isSelected += valueClasses.length ? \" checkbox-values-\" + valueClasses.join('-') : \" checkbox-values-empty\";\n                boxes = React.createElement(\n                    'div',\n                    { className: \"tree-checkboxes\" + additionalClassName },\n                    boxes\n                );\n            }\n            var itemStyle = { paddingLeft: depth * 20 };\n            if (this.nodeIsSelected(node) && selectedItemStyle) {\n                itemStyle = _extends({}, itemStyle, selectedItemStyle);\n            }\n            if (getItemStyle) {\n                itemStyle = _extends({}, itemStyle, getItemStyle(node));\n            }\n            var icon = 'mdi mdi-folder';\n            var ajxpMime = node.getAjxpMime();\n            if (ajxpMime === 'ajxp_browsable_archive') {\n                icon = 'mdi mdi-archive';\n            } else if (ajxpMime === 'ajxp_recycle') {\n                icon = 'mdi mdi-delete';\n            }\n            selfLabel = React.createElement(\n                ContextMenuWrapper,\n                { node: node, className: 'tree-item ' + isSelected + (boxes ? ' has-checkboxes' : ''), style: itemStyle },\n                React.createElement(\n                    'div',\n                    { className: 'tree-item-label', onClick: this.onNodeSelect, title: node.getLabel(),\n                        'data-id': node.getPath() },\n                    hasChildren,\n                    React.createElement('span', { className: \"tree-icon \" + icon }),\n                    forceLabel ? forceLabel : node.getLabel()\n                ),\n                boxes\n            );\n        }\n\n        var children = [];\n        var connector = function connector(instance) {\n            return instance;\n        };\n        var draggable = false;\n        if (window.ReactDND && this.props.connectDropTarget && this.props.connectDragSource) {\n            (function () {\n                var connectDragSource = _this.props.connectDragSource;\n                var connectDropTarget = _this.props.connectDropTarget;\n                connector = function (instance) {\n                    connectDragSource(ReactDOM.findDOMNode(instance));\n                    connectDropTarget(ReactDOM.findDOMNode(instance));\n                };\n                draggable = true;\n            })();\n        }\n\n        if (this.state.showChildren || forceExpand) {\n            children = this.state.children.map((function (child) {\n                var props = _extends({}, this.props, {\n                    forceLabel: null,\n                    childrenOnly: false,\n                    key: child.getPath(),\n                    node: child,\n                    depth: depth + 1\n                });\n                return React.createElement(draggable ? DragDropTreeNode : SimpleTreeNode, props);\n            }).bind(this));\n        }\n        return React.createElement(\n            'li',\n            { ref: connector, className: \"treenode\" + node.getPath().replace(/\\//g, '_') },\n            selfLabel,\n            React.createElement(\n                'ul',\n                null,\n                children\n            )\n        );\n    }\n});\n\nvar DragDropTreeNode;\nif (window.ReactDND) {\n    DragDropTreeNode = ReactDND.flow(ReactDND.DragSource(_utilDND.Types.NODE_PROVIDER, _utilDND.nodeDragSource, _utilDND.collect), ReactDND.DropTarget(_utilDND.Types.NODE_PROVIDER, _utilDND.nodeDropTarget, _utilDND.collectDrop))(SimpleTreeNode);\n} else {\n    DragDropTreeNode = SimpleTreeNode;\n}\n\n/**\n * Simple openable / loadable tree taking AjxpNode as inputs\n */\nvar DNDTreeView = React.createClass({\n    displayName: 'DNDTreeView',\n\n    propTypes: {\n        showRoot: React.PropTypes.bool,\n        rootLabel: React.PropTypes.string,\n        onNodeSelect: React.PropTypes.func,\n        node: React.PropTypes.instanceOf(AjxpNode).isRequired,\n        dataModel: React.PropTypes.instanceOf(PydioDataModel).isRequired,\n        selectable: React.PropTypes.bool,\n        selectableMultiple: React.PropTypes.bool,\n        initialSelectionModel: React.PropTypes.array,\n        onSelectionChange: React.PropTypes.func,\n        forceExpand: React.PropTypes.bool,\n        // Optional currently selected detection\n        nodeIsSelected: React.PropTypes.func,\n        // Optional checkboxes\n        checkboxes: React.PropTypes.array,\n        checkboxesValues: React.PropTypes.object,\n        checkboxesComputeStatus: React.PropTypes.func,\n        onCheckboxCheck: React.PropTypes.func\n    },\n\n    getDefaultProps: function getDefaultProps() {\n        return {\n            showRoot: true,\n            onNodeSelect: this.onNodeSelect\n        };\n    },\n\n    onNodeSelect: function onNodeSelect(node) {\n        if (this.props.onNodeSelect) {\n            this.props.onNodeSelect(node);\n        } else {\n            this.props.dataModel.setSelectedNodes([node]);\n        }\n    },\n\n    render: function render() {\n        return React.createElement(\n            'ul',\n            { className: this.props.className },\n            React.createElement(DragDropTreeNode, {\n                childrenOnly: !this.props.showRoot,\n                forceExpand: this.props.forceExpand,\n                node: this.props.node ? this.props.node : this.props.dataModel.getRootNode(),\n                dataModel: this.props.dataModel,\n                onNodeSelect: this.onNodeSelect,\n                nodeIsSelected: this.props.nodeIsSelected,\n                forceLabel: this.props.rootLabel,\n                checkboxes: this.props.checkboxes,\n                checkboxesValues: this.props.checkboxesValues,\n                checkboxesComputeStatus: this.props.checkboxesComputeStatus,\n                onCheckboxCheck: this.props.onCheckboxCheck,\n                selectedItemStyle: this.props.selectedItemStyle,\n                getItemStyle: this.props.getItemStyle\n            })\n        );\n    }\n});\n\nvar TreeView = React.createClass({\n    displayName: 'TreeView',\n\n    propTypes: {\n        showRoot: React.PropTypes.bool,\n        rootLabel: React.PropTypes.string,\n        onNodeSelect: React.PropTypes.func,\n        node: React.PropTypes.instanceOf(AjxpNode).isRequired,\n        dataModel: React.PropTypes.instanceOf(PydioDataModel).isRequired,\n        selectable: React.PropTypes.bool,\n        selectableMultiple: React.PropTypes.bool,\n        initialSelectionModel: React.PropTypes.array,\n        onSelectionChange: React.PropTypes.func,\n        forceExpand: React.PropTypes.bool,\n        // Optional currently selected detection\n        nodeIsSelected: React.PropTypes.func,\n        // Optional checkboxes\n        checkboxes: React.PropTypes.array,\n        checkboxesValues: React.PropTypes.object,\n        checkboxesComputeStatus: React.PropTypes.func,\n        onCheckboxCheck: React.PropTypes.func\n    },\n\n    getDefaultProps: function getDefaultProps() {\n        return {\n            showRoot: true,\n            onNodeSelect: this.onNodeSelect\n        };\n    },\n\n    onNodeSelect: function onNodeSelect(node) {\n        if (this.props.onNodeSelect) {\n            this.props.onNodeSelect(node);\n        } else {\n            this.props.dataModel.setSelectedNodes([node]);\n        }\n    },\n\n    render: function render() {\n        return React.createElement(\n            'ul',\n            { className: this.props.className },\n            React.createElement(SimpleTreeNode, {\n                childrenOnly: !this.props.showRoot,\n                forceExpand: this.props.forceExpand,\n                node: this.props.node ? this.props.node : this.props.dataModel.getRootNode(),\n                dataModel: this.props.dataModel,\n                onNodeSelect: this.onNodeSelect,\n                nodeIsSelected: this.props.nodeIsSelected,\n                forceLabel: this.props.rootLabel,\n                checkboxes: this.props.checkboxes,\n                checkboxesValues: this.props.checkboxesValues,\n                checkboxesComputeStatus: this.props.checkboxesComputeStatus,\n                onCheckboxCheck: this.props.onCheckboxCheck,\n                selectedItemStyle: this.props.selectedItemStyle,\n                getItemStyle: this.props.getItemStyle\n            })\n        );\n    }\n\n});\n\nvar FoldersTree = React.createClass({\n    displayName: 'FoldersTree',\n\n    propTypes: {\n        pydio: React.PropTypes.instanceOf(Pydio).isRequired,\n        dataModel: React.PropTypes.instanceOf(PydioDataModel).isRequired,\n        className: React.PropTypes.string,\n        onNodeSelected: React.PropTypes.func,\n        draggable: React.PropTypes.bool\n    },\n\n    nodeObserver: function nodeObserver() {\n        var r = this.props.dataModel.getRootNode();\n        if (!r.isLoaded()) {\n            r.observeOnce(\"loaded\", (function () {\n                this.forceUpdate();\n            }).bind(this));\n        } else {\n            this.forceUpdate();\n        }\n    },\n\n    componentDidMount: function componentDidMount() {\n        var dm = this.props.dataModel;\n        this._dmObs = this.nodeObserver;\n        dm.observe(\"context_changed\", this._dmObs);\n        dm.observe(\"root_node_changed\", this._dmObs);\n        this.nodeObserver();\n    },\n\n    componentWillUnmount: function componentWillUnmount() {\n        if (this._dmObs) {\n            var dm = this.props.dataModel;\n            dm.stopObserving(\"context_changed\", this._dmObs);\n            dm.stopObserving(\"root_node_changed\", this._dmObs);\n        }\n    },\n\n    treeNodeSelected: function treeNodeSelected(n) {\n        if (this.props.onNodeSelected) {\n            this.props.onNodeSelected(n);\n        } else {\n            this.props.dataModel.requireContextChange(n);\n        }\n    },\n\n    nodeIsSelected: function nodeIsSelected(n) {\n        return n === this.props.dataModel.getContextNode();\n    },\n\n    render: function render() {\n        if (this.props.draggable) {\n            return React.createElement(PydioComponents.DNDTreeView, {\n                onNodeSelect: this.treeNodeSelected,\n                nodeIsSelected: this.nodeIsSelected,\n                dataModel: this.props.dataModel,\n                node: this.props.dataModel.getRootNode(),\n                showRoot: this.props.showRoot ? true : false,\n                selectedItemStyle: this.props.selectedItemStyle,\n                getItemStyle: this.props.getItemStyle,\n                className: \"folders-tree\" + (this.props.className ? ' ' + this.props.className : '')\n            });\n        } else {\n            return React.createElement(PydioComponents.TreeView, {\n                onNodeSelect: this.treeNodeSelected,\n                nodeIsSelected: this.nodeIsSelected,\n                dataModel: this.props.dataModel,\n                node: this.props.dataModel.getRootNode(),\n                selectedItemStyle: this.props.selectedItemStyle,\n                getItemStyle: this.props.getItemStyle,\n                showRoot: this.props.showRoot ? true : false,\n                className: \"folders-tree\" + (this.props.className ? ' ' + this.props.className : '')\n            });\n        }\n    }\n\n});\n\nexports.TreeView = TreeView;\nexports.DNDTreeView = DNDTreeView;\nexports.FoldersTree = FoldersTree;\n"]}