StepInfo tweaks
This commit is contained in:
		
							parent
							
								
									aa239451af
								
							
						
					
					
						commit
						bcffaffc07
					
				
					 2 changed files with 38 additions and 69 deletions
				
			
		|  | @ -2,19 +2,20 @@ import React from 'react' | ||||||
| import {View} from 'react-native' | import {View} from 'react-native' | ||||||
| import {msg, Trans} from '@lingui/macro' | import {msg, Trans} from '@lingui/macro' | ||||||
| import {useLingui} from '@lingui/react' | import {useLingui} from '@lingui/react' | ||||||
|  | 
 | ||||||
|  | import {logger} from '#/logger' | ||||||
|  | import {Policies} from 'view/com/auth/create/Policies' | ||||||
|  | import {ScreenTransition} from '#/screens/Login/ScreenTransition' | ||||||
|  | import {is13, is18, useSignupContext} from '#/screens/Signup/state' | ||||||
| import {atoms as a} from '#/alf' | import {atoms as a} from '#/alf' | ||||||
|  | import * as DateField from '#/components/forms/DateField' | ||||||
|  | import {FormError} from '#/components/forms/FormError' | ||||||
|  | import {HostingProvider} from '#/components/forms/HostingProvider' | ||||||
| import * as TextField from '#/components/forms/TextField' | import * as TextField from '#/components/forms/TextField' | ||||||
| import {Envelope_Stroke2_Corner0_Rounded as Envelope} from '#/components/icons/Envelope' | import {Envelope_Stroke2_Corner0_Rounded as Envelope} from '#/components/icons/Envelope' | ||||||
| import {Lock_Stroke2_Corner0_Rounded as Lock} from '#/components/icons/Lock' | import {Lock_Stroke2_Corner0_Rounded as Lock} from '#/components/icons/Lock' | ||||||
| import {Ticket_Stroke2_Corner0_Rounded as Ticket} from '#/components/icons/Ticket' | import {Ticket_Stroke2_Corner0_Rounded as Ticket} from '#/components/icons/Ticket' | ||||||
| import {is13, is18, useSignupContext} from '#/screens/Signup/state' |  | ||||||
| import * as DateField from '#/components/forms/DateField' |  | ||||||
| import {logger} from '#/logger' |  | ||||||
| import {Loader} from '#/components/Loader' | import {Loader} from '#/components/Loader' | ||||||
| import {Policies} from 'view/com/auth/create/Policies' |  | ||||||
| import {HostingProvider} from '#/components/forms/HostingProvider' |  | ||||||
| import {FormError} from '#/components/forms/FormError' |  | ||||||
| import {ScreenTransition} from '#/screens/Login/ScreenTransition' |  | ||||||
| 
 | 
 | ||||||
| function sanitizeDate(date: Date): Date { | function sanitizeDate(date: Date): Date { | ||||||
|   if (!date || date.toString() === 'Invalid Date') { |   if (!date || date.toString() === 'Invalid Date') { | ||||||
|  | @ -32,7 +33,7 @@ export function StepInfo() { | ||||||
| 
 | 
 | ||||||
|   return ( |   return ( | ||||||
|     <ScreenTransition> |     <ScreenTransition> | ||||||
|       <View style={[a.gap_lg]}> |       <View style={[a.gap_md]}> | ||||||
|         <FormError error={state.error} /> |         <FormError error={state.error} /> | ||||||
|         <View> |         <View> | ||||||
|           <TextField.Label> |           <TextField.Label> | ||||||
|  |  | ||||||
|  | @ -1,50 +1,39 @@ | ||||||
| import React from 'react' | import React from 'react' | ||||||
| import {Linking, StyleSheet, View} from 'react-native' | import {View} from 'react-native' | ||||||
| import { |  | ||||||
|   FontAwesomeIcon, |  | ||||||
|   FontAwesomeIconStyle, |  | ||||||
| } from '@fortawesome/react-native-fontawesome' |  | ||||||
| import {ComAtprotoServerDescribeServer} from '@atproto/api' | import {ComAtprotoServerDescribeServer} from '@atproto/api' | ||||||
| import {TextLink} from '../../util/Link' | import {msg, Trans} from '@lingui/macro' | ||||||
| import {Text} from '../../util/text/Text' |  | ||||||
| import {s, colors} from 'lib/styles' |  | ||||||
| import {usePalette} from 'lib/hooks/usePalette' |  | ||||||
| import {Trans, msg} from '@lingui/macro' |  | ||||||
| import {useLingui} from '@lingui/react' | import {useLingui} from '@lingui/react' | ||||||
| 
 | 
 | ||||||
| type ServiceDescription = ComAtprotoServerDescribeServer.OutputSchema | import {atoms as a, useTheme} from '#/alf' | ||||||
|  | import {CircleInfo_Stroke2_Corner0_Rounded as CircleInfo} from '#/components/icons/CircleInfo' | ||||||
|  | import {InlineLink} from '#/components/Link' | ||||||
|  | import {Text} from '#/components/Typography' | ||||||
| 
 | 
 | ||||||
| export const Policies = ({ | export const Policies = ({ | ||||||
|   serviceDescription, |   serviceDescription, | ||||||
|   needsGuardian, |   needsGuardian, | ||||||
|   under13, |   under13, | ||||||
| }: { | }: { | ||||||
|   serviceDescription: ServiceDescription |   serviceDescription: ComAtprotoServerDescribeServer.OutputSchema | ||||||
|   needsGuardian: boolean |   needsGuardian: boolean | ||||||
|   under13: boolean |   under13: boolean | ||||||
| }) => { | }) => { | ||||||
|   const pal = usePalette('default') |   const t = useTheme() | ||||||
|   const {_} = useLingui() |   const {_} = useLingui() | ||||||
|  | 
 | ||||||
|   if (!serviceDescription) { |   if (!serviceDescription) { | ||||||
|     return <View /> |     return <View /> | ||||||
|   } |   } | ||||||
|  | 
 | ||||||
|   const tos = validWebLink(serviceDescription.links?.termsOfService) |   const tos = validWebLink(serviceDescription.links?.termsOfService) | ||||||
|   const pp = validWebLink(serviceDescription.links?.privacyPolicy) |   const pp = validWebLink(serviceDescription.links?.privacyPolicy) | ||||||
|  | 
 | ||||||
|   if (!tos && !pp) { |   if (!tos && !pp) { | ||||||
|     return ( |     return ( | ||||||
|       <View style={[styles.policies, {flexDirection: 'row'}]}> |       <View style={[a.flex_row, a.align_center, a.gap_xs]}> | ||||||
|         <View |         <CircleInfo size="md" fill={t.atoms.text_contrast_low.color} /> | ||||||
|           style={[ | 
 | ||||||
|             styles.errorIcon, |         <Text style={[t.atoms.text_contrast_medium]}> | ||||||
|             {borderColor: pal.colors.text, marginTop: 1}, |  | ||||||
|           ]}> |  | ||||||
|           <FontAwesomeIcon |  | ||||||
|             icon="exclamation" |  | ||||||
|             style={pal.textLight as FontAwesomeIconStyle} |  | ||||||
|             size={10} |  | ||||||
|           /> |  | ||||||
|         </View> |  | ||||||
|         <Text style={[pal.textLight, s.pl5, s.flex1]}> |  | ||||||
|           <Trans> |           <Trans> | ||||||
|             This service has not provided terms of service or a privacy policy. |             This service has not provided terms of service or a privacy policy. | ||||||
|           </Trans> |           </Trans> | ||||||
|  | @ -52,50 +41,45 @@ export const Policies = ({ | ||||||
|       </View> |       </View> | ||||||
|     ) |     ) | ||||||
|   } |   } | ||||||
|  | 
 | ||||||
|   const els = [] |   const els = [] | ||||||
|   if (tos) { |   if (tos) { | ||||||
|     els.push( |     els.push( | ||||||
|       <TextLink |       <InlineLink key="tos" to={tos}> | ||||||
|         key="tos" |         {_(msg`Terms of Service`)} | ||||||
|         href={tos} |       </InlineLink>, | ||||||
|         text={_(msg`Terms of Service`)} |  | ||||||
|         style={[pal.link, s.underline]} |  | ||||||
|         onPress={() => Linking.openURL(tos)} |  | ||||||
|       />, |  | ||||||
|     ) |     ) | ||||||
|   } |   } | ||||||
|   if (pp) { |   if (pp) { | ||||||
|     els.push( |     els.push( | ||||||
|       <TextLink |       <InlineLink key="pp" to={pp}> | ||||||
|         key="pp" |         {_(msg`Privacy Policy`)} | ||||||
|         href={pp} |       </InlineLink>, | ||||||
|         text={_(msg`Privacy Policy`)} |  | ||||||
|         style={[pal.link, s.underline]} |  | ||||||
|         onPress={() => Linking.openURL(pp)} |  | ||||||
|       />, |  | ||||||
|     ) |     ) | ||||||
|   } |   } | ||||||
|   if (els.length === 2) { |   if (els.length === 2) { | ||||||
|     els.splice( |     els.splice( | ||||||
|       1, |       1, | ||||||
|       0, |       0, | ||||||
|       <Text key="and" style={pal.textLight}> |       <Text key="and" style={[t.atoms.text_contrast_medium]}> | ||||||
|         {' '} |         {' '} | ||||||
|         and{' '} |         and{' '} | ||||||
|       </Text>, |       </Text>, | ||||||
|     ) |     ) | ||||||
|   } |   } | ||||||
|  | 
 | ||||||
|   return ( |   return ( | ||||||
|     <View style={styles.policies}> |     <View style={[a.gap_sm]}> | ||||||
|       <Text style={pal.textLight}> |       <Text style={[a.leading_snug, t.atoms.text_contrast_medium]}> | ||||||
|         <Trans>By creating an account you agree to the {els}.</Trans> |         <Trans>By creating an account you agree to the {els}.</Trans> | ||||||
|       </Text> |       </Text> | ||||||
|  | 
 | ||||||
|       {under13 ? ( |       {under13 ? ( | ||||||
|         <Text style={[pal.textLight, s.bold]}> |         <Text style={[a.font_bold, a.leading_snug, t.atoms.text_contrast_high]}> | ||||||
|           You must be 13 years of age or older to sign up. |           You must be 13 years of age or older to sign up. | ||||||
|         </Text> |         </Text> | ||||||
|       ) : needsGuardian ? ( |       ) : needsGuardian ? ( | ||||||
|         <Text style={[pal.textLight, s.bold]}> |         <Text style={[a.font_bold, a.leading_snug, t.atoms.text_contrast_high]}> | ||||||
|           <Trans> |           <Trans> | ||||||
|             If you are not yet an adult according to the laws of your country, |             If you are not yet an adult according to the laws of your country, | ||||||
|             your parent or legal guardian must read these Terms on your behalf. |             your parent or legal guardian must read these Terms on your behalf. | ||||||
|  | @ -111,19 +95,3 @@ function validWebLink(url?: string): string | undefined { | ||||||
|     ? url |     ? url | ||||||
|     : undefined |     : undefined | ||||||
| } | } | ||||||
| 
 |  | ||||||
| const styles = StyleSheet.create({ |  | ||||||
|   policies: { |  | ||||||
|     flexDirection: 'column', |  | ||||||
|     gap: 8, |  | ||||||
|   }, |  | ||||||
|   errorIcon: { |  | ||||||
|     borderWidth: 1, |  | ||||||
|     borderColor: colors.white, |  | ||||||
|     borderRadius: 30, |  | ||||||
|     width: 16, |  | ||||||
|     height: 16, |  | ||||||
|     alignItems: 'center', |  | ||||||
|     justifyContent: 'center', |  | ||||||
|   }, |  | ||||||
| }) |  | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue