diff options
Diffstat (limited to 'src/screens/Settings/AboutSettings.tsx')
-rw-r--r-- | src/screens/Settings/AboutSettings.tsx | 78 |
1 files changed, 78 insertions, 0 deletions
diff --git a/src/screens/Settings/AboutSettings.tsx b/src/screens/Settings/AboutSettings.tsx new file mode 100644 index 000000000..3c445b966 --- /dev/null +++ b/src/screens/Settings/AboutSettings.tsx @@ -0,0 +1,78 @@ +import React from 'react' +import {Platform} from 'react-native' +import {setStringAsync} from 'expo-clipboard' +import {msg, Trans} from '@lingui/macro' +import {useLingui} from '@lingui/react' +import {NativeStackScreenProps} from '@react-navigation/native-stack' + +import {appVersion, BUNDLE_DATE, bundleInfo} from '#/lib/app-info' +import {STATUS_PAGE_URL} from '#/lib/constants' +import {CommonNavigatorParams} from '#/lib/routes/types' +import * as Toast from '#/view/com/util/Toast' +import * as SettingsList from '#/screens/Settings/components/SettingsList' +import {CodeLines_Stroke2_Corner2_Rounded as CodeLinesIcon} from '#/components/icons/CodeLines' +import {Globe_Stroke2_Corner0_Rounded as GlobeIcon} from '#/components/icons/Globe' +import {Newspaper_Stroke2_Corner2_Rounded as NewspaperIcon} from '#/components/icons/Newspaper' +import {Wrench_Stroke2_Corner2_Rounded as WrenchIcon} from '#/components/icons/Wrench' +import * as Layout from '#/components/Layout' + +type Props = NativeStackScreenProps<CommonNavigatorParams, 'AboutSettings'> +export function AboutSettingsScreen({}: Props) { + const {_} = useLingui() + + return ( + <Layout.Screen> + <Layout.Header title={_(msg`About`)} /> + <Layout.Content> + <SettingsList.Container> + <SettingsList.LinkItem + to="https://bsky.social/about/support/tos" + label={_(msg`Terms of Service`)}> + <SettingsList.ItemIcon icon={NewspaperIcon} /> + <SettingsList.ItemText> + <Trans>Terms of Service</Trans> + </SettingsList.ItemText> + </SettingsList.LinkItem> + <SettingsList.LinkItem + to="https://bsky.social/about/support/privacy-policy" + label={_(msg`Privacy Policy`)}> + <SettingsList.ItemIcon icon={NewspaperIcon} /> + <SettingsList.ItemText> + <Trans>Privacy Policy</Trans> + </SettingsList.ItemText> + </SettingsList.LinkItem> + <SettingsList.LinkItem + to={STATUS_PAGE_URL} + label={_(msg`Status Page`)}> + <SettingsList.ItemIcon icon={GlobeIcon} /> + <SettingsList.ItemText> + <Trans>Status Page</Trans> + </SettingsList.ItemText> + </SettingsList.LinkItem> + <SettingsList.Divider /> + <SettingsList.LinkItem to="/sys/log" label={_(msg`System log`)}> + <SettingsList.ItemIcon icon={CodeLinesIcon} /> + <SettingsList.ItemText> + <Trans>System log</Trans> + </SettingsList.ItemText> + </SettingsList.LinkItem> + <SettingsList.PressableItem + label={_(msg`Version ${appVersion}`)} + accessibilityHint={_(msg`Copy build version to clipboard`)} + onPress={() => { + setStringAsync( + `Build version: ${appVersion}; Bundle info: ${bundleInfo}; Bundle date: ${BUNDLE_DATE}; Platform: ${Platform.OS}; Platform version: ${Platform.Version}`, + ) + Toast.show(_(msg`Copied build version to clipboard`)) + }}> + <SettingsList.ItemIcon icon={WrenchIcon} /> + <SettingsList.ItemText> + <Trans>Version {appVersion}</Trans> + </SettingsList.ItemText> + <SettingsList.BadgeText>{bundleInfo}</SettingsList.BadgeText> + </SettingsList.PressableItem> + </SettingsList.Container> + </Layout.Content> + </Layout.Screen> + ) +} |