import { Component, ReactElement } from 'react'; import { observer } from 'mobx-react'; import { defineMessages, injectIntl, WrappedComponentProps } from 'react-intl'; import withStyles, { WithStylesProps } from 'react-jss'; import Infobox from '../../../components/ui/infobox/index'; import Loader from '../../../components/ui/loader'; import WorkspaceItem from './WorkspaceItem'; import CreateWorkspaceForm from './CreateWorkspaceForm'; import Request from '../../../stores/lib/Request'; import Appear from '../../../components/ui/effects/Appear'; import { H1 } from '../../../components/ui/headline'; import Workspace from '../models/Workspace'; const messages = defineMessages({ headline: { id: 'settings.workspaces.headline', defaultMessage: 'Your workspaces', }, noServicesAdded: { id: 'settings.workspaces.noWorkspacesAdded', defaultMessage: "You haven't created any workspaces yet.", }, workspacesRequestFailed: { id: 'settings.workspaces.workspacesRequestFailed', defaultMessage: 'Could not load your workspaces', }, tryReloadWorkspaces: { id: 'settings.workspaces.tryReloadWorkspaces', defaultMessage: 'Try again', }, updatedInfo: { id: 'settings.workspaces.updatedInfo', defaultMessage: 'Your changes have been saved', }, deletedInfo: { id: 'settings.workspaces.deletedInfo', defaultMessage: 'Workspace has been deleted', }, workspaceFeatureInfo: { id: 'settings.workspaces.workspaceFeatureInfo', defaultMessage: 'Ferdium Workspaces let you focus on what’s important right now. Set up different sets of services and easily switch between them at any time. You decide which services you need when and where, so we can help you stay on top of your game - or easily switch off from work whenever you want.', }, workspaceFeatureHeadline: { id: 'settings.workspaces.workspaceFeatureHeadline', defaultMessage: 'Less is More: Introducing Ferdium Workspaces', }, }); const styles = { table: { width: '100%', '& td': { padding: '10px', }, }, createForm: { height: 'auto', }, appear: { height: 'auto', }, teaserImage: { width: 250, margin: [-8, 0, 0, 20], alignSelf: 'center', }, }; interface IProps extends WithStylesProps, WrappedComponentProps { getUserWorkspacesRequest: Request; createWorkspaceRequest: Request; deleteWorkspaceRequest: Request; updateWorkspaceRequest: Request; onCreateWorkspaceSubmit: (workspace: Workspace) => void; onWorkspaceClick: (workspace: Workspace) => void; workspaces: Workspace[]; } @observer class WorkspacesDashboard extends Component { render(): ReactElement { const { classes, getUserWorkspacesRequest, createWorkspaceRequest, deleteWorkspaceRequest, updateWorkspaceRequest, onCreateWorkspaceSubmit, onWorkspaceClick, workspaces, } = this.props; const { intl } = this.props; return (

{intl.formatMessage(messages.headline)}

{/* ===== Workspace updated info ===== */} {updateWorkspaceRequest.wasExecuted && updateWorkspaceRequest.result && ( {intl.formatMessage(messages.updatedInfo)} )} {/* ===== Workspace deleted info ===== */} {deleteWorkspaceRequest.wasExecuted && deleteWorkspaceRequest.result && ( {intl.formatMessage(messages.deletedInfo)} )} {/* ===== Create workspace form ===== */}
{getUserWorkspacesRequest.isExecuting ? ( ) : ( <> {/* ===== Workspace could not be loaded error ===== */} {getUserWorkspacesRequest.error ? ( {intl.formatMessage(messages.workspacesRequestFailed)} ) : ( // eslint-disable-next-line react/jsx-no-useless-fragment <> {workspaces.length === 0 ? (
{/* ===== Workspaces empty state ===== */}

{intl.formatMessage(messages.noServicesAdded)}

) : ( {/* ===== Workspaces list ===== */} {workspaces.map(workspace => ( onWorkspaceClick(w)} /> ))}
)} )} )}
); } } export default injectIntl( withStyles(styles, { injectTheme: true })(WorkspacesDashboard), );