form.tsx 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221
  1. import { useState } from 'react';
  2. import {
  3. View,
  4. Text,
  5. StyleSheet,
  6. Pressable,
  7. TouchableWithoutFeedback,
  8. Keyboard
  9. } from 'react-native';
  10. import Verification from './formPages/verification';
  11. import BasicInformation from './formPages/basicInformation';
  12. import UberDriver from './formPages/uberDriver';
  13. import CarInformation from './formPages/carInformation';
  14. import PaginationIndicator from '../../global/PaginationIndicator';
  15. import CreateWallet from './formPages/createWallet';
  16. import FinishSignUp from './formPages/finishSignUp';
  17. import LoginPage from './formPages/loginPage';
  18. import { KeyboardAwareScrollView } from 'react-native-keyboard-aware-scroll-view';
  19. import ChooseCarBrand from './formPages/chooseCarPage/carBrand';
  20. import ChooseCarSeries from './formPages/chooseCarPage/carSeries';
  21. import ChooseCarModel from './formPages/chooseCarPage/carModel';
  22. import ForgetPasswordPage from '../../forgetPasswordMultiStepForm/formComponent/formPages/forgetPasswordPage';
  23. import ForgetPasswordForm from '../../forgetPasswordMultiStepForm/forgetPasswordForm';
  24. type FormProps = {};
  25. const Form: React.FC<FormProps> = ({}) => {
  26. const [screen, setScreen] = useState<number>(0);
  27. const FormTitle = [
  28. '',
  29. '註冊 - 電話驗證',
  30. '註冊 - 基本資料',
  31. '註冊 - Uber Driver',
  32. '註冊 - 車輛資料',
  33. '註冊 - 設立銀包'
  34. ];
  35. const ScreenDisplay = () => {
  36. switch (screen) {
  37. case 0:
  38. return (
  39. <LoginPage
  40. goToNextPage={goToNextPage}
  41. goToForgetPassWordPage={goToForgetPassWordPage}
  42. />
  43. );
  44. case 1:
  45. return <Verification setScreen={setScreen} />;
  46. case 2:
  47. return <BasicInformation goToNextPage={goToNextPage} />;
  48. case 3:
  49. return <UberDriver goToNextPage={goToNextPage} />;
  50. case 4:
  51. return (
  52. <CarInformation
  53. goToNextPage={goToNextPage}
  54. goToChooseCarPage={goToChooseCarBrandPage}
  55. />
  56. );
  57. case 5:
  58. return <CreateWallet goToNextPage={goToNextPage} />;
  59. case 6:
  60. return <FinishSignUp />;
  61. case 7:
  62. return (
  63. <ChooseCarBrand
  64. goToCarInformation={goToCarInformation}
  65. goToChooseCarSeriesPage={goToChooseCarSeriesPage}
  66. />
  67. );
  68. case 8:
  69. return (
  70. <ChooseCarSeries
  71. goToChooseCarBrandPage={goToChooseCarBrandPage}
  72. goToChooseCarModelPage={goToChooseCarModelPage}
  73. />
  74. );
  75. case 9:
  76. return (
  77. <ChooseCarModel
  78. goToChooseCarSeriesPage={goToChooseCarSeriesPage}
  79. goToCarInformation={goToCarInformation}
  80. />
  81. );
  82. case 10:
  83. return (
  84. <ForgetPasswordForm />
  85. )
  86. default:
  87. return <></>;
  88. }
  89. };
  90. const goToPreviousPage = () => {
  91. setScreen((prevState) => {
  92. if (prevState > 0) {
  93. return prevState - 1;
  94. } else {
  95. return prevState;
  96. }
  97. });
  98. };
  99. const goToNextPage = () => {
  100. setScreen((prevState) => {
  101. if (prevState < 6) {
  102. return prevState + 1;
  103. } else {
  104. return prevState;
  105. }
  106. });
  107. };
  108. const goToChooseCarBrandPage = () => {
  109. setScreen((prevState) => {
  110. return 7;
  111. });
  112. };
  113. const goToChooseCarSeriesPage = () => {
  114. setScreen((prevState) => {
  115. return 8;
  116. });
  117. };
  118. const goToChooseCarModelPage = () => {
  119. setScreen((prevState) => {
  120. return 9;
  121. });
  122. };
  123. const goToCarInformation = () => {
  124. setScreen((prevState) => {
  125. return 4;
  126. });
  127. };
  128. const goToForgetPassWordPage = () => {
  129. setScreen((prevState) => {
  130. return 10;
  131. });
  132. };
  133. return (
  134. <>
  135. <KeyboardAwareScrollView
  136. enableOnAndroid={true}
  137. resetScrollToCoords={{ x: 0, y: 0 }}
  138. >
  139. {/* not showing title and pagination on the first and last page */}
  140. {screen == 0 ||
  141. (screen < 6 && (
  142. //dismiss keyboard when user click outside of the input field to improve user experience
  143. <TouchableWithoutFeedback
  144. onPress={() => Keyboard.dismiss()}
  145. >
  146. <View style={styles.topContainer}>
  147. <Text style={styles.text}>
  148. {FormTitle[screen]}
  149. </Text>
  150. <View style={styles.breakline} />
  151. <View
  152. style={
  153. styles.previouspageAndPaginationWrapper
  154. }
  155. >
  156. <Pressable onPress={goToPreviousPage}>
  157. <Text
  158. style={{ color: '#888888' }}
  159. >{`< 上一步`}</Text>
  160. </Pressable>
  161. <PaginationIndicator
  162. totalPages={FormTitle.length}
  163. currentPage={screen}
  164. />
  165. <Pressable
  166. disabled={true}
  167. onPress={goToNextPage}
  168. >
  169. <Text
  170. style={{
  171. color: '#888888',
  172. opacity: 0
  173. }}
  174. >{`下一步 >`}</Text>
  175. </Pressable>
  176. </View>
  177. </View>
  178. </TouchableWithoutFeedback>
  179. ))}
  180. <View style={styles.bottomContainer}>{ScreenDisplay()}</View>
  181. </KeyboardAwareScrollView>
  182. </>
  183. );
  184. };
  185. const styles = StyleSheet.create({
  186. topContainer: {
  187. flex: 1,
  188. alignItems: 'center',
  189. justifyContent: 'center',
  190. paddingBottom: '20%',
  191. paddingTop: '15%'
  192. },
  193. previouspageAndPaginationWrapper: {
  194. display: 'flex',
  195. width: '100%',
  196. flexDirection: 'row',
  197. justifyContent: 'space-between',
  198. alignItems: 'center',
  199. paddingHorizontal: 25
  200. },
  201. bottomContainer: { flex: 2.5 },
  202. breakline: {
  203. width: 24,
  204. height: 1,
  205. backgroundColor: '#000000',
  206. marginVertical: 17
  207. },
  208. text: { fontSize: 24, fontWeight: '300' }
  209. });
  210. export default Form;