@bifold/core 2.0.1 → 2.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (252) hide show
  1. package/lib/commonjs/components/inputs/BiometryControl.js.map +1 -1
  2. package/lib/commonjs/components/misc/CredentialCard.js +3 -2
  3. package/lib/commonjs/components/misc/CredentialCard.js.map +1 -1
  4. package/lib/commonjs/components/misc/FauxHeader.js +89 -0
  5. package/lib/commonjs/components/misc/FauxHeader.js.map +1 -0
  6. package/lib/commonjs/components/misc/QRScanner.js +1 -1
  7. package/lib/commonjs/components/misc/QRScanner.js.map +1 -1
  8. package/lib/commonjs/components/modals/DeveloperModal.js +43 -0
  9. package/lib/commonjs/components/modals/DeveloperModal.js.map +1 -0
  10. package/lib/commonjs/components/views/PushNotificationsContent.js.map +1 -1
  11. package/lib/commonjs/components/views/PushNotificationsDisabledContent.js.map +1 -1
  12. package/lib/commonjs/contexts/auth.js +24 -3
  13. package/lib/commonjs/contexts/auth.js.map +1 -1
  14. package/lib/commonjs/hooks/chat-messages.js +1 -1
  15. package/lib/commonjs/hooks/chat-messages.js.map +1 -1
  16. package/lib/commonjs/hooks/developer-mode.js +31 -0
  17. package/lib/commonjs/hooks/developer-mode.js.map +1 -0
  18. package/lib/commonjs/hooks/lockout.js +80 -0
  19. package/lib/commonjs/hooks/lockout.js.map +1 -0
  20. package/lib/commonjs/hooks/onboarding.js +23 -0
  21. package/lib/commonjs/hooks/onboarding.js.map +1 -0
  22. package/lib/commonjs/index.js +24 -0
  23. package/lib/commonjs/index.js.map +1 -1
  24. package/lib/commonjs/localization/en/index.js +2 -1
  25. package/lib/commonjs/localization/en/index.js.map +1 -1
  26. package/lib/commonjs/localization/fr/index.js +2 -1
  27. package/lib/commonjs/localization/fr/index.js.map +1 -1
  28. package/lib/commonjs/localization/pt-br/index.js +2 -1
  29. package/lib/commonjs/localization/pt-br/index.js.map +1 -1
  30. package/lib/commonjs/modules/openid/components/OpenIDCredentialCard.js +4 -5
  31. package/lib/commonjs/modules/openid/components/OpenIDCredentialCard.js.map +1 -1
  32. package/lib/commonjs/modules/openid/display.js +6 -3
  33. package/lib/commonjs/modules/openid/display.js.map +1 -1
  34. package/lib/commonjs/modules/openid/metadata.js +2 -1
  35. package/lib/commonjs/modules/openid/metadata.js.map +1 -1
  36. package/lib/commonjs/modules/openid/screens/OpenIDProofChangeCredential.js +128 -0
  37. package/lib/commonjs/modules/openid/screens/OpenIDProofChangeCredential.js.map +1 -0
  38. package/lib/commonjs/modules/openid/screens/OpenIDProofPresentation.js +99 -44
  39. package/lib/commonjs/modules/openid/screens/OpenIDProofPresentation.js.map +1 -1
  40. package/lib/commonjs/modules/openid/types.js.map +1 -1
  41. package/lib/commonjs/modules/openid/utils/utils.js +0 -14
  42. package/lib/commonjs/modules/openid/utils/utils.js.map +1 -1
  43. package/lib/commonjs/navigators/DeliveryStack.js +8 -0
  44. package/lib/commonjs/navigators/DeliveryStack.js.map +1 -1
  45. package/lib/commonjs/navigators/OnboardingScreens.js +0 -8
  46. package/lib/commonjs/navigators/OnboardingScreens.js.map +1 -1
  47. package/lib/commonjs/navigators/OnboardingStack.js +3 -4
  48. package/lib/commonjs/navigators/OnboardingStack.js.map +1 -1
  49. package/lib/commonjs/navigators/TabStack.js +11 -4
  50. package/lib/commonjs/navigators/TabStack.js.map +1 -1
  51. package/lib/commonjs/navigators/defaultStackOptions.js +2 -1
  52. package/lib/commonjs/navigators/defaultStackOptions.js.map +1 -1
  53. package/lib/commonjs/screens/Biometry.js.map +1 -1
  54. package/lib/commonjs/screens/NameWallet.js +4 -3
  55. package/lib/commonjs/screens/NameWallet.js.map +1 -1
  56. package/lib/commonjs/screens/OnboardingPages.js +8 -38
  57. package/lib/commonjs/screens/OnboardingPages.js.map +1 -1
  58. package/lib/commonjs/screens/PINChange.js +5 -1
  59. package/lib/commonjs/screens/PINChange.js.map +1 -1
  60. package/lib/commonjs/screens/PINCreate.js +4 -1
  61. package/lib/commonjs/screens/PINCreate.js.map +1 -1
  62. package/lib/commonjs/screens/PINEnter.js +114 -292
  63. package/lib/commonjs/screens/PINEnter.js.map +1 -1
  64. package/lib/commonjs/screens/PINVerify.js +181 -0
  65. package/lib/commonjs/screens/PINVerify.js.map +1 -0
  66. package/lib/commonjs/screens/PushNotifications.js.map +1 -1
  67. package/lib/commonjs/screens/Settings.js +9 -18
  68. package/lib/commonjs/screens/Settings.js.map +1 -1
  69. package/lib/commonjs/screens/ToggleBiometry.js +16 -24
  70. package/lib/commonjs/screens/ToggleBiometry.js.map +1 -1
  71. package/lib/commonjs/theme.js +2 -1
  72. package/lib/commonjs/theme.js.map +1 -1
  73. package/lib/commonjs/types/navigators.js +1 -0
  74. package/lib/commonjs/types/navigators.js.map +1 -1
  75. package/lib/commonjs/utils/oca.js +46 -17
  76. package/lib/commonjs/utils/oca.js.map +1 -1
  77. package/lib/module/components/inputs/BiometryControl.js.map +1 -1
  78. package/lib/module/components/misc/CredentialCard.js +3 -2
  79. package/lib/module/components/misc/CredentialCard.js.map +1 -1
  80. package/lib/module/components/misc/FauxHeader.js +80 -0
  81. package/lib/module/components/misc/FauxHeader.js.map +1 -0
  82. package/lib/module/components/misc/QRScanner.js +1 -1
  83. package/lib/module/components/misc/QRScanner.js.map +1 -1
  84. package/lib/module/components/modals/DeveloperModal.js +36 -0
  85. package/lib/module/components/modals/DeveloperModal.js.map +1 -0
  86. package/lib/module/components/views/PushNotificationsContent.js.map +1 -1
  87. package/lib/module/components/views/PushNotificationsDisabledContent.js.map +1 -1
  88. package/lib/module/contexts/auth.js +22 -1
  89. package/lib/module/contexts/auth.js.map +1 -1
  90. package/lib/module/hooks/chat-messages.js +1 -1
  91. package/lib/module/hooks/chat-messages.js.map +1 -1
  92. package/lib/module/hooks/developer-mode.js +24 -0
  93. package/lib/module/hooks/developer-mode.js.map +1 -0
  94. package/lib/module/hooks/lockout.js +70 -0
  95. package/lib/module/hooks/lockout.js.map +1 -0
  96. package/lib/module/hooks/onboarding.js +16 -0
  97. package/lib/module/hooks/onboarding.js.map +1 -0
  98. package/lib/module/index.js +4 -1
  99. package/lib/module/index.js.map +1 -1
  100. package/lib/module/localization/en/index.js +2 -1
  101. package/lib/module/localization/en/index.js.map +1 -1
  102. package/lib/module/localization/fr/index.js +2 -1
  103. package/lib/module/localization/fr/index.js.map +1 -1
  104. package/lib/module/localization/pt-br/index.js +2 -1
  105. package/lib/module/localization/pt-br/index.js.map +1 -1
  106. package/lib/module/modules/openid/components/OpenIDCredentialCard.js +4 -4
  107. package/lib/module/modules/openid/components/OpenIDCredentialCard.js.map +1 -1
  108. package/lib/module/modules/openid/display.js +6 -3
  109. package/lib/module/modules/openid/display.js.map +1 -1
  110. package/lib/module/modules/openid/metadata.js +2 -1
  111. package/lib/module/modules/openid/metadata.js.map +1 -1
  112. package/lib/module/modules/openid/screens/OpenIDProofChangeCredential.js +121 -0
  113. package/lib/module/modules/openid/screens/OpenIDProofChangeCredential.js.map +1 -0
  114. package/lib/module/modules/openid/screens/OpenIDProofPresentation.js +100 -45
  115. package/lib/module/modules/openid/screens/OpenIDProofPresentation.js.map +1 -1
  116. package/lib/module/modules/openid/types.js.map +1 -1
  117. package/lib/module/modules/openid/utils/utils.js +1 -12
  118. package/lib/module/modules/openid/utils/utils.js.map +1 -1
  119. package/lib/module/navigators/DeliveryStack.js +8 -0
  120. package/lib/module/navigators/DeliveryStack.js.map +1 -1
  121. package/lib/module/navigators/OnboardingScreens.js +0 -8
  122. package/lib/module/navigators/OnboardingScreens.js.map +1 -1
  123. package/lib/module/navigators/OnboardingStack.js +4 -5
  124. package/lib/module/navigators/OnboardingStack.js.map +1 -1
  125. package/lib/module/navigators/TabStack.js +11 -4
  126. package/lib/module/navigators/TabStack.js.map +1 -1
  127. package/lib/module/navigators/defaultStackOptions.js +2 -1
  128. package/lib/module/navigators/defaultStackOptions.js.map +1 -1
  129. package/lib/module/screens/Biometry.js.map +1 -1
  130. package/lib/module/screens/NameWallet.js +4 -3
  131. package/lib/module/screens/NameWallet.js.map +1 -1
  132. package/lib/module/screens/OnboardingPages.js +8 -38
  133. package/lib/module/screens/OnboardingPages.js.map +1 -1
  134. package/lib/module/screens/PINChange.js +5 -1
  135. package/lib/module/screens/PINChange.js.map +1 -1
  136. package/lib/module/screens/PINCreate.js +4 -1
  137. package/lib/module/screens/PINCreate.js.map +1 -1
  138. package/lib/module/screens/PINEnter.js +116 -294
  139. package/lib/module/screens/PINEnter.js.map +1 -1
  140. package/lib/module/screens/PINVerify.js +172 -0
  141. package/lib/module/screens/PINVerify.js.map +1 -0
  142. package/lib/module/screens/PushNotifications.js.map +1 -1
  143. package/lib/module/screens/Settings.js +7 -16
  144. package/lib/module/screens/Settings.js.map +1 -1
  145. package/lib/module/screens/ToggleBiometry.js +15 -23
  146. package/lib/module/screens/ToggleBiometry.js.map +1 -1
  147. package/lib/module/theme.js +2 -1
  148. package/lib/module/theme.js.map +1 -1
  149. package/lib/module/types/navigators.js +1 -0
  150. package/lib/module/types/navigators.js.map +1 -1
  151. package/lib/module/utils/oca.js +43 -15
  152. package/lib/module/utils/oca.js.map +1 -1
  153. package/lib/typescript/src/components/inputs/BiometryControl.d.ts.map +1 -1
  154. package/lib/typescript/src/components/misc/CredentialCard.d.ts.map +1 -1
  155. package/lib/typescript/src/components/misc/FauxHeader.d.ts +8 -0
  156. package/lib/typescript/src/components/misc/FauxHeader.d.ts.map +1 -0
  157. package/lib/typescript/src/components/modals/DeveloperModal.d.ts +7 -0
  158. package/lib/typescript/src/components/modals/DeveloperModal.d.ts.map +1 -0
  159. package/lib/typescript/src/contexts/auth.d.ts +1 -0
  160. package/lib/typescript/src/contexts/auth.d.ts.map +1 -1
  161. package/lib/typescript/src/hooks/developer-mode.d.ts +4 -0
  162. package/lib/typescript/src/hooks/developer-mode.d.ts.map +1 -0
  163. package/lib/typescript/src/hooks/lockout.d.ts +9 -0
  164. package/lib/typescript/src/hooks/lockout.d.ts.map +1 -0
  165. package/lib/typescript/src/hooks/onboarding.d.ts +2 -0
  166. package/lib/typescript/src/hooks/onboarding.d.ts.map +1 -0
  167. package/lib/typescript/src/index.d.ts +5 -2
  168. package/lib/typescript/src/index.d.ts.map +1 -1
  169. package/lib/typescript/src/localization/en/index.d.ts +1 -0
  170. package/lib/typescript/src/localization/en/index.d.ts.map +1 -1
  171. package/lib/typescript/src/localization/fr/index.d.ts +1 -0
  172. package/lib/typescript/src/localization/fr/index.d.ts.map +1 -1
  173. package/lib/typescript/src/localization/pt-br/index.d.ts +1 -0
  174. package/lib/typescript/src/localization/pt-br/index.d.ts.map +1 -1
  175. package/lib/typescript/src/modules/openid/components/OpenIDCredentialCard.d.ts.map +1 -1
  176. package/lib/typescript/src/modules/openid/display.d.ts.map +1 -1
  177. package/lib/typescript/src/modules/openid/metadata.d.ts +8 -1
  178. package/lib/typescript/src/modules/openid/metadata.d.ts.map +1 -1
  179. package/lib/typescript/src/modules/openid/screens/OpenIDProofChangeCredential.d.ts +6 -0
  180. package/lib/typescript/src/modules/openid/screens/OpenIDProofChangeCredential.d.ts.map +1 -0
  181. package/lib/typescript/src/modules/openid/screens/OpenIDProofPresentation.d.ts.map +1 -1
  182. package/lib/typescript/src/modules/openid/types.d.ts +9 -0
  183. package/lib/typescript/src/modules/openid/types.d.ts.map +1 -1
  184. package/lib/typescript/src/modules/openid/utils/utils.d.ts +1 -3
  185. package/lib/typescript/src/modules/openid/utils/utils.d.ts.map +1 -1
  186. package/lib/typescript/src/navigators/DeliveryStack.d.ts.map +1 -1
  187. package/lib/typescript/src/navigators/OnboardingScreens.d.ts +0 -1
  188. package/lib/typescript/src/navigators/OnboardingScreens.d.ts.map +1 -1
  189. package/lib/typescript/src/navigators/OnboardingStack.d.ts.map +1 -1
  190. package/lib/typescript/src/navigators/TabStack.d.ts.map +1 -1
  191. package/lib/typescript/src/navigators/defaultStackOptions.d.ts.map +1 -1
  192. package/lib/typescript/src/screens/Biometry.d.ts.map +1 -1
  193. package/lib/typescript/src/screens/OnboardingPages.d.ts +1 -1
  194. package/lib/typescript/src/screens/OnboardingPages.d.ts.map +1 -1
  195. package/lib/typescript/src/screens/PINChange.d.ts.map +1 -1
  196. package/lib/typescript/src/screens/PINCreate.d.ts.map +1 -1
  197. package/lib/typescript/src/screens/PINEnter.d.ts +0 -7
  198. package/lib/typescript/src/screens/PINEnter.d.ts.map +1 -1
  199. package/lib/typescript/src/screens/PINVerify.d.ts +13 -0
  200. package/lib/typescript/src/screens/PINVerify.d.ts.map +1 -0
  201. package/lib/typescript/src/screens/Settings.d.ts.map +1 -1
  202. package/lib/typescript/src/screens/ToggleBiometry.d.ts.map +1 -1
  203. package/lib/typescript/src/theme.d.ts +10 -25
  204. package/lib/typescript/src/theme.d.ts.map +1 -1
  205. package/lib/typescript/src/types/navigators.d.ts +14 -1
  206. package/lib/typescript/src/types/navigators.d.ts.map +1 -1
  207. package/lib/typescript/src/utils/oca.d.ts +7 -2
  208. package/lib/typescript/src/utils/oca.d.ts.map +1 -1
  209. package/package.json +3 -3
  210. package/src/components/inputs/BiometryControl.tsx +16 -13
  211. package/src/components/misc/CredentialCard.tsx +5 -2
  212. package/src/components/misc/FauxHeader.tsx +75 -0
  213. package/src/components/misc/QRScanner.tsx +1 -1
  214. package/src/components/modals/DeveloperModal.tsx +30 -0
  215. package/src/components/views/PushNotificationsContent.tsx +15 -15
  216. package/src/components/views/PushNotificationsDisabledContent.tsx +10 -10
  217. package/src/contexts/auth.tsx +33 -1
  218. package/src/hooks/chat-messages.tsx +1 -1
  219. package/src/hooks/developer-mode.ts +25 -0
  220. package/src/hooks/lockout.ts +77 -0
  221. package/src/hooks/onboarding.ts +16 -0
  222. package/src/hooks/usePINValidation.ts +3 -3
  223. package/src/index.ts +7 -0
  224. package/src/localization/en/index.ts +1 -0
  225. package/src/localization/fr/index.ts +1 -0
  226. package/src/localization/pt-br/index.ts +1 -0
  227. package/src/modules/openid/components/OpenIDCredentialCard.tsx +3 -4
  228. package/src/modules/openid/display.tsx +3 -0
  229. package/src/modules/openid/metadata.tsx +7 -1
  230. package/src/modules/openid/screens/OpenIDProofChangeCredential.tsx +132 -0
  231. package/src/modules/openid/screens/OpenIDProofPresentation.tsx +131 -59
  232. package/src/modules/openid/types.tsx +8 -0
  233. package/src/modules/openid/utils/utils.tsx +0 -14
  234. package/src/navigators/DeliveryStack.tsx +9 -0
  235. package/src/navigators/OnboardingScreens.ts +0 -10
  236. package/src/navigators/OnboardingStack.tsx +2 -6
  237. package/src/navigators/RootStack.tsx +1 -1
  238. package/src/navigators/TabStack.tsx +3 -2
  239. package/src/navigators/defaultStackOptions.tsx +1 -0
  240. package/src/screens/Biometry.tsx +1 -4
  241. package/src/screens/NameWallet.tsx +2 -2
  242. package/src/screens/OnboardingPages.tsx +9 -61
  243. package/src/screens/PINChange.tsx +6 -9
  244. package/src/screens/PINCreate.tsx +7 -18
  245. package/src/screens/PINEnter.tsx +114 -361
  246. package/src/screens/PINVerify.tsx +193 -0
  247. package/src/screens/PushNotifications.tsx +2 -2
  248. package/src/screens/Settings.tsx +6 -21
  249. package/src/screens/ToggleBiometry.tsx +20 -34
  250. package/src/theme.ts +34 -3
  251. package/src/types/navigators.ts +18 -1
  252. package/src/utils/oca.ts +60 -19
@@ -25,6 +25,7 @@ import { useAnimatedComponents } from '../contexts/animated-components'
25
25
  import { useAuth } from '../contexts/auth'
26
26
  import { useStore } from '../contexts/store'
27
27
  import { useTheme } from '../contexts/theme'
28
+ import usePreventScreenCapture from '../hooks/screen-capture'
28
29
  import { usePINValidation } from '../hooks/usePINValidation'
29
30
  import { HistoryCardType, HistoryRecord } from '../modules/history/types'
30
31
  import { BifoldError } from '../types/error'
@@ -55,6 +56,7 @@ const PINChange: React.FC<StackScreenProps<ParamListBase, Screens.ChangePIN>> =
55
56
  historyManagerCurried,
56
57
  historyEnabled,
57
58
  historyEventsLogger,
59
+ { preventScreenCapture },
58
60
  ] = useServices([
59
61
  TOKENS.COMPONENT_PIN_HEADER,
60
62
  TOKENS.COMP_BUTTON,
@@ -63,6 +65,7 @@ const PINChange: React.FC<StackScreenProps<ParamListBase, Screens.ChangePIN>> =
63
65
  TOKENS.FN_LOAD_HISTORY,
64
66
  TOKENS.HISTORY_ENABLED,
65
67
  TOKENS.HISTORY_EVENTS_LOGGER,
68
+ TOKENS.CONFIG,
66
69
  ])
67
70
 
68
71
  const {
@@ -75,6 +78,7 @@ const PINChange: React.FC<StackScreenProps<ParamListBase, Screens.ChangePIN>> =
75
78
  clearModal,
76
79
  PINSecurity,
77
80
  } = usePINValidation(PIN, PINTwo)
81
+ usePreventScreenCapture(preventScreenCapture)
78
82
 
79
83
  const style = StyleSheet.create({
80
84
  screenContainer: {
@@ -169,7 +173,6 @@ const PINChange: React.FC<StackScreenProps<ParamListBase, Screens.ChangePIN>> =
169
173
  return PIN === '' || PINTwo === '' || PINOld === '' || PIN.length < minPINLength || PINTwo.length < minPINLength
170
174
  }, [inlineMessages, isLoading, PIN, PINTwo, PINOld])
171
175
 
172
-
173
176
  return (
174
177
  <KeyboardView>
175
178
  <View style={style.screenContainer}>
@@ -218,15 +221,9 @@ const PINChange: React.FC<StackScreenProps<ParamListBase, Screens.ChangePIN>> =
218
221
  ref={PINTwoInputRef}
219
222
  inlineMessage={inlineMessageField2}
220
223
  />
221
- {PINSecurity.displayHelper && (
222
- <PINValidationHelper validations={PINValidations} />
223
- )}
224
+ {PINSecurity.displayHelper && <PINValidationHelper validations={PINValidations} />}
224
225
  {modalState.visible && (
225
- <AlertModal
226
- title={modalState.title}
227
- message={modalState.message}
228
- submit={modalState.onModalDismiss}
229
- />
226
+ <AlertModal title={modalState.title} message={modalState.message} submit={modalState.onModalDismiss} />
230
227
  )}
231
228
  </View>
232
229
  <View style={style.controlsContainer}>
@@ -26,6 +26,7 @@ import { useAuth } from '../contexts/auth'
26
26
  import { DispatchAction } from '../contexts/reducers/store'
27
27
  import { useStore } from '../contexts/store'
28
28
  import { useTheme } from '../contexts/theme'
29
+ import usePreventScreenCapture from '../hooks/screen-capture'
29
30
  import { usePINValidation } from '../hooks/usePINValidation'
30
31
  import { BifoldError } from '../types/error'
31
32
  import { Screens } from '../types/navigators'
@@ -48,7 +49,7 @@ const PINCreate: React.FC<PINCreateProps> = ({ setAuthenticated, explainedStatus
48
49
  const { ButtonLoading } = useAnimatedComponents()
49
50
  const PINTwoInputRef = useRef<TextInput>(null)
50
51
  const createPINButtonRef = useRef<TouchableOpacity>(null)
51
- const [PINExplainer, PINHeader, { showPINExplainer }, Button, inlineMessages] = useServices([
52
+ const [PINExplainer, PINHeader, { showPINExplainer, preventScreenCapture }, Button, inlineMessages] = useServices([
52
53
  TOKENS.SCREEN_PIN_EXPLAINER,
53
54
  TOKENS.COMPONENT_PIN_HEADER,
54
55
  TOKENS.CONFIG,
@@ -57,15 +58,9 @@ const PINCreate: React.FC<PINCreateProps> = ({ setAuthenticated, explainedStatus
57
58
  ])
58
59
 
59
60
  const [explained, setExplained] = useState(explainedStatus || showPINExplainer === false)
60
-
61
- const {
62
- PINValidations,
63
- validatePINEntry,
64
- inlineMessageField1,
65
- inlineMessageField2,
66
- modalState,
67
- PINSecurity
68
- } = usePINValidation(PIN, PINTwo)
61
+ const { PINValidations, validatePINEntry, inlineMessageField1, inlineMessageField2, modalState, PINSecurity } =
62
+ usePINValidation(PIN, PINTwo)
63
+ usePreventScreenCapture(preventScreenCapture)
69
64
 
70
65
  const style = StyleSheet.create({
71
66
  screenContainer: {
@@ -162,15 +157,9 @@ const PINCreate: React.FC<PINCreateProps> = ({ setAuthenticated, explainedStatus
162
157
  ref={PINTwoInputRef}
163
158
  inlineMessage={inlineMessageField2}
164
159
  />
165
- {PINSecurity.displayHelper && (
166
- <PINValidationHelper validations={PINValidations} />
167
- )}
160
+ {PINSecurity.displayHelper && <PINValidationHelper validations={PINValidations} />}
168
161
  {modalState.visible && (
169
- <AlertModal
170
- title={modalState.title}
171
- message={modalState.message}
172
- submit={modalState.onModalDismiss}
173
- />
162
+ <AlertModal title={modalState.title} message={modalState.message} submit={modalState.onModalDismiss} />
174
163
  )}
175
164
  </View>
176
165
  <View style={style.controlsContainer}>