@kiosinc/commons-rn 0.1.48 → 0.1.49

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 (68) hide show
  1. package/lib/commonjs/assets/icons/appLogo.svg +2 -8
  2. package/lib/commonjs/assets/icons/tick.svg +1 -1
  3. package/lib/commonjs/auth/screens/Login.js +17 -30
  4. package/lib/commonjs/auth/screens/Login.js.map +1 -1
  5. package/lib/commonjs/auth/screens/LoginWithEmail.js +18 -13
  6. package/lib/commonjs/auth/screens/LoginWithEmail.js.map +1 -1
  7. package/lib/commonjs/auth/screens/LoginWithPhoneNumber.js +24 -13
  8. package/lib/commonjs/auth/screens/LoginWithPhoneNumber.js.map +1 -1
  9. package/lib/commonjs/auth/screens/ResetPassword.js +4 -9
  10. package/lib/commonjs/auth/screens/ResetPassword.js.map +1 -1
  11. package/lib/commonjs/auth/screens/SignUp.js +6 -19
  12. package/lib/commonjs/auth/screens/SignUp.js.map +1 -1
  13. package/lib/commonjs/auth/screens/VerifyPhoneNumberForLogin.js +1 -1
  14. package/lib/commonjs/auth/screens/VerifyPhoneNumberForLogin.js.map +1 -1
  15. package/lib/commonjs/components/OtpInputs.js +7 -5
  16. package/lib/commonjs/components/OtpInputs.js.map +1 -1
  17. package/lib/commonjs/components/ParentView.js +1 -10
  18. package/lib/commonjs/components/ParentView.js.map +1 -1
  19. package/lib/commonjs/selectBusiness/SelectBusiness.js +13 -2
  20. package/lib/commonjs/selectBusiness/SelectBusiness.js.map +1 -1
  21. package/lib/commonjs/selectBusiness/useBusinesses.js +25 -18
  22. package/lib/commonjs/selectBusiness/useBusinesses.js.map +1 -1
  23. package/lib/module/assets/icons/appLogo.svg +2 -8
  24. package/lib/module/assets/icons/tick.svg +1 -1
  25. package/lib/module/auth/screens/Login.js +19 -32
  26. package/lib/module/auth/screens/Login.js.map +1 -1
  27. package/lib/module/auth/screens/LoginWithEmail.js +19 -14
  28. package/lib/module/auth/screens/LoginWithEmail.js.map +1 -1
  29. package/lib/module/auth/screens/LoginWithPhoneNumber.js +24 -14
  30. package/lib/module/auth/screens/LoginWithPhoneNumber.js.map +1 -1
  31. package/lib/module/auth/screens/ResetPassword.js +5 -10
  32. package/lib/module/auth/screens/ResetPassword.js.map +1 -1
  33. package/lib/module/auth/screens/SignUp.js +6 -19
  34. package/lib/module/auth/screens/SignUp.js.map +1 -1
  35. package/lib/module/auth/screens/VerifyPhoneNumberForLogin.js +1 -1
  36. package/lib/module/auth/screens/VerifyPhoneNumberForLogin.js.map +1 -1
  37. package/lib/module/components/OtpInputs.js +8 -5
  38. package/lib/module/components/OtpInputs.js.map +1 -1
  39. package/lib/module/components/ParentView.js +1 -10
  40. package/lib/module/components/ParentView.js.map +1 -1
  41. package/lib/module/selectBusiness/SelectBusiness.js +14 -3
  42. package/lib/module/selectBusiness/SelectBusiness.js.map +1 -1
  43. package/lib/module/selectBusiness/useBusinesses.js +25 -18
  44. package/lib/module/selectBusiness/useBusinesses.js.map +1 -1
  45. package/lib/typescript/src/auth/screens/Login.d.ts.map +1 -1
  46. package/lib/typescript/src/auth/screens/LoginWithEmail.d.ts.map +1 -1
  47. package/lib/typescript/src/auth/screens/LoginWithPhoneNumber.d.ts.map +1 -1
  48. package/lib/typescript/src/auth/screens/ResetPassword.d.ts.map +1 -1
  49. package/lib/typescript/src/auth/screens/SignUp.d.ts.map +1 -1
  50. package/lib/typescript/src/components/OtpInputs.d.ts +862 -9
  51. package/lib/typescript/src/components/OtpInputs.d.ts.map +1 -1
  52. package/lib/typescript/src/components/ParentView.d.ts +1 -2
  53. package/lib/typescript/src/components/ParentView.d.ts.map +1 -1
  54. package/lib/typescript/src/selectBusiness/SelectBusiness.d.ts.map +1 -1
  55. package/lib/typescript/src/selectBusiness/useBusinesses.d.ts.map +1 -1
  56. package/package.json +2 -1
  57. package/src/assets/icons/appLogo.svg +2 -8
  58. package/src/assets/icons/tick.svg +1 -1
  59. package/src/auth/screens/Login.tsx +17 -45
  60. package/src/auth/screens/LoginWithEmail.tsx +24 -9
  61. package/src/auth/screens/LoginWithPhoneNumber.tsx +29 -10
  62. package/src/auth/screens/ResetPassword.tsx +39 -44
  63. package/src/auth/screens/SignUp.tsx +109 -119
  64. package/src/auth/screens/VerifyPhoneNumberForLogin.tsx +1 -1
  65. package/src/components/OtpInputs.tsx +4 -4
  66. package/src/components/ParentView.tsx +0 -17
  67. package/src/selectBusiness/SelectBusiness.tsx +28 -4
  68. package/src/selectBusiness/useBusinesses.ts +6 -2
@@ -1 +1 @@
1
- {"version":3,"file":"OtpInputs.d.ts","sourceRoot":"","sources":["../../../../src/components/OtpInputs.tsx"],"names":[],"mappings":";AAEA,OAAO,EAEL,KAAK,cAAc,EAEpB,MAAM,oBAAoB,CAAC;AAE5B,OAAO,EAML,KAAK,YAAY,EACjB,KAAK,WAAW,EAChB,KAAK,oBAAoB,EAEzB,KAAK,qBAAqB,EAC1B,KAAK,WAAW,EAChB,KAAK,aAAa,EAIlB,KAAK,6BAA6B,EACnC,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,UAAU,CAAC;AAE1C,KAAK,YAAY,GAAG,YAAY,CAAC,SAAS,CAAC,GACzC,qBAAqB,CAAC,SAAS,CAAC,GAChC,WAAW,CAAC,SAAS,CAAC,GACtB,aAAa,CAAC,SAAS,CAAC,GACxB,WAAW,CAAC,SAAS,CAAC,GACtB,oBAAoB,CAAC,SAAS,CAAC,GAC/B,6BAA6B,CAAC,SAAS,CAAC,CAAC;AAY3C,KAAK,KAAK,GAAG,YAAY,GACvB,cAAc,GAAG;IACf,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,CAAC;AAEJ,eAAO,MAAM,SAAS,gBAAiB,KAAK,gBAI3C,CAAC;AAEF,KAAK,kBAAkB,GAAG;IACxB,YAAY,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACvC,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf,CAAC;AAEF,eAAO,MAAM,SAAS,mDAKnB,kBAAkB,gBA2EpB,CAAC"}
1
+ {"version":3,"file":"OtpInputs.d.ts","sourceRoot":"","sources":["../../../../src/components/OtpInputs.tsx"],"names":[],"mappings":"AACA,OAAO,KAAgC,MAAM,OAAO,CAAC;AAOrD,OAAO,EAML,KAAK,YAAY,EAEjB,KAAK,oBAAoB,EAEzB,KAAK,qBAAqB,EAC1B,KAAK,WAAW,EAKhB,KAAK,6BAA6B,EACnC,MAAM,kBAAkB,CAAC;AA0B1B,eAAO,MAAM,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;yoDAIpB,CAAC;AAEH,KAAK,kBAAkB,GAAG;IACxB,YAAY,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACvC,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf,CAAC;AAEF,eAAO,MAAM,SAAS,mDAKnB,kBAAkB,gBA2EpB,CAAC"}
@@ -7,13 +7,12 @@ type RestyleProps = SpacingProps<ThemeType> & SpacingShorthandProps<ThemeType> &
7
7
  type Props = RestyleProps & ViewProps & {
8
8
  barStyle?: StatusBarStyle;
9
9
  children?: React.ReactNode;
10
- shouldDismissKeyboardOnTap?: boolean;
11
10
  topInset?: boolean;
12
11
  rightInset?: boolean;
13
12
  leftInset?: boolean;
14
13
  bottomInset?: boolean;
15
14
  };
16
15
  export declare function useKeyboard(): number;
17
- export declare const ParentView: ({ children, bg, topInset, rightInset, leftInset, bottomInset, shouldDismissKeyboardOnTap, ...rest }: Props) => JSX.Element;
16
+ export declare const ParentView: ({ children, bg, topInset, rightInset, leftInset, bottomInset, ...rest }: Props) => JSX.Element;
18
17
  export {};
19
18
  //# sourceMappingURL=ParentView.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"ParentView.d.ts","sourceRoot":"","sources":["../../../../src/components/ParentView.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,OAAO,EAIL,KAAK,cAAc,EACpB,MAAM,cAAc,CAAC;AAUtB,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,EAML,KAAK,YAAY,EACjB,KAAK,WAAW,EAChB,KAAK,oBAAoB,EAEzB,KAAK,qBAAqB,EAC1B,KAAK,WAAW,EAChB,KAAK,aAAa,EAIlB,KAAK,6BAA6B,EACnC,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,UAAU,CAAC;AAE1C,KAAK,YAAY,GAAG,YAAY,CAAC,SAAS,CAAC,GACzC,qBAAqB,CAAC,SAAS,CAAC,GAChC,WAAW,CAAC,SAAS,CAAC,GACtB,aAAa,CAAC,SAAS,CAAC,GACxB,WAAW,CAAC,SAAS,CAAC,GACtB,oBAAoB,CAAC,SAAS,CAAC,GAC/B,6BAA6B,CAAC,SAAS,CAAC,CAAC;AAY3C,KAAK,KAAK,GAAG,YAAY,GACvB,SAAS,GAAG;IACV,QAAQ,CAAC,EAAE,cAAc,CAAC;IAC1B,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,0BAA0B,CAAC,EAAE,OAAO,CAAC;IACrC,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB,CAAC;AAEJ,wBAAgB,WAAW,WA4B1B;AAED,eAAO,MAAM,UAAU,wGASpB,KAAK,gBAkDP,CAAC"}
1
+ {"version":3,"file":"ParentView.d.ts","sourceRoot":"","sources":["../../../../src/components/ParentView.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,OAAO,EAIL,KAAK,cAAc,EACpB,MAAM,cAAc,CAAC;AAUtB,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,EAML,KAAK,YAAY,EACjB,KAAK,WAAW,EAChB,KAAK,oBAAoB,EAEzB,KAAK,qBAAqB,EAC1B,KAAK,WAAW,EAChB,KAAK,aAAa,EAIlB,KAAK,6BAA6B,EACnC,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,UAAU,CAAC;AAE1C,KAAK,YAAY,GAAG,YAAY,CAAC,SAAS,CAAC,GACzC,qBAAqB,CAAC,SAAS,CAAC,GAChC,WAAW,CAAC,SAAS,CAAC,GACtB,aAAa,CAAC,SAAS,CAAC,GACxB,WAAW,CAAC,SAAS,CAAC,GACtB,oBAAoB,CAAC,SAAS,CAAC,GAC/B,6BAA6B,CAAC,SAAS,CAAC,CAAC;AAY3C,KAAK,KAAK,GAAG,YAAY,GACvB,SAAS,GAAG;IACV,QAAQ,CAAC,EAAE,cAAc,CAAC;IAC1B,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB,CAAC;AAEJ,wBAAgB,WAAW,WA4B1B;AAED,eAAO,MAAM,UAAU,4EAQpB,KAAK,gBAmCP,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"SelectBusiness.d.ts","sourceRoot":"","sources":["../../../../src/selectBusiness/SelectBusiness.tsx"],"names":[],"mappings":";AA8DA,eAAO,MAAM,cAAc,mBA6G1B,CAAC"}
1
+ {"version":3,"file":"SelectBusiness.d.ts","sourceRoot":"","sources":["../../../../src/selectBusiness/SelectBusiness.tsx"],"names":[],"mappings":";AA8DA,eAAO,MAAM,cAAc,mBAqI1B,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"useBusinesses.d.ts","sourceRoot":"","sources":["../../../../src/selectBusiness/useBusinesses.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,eAAe,wDAE3B,CAAC;AAEF,eAAO,MAAM,aAAa;QAKd,MAAM;UACJ,MAAM;aAkBhB,CAAC"}
1
+ {"version":3,"file":"useBusinesses.d.ts","sourceRoot":"","sources":["../../../../src/selectBusiness/useBusinesses.ts"],"names":[],"mappings":"AAKA,eAAO,MAAM,eAAe,wDAE3B,CAAC;AAEF,eAAO,MAAM,aAAa;QAOd,MAAM;UACJ,MAAM;aAmBnB,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@kiosinc/commons-rn",
3
- "version": "0.1.48",
3
+ "version": "0.1.49",
4
4
  "description": "Common Code",
5
5
  "main": "lib/commonjs/index",
6
6
  "module": "lib/module/index",
@@ -194,6 +194,7 @@
194
194
  "react-hook-form": "^7.48.2",
195
195
  "react-i18next": "^13.5.0",
196
196
  "react-native-config": "^1.5.1",
197
+ "react-native-device-info": "^10.13.2",
197
198
  "react-native-international-phone-number": "^0.7.6",
198
199
  "react-native-paper": "^5.11.1",
199
200
  "react-native-size-matters": "^0.4.2",
@@ -1,9 +1,3 @@
1
- <svg width="120" height="64" viewBox="0 0 120 64" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
2
- <rect y="0.399994" width="120" height="63.2" fill="url(#pattern0)"/>
3
- <defs>
4
- <pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
5
- <use xlink:href="#image0_214_42168" transform="matrix(0.00210667 0 0 0.004 -0.0266667 0)"/>
6
- </pattern>
7
- <image id="image0_214_42168" width="500" height="250" xlink:href=""/>
8
- </defs>
1
+ <svg width="85" height="27" viewBox="0 0 85 27" fill="none" xmlns="http://www.w3.org/2000/svg">
2
+ <path d="M0.47175 0.799998H5.18775L5.00775 13.184L5.25975 13.22C6.12375 12.116 6.97575 11.084 7.81575 10.124C8.67975 9.164 9.74775 8 11.0198 6.632L16.3838 0.799998H22.0358L16.2398 7.028C14.7998 8.588 13.4078 10.04 12.0638 11.384L12.1358 11.6C13.3118 11.744 14.2838 12.116 15.0518 12.716C15.8438 13.316 16.5518 14.228 17.1758 15.452L22.7198 26H17.7878L13.3238 17.756C12.7238 16.652 12.1118 15.92 11.4878 15.56C10.8638 15.176 9.97575 14.984 8.82375 14.984L5.18775 18.836V26H0.47175V0.799998ZM30.7463 0.799998V26H26.0303V0.799998H30.7463ZM47.6067 26.576C45.0867 26.576 42.8667 26.048 40.9467 24.992C39.0507 23.912 37.5747 22.376 36.5187 20.384C35.4627 18.368 34.9347 16.028 34.9347 13.364C34.9347 10.7 35.4627 8.384 36.5187 6.416C37.5747 4.424 39.0507 2.9 40.9467 1.844C42.8667 0.763999 45.0867 0.223999 47.6067 0.223999C50.1267 0.223999 52.3347 0.763999 54.2307 1.844C56.1507 2.9 57.6387 4.424 58.6947 6.416C59.7507 8.384 60.2787 10.7 60.2787 13.364C60.2787 16.028 59.7507 18.368 58.6947 20.384C57.6387 22.376 56.1507 23.912 54.2307 24.992C52.3347 26.048 50.1267 26.576 47.6067 26.576ZM39.7947 13.364C39.7947 16.34 40.5027 18.644 41.9187 20.276C43.3347 21.908 45.2307 22.724 47.6067 22.724C49.9827 22.724 51.8787 21.908 53.2947 20.276C54.7107 18.644 55.4187 16.34 55.4187 13.364C55.4187 10.436 54.7107 8.156 53.2947 6.524C51.8787 4.892 49.9827 4.076 47.6067 4.076C45.2307 4.076 43.3347 4.892 41.9187 6.524C40.5027 8.156 39.7947 10.436 39.7947 13.364ZM74.1469 26.576C71.8189 26.576 69.8029 26.228 68.0989 25.532C66.4189 24.836 65.1349 23.828 64.2469 22.508C63.3589 21.188 62.9149 19.64 62.9149 17.864L67.5589 17.9C67.6309 19.412 68.2549 20.588 69.4309 21.428C70.6069 22.268 72.2149 22.7 74.2549 22.724C76.1269 22.724 77.5669 22.412 78.5749 21.788C79.6069 21.14 80.1229 20.216 80.1229 19.016C80.1229 18.008 79.6789 17.252 78.7909 16.748C77.9269 16.244 76.6429 15.824 74.9389 15.488L72.4549 14.984C70.6549 14.624 69.1309 14.204 67.8829 13.724C66.6589 13.22 65.6389 12.464 64.8229 11.456C64.0069 10.448 63.5989 9.092 63.5989 7.388C63.5989 5.948 64.0189 4.7 64.8589 3.644C65.7229 2.564 66.9349 1.736 68.4949 1.16C70.0789 0.559999 71.9389 0.259999 74.0749 0.259999C77.1949 0.259999 79.6789 1.04 81.5269 2.6C83.3749 4.16 84.3109 6.296 84.3349 9.008H79.7629C79.7389 7.472 79.1989 6.272 78.1429 5.408C77.0869 4.544 75.6829 4.112 73.9309 4.112C72.2029 4.112 70.8469 4.412 69.8629 5.012C68.8789 5.612 68.3869 6.44 68.3869 7.496C68.3869 8.528 68.8429 9.308 69.7549 9.836C70.6669 10.364 71.9869 10.808 73.7149 11.168L76.3789 11.708C78.1309 12.068 79.5949 12.488 80.7709 12.968C81.9709 13.424 82.9549 14.132 83.7229 15.092C84.5149 16.028 84.9109 17.276 84.9109 18.836C84.9109 21.236 83.9509 23.132 82.0309 24.524C80.1349 25.892 77.5069 26.576 74.1469 26.576Z" fill="#23A969"/>
9
3
  </svg>
@@ -1,3 +1,3 @@
1
1
  <svg width="24" height="24" viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
2
- <path d="M9.00016 16.1698L4.83016 11.9998L3.41016 13.4098L9.00016 18.9998L21.0002 6.99984L19.5902 5.58984L9.00016 16.1698Z" fill="#191C1A"/>
2
+ <path d="M9.00016 16.1698L4.83016 11.9998L3.41016 13.4098L9.00016 18.9998L21.0002 6.99984L19.5902 5.58984L9.00016 16.1698Z"/>
3
3
  </svg>
@@ -2,30 +2,22 @@ import {
2
2
  ParentView,
3
3
  Text,
4
4
  View,
5
- LinkButton,
6
5
  KeyboardAvoidingView,
7
6
  Header,
8
7
  } from '../../components';
9
- import {
10
- type NavigationProp,
11
- useNavigation,
12
- useTheme,
13
- } from '@react-navigation/native';
8
+ import { useTheme } from '@react-navigation/native';
14
9
  import React, { useEffect } from 'react';
15
10
  import { useTranslation } from 'react-i18next';
16
11
  import AppLogo from '../../assets/icons/appLogo.svg';
17
12
  import { useMMKVString } from 'react-native-mmkv';
18
13
  import { MMKV_KEYS } from '../../constants';
19
14
  import FastImage from 'react-native-fast-image';
20
- import Config from 'react-native-config';
21
15
  import { useQueryClient } from '@tanstack/react-query';
22
16
  import { StyleSheet } from 'react-native';
23
17
  import { createMaterialTopTabNavigator } from '@react-navigation/material-top-tabs';
24
18
  import { LoginWithPhoneNumber } from './LoginWithPhoneNumber';
25
19
  import { LoginWithEmail } from './LoginWithEmail';
26
- import { moderateScale } from 'react-native-size-matters';
27
- import { analytics } from '../../utils/analytics';
28
- import { analyticsKeys } from '../../constants/analyticsKeys';
20
+ import DeviceInfo from 'react-native-device-info';
29
21
 
30
22
  const Tab = createMaterialTopTabNavigator();
31
23
 
@@ -41,8 +33,6 @@ const TabBarTitle =
41
33
 
42
34
  export const Login = () => {
43
35
  const { t } = useTranslation();
44
- const navigation = useNavigation<NavigationProp<RootStackType>>();
45
-
46
36
  const [_, setBusinessId] = useMMKVString(MMKV_KEYS.BUSINESS_ID);
47
37
  const queryClient = useQueryClient();
48
38
  useEffect(() => {
@@ -59,22 +49,17 @@ export const Login = () => {
59
49
  <ParentView px="16">
60
50
  <Header left={10} position={'absolute'} zIndex={'100'} />
61
51
  <View flex={1} justifyContent={'center'}>
62
- <KeyboardAvoidingView
63
- flex={1}
64
- behavior="padding"
65
- alignSelf="center"
66
- justifyContent={'center'}
67
- width={{ phone: '100%', tablet: 372 }}
68
- >
69
- <View alignItems="center">
52
+ <KeyboardAvoidingView flex={1} width={{ phone: '100%', tablet: 372 }}>
53
+ <View alignItems="center" pt={'16'}>
70
54
  <AppLogo />
71
- <Text style={styles.text} variant="titleLarge">
55
+ <Text pt={'20'} variant="titleMedium">
72
56
  {t('authentication.logIn')}
73
57
  </Text>
74
58
  </View>
75
- <View height={moderateScale(360)} pt="24">
59
+ <View flexGrow={1} flexShrink={1} pt="24">
76
60
  <Tab.Navigator
77
61
  screenOptions={{
62
+ animationEnabled: false,
78
63
  tabBarIndicatorStyle: tabBarStyles.tabBarIndicatorStyle,
79
64
  tabBarStyle: {
80
65
  backgroundColor: theme.colors.background,
@@ -101,35 +86,22 @@ export const Login = () => {
101
86
  />
102
87
  </Tab.Navigator>
103
88
  </View>
104
- {Config.APP_NAME !== 'git' && (
105
- <View
106
- alignItems="center"
107
- justifyContent="center"
108
- pt="4"
109
- flexDirection="row"
110
- >
111
- <Text variant="labelLarge">{t('authentication.newToApp')}</Text>
112
- <LinkButton
113
- mode="text"
114
- onPress={() => {
115
- analytics.track(analyticsKeys.signupStarted);
116
- navigation.navigate('SignUp');
117
- }}
118
- >
119
- {t('authentication.signUp')}
120
- </LinkButton>
121
- </View>
122
- )}
123
89
  </KeyboardAvoidingView>
90
+ <View position={'absolute'} bottom={16} width={'100%'}>
91
+ <Text
92
+ variant="bodySmall"
93
+ alignSelf={'center'}
94
+ color="secondary"
95
+ textAlign="center"
96
+ >{`${t(
97
+ 'profile.version'
98
+ )} ${DeviceInfo.getVersion()} (${DeviceInfo.getBuildNumber()})`}</Text>
99
+ </View>
124
100
  </View>
125
101
  </ParentView>
126
102
  );
127
103
  };
128
104
 
129
- const styles = StyleSheet.create({
130
- text: { paddingTop: '5%' },
131
- });
132
-
133
105
  const getStyles = (theme: any) =>
134
106
  StyleSheet.create({
135
107
  tabBarIndicatorStyle: {
@@ -4,6 +4,7 @@ import {
4
4
  Button,
5
5
  LinkButton,
6
6
  Snackbar,
7
+ Text,
7
8
  } from '../../components';
8
9
  import { type NavigationProp, useNavigation } from '@react-navigation/native';
9
10
  import React, { useState } from 'react';
@@ -12,10 +13,10 @@ import { Controller, useForm } from 'react-hook-form';
12
13
  import { yupResolver } from '@hookform/resolvers/yup';
13
14
  import { loginValidationSchema } from './validators';
14
15
  import auth from '@react-native-firebase/auth';
15
- import { StyleSheet } from 'react-native';
16
16
  import { analytics } from '../../utils/analytics';
17
17
  import Config from 'react-native-config';
18
18
  import { analyticsKeys } from '../../constants/analyticsKeys';
19
+ import { Keyboard } from 'react-native';
19
20
 
20
21
  type FormData = {
21
22
  email: string;
@@ -40,6 +41,7 @@ export const LoginWithEmail = () => {
40
41
  });
41
42
 
42
43
  const onSubmit = (data: FormData) => {
44
+ Keyboard.dismiss();
43
45
  setIsLoading(true);
44
46
  auth()
45
47
  .signInWithEmailAndPassword(data.email, data.password)
@@ -57,8 +59,8 @@ export const LoginWithEmail = () => {
57
59
  };
58
60
 
59
61
  return (
60
- <View paddingTop={'24'}>
61
- <View height={160}>
62
+ <View paddingTop={'8'}>
63
+ <View minHeight={180}>
62
64
  <Controller
63
65
  control={control}
64
66
  render={({ field: { onChange, onBlur, value } }) => {
@@ -113,17 +115,30 @@ export const LoginWithEmail = () => {
113
115
  </View>
114
116
  <Button
115
117
  loading={isLoading}
116
- style={styles.button}
117
118
  mode="contained"
118
119
  onPress={handleSubmit(onSubmit)}
119
120
  >
120
121
  {t('authentication.logIn')}
121
122
  </Button>
123
+ {Config.APP_NAME !== 'git' && (
124
+ <View
125
+ alignItems="center"
126
+ justifyContent="center"
127
+ pt="4"
128
+ flexDirection="row"
129
+ >
130
+ <Text variant="labelLarge">{t('authentication.newToApp')}</Text>
131
+ <LinkButton
132
+ mode="text"
133
+ onPress={() => {
134
+ analytics.track(analyticsKeys.signupStarted);
135
+ navigation.navigate('SignUp');
136
+ }}
137
+ >
138
+ {t('authentication.signUp')}
139
+ </LinkButton>
140
+ </View>
141
+ )}
122
142
  </View>
123
143
  );
124
144
  };
125
-
126
- const styles = StyleSheet.create({
127
- button: { marginVertical: '5%' },
128
- text: { paddingTop: '5%' },
129
- });
@@ -1,12 +1,16 @@
1
- import { Button, PhoneInput, View } from '../../components';
1
+ import { Button, LinkButton, PhoneInput, Text, View } from '../../components';
2
2
  import React, { useState } from 'react';
3
3
  import { useTranslation } from 'react-i18next';
4
4
  import { Controller, useForm } from 'react-hook-form';
5
5
  import { yupResolver } from '@hookform/resolvers/yup';
6
6
  import { loginWithPhoneNumberValidationSchema } from './validators';
7
- import { StyleSheet } from 'react-native';
8
7
  import { useAuthentication } from '../hooks/useAuthentication';
9
8
  import { ICountry } from 'react-native-international-phone-number';
9
+ import { Keyboard } from 'react-native';
10
+ import Config from 'react-native-config';
11
+ import { analytics } from '../../utils/analytics';
12
+ import { analyticsKeys } from '../../constants/analyticsKeys';
13
+ import { NavigationProp, useNavigation } from '@react-navigation/native';
10
14
 
11
15
  type FormData = {
12
16
  phoneNumber: string;
@@ -30,7 +34,9 @@ export const LoginWithPhoneNumber = () => {
30
34
  },
31
35
  });
32
36
 
37
+ const navigation = useNavigation<NavigationProp<RootStackType>>();
33
38
  const onSubmit = (data: FormData) => {
39
+ Keyboard.dismiss();
34
40
  sendCode({
35
41
  phoneNumber: (
36
42
  (selectedCountry?.callingCode ?? '') + data.phoneNumber
@@ -39,8 +45,8 @@ export const LoginWithPhoneNumber = () => {
39
45
  };
40
46
 
41
47
  return (
42
- <View paddingTop="24">
43
- <View height={160}>
48
+ <View paddingTop={'8'}>
49
+ <View minHeight={180}>
44
50
  <Controller
45
51
  control={control}
46
52
  render={({ field: { onChange, onBlur, value } }) => {
@@ -62,17 +68,30 @@ export const LoginWithPhoneNumber = () => {
62
68
  </View>
63
69
  <Button
64
70
  loading={isSendingCode}
65
- style={styles.button}
66
71
  mode="contained"
67
72
  onPress={handleSubmit(onSubmit)}
68
73
  >
69
74
  {t('authentication.logIn')}
70
75
  </Button>
76
+ {Config.APP_NAME !== 'git' && (
77
+ <View
78
+ alignItems="center"
79
+ justifyContent="center"
80
+ pt="4"
81
+ flexDirection="row"
82
+ >
83
+ <Text variant="labelLarge">{t('authentication.newToApp')}</Text>
84
+ <LinkButton
85
+ mode="text"
86
+ onPress={() => {
87
+ analytics.track(analyticsKeys.signupStarted);
88
+ navigation.navigate('SignUp');
89
+ }}
90
+ >
91
+ {t('authentication.signUp')}
92
+ </LinkButton>
93
+ </View>
94
+ )}
71
95
  </View>
72
96
  );
73
97
  };
74
-
75
- const styles = StyleSheet.create({
76
- button: { marginVertical: '5%' },
77
- text: { paddingTop: '5%' },
78
- });
@@ -1,7 +1,6 @@
1
1
  import {
2
2
  ParentView,
3
3
  Text,
4
- View,
5
4
  TextInput,
6
5
  Button,
7
6
  KeyboardAvoidingView,
@@ -43,50 +42,46 @@ export const ResetPassword = () => {
43
42
  return (
44
43
  <ParentView px="16">
45
44
  <Header left={10} position={'absolute'} zIndex={'100'} />
46
- <View flex={1} justifyContent={'center'}>
47
- <KeyboardAvoidingView
48
- alignSelf="center"
49
- justifyContent={'center'}
50
- width={{ phone: '100%', tablet: 372 }}
45
+ <KeyboardAvoidingView
46
+ justifyContent={'center'}
47
+ width={{ phone: '100%', tablet: 372 }}
48
+ >
49
+ <Text py="48" textAlign="center" variant="titleLarge">
50
+ {t('authentication.enterYour')}
51
+ </Text>
52
+ <Controller
53
+ control={control}
54
+ render={({ field: { onChange, onBlur, value } }) => {
55
+ return (
56
+ <TextInput
57
+ autoFocus
58
+ keyboardType="email-address"
59
+ autoCapitalize="none"
60
+ mode="outlined"
61
+ autoComplete="email"
62
+ error={!!errors.email?.message}
63
+ errorMessage={errors.email?.message}
64
+ onBlur={onBlur}
65
+ onChangeText={onChange}
66
+ value={value}
67
+ label={t('authentication.email')}
68
+ />
69
+ );
70
+ }}
71
+ name="email"
72
+ />
73
+ <Button
74
+ loading={isLoading}
75
+ mt="16"
76
+ mode="contained"
77
+ onPress={handleSubmit(onSubmit)}
51
78
  >
52
- <View alignItems="center">
53
- <Text py="48" textAlign="center" variant="titleLarge">
54
- {t('authentication.enterYour')}
55
- </Text>
56
- </View>
57
- <Controller
58
- control={control}
59
- render={({ field: { onChange, onBlur, value } }) => {
60
- return (
61
- <TextInput
62
- keyboardType="email-address"
63
- autoCapitalize="none"
64
- mode="outlined"
65
- autoComplete="email"
66
- error={!!errors.email?.message}
67
- errorMessage={errors.email?.message}
68
- onBlur={onBlur}
69
- onChangeText={onChange}
70
- value={value}
71
- label={t('authentication.email')}
72
- />
73
- );
74
- }}
75
- name="email"
76
- />
77
- <Button
78
- loading={isLoading}
79
- mt="16"
80
- mode="contained"
81
- onPress={handleSubmit(onSubmit)}
82
- >
83
- {t('authentication.resetPassword')}
84
- </Button>
85
- <Button mt="48" mode="outlined" onPress={navigation.goBack}>
86
- {t('cancel')}
87
- </Button>
88
- </KeyboardAvoidingView>
89
- </View>
79
+ {t('authentication.resetPassword')}
80
+ </Button>
81
+ <Button mt="48" mode="outlined" onPress={navigation.goBack}>
82
+ {t('cancel')}
83
+ </Button>
84
+ </KeyboardAvoidingView>
90
85
  </ParentView>
91
86
  );
92
87
  };