/* * 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 . */ const React = require('react') const Pydio = require('pydio') const {ActionDialogMixin, SubmitButtonProviderMixin, AsyncComponent} = Pydio.requireLib('boot') const {Tabs, Tab, FontIcon, FlatButton} = require('material-ui') import ProfilePane from './ProfilePane' import ComponentConfigParser from './ComponentConfigParser' let ModalDashboard = React.createClass({ mixins: [ ActionDialogMixin, SubmitButtonProviderMixin ], getDefaultProps: function(){ return { dialogTitle: '', dialogSize: 'md', dialogPadding: false, dialogIsModal: false, dialogScrollBody: false }; }, submit: function(){ this.dismiss(); }, getDefaultButtons: function(){ return []; }, getButtons: function(updater){ this._updater = updater; if(this.refs['profile']){ return this.refs['profile'].getButtons(this._updater); }else{ return this.getDefaultButtons(); } }, onTabChange: function(value){ if(!this._updater) return; if(value && this.refs[value] && this.refs[value].getButtons){ this._updater(this.refs[value].getButtons(this._updater)); }else{ this._updater(this.getDefaultButtons()); } }, render: function(){ const buttonStyle = { textTransform: 'none' }; let tabs = [ (} buttonStyle={buttonStyle} value="profile"> ) ]; ComponentConfigParser.getAccountTabs(this.props.pydio).map(function(tab){ tabs.push( } buttonStyle={buttonStyle} value={tab.id}> ); }.bind(this)); return ( {tabs} ); } }); export {ModalDashboard as default}