Refactoring the sidebar
This commit is contained in:
parent
499780fcf0
commit
94c39b87de
4 changed files with 162 additions and 125 deletions
|
@ -3,34 +3,36 @@
|
|||
import React from 'react'
|
||||
import {FormattedMessage, injectIntl, IntlShape} from 'react-intl'
|
||||
|
||||
import {Archiver} from '../archiver'
|
||||
import {Board, MutableBoard} from '../blocks/board'
|
||||
import {BoardView, IViewType, MutableBoardView} from '../blocks/boardView'
|
||||
import {Constants} from '../constants'
|
||||
import mutator from '../mutator'
|
||||
import octoClient from '../octoClient'
|
||||
import {darkTheme, defaultTheme, lightTheme, loadTheme, setTheme, Theme} from '../theme'
|
||||
import {IUser, UserContext} from '../user'
|
||||
import {WorkspaceTree} from '../viewModel/workspaceTree'
|
||||
import Button from '../widgets/buttons/button'
|
||||
import IconButton from '../widgets/buttons/iconButton'
|
||||
import BoardIcon from '../widgets/icons/board'
|
||||
import DeleteIcon from '../widgets/icons/delete'
|
||||
import EditIcon from '../widgets/icons/edit'
|
||||
import DisclosureTriangle from '../widgets/icons/disclosureTriangle'
|
||||
import DuplicateIcon from '../widgets/icons/duplicate'
|
||||
import HamburgerIcon from '../widgets/icons/hamburger'
|
||||
import HideSidebarIcon from '../widgets/icons/hideSidebar'
|
||||
import LogoWithNameIcon from '../widgets/icons/logoWithName'
|
||||
import LogoWithNameWhiteIcon from '../widgets/icons/logoWithNameWhite'
|
||||
import OptionsIcon from '../widgets/icons/options'
|
||||
import ShowSidebarIcon from '../widgets/icons/showSidebar'
|
||||
import TableIcon from '../widgets/icons/table'
|
||||
import Menu from '../widgets/menu'
|
||||
import MenuWrapper from '../widgets/menuWrapper'
|
||||
import {Archiver} from '../../archiver'
|
||||
import {Board, MutableBoard} from '../../blocks/board'
|
||||
import {BoardView, IViewType, MutableBoardView} from '../../blocks/boardView'
|
||||
import {Constants} from '../../constants'
|
||||
import mutator from '../../mutator'
|
||||
import octoClient from '../../octoClient'
|
||||
import {darkTheme, defaultTheme, lightTheme, loadTheme, setTheme, Theme} from '../../theme'
|
||||
import {IUser, UserContext} from '../../user'
|
||||
import {WorkspaceTree} from '../../viewModel/workspaceTree'
|
||||
import Button from '../../widgets/buttons/button'
|
||||
import IconButton from '../../widgets/buttons/iconButton'
|
||||
import BoardIcon from '../../widgets/icons/board'
|
||||
import DeleteIcon from '../../widgets/icons/delete'
|
||||
import EditIcon from '../../widgets/icons/edit'
|
||||
import DisclosureTriangle from '../../widgets/icons/disclosureTriangle'
|
||||
import DuplicateIcon from '../../widgets/icons/duplicate'
|
||||
import HamburgerIcon from '../../widgets/icons/hamburger'
|
||||
import HideSidebarIcon from '../../widgets/icons/hideSidebar'
|
||||
import LogoWithNameIcon from '../../widgets/icons/logoWithName'
|
||||
import LogoWithNameWhiteIcon from '../../widgets/icons/logoWithNameWhite'
|
||||
import OptionsIcon from '../../widgets/icons/options'
|
||||
import ShowSidebarIcon from '../../widgets/icons/showSidebar'
|
||||
import TableIcon from '../../widgets/icons/table'
|
||||
import Menu from '../../widgets/menu'
|
||||
import MenuWrapper from '../../widgets/menuWrapper'
|
||||
|
||||
import ModalWrapper from './modalWrapper'
|
||||
import RegistrationLink from './registrationLink'
|
||||
import ModalWrapper from '../modalWrapper'
|
||||
import RegistrationLink from '../registrationLink'
|
||||
|
||||
import SidebarSettingsMenu from './sidebarSettingsMenu'
|
||||
import './sidebar.scss'
|
||||
|
||||
type Props = {
|
||||
|
@ -294,104 +296,11 @@ class Sidebar extends React.Component<Props, State> {
|
|||
</Menu>
|
||||
</MenuWrapper>
|
||||
|
||||
<MenuWrapper>
|
||||
<div className='octo-sidebar-item subitem'>
|
||||
<FormattedMessage
|
||||
id='Sidebar.settings'
|
||||
defaultMessage='Settings'
|
||||
<SidebarSettingsMenu
|
||||
setLanguage={this.props.setLanguage}
|
||||
setWhiteLogo={(whiteLogo: boolean) => this.setState({whiteLogo})}
|
||||
/>
|
||||
</div>
|
||||
<Menu position='top'>
|
||||
<Menu.Text
|
||||
id='import'
|
||||
name={intl.formatMessage({id: 'Sidebar.import-archive', defaultMessage: 'Import archive'})}
|
||||
onClick={async () => Archiver.importFullArchive()}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='export'
|
||||
name={intl.formatMessage({id: 'Sidebar.export-archive', defaultMessage: 'Export archive'})}
|
||||
onClick={async () => Archiver.exportFullArchive()}
|
||||
/>
|
||||
<Menu.SubMenu
|
||||
id='lang'
|
||||
name={intl.formatMessage({id: 'Sidebar.set-language', defaultMessage: 'Set language'})}
|
||||
position='top'
|
||||
>
|
||||
<Menu.Text
|
||||
id='english-lang'
|
||||
name={intl.formatMessage({id: 'Sidebar.english', defaultMessage: 'English'})}
|
||||
onClick={async () => this.props.setLanguage('en')}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='spanish-lang'
|
||||
name={intl.formatMessage({id: 'Sidebar.spanish', defaultMessage: 'Spanish'})}
|
||||
onClick={async () => this.props.setLanguage('es')}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='german-lang'
|
||||
name={intl.formatMessage({id: 'Sidebar.german', defaultMessage: 'German'})}
|
||||
onClick={async () => this.props.setLanguage('de')}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='japanese-lang'
|
||||
name={intl.formatMessage({id: 'Sidebar.japanese', defaultMessage: 'Japanese'})}
|
||||
onClick={async () => this.props.setLanguage('ja')}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='french-lang'
|
||||
name={intl.formatMessage({id: 'Sidebar.french', defaultMessage: 'French'})}
|
||||
onClick={async () => this.props.setLanguage('fr')}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='dutch-lang'
|
||||
name={intl.formatMessage({id: 'Sidebar.dutch', defaultMessage: 'Dutch'})}
|
||||
onClick={async () => this.props.setLanguage('nl')}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='russian-lang'
|
||||
name={intl.formatMessage({id: 'Sidebar.russian', defaultMessage: 'Russian'})}
|
||||
onClick={async () => this.props.setLanguage('ru')}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='chinese-lang'
|
||||
name={intl.formatMessage({id: 'Sidebar.chinese', defaultMessage: 'Chinese'})}
|
||||
onClick={async () => this.props.setLanguage('zh')}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='turkish-lang'
|
||||
name={intl.formatMessage({id: 'Sidebar.turkish', defaultMessage: 'Turkish'})}
|
||||
onClick={async () => this.props.setLanguage('tr')}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='occitan-lang'
|
||||
name={intl.formatMessage({id: 'Sidebar.occitan', defaultMessage: 'Occitan'})}
|
||||
onClick={async () => this.props.setLanguage('oc')}
|
||||
/>
|
||||
</Menu.SubMenu>
|
||||
<Menu.SubMenu
|
||||
id='theme'
|
||||
name={intl.formatMessage({id: 'Sidebar.set-theme', defaultMessage: 'Set theme'})}
|
||||
position='top'
|
||||
>
|
||||
<Menu.Text
|
||||
id='default-theme'
|
||||
name={intl.formatMessage({id: 'Sidebar.default-theme', defaultMessage: 'Default theme'})}
|
||||
onClick={async () => this.updateTheme(defaultTheme)}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='dark-theme'
|
||||
name={intl.formatMessage({id: 'Sidebar.dark-theme', defaultMessage: 'Dark theme'})}
|
||||
onClick={async () => this.updateTheme(darkTheme)}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='light-theme'
|
||||
name={intl.formatMessage({id: 'Sidebar.light-theme', defaultMessage: 'Light theme'})}
|
||||
onClick={async () => this.updateTheme(lightTheme)}
|
||||
/>
|
||||
</Menu.SubMenu>
|
||||
</Menu>
|
||||
</MenuWrapper>
|
||||
</div>
|
||||
)
|
||||
}
|
||||
|
128
webapp/src/components/sidebar/sidebarSettingsMenu.tsx
Normal file
128
webapp/src/components/sidebar/sidebarSettingsMenu.tsx
Normal file
|
@ -0,0 +1,128 @@
|
|||
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
||||
// See LICENSE.txt for license information.
|
||||
import React from 'react'
|
||||
import {FormattedMessage, injectIntl, IntlShape} from 'react-intl'
|
||||
|
||||
import {Archiver} from '../../archiver'
|
||||
import {darkTheme, defaultTheme, lightTheme, setTheme, Theme} from '../../theme'
|
||||
import Menu from '../../widgets/menu'
|
||||
import MenuWrapper from '../../widgets/menuWrapper'
|
||||
|
||||
import './sidebar.scss'
|
||||
|
||||
type Props = {
|
||||
setLanguage: (lang: string) => void
|
||||
intl: IntlShape
|
||||
setWhiteLogo: (whiteLogo: boolean) => void
|
||||
}
|
||||
|
||||
const SidebarSettingsMenu = React.memo((props: Props) => {
|
||||
const {intl} = props
|
||||
|
||||
const updateTheme = (theme: Theme) => {
|
||||
setTheme(theme)
|
||||
const whiteLogo = (theme.sidebarWhiteLogo === 'true')
|
||||
props.setWhiteLogo(whiteLogo)
|
||||
}
|
||||
return (
|
||||
<MenuWrapper>
|
||||
<div className='octo-sidebar-item subitem'>
|
||||
<FormattedMessage
|
||||
id='Sidebar.settings'
|
||||
defaultMessage='Settings'
|
||||
/>
|
||||
</div>
|
||||
<Menu position='top'>
|
||||
<Menu.Text
|
||||
id='import'
|
||||
name={intl.formatMessage({id: 'Sidebar.import-archive', defaultMessage: 'Import archive'})}
|
||||
onClick={async () => Archiver.importFullArchive()}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='export'
|
||||
name={intl.formatMessage({id: 'Sidebar.export-archive', defaultMessage: 'Export archive'})}
|
||||
onClick={async () => Archiver.exportFullArchive()}
|
||||
/>
|
||||
<Menu.SubMenu
|
||||
id='lang'
|
||||
name={intl.formatMessage({id: 'Sidebar.set-language', defaultMessage: 'Set language'})}
|
||||
position='top'
|
||||
>
|
||||
<Menu.Text
|
||||
id='english-lang'
|
||||
name={intl.formatMessage({id: 'Sidebar.english', defaultMessage: 'English'})}
|
||||
onClick={async () => props.setLanguage('en')}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='spanish-lang'
|
||||
name={intl.formatMessage({id: 'Sidebar.spanish', defaultMessage: 'Spanish'})}
|
||||
onClick={async () => props.setLanguage('es')}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='german-lang'
|
||||
name={intl.formatMessage({id: 'Sidebar.german', defaultMessage: 'German'})}
|
||||
onClick={async () => props.setLanguage('de')}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='japanese-lang'
|
||||
name={intl.formatMessage({id: 'Sidebar.japanese', defaultMessage: 'Japanese'})}
|
||||
onClick={async () => props.setLanguage('ja')}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='french-lang'
|
||||
name={intl.formatMessage({id: 'Sidebar.french', defaultMessage: 'French'})}
|
||||
onClick={async () => props.setLanguage('fr')}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='dutch-lang'
|
||||
name={intl.formatMessage({id: 'Sidebar.dutch', defaultMessage: 'Dutch'})}
|
||||
onClick={async () => props.setLanguage('nl')}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='russian-lang'
|
||||
name={intl.formatMessage({id: 'Sidebar.russian', defaultMessage: 'Russian'})}
|
||||
onClick={async () => props.setLanguage('ru')}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='chinese-lang'
|
||||
name={intl.formatMessage({id: 'Sidebar.chinese', defaultMessage: 'Chinese'})}
|
||||
onClick={async () => props.setLanguage('zh')}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='turkish-lang'
|
||||
name={intl.formatMessage({id: 'Sidebar.turkish', defaultMessage: 'Turkish'})}
|
||||
onClick={async () => props.setLanguage('tr')}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='occitan-lang'
|
||||
name={intl.formatMessage({id: 'Sidebar.occitan', defaultMessage: 'Occitan'})}
|
||||
onClick={async () => props.setLanguage('oc')}
|
||||
/>
|
||||
</Menu.SubMenu>
|
||||
<Menu.SubMenu
|
||||
id='theme'
|
||||
name={intl.formatMessage({id: 'Sidebar.set-theme', defaultMessage: 'Set theme'})}
|
||||
position='top'
|
||||
>
|
||||
<Menu.Text
|
||||
id='default-theme'
|
||||
name={intl.formatMessage({id: 'Sidebar.default-theme', defaultMessage: 'Default theme'})}
|
||||
onClick={async () => updateTheme(defaultTheme)}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='dark-theme'
|
||||
name={intl.formatMessage({id: 'Sidebar.dark-theme', defaultMessage: 'Dark theme'})}
|
||||
onClick={async () => updateTheme(darkTheme)}
|
||||
/>
|
||||
<Menu.Text
|
||||
id='light-theme'
|
||||
name={intl.formatMessage({id: 'Sidebar.light-theme', defaultMessage: 'Light theme'})}
|
||||
onClick={async () => updateTheme(lightTheme)}
|
||||
/>
|
||||
</Menu.SubMenu>
|
||||
</Menu>
|
||||
</MenuWrapper>
|
||||
)
|
||||
})
|
||||
|
||||
export default injectIntl(SidebarSettingsMenu)
|
|
@ -7,7 +7,7 @@ import {Utils} from '../utils'
|
|||
import {BoardTree} from '../viewModel/boardTree'
|
||||
import {WorkspaceTree} from '../viewModel/workspaceTree'
|
||||
|
||||
import Sidebar from './sidebar'
|
||||
import Sidebar from './sidebar/sidebar'
|
||||
import CenterPanel from './centerPanel'
|
||||
import './workspace.scss'
|
||||
|
||||
|
|
Loading…
Reference in a new issue