Port 134de736dc to glitch-soc
Co-authored-by: Renaud Chaput <renchap@gmail.com>
Signed-off-by: Claire <claire.github-309c@sitedethib.com>
		
	
			
		
			
				
	
	
		
			105 lines
		
	
	
	
		
			3.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			105 lines
		
	
	
	
		
			3.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| //  Package imports
 | |
| import PropTypes from 'prop-types';
 | |
| import { PureComponent } from 'react';
 | |
| 
 | |
| import { injectIntl, defineMessages } from 'react-intl';
 | |
| 
 | |
| import { ReactComponent as CloseIcon } from '@material-symbols/svg-600/outlined/close.svg';
 | |
| import { ReactComponent as EditIcon } from '@material-symbols/svg-600/outlined/edit.svg';
 | |
| import { ReactComponent as ExpandLessIcon } from '@material-symbols/svg-600/outlined/expand_less.svg';
 | |
| import { ReactComponent as ImageIcon } from '@material-symbols/svg-600/outlined/image.svg';
 | |
| import { ReactComponent as ManufacturingIcon } from '@material-symbols/svg-600/outlined/manufacturing.svg';
 | |
| import { ReactComponent as SettingsIcon } from '@material-symbols/svg-600/outlined/settings-fill.svg';
 | |
| 
 | |
| import { preferencesLink } from 'flavours/glitch/utils/backend_links';
 | |
| 
 | |
| import LocalSettingsNavigationItem from './item';
 | |
| 
 | |
| const messages = defineMessages({
 | |
|   general: {  id: 'settings.general', defaultMessage: 'General' },
 | |
|   compose: {  id: 'settings.compose_box_opts', defaultMessage: 'Compose box' },
 | |
|   content_warnings: { id: 'settings.content_warnings', defaultMessage: 'Content Warnings' },
 | |
|   collapsed: { id: 'settings.collapsed_statuses', defaultMessage: 'Collapsed toots' },
 | |
|   media: { id: 'settings.media', defaultMessage: 'Media' },
 | |
|   preferences: { id: 'settings.preferences', defaultMessage: 'Preferences' },
 | |
|   close: { id: 'settings.close', defaultMessage: 'Close' },
 | |
| });
 | |
| 
 | |
| class LocalSettingsNavigation extends PureComponent {
 | |
| 
 | |
|   static propTypes = {
 | |
|     index      : PropTypes.number,
 | |
|     intl       : PropTypes.object.isRequired,
 | |
|     onClose    : PropTypes.func.isRequired,
 | |
|     onNavigate : PropTypes.func.isRequired,
 | |
|   };
 | |
| 
 | |
|   render () {
 | |
| 
 | |
|     const { index, intl, onClose, onNavigate } = this.props;
 | |
| 
 | |
|     return (
 | |
|       <nav className='glitch local-settings__navigation'>
 | |
|         <LocalSettingsNavigationItem
 | |
|           active={index === 0}
 | |
|           index={0}
 | |
|           onNavigate={onNavigate}
 | |
|           icon='cogs'
 | |
|           iconComponent={ManufacturingIcon}
 | |
|           title={intl.formatMessage(messages.general)}
 | |
|         />
 | |
|         <LocalSettingsNavigationItem
 | |
|           active={index === 1}
 | |
|           index={1}
 | |
|           onNavigate={onNavigate}
 | |
|           icon='pencil'
 | |
|           iconComponent={EditIcon}
 | |
|           title={intl.formatMessage(messages.compose)}
 | |
|         />
 | |
|         <LocalSettingsNavigationItem
 | |
|           active={index === 2}
 | |
|           index={2}
 | |
|           onNavigate={onNavigate}
 | |
|           textIcon='CW'
 | |
|           title={intl.formatMessage(messages.content_warnings)}
 | |
|         />
 | |
|         <LocalSettingsNavigationItem
 | |
|           active={index === 3}
 | |
|           index={3}
 | |
|           onNavigate={onNavigate}
 | |
|           icon='angle-double-up'
 | |
|           iconComponent={ExpandLessIcon}
 | |
|           title={intl.formatMessage(messages.collapsed)}
 | |
|         />
 | |
|         <LocalSettingsNavigationItem
 | |
|           active={index === 4}
 | |
|           index={4}
 | |
|           onNavigate={onNavigate}
 | |
|           icon='image'
 | |
|           iconComponent={ImageIcon}
 | |
|           title={intl.formatMessage(messages.media)}
 | |
|         />
 | |
|         <LocalSettingsNavigationItem
 | |
|           active={index === 5}
 | |
|           href={preferencesLink}
 | |
|           index={5}
 | |
|           icon='cog'
 | |
|           iconComponent={SettingsIcon}
 | |
|           title={intl.formatMessage(messages.preferences)}
 | |
|         />
 | |
|         <LocalSettingsNavigationItem
 | |
|           active={index === 6}
 | |
|           className='close'
 | |
|           index={6}
 | |
|           onNavigate={onClose}
 | |
|           icon='times'
 | |
|           iconComponent={CloseIcon}
 | |
|           title={intl.formatMessage(messages.close)}
 | |
|         />
 | |
|       </nav>
 | |
|     );
 | |
|   }
 | |
| 
 | |
| }
 | |
| 
 | |
| export default injectIntl(LocalSettingsNavigation);
 |