2022-03-21 11:09:01 -07:00
import React from 'react' ;
import { defineMessages , FormattedMessage , useIntl } from 'react-intl' ;
import { useDispatch } from 'react-redux' ;
2022-07-11 09:54:51 -07:00
import { changeSetting } from 'soapbox/actions/settings' ;
2022-03-21 11:09:01 -07:00
import List , { ListItem } from 'soapbox/components/list' ;
import { Form } from 'soapbox/components/ui' ;
import { SelectDropdown } from 'soapbox/features/forms' ;
2022-11-15 11:00:40 -08:00
import SettingToggle from 'soapbox/features/notifications/components/setting-toggle' ;
2022-07-11 09:54:51 -07:00
import { useFeatures , useSettings } from 'soapbox/hooks' ;
2022-03-21 11:09:01 -07:00
2022-05-04 09:11:47 -07:00
import ThemeToggle from '../ui/components/theme-toggle' ;
2022-03-21 11:09:01 -07:00
const languages = {
en : 'English' ,
ar : 'العربية' ,
ast : 'Asturianu' ,
bg : 'Български' ,
bn : 'বাংলা' ,
ca : 'Català' ,
co : 'Corsu' ,
cs : 'Čeština' ,
cy : 'Cymraeg' ,
da : 'Dansk' ,
de : 'Deutsch' ,
el : 'Ελληνικά' ,
'en-Shaw' : '𐑖𐑱𐑝𐑾𐑯' ,
eo : 'Esperanto' ,
es : 'Español' ,
eu : 'Euskara' ,
fa : 'فارسی' ,
fi : 'Suomi' ,
fr : 'Français' ,
ga : 'Gaeilge' ,
gl : 'Galego' ,
he : 'עברית' ,
hi : 'हिन्दी' ,
hr : 'Hrvatski' ,
hu : 'Magyar' ,
hy : 'Հայերեն' ,
id : 'Bahasa Indonesia' ,
io : 'Ido' ,
2022-05-01 14:30:29 -07:00
is : 'íslenska' ,
2022-03-21 11:09:01 -07:00
it : 'Italiano' ,
ja : '日本語' ,
ka : 'ქართული' ,
kk : 'Қазақша' ,
ko : '한국어' ,
lt : 'Lietuvių' ,
lv : 'Latviešu' ,
ml : 'മലയാളം' ,
ms : 'Bahasa Melayu' ,
nl : 'Nederlands' ,
no : 'Norsk' ,
oc : 'Occitan' ,
pl : 'Polski' ,
pt : 'Português' ,
'pt-BR' : 'Português do Brasil' ,
ro : 'Română' ,
ru : 'Русский' ,
sk : 'Slovenčina' ,
sl : 'Slovenščina' ,
sq : 'Shqip' ,
sr : 'Српски' ,
'sr-Latn' : 'Srpski (latinica)' ,
sv : 'Svenska' ,
ta : 'தமிழ்' ,
te : 'తెలుగు' ,
th : 'ไทย' ,
tr : 'Türkçe' ,
uk : 'Українська' ,
zh : '中文' ,
'zh-CN' : '简体中文' ,
'zh-HK' : '繁體中文(香港)' ,
'zh-TW' : '繁體中文(臺灣)' ,
} ;
const messages = defineMessages ( {
heading : { id : 'column.preferences' , defaultMessage : 'Preferences' } ,
2022-10-31 13:22:25 -07:00
displayPostsDefault : { id : 'preferences.fields.display_media.default' , defaultMessage : 'Hide posts marked as sensitive' } ,
displayPostsHideAll : { id : 'preferences.fields.display_media.hide_all' , defaultMessage : 'Always hide posts' } ,
displayPostsShowAll : { id : 'preferences.fields.display_media.show_all' , defaultMessage : 'Always show posts' } ,
2022-05-24 02:46:51 -07:00
privacy_public : { id : 'preferences.options.privacy_public' , defaultMessage : 'Public' } ,
privacy_unlisted : { id : 'preferences.options.privacy_unlisted' , defaultMessage : 'Unlisted' } ,
privacy_followers_only : { id : 'preferences.options.privacy_followers_only' , defaultMessage : 'Followers-only' } ,
content_type_plaintext : { id : 'preferences.options.content_type_plaintext' , defaultMessage : 'Plain text' } ,
content_type_markdown : { id : 'preferences.options.content_type_markdown' , defaultMessage : 'Markdown' } ,
2022-03-21 11:09:01 -07:00
} ) ;
const Preferences = ( ) = > {
const intl = useIntl ( ) ;
const dispatch = useDispatch ( ) ;
2022-07-11 09:54:51 -07:00
const features = useFeatures ( ) ;
const settings = useSettings ( ) ;
2022-03-21 11:09:01 -07:00
const onSelectChange = ( event : React.ChangeEvent < HTMLSelectElement > , path : string [ ] ) = > {
2022-06-22 10:54:36 -07:00
dispatch ( changeSetting ( path , event . target . value , { showAlert : true } ) ) ;
2022-03-21 11:09:01 -07:00
} ;
2022-05-06 11:03:55 -07:00
const onToggleChange = ( key : string [ ] , checked : boolean ) = > {
2022-06-22 10:54:36 -07:00
dispatch ( changeSetting ( key , checked , { showAlert : true } ) ) ;
2022-03-21 11:09:01 -07:00
} ;
const displayMediaOptions = React . useMemo ( ( ) = > ( {
2022-10-31 13:22:25 -07:00
default : intl . formatMessage ( messages . displayPostsDefault ) ,
hide_all : intl.formatMessage ( messages . displayPostsHideAll ) ,
show_all : intl.formatMessage ( messages . displayPostsShowAll ) ,
2022-03-21 11:09:01 -07:00
} ) , [ ] ) ;
2022-05-24 02:46:51 -07:00
const defaultPrivacyOptions = React . useMemo ( ( ) = > ( {
public : intl . formatMessage ( messages . privacy_public ) ,
unlisted : intl.formatMessage ( messages . privacy_unlisted ) ,
private : intl . formatMessage ( messages . privacy_followers_only ) ,
} ) , [ ] ) ;
const defaultContentTypeOptions = React . useMemo ( ( ) = > ( {
'text/plain' : intl . formatMessage ( messages . content_type_plaintext ) ,
'text/markdown' : intl . formatMessage ( messages . content_type_markdown ) ,
} ) , [ ] ) ;
2022-03-21 11:09:01 -07:00
return (
< Form >
< List >
2022-12-23 10:20:11 -08:00
< ListItem label = { < FormattedMessage id = 'home.column_settings.show_reblogs' defaultMessage = 'Show reposts' / > } >
2022-03-21 11:09:01 -07:00
< SettingToggle settings = { settings } settingPath = { [ 'home' , 'shows' , 'reblog' ] } onChange = { onToggleChange } / >
< / ListItem >
2022-12-23 10:20:11 -08:00
< ListItem label = { < FormattedMessage id = 'home.column_settings.show_replies' defaultMessage = 'Show replies' / > } >
2022-03-21 11:09:01 -07:00
< SettingToggle settings = { settings } settingPath = { [ 'home' , 'shows' , 'reply' ] } onChange = { onToggleChange } / >
< / ListItem >
< / List >
< List >
2022-05-04 09:11:47 -07:00
< ListItem label = { < FormattedMessage id = 'preferences.fields.theme' defaultMessage = 'Theme' / > } >
< ThemeToggle / >
< / ListItem >
2022-03-21 11:09:01 -07:00
< ListItem label = { < FormattedMessage id = 'preferences.fields.language_label' defaultMessage = 'Language' / > } >
< SelectDropdown
items = { languages }
2022-04-28 10:43:36 -07:00
defaultValue = { settings . get ( 'locale' ) as string | undefined }
2022-03-21 11:09:01 -07:00
onChange = { ( event : React.ChangeEvent < HTMLSelectElement > ) = > onSelectChange ( event , [ 'locale' ] ) }
/ >
< / ListItem >
2022-10-31 16:02:55 -07:00
< ListItem label = { < FormattedMessage id = 'preferences.fields.media_display_label' defaultMessage = 'Sensitive content' / > } >
2022-03-21 11:09:01 -07:00
< SelectDropdown
items = { displayMediaOptions }
2022-04-28 10:43:36 -07:00
defaultValue = { settings . get ( 'displayMedia' ) as string | undefined }
2022-03-21 11:09:01 -07:00
onChange = { ( event : React.ChangeEvent < HTMLSelectElement > ) = > onSelectChange ( event , [ 'displayMedia' ] ) }
/ >
< / ListItem >
2022-05-24 02:46:51 -07:00
2022-07-11 10:04:00 -07:00
{ features . privacyScopes && (
< ListItem label = { < FormattedMessage id = 'preferences.fields.privacy_label' defaultMessage = 'Default post privacy' / > } >
< SelectDropdown
items = { defaultPrivacyOptions }
defaultValue = { settings . get ( 'defaultPrivacy' ) as string | undefined }
onChange = { ( event : React.ChangeEvent < HTMLSelectElement > ) = > onSelectChange ( event , [ 'defaultPrivacy' ] ) }
2022-03-21 11:09:01 -07:00
/ >
2022-07-11 10:04:00 -07:00
< / ListItem >
) }
{ features . richText && (
< ListItem label = { < FormattedMessage id = 'preferences.fields.content_type_label' defaultMessage = 'Default post format' / > } >
< SelectDropdown
items = { defaultContentTypeOptions }
defaultValue = { settings . get ( 'defaultContentType' ) as string | undefined }
onChange = { ( event : React.ChangeEvent < HTMLSelectElement > ) = > onSelectChange ( event , [ 'defaultContentType' ] ) }
2022-03-21 11:09:01 -07:00
/ >
2022-07-11 10:04:00 -07:00
< / ListItem >
) }
< / List >
2022-03-21 11:09:01 -07:00
< List >
< ListItem label = { < FormattedMessage id = 'preferences.fields.boost_modal_label' defaultMessage = 'Show confirmation dialog before reposting' / > } >
< SettingToggle settings = { settings } settingPath = { [ 'boostModal' ] } onChange = { onToggleChange } / >
< / ListItem >
< ListItem label = { < FormattedMessage id = 'preferences.fields.delete_modal_label' defaultMessage = 'Show confirmation dialog before deleting a post' / > } >
< SettingToggle settings = { settings } settingPath = { [ 'deleteModal' ] } onChange = { onToggleChange } / >
< / ListItem >
< / List >
< List >
< ListItem label = { < FormattedMessage id = 'preferences.fields.auto_play_gif_label' defaultMessage = 'Auto-play animated GIFs' / > } >
< SettingToggle settings = { settings } settingPath = { [ 'autoPlayGif' ] } onChange = { onToggleChange } / >
< / ListItem >
2022-11-11 07:21:32 -08:00
< ListItem label = { < FormattedMessage id = 'preferences.fields.auto_play_video_label' defaultMessage = 'Auto-play videos' / > } >
< SettingToggle settings = { settings } settingPath = { [ 'autoPlayVideo' ] } onChange = { onToggleChange } / >
< / ListItem >
2022-03-21 11:09:01 -07:00
2022-06-29 14:54:51 -07:00
{ features . spoilers && < ListItem label = { < FormattedMessage id = 'preferences.fields.expand_spoilers_label' defaultMessage = 'Always expand posts marked with content warnings' / > } >
2022-03-21 11:09:01 -07:00
< SettingToggle settings = { settings } settingPath = { [ 'expandSpoilers' ] } onChange = { onToggleChange } / >
2022-06-29 14:54:51 -07:00
< / ListItem > }
2022-03-21 11:09:01 -07:00
< ListItem label = { < FormattedMessage id = 'preferences.fields.autoload_timelines_label' defaultMessage = 'Automatically load new posts when scrolled to the top of the page' / > } >
< SettingToggle settings = { settings } settingPath = { [ 'autoloadTimelines' ] } onChange = { onToggleChange } / >
< / ListItem >
< ListItem label = { < FormattedMessage id = 'preferences.fields.autoload_more_label' defaultMessage = 'Automatically load more items when scrolled to the bottom of the page' / > } >
< SettingToggle settings = { settings } settingPath = { [ 'autoloadMore' ] } onChange = { onToggleChange } / >
< / ListItem >
< / List >
< / Form >
) ;
} ;
export { Preferences as default , languages } ;