2022-07-11 08:48:25 -07:00
import React , { useState , useEffect } from 'react' ;
import { useIntl , FormattedMessage , defineMessages } from 'react-intl' ;
import { showAlertForError } from 'soapbox/actions/alerts' ;
import { patchMe } from 'soapbox/actions/me' ;
2022-07-11 10:04:00 -07:00
import { FE_NAME , SETTINGS_UPDATE , changeSetting } from 'soapbox/actions/settings' ;
import List , { ListItem } from 'soapbox/components/list' ;
import {
CardHeader ,
CardTitle ,
Column ,
Button ,
Form ,
FormActions ,
FormGroup ,
Textarea ,
} from 'soapbox/components/ui' ;
import SettingToggle from 'soapbox/features/notifications/components/setting_toggle' ;
import { useAppSelector , useAppDispatch , useSettings } from 'soapbox/hooks' ;
2022-07-11 08:48:25 -07:00
const isJSONValid = ( text : any ) : boolean = > {
try {
JSON . parse ( text ) ;
return true ;
} catch {
return false ;
}
} ;
const messages = defineMessages ( {
heading : { id : 'column.settings_store' , defaultMessage : 'Settings store' } ,
hint : { id : 'developers.settings_store.hint' , defaultMessage : 'It is possible to directly edit your user settings here. BE CAREFUL! Editing this section can break your account, and you will only be able to recover through the API.' } ,
} ) ;
const SettingsStore : React.FC = ( ) = > {
const intl = useIntl ( ) ;
const dispatch = useAppDispatch ( ) ;
2022-07-11 10:04:00 -07:00
const settings = useSettings ( ) ;
2022-07-11 08:48:25 -07:00
const settingsStore = useAppSelector ( state = > state . get ( 'settings' ) ) ;
const [ rawJSON , setRawJSON ] = useState < string > ( JSON . stringify ( settingsStore , null , 2 ) ) ;
const [ jsonValid , setJsonValid ] = useState ( true ) ;
const [ isLoading , setLoading ] = useState ( false ) ;
const handleEditJSON : React.ChangeEventHandler < HTMLTextAreaElement > = ( { target } ) = > {
const rawJSON = target . value ;
setRawJSON ( rawJSON ) ;
setJsonValid ( isJSONValid ( rawJSON ) ) ;
} ;
2022-07-11 10:04:00 -07:00
const onToggleChange = ( key : string [ ] , checked : boolean ) = > {
dispatch ( changeSetting ( key , checked , { showAlert : true } ) ) ;
} ;
2022-07-11 08:48:25 -07:00
const handleSubmit : React.FormEventHandler = e = > {
const settings = JSON . parse ( rawJSON ) ;
setLoading ( true ) ;
dispatch ( patchMe ( {
pleroma_settings_store : {
[ FE_NAME ] : settings ,
} ,
} ) ) . then ( response = > {
dispatch ( { type : SETTINGS_UPDATE , settings } ) ;
setLoading ( false ) ;
} ) . catch ( error = > {
dispatch ( showAlertForError ( error ) ) ;
setLoading ( false ) ;
} ) ;
} ;
useEffect ( ( ) = > {
setRawJSON ( JSON . stringify ( settingsStore , null , 2 ) ) ;
setJsonValid ( true ) ;
} , [ settingsStore ] ) ;
return (
< Column label = { intl . formatMessage ( messages . heading ) } backHref = '/developers' >
< Form onSubmit = { handleSubmit } >
< FormGroup
hintText = { intl . formatMessage ( messages . hint ) }
errors = { jsonValid ? [ ] : [ 'is invalid' ] }
>
< Textarea
value = { rawJSON }
onChange = { handleEditJSON }
disabled = { isLoading }
rows = { 12 }
isCodeEditor
/ >
< / FormGroup >
< FormActions >
< Button theme = 'primary' type = 'submit' disabled = { ! jsonValid || isLoading } >
< FormattedMessage id = 'soapbox_config.save' defaultMessage = 'Save' / >
< / Button >
< / FormActions >
< / Form >
2022-07-11 10:04:00 -07:00
< CardHeader >
< CardTitle title = 'Advanced settings' / >
< / CardHeader >
< List >
< ListItem label = { < FormattedMessage id = 'preferences.fields.unfollow_modal_label' defaultMessage = 'Show confirmation dialog before unfollowing someone' / > } >
< SettingToggle settings = { settings } settingPath = { [ 'unfollowModal' ] } onChange = { onToggleChange } / >
< / ListItem >
< ListItem label = { < FormattedMessage id = 'preferences.fields.missing_description_modal_label' defaultMessage = 'Show confirmation dialog before sending a post without media descriptions' / > } >
< SettingToggle settings = { settings } settingPath = { [ 'missingDescriptionModal' ] } onChange = { onToggleChange } / >
< / ListItem >
< ListItem label = { < FormattedMessage id = 'preferences.fields.reduce_motion_label' defaultMessage = 'Reduce motion in animations' / > } >
< SettingToggle settings = { settings } settingPath = { [ 'reduceMotion' ] } onChange = { onToggleChange } / >
< / ListItem >
< ListItem label = { < FormattedMessage id = 'preferences.fields.underline_links_label' defaultMessage = 'Always underline links in posts' / > } >
< SettingToggle settings = { settings } settingPath = { [ 'underlineLinks' ] } onChange = { onToggleChange } / >
< / ListItem >
< ListItem label = { < FormattedMessage id = 'preferences.fields.system_font_label' defaultMessage = "Use system's default font" / > } >
< SettingToggle settings = { settings } settingPath = { [ 'systemFont' ] } onChange = { onToggleChange } / >
< / ListItem >
< div className = 'dyslexic' >
< ListItem label = { < FormattedMessage id = 'preferences.fields.dyslexic_font_label' defaultMessage = 'Dyslexic mode' / > } >
< SettingToggle settings = { settings } settingPath = { [ 'dyslexicFont' ] } onChange = { onToggleChange } / >
< / ListItem >
< / div >
{ / * < L i s t I t e m
label = { < FormattedMessage id = 'preferences.fields.halloween_label' defaultMessage = 'Halloween mode' / > }
hint = { < FormattedMessage id = 'preferences.hints.halloween' defaultMessage = 'Beware: SPOOKY! Supports light/dark toggle.' / > }
>
< SettingToggle settings = { settings } settingPath = { [ 'halloween' ] } onChange = { onToggleChange } / >
< / ListItem > * / }
< ListItem
label = { < FormattedMessage id = 'preferences.fields.demetricator_label' defaultMessage = 'Use Demetricator' / > }
hint = { < FormattedMessage id = 'preferences.hints.demetricator' defaultMessage = 'Decrease social media anxiety by hiding all numbers from the site.' / > }
>
< SettingToggle settings = { settings } settingPath = { [ 'demetricator' ] } onChange = { onToggleChange } / >
< / ListItem >
< / List >
2022-07-11 08:48:25 -07:00
< / Column >
) ;
} ;
export default SettingsStore ;