import { h, Component } from 'preact'; import { Router, route } from 'preact-router'; import WBBrowse from 'wb-browse'; import WBSignIn from 'wb-sign-in'; import WBSignOut from 'wb-sign-out'; import WBLandingPage from 'wb-landing-page'; import WBProcessView from 'wb-process-view'; import WBCollectionView from 'wb-collection-view'; import WBCollectionBrowse from 'wb-collection-browse'; import WBUsersPage from 'wb-users-page'; import arvadosTypeName from 'arvados-type-name'; class WBApp extends Component { constructor(...args) { super(...args); this.state.arvHost = window.localStorage['arvHost']; this.state.arvToken = window.localStorage['arvToken']; if ('currentUser' in window.localStorage) this.state.currentUser = JSON.parse(window.localStorage['currentUser']); } navbarItemUrl(item) { if (item['id'] === 'sign-out') { return ('/sign-out'); } else if (item['id'] === 'home') { return ('/browse/' + this.state.currentUser.uuid); } else if (item['id'] === 'all-projects') { return ('/browse'); } else if (item['id'] === 'all-users') { return ('/users'); } } breadcrumbClicked(item) { let objectType = arvadosTypeName(item.uuid.split('-')[1]); if (objectType === 'user') route('/browse/' + item.uuid) else if (objectType === 'group' && item.group_class === 'project') route('/browse/' + item.uuid); else if (objectType === 'container_request') route('/process/' + item.uuid) } render() { return ( ); } } export default WBApp;