tooot/src/screens/Tabs/Me/Settings/Tooot.tsx

77 lines
2.8 KiB
TypeScript
Raw Normal View History

2021-01-27 00:35:34 +01:00
import Icon from '@components/Icon'
import { MenuContainer, MenuRow } from '@components/Menu'
import { useNavigation } from '@react-navigation/native'
import { StyleConstants } from '@utils/styles/constants'
import { useTheme } from '@utils/styles/ThemeManager'
import * as Linking from 'expo-linking'
import * as WebBrowser from 'expo-web-browser'
import React from 'react'
import { useTranslation } from 'react-i18next'
import { useSelector } from 'react-redux'
2022-11-17 21:48:22 +01:00
import { getInstanceActive, getInstanceVersion } from '@utils/slices/instancesSlice'
import { Platform } from 'react-native'
import Constants from 'expo-constants'
import { getExpoToken } from '@utils/slices/appSlice'
2022-12-04 00:35:13 +01:00
import browserPackage from '@helpers/browserPackage'
2021-01-27 00:35:34 +01:00
const SettingsTooot: React.FC = () => {
2021-02-20 19:12:44 +01:00
const instanceActive = useSelector(getInstanceActive)
2021-08-29 15:25:38 +02:00
const navigation = useNavigation<any>()
2022-02-12 14:51:01 +01:00
const { colors } = useTheme()
2021-03-28 23:31:10 +02:00
const { t } = useTranslation('screenTabs')
2021-01-27 00:35:34 +01:00
2022-11-17 21:48:22 +01:00
const instanceVersion = useSelector(getInstanceVersion, () => true)
const expoToken = useSelector(getExpoToken)
2021-01-27 00:35:34 +01:00
return (
<MenuContainer>
2022-12-08 00:11:03 +01:00
<MenuRow
title={t('me.settings.support.heading')}
content={<Icon name='Heart' size={StyleConstants.Font.Size.M} color={colors.red} />}
iconBack='ChevronRight'
onPress={() => Linking.openURL('https://www.buymeacoffee.com/xmflsct')}
/>
2022-02-10 22:42:46 +01:00
<MenuRow
title={t('me.settings.feedback.heading')}
content={
2022-11-17 21:48:22 +01:00
<Icon name='MessageSquare' size={StyleConstants.Font.Size.M} color={colors.secondary} />
2022-02-10 22:42:46 +01:00
}
iconBack='ChevronRight'
2022-11-29 23:44:11 +01:00
onPress={() => Linking.openURL('https://feedback.tooot.app/feature-requests')}
2022-02-10 22:42:46 +01:00
/>
2021-01-27 00:35:34 +01:00
<MenuRow
2021-03-28 23:31:10 +02:00
title={t('me.settings.contact.heading')}
2022-11-17 21:48:22 +01:00
content={<Icon name='Mail' size={StyleConstants.Font.Size.M} color={colors.secondary} />}
2021-01-27 00:35:34 +01:00
iconBack='ChevronRight'
2022-12-04 00:35:13 +01:00
onPress={async () => {
2021-04-19 17:35:01 +02:00
if (instanceActive !== -1) {
2021-01-30 01:29:15 +01:00
navigation.navigate('Screen-Compose', {
2021-01-27 00:35:34 +01:00
type: 'conversation',
2022-11-17 21:48:22 +01:00
accts: ['tooot@xmflsct.com'],
2022-12-04 13:26:36 +01:00
visibility: 'direct',
2022-11-17 21:48:22 +01:00
text:
'[' +
`${Platform.OS}/${Platform.Version}` +
' - ' +
(Constants.expoConfig?.version ? `t/${Constants.expoConfig?.version}` : '') +
' - ' +
(instanceVersion ? `m/${instanceVersion}` : '') +
' - ' +
(expoToken
? `e/${expoToken.replace(/^ExponentPushToken\[/, '').replace(/\]$/, '')}`
: '') +
']'
2021-01-27 00:35:34 +01:00
})
} else {
2022-12-04 00:35:13 +01:00
WebBrowser.openBrowserAsync('https://social.xmflsct.com/@tooot', {
2022-12-16 22:00:22 +01:00
...(await browserPackage())
2022-12-04 00:35:13 +01:00
})
2021-01-27 00:35:34 +01:00
}
}}
/>
</MenuContainer>
)
}
export default SettingsTooot