Bluesky app fork with some witchin' additions 馃挮 witchsky.app
bluesky fork client
120
fork

Configure Feed

Select the types of activity you want to include in your feed.

at a876aae44ea07494ebea9727350aa060b81f317b 63 lines 2.1 kB view raw
1import {View} from 'react-native' 2import {Trans} from '@lingui/react/macro' 3 4import { 5 type AllNavigatorParams, 6 type NativeStackScreenProps, 7} from '#/lib/routes/types' 8import {useNotificationSettingsQuery} from '#/state/queries/notifications/settings' 9import {atoms as a} from '#/alf' 10import {Admonition} from '#/components/Admonition' 11import {At_Stroke2_Corner2_Rounded as AtIcon} from '#/components/icons/At' 12import * as Layout from '#/components/Layout' 13import * as SettingsList from '../components/SettingsList' 14import {ItemTextWithSubtitle} from './components/ItemTextWithSubtitle' 15import {PreferenceControls} from './components/PreferenceControls' 16 17type Props = NativeStackScreenProps< 18 AllNavigatorParams, 19 'MentionNotificationSettings' 20> 21export function MentionNotificationSettingsScreen({}: Props) { 22 const {data: preferences, isError} = useNotificationSettingsQuery() 23 24 return ( 25 <Layout.Screen> 26 <Layout.Header.Outer> 27 <Layout.Header.BackButton /> 28 <Layout.Header.Content> 29 <Layout.Header.TitleText> 30 <Trans>Notifications</Trans> 31 </Layout.Header.TitleText> 32 </Layout.Header.Content> 33 <Layout.Header.Slot /> 34 </Layout.Header.Outer> 35 <Layout.Content> 36 <SettingsList.Container> 37 <SettingsList.Item style={[a.align_start]}> 38 <SettingsList.ItemIcon icon={AtIcon} /> 39 <ItemTextWithSubtitle 40 bold 41 titleText={<Trans>Mentions</Trans>} 42 subtitleText={ 43 <Trans>Get notifications when people mention you.</Trans> 44 } 45 /> 46 </SettingsList.Item> 47 {isError ? ( 48 <View style={[a.px_lg, a.pt_md]}> 49 <Admonition type="error"> 50 <Trans>Failed to load notification settings.</Trans> 51 </Admonition> 52 </View> 53 ) : ( 54 <PreferenceControls 55 name="mention" 56 preference={preferences?.mention} 57 /> 58 )} 59 </SettingsList.Container> 60 </Layout.Content> 61 </Layout.Screen> 62 ) 63}