@eohjsc/react-native-smart-city 0.2.20 → 0.2.26

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 (340) hide show
  1. package/README.md +1 -1
  2. package/assets/images/Add.svg +5 -0
  3. package/assets/images/AddLocationMaps/Point.svg +3 -0
  4. package/assets/images/CheckCircle.svg +4 -0
  5. package/assets/images/Close.svg +3 -0
  6. package/assets/images/HowToStart.svg +14 -0
  7. package/assets/images/OneTap.svg +14 -0
  8. package/assets/images/OneTap@1x.svg +14 -0
  9. package/assets/images/Rearrange.svg +3 -0
  10. package/assets/images/Schedule.svg +39 -0
  11. package/assets/images/WeatherChange.svg +49 -0
  12. package/package.json +12 -2
  13. package/src/Images/Common/ActiveButton.png +0 -0
  14. package/src/Images/Common/ActiveButton@2x.png +0 -0
  15. package/src/Images/Common/ActiveButton@3x.png +0 -0
  16. package/src/Images/Common/arrow-back.png +0 -0
  17. package/src/Images/Common/checked@2x.png +0 -0
  18. package/src/Images/Common/checked@3x.png +0 -0
  19. package/src/Images/Common/file.png +0 -0
  20. package/src/Images/Common/fullscreen.png +0 -0
  21. package/src/Images/Common/refresh.png +0 -0
  22. package/src/commons/ActionGroup/NumberUpDownActionTemplate.js +1 -1
  23. package/src/commons/ActionGroup/OnOffTemplate/index.js +4 -4
  24. package/src/commons/ActionGroup/OptionsDropdownActionTemplate.js +7 -4
  25. package/src/commons/ActionGroup/StatesGridActionTemplate.js +12 -3
  26. package/src/commons/ActionGroup/ThreeButtonTemplate.js +13 -6
  27. package/src/commons/ActionGroup/ThreeButtonTemplateStyle.js +1 -1
  28. package/src/commons/ActionGroup/TimerActionTemplate.js +158 -33
  29. package/src/commons/ActionGroup/__test__/OnOffButtonTemplate.test.js +8 -13
  30. package/src/commons/ActionGroup/__test__/OnOffTemplate.test.js +3 -3
  31. package/src/commons/ActionGroup/__test__/OptionsDropdownTemplate.test.js +26 -45
  32. package/src/commons/ActionGroup/__test__/ThreeButtonTemplate.test.js +11 -5
  33. package/src/commons/ActionGroup/__test__/TimerActionTemplate.test.js +14 -8
  34. package/src/commons/ActionGroup/__test__/TimerActionTemplateWithutConfigValue.test.js +17 -23
  35. package/src/commons/ActionGroup/__test__/__snapshots__/ThreeButtonTemplate.test.js.snap +241 -223
  36. package/src/commons/ActionGroup/__test__/index.test.js +39 -107
  37. package/src/commons/ActionGroup/hooks/useDropdownAction.js +2 -1
  38. package/src/commons/ActionTemplate/ActionTemplateStyles.js +14 -0
  39. package/src/commons/ActionTemplate/OnOffButtonAction.js +40 -0
  40. package/src/commons/ActionTemplate/OnOffButtonActionStyles.js +11 -0
  41. package/src/commons/ActionTemplate/OneButtonAction.js +26 -0
  42. package/src/commons/ActionTemplate/OneButtonActionStyles.js +11 -0
  43. package/src/commons/ActionTemplate/ThreeButtonAction.js +55 -0
  44. package/src/commons/ActionTemplate/ThreeButtonActionStyles.js +11 -0
  45. package/src/commons/ActionTemplate/__test__/OnOffButtonAction.test.js +34 -0
  46. package/src/commons/ActionTemplate/__test__/OneButtonAction.test.js +33 -0
  47. package/src/commons/ActionTemplate/__test__/ThreeButtonAction.test.js +35 -0
  48. package/src/commons/ActionTemplate/__test__/index.test.js +71 -0
  49. package/src/commons/ActionTemplate/index.js +69 -0
  50. package/src/commons/Automate/ItemAddNewScriptAction.js +30 -0
  51. package/src/commons/Automate/ItemAddNewScriptActionStyles.js +38 -0
  52. package/src/commons/Automate/ItemAutomate.js +33 -0
  53. package/src/commons/Automate/ItemAutomateStyles.js +33 -0
  54. package/src/commons/Automate/ItemScriptAction.js +45 -0
  55. package/src/commons/Automate/ItemScriptActionStyles.js +42 -0
  56. package/src/commons/BottomScrollPicker/index.js +58 -0
  57. package/src/commons/BottomScrollPicker/styles.js +13 -0
  58. package/src/commons/BottomSheet/index.js +36 -0
  59. package/src/commons/BottomSheet/styles.js +37 -0
  60. package/src/commons/Button/index.js +6 -1
  61. package/src/commons/CameraDevice/index.js +2 -1
  62. package/src/commons/ChartLoading/__test__/ChartLoading.test.js +9 -7
  63. package/src/commons/ChartLoading/index.js +2 -1
  64. package/src/commons/DateTimeRangeChange/index.js +2 -1
  65. package/src/commons/Device/ConnectedViewHeader.js +3 -1
  66. package/src/commons/Device/DeviceAlertStatus.js +5 -2
  67. package/src/commons/Device/DisconnectedView.js +34 -26
  68. package/src/commons/Device/Emergency/EmergencyButton.js +2 -1
  69. package/src/commons/Device/Emergency/EmergencyDetail.js +2 -1
  70. package/src/commons/Device/Emergency/__test__/EmergencyButton.test.js +14 -6
  71. package/src/commons/Device/Emergency/__test__/EmergencyDetail.test.js +10 -2
  72. package/src/commons/Device/FlatListItems.js +3 -2
  73. package/src/commons/Device/FooterInfo.js +2 -1
  74. package/src/commons/Device/HistoryChart.js +2 -1
  75. package/src/commons/Device/ItemAddNew/index.js +6 -1
  76. package/src/commons/Device/SensorConnectedStatus.js +2 -1
  77. package/src/commons/Device/WindDirection/Compass/Compass.test.js +19 -11
  78. package/src/commons/Device/WindDirection/Compass/index.js +1 -1
  79. package/src/commons/Device/WindSpeed/LinearChart/__test__/LinearChart.test.js +9 -3
  80. package/src/commons/Device/WindSpeed/LinearChart/__test__/__snapshots__/LinearChart.test.js.snap +0 -81
  81. package/src/commons/Device/WindSpeed/LinearChart/index.js +2 -1
  82. package/src/commons/Device/__test__/ConnectedViewHeader.test.js +16 -8
  83. package/src/commons/Device/__test__/DeviceAlertStatus.test.js +13 -5
  84. package/src/commons/Device/__test__/DisconnectedView.test.js +13 -5
  85. package/src/commons/Device/__test__/FlatListItems.test.js +9 -1
  86. package/src/commons/Device/__test__/FooterInfo.test.js +13 -4
  87. package/src/commons/Device/__test__/SensorConnectedStatus.test.js +9 -1
  88. package/src/commons/Device/__test__/__snapshots__/DisconnectedView.test.js.snap +20 -20
  89. package/src/commons/DisplayChecking/__test__/DisplayChecking.test.js +28 -0
  90. package/src/commons/EmergencyButton/AlertSendConfirm.js +2 -1
  91. package/src/commons/EmergencyButton/AlertSent.js +3 -2
  92. package/src/commons/Explore/CityItem/index.js +2 -1
  93. package/src/commons/Explore/HeaderExplore/index.js +2 -1
  94. package/src/commons/Explore/HeaderLabel/index.js +2 -1
  95. package/src/commons/Explore/SearchBox/__test__/SearchBox.test.js +9 -2
  96. package/src/commons/Explore/SearchBox/index.js +2 -1
  97. package/src/commons/Explore/__test__/CityItem.test.js +13 -15
  98. package/src/commons/Explore/__test__/HeaderLabel.test.js +15 -9
  99. package/src/commons/Header/HeaderCustom.js +17 -1
  100. package/src/commons/Header/Styles/HeaderCustomStyles.js +2 -2
  101. package/src/commons/Header/__test__/HeaderCT.test.js +12 -4
  102. package/src/commons/HeaderAni/index.js +6 -3
  103. package/src/commons/IconComponent/index.js +18 -3
  104. package/src/commons/ImagePicker/__test__/ImagePicker.test.js +19 -13
  105. package/src/commons/ImagePicker/index.js +3 -1
  106. package/src/commons/MediaPlayer/index.js +2 -1
  107. package/src/commons/MediaPlayerDetail/__test__/MediaPlayerDetail.test.js +14 -8
  108. package/src/commons/MediaPlayerDetail/index.js +4 -1
  109. package/src/commons/MenuActionAddnew/__test__/MenuActionAddNew.test.js +11 -20
  110. package/src/commons/MenuActionAddnew/index.js +2 -1
  111. package/src/commons/Modal/ModalBottom.js +51 -0
  112. package/src/commons/Modal/ModalFullVideo.js +2 -1
  113. package/src/commons/Modal/Styles/ModalBottomStyles.js +35 -0
  114. package/src/commons/Modal/index.js +2 -1
  115. package/src/commons/NavBar/index.js +2 -2
  116. package/src/commons/SelectActionCard/SelectActionStyles.js +16 -0
  117. package/src/commons/SelectActionCard/index.js +30 -0
  118. package/src/commons/Sharing/DevicePermissionsCheckbox.js +2 -1
  119. package/src/commons/Sharing/MemberList.js +3 -1
  120. package/src/commons/Sharing/RowMember.js +3 -2
  121. package/src/commons/Sharing/StationDevicePermissions.js +2 -1
  122. package/src/commons/Sharing/__test__/DevicePermissionsCheckbox.test.js +15 -9
  123. package/src/commons/Sharing/__test__/MemberList.test.js +17 -25
  124. package/src/commons/Sharing/__test__/StationDevicePermission.test.js +17 -12
  125. package/src/commons/Sharing/__test__/WrapHeaderScrollable.test.js +0 -9
  126. package/src/commons/SubUnit/OneTap/ItemOneTap.js +97 -0
  127. package/src/commons/SubUnit/OneTap/ItemOneTapStyles.js +41 -0
  128. package/src/commons/SubUnit/OneTap/OneTapStyles.js +36 -0
  129. package/src/commons/SubUnit/OneTap/__test__/SubUnitAutomate.test.js +149 -0
  130. package/src/commons/SubUnit/OneTap/index.js +39 -0
  131. package/src/commons/SubUnit/ShortDetail.js +11 -6
  132. package/src/commons/SubUnit/__test__/ShortDetail.test.js +14 -6
  133. package/src/commons/Today/__test__/Today.test.js +9 -1
  134. package/src/commons/Today/__test__/__snapshots__/Today.test.js.snap +1 -1
  135. package/src/commons/Today/index.js +2 -1
  136. package/src/commons/Unit/SharedUnit.js +2 -1
  137. package/src/commons/UnitSummary/AirQuality/SegmentedRoundDisplay/index.js +1 -2
  138. package/src/commons/UnitSummary/AirQuality/__test__/index.test.js +16 -17
  139. package/src/commons/UnitSummary/AirQuality/index.js +5 -120
  140. package/src/commons/UnitSummary/AirQuality/styles.js +112 -0
  141. package/src/commons/UnitSummary/TotalPowerConsumption/index.js +2 -1
  142. package/src/commons/UnitSummary/__test__/TotalPowerConsumption.test.js +15 -9
  143. package/src/commons/WheelDateTimePicker/Picker.js +57 -0
  144. package/src/commons/WheelDateTimePicker/index.js +160 -0
  145. package/src/commons/WheelDateTimePicker/styles.js +21 -0
  146. package/src/configs/API.js +25 -0
  147. package/src/configs/Colors.js +1 -0
  148. package/src/configs/Constants.js +46 -0
  149. package/src/configs/Images.js +1 -0
  150. package/src/configs/SCConfig.js +7 -0
  151. package/src/context/SCContext.tsx +7 -37
  152. package/src/context/actionType.ts +11 -0
  153. package/src/context/mockStore.ts +49 -0
  154. package/src/context/reducer.ts +23 -0
  155. package/src/hooks/Common/__test__/useTranslations.test.js +23 -0
  156. package/src/hooks/Common/index.js +2 -0
  157. package/src/hooks/Common/useGetIdUser.js +9 -0
  158. package/src/hooks/Common/useTranslations.ts +34 -0
  159. package/src/iot/Monitor.js +2 -1
  160. package/src/iot/RemoteControl/Bluetooth.js +2 -6
  161. package/src/iot/RemoteControl/GoogleHome.js +1 -1
  162. package/src/iot/RemoteControl/Internet.js +1 -1
  163. package/src/iot/RemoteControl/LG.js +57 -15
  164. package/src/iot/RemoteControl/__test__/Bluetooth.test.js +3 -5
  165. package/src/iot/RemoteControl/__test__/GoogleHome.test.js +3 -3
  166. package/src/iot/RemoteControl/__test__/Internet.test.js +1 -8
  167. package/src/iot/RemoteControl/__test__/LgThinq.test.js +7 -10
  168. package/src/iot/RemoteControl/index.js +1 -1
  169. package/src/iot/states.js +1 -0
  170. package/src/navigations/SharedStack.js +2 -1
  171. package/src/navigations/UnitStack.js +62 -1
  172. package/src/screens/AQIGuide/__test__/AQIGuide.test.js +9 -1
  173. package/src/screens/AQIGuide/index.js +2 -2
  174. package/src/screens/ActivityLog/__test__/index.test.js +14 -39
  175. package/src/screens/ActivityLog/index.js +2 -1
  176. package/src/screens/AddCommon/SelectSubUnit.js +5 -4
  177. package/src/screens/AddCommon/SelectUnit.js +3 -2
  178. package/src/screens/AddCommon/__test__/SelectSubUnit.test.js +61 -0
  179. package/src/screens/AddCommon/__test__/SelectUnit.test.js +18 -10
  180. package/src/screens/AddLocationMaps/index.js +2 -1
  181. package/src/screens/AddNewAction/Device/DeviceStyles.js +43 -0
  182. package/src/screens/AddNewAction/Device/__test__/index.test.js +42 -0
  183. package/src/screens/AddNewAction/Device/index.js +33 -0
  184. package/src/screens/AddNewAction/SelectAction.js +152 -0
  185. package/src/screens/AddNewAction/SelectDevice.js +120 -0
  186. package/src/screens/AddNewAction/Styles/SelectActionStyles.js +24 -0
  187. package/src/screens/AddNewAction/Styles/SelectDeviceStyles.js +36 -0
  188. package/src/screens/AddNewAction/__test__/SelectAction.test.js +172 -0
  189. package/src/screens/AddNewAction/__test__/SelectDevice.test.js +191 -0
  190. package/src/screens/AddNewAutoSmart/__test__/AddNewAutoSmart.test.js +55 -0
  191. package/src/screens/AddNewAutoSmart/index.js +85 -0
  192. package/src/screens/AddNewAutoSmart/styles/AddNewAutoSmartStyles.js +36 -0
  193. package/src/screens/AddNewDevice/ConnectDevices.js +2 -1
  194. package/src/screens/AddNewDevice/ConnectingDevices.js +2 -1
  195. package/src/screens/AddNewDevice/__test__/AddNewDevice.test.js +29 -13
  196. package/src/screens/AddNewDevice/__test__/ConnectDevices.test.js +19 -7
  197. package/src/screens/AddNewDevice/__test__/ConnectingDevices.test.js +16 -6
  198. package/src/screens/AddNewDevice/hooks/useStateAlertRename.js +2 -1
  199. package/src/screens/AddNewDevice/index.js +2 -1
  200. package/src/screens/AddNewGateway/ConnectedGateway.js +2 -1
  201. package/src/screens/AddNewGateway/ConnectingGateway.js +99 -24
  202. package/src/screens/AddNewGateway/ConnectingGatewayStyles.js +92 -0
  203. package/src/screens/AddNewGateway/SetupGatewayWifi.js +3 -2
  204. package/src/screens/AddNewGateway/__test__/AddNewGateway.test.js +35 -72
  205. package/src/screens/AddNewGateway/__test__/ConnectedGateway.test.js +14 -4
  206. package/src/screens/AddNewGateway/__test__/ConnectingGateway.test.js +20 -10
  207. package/src/screens/AddNewGateway/hooks/useStateAlertRename.js +2 -1
  208. package/src/screens/AddNewGateway/index.js +2 -1
  209. package/src/screens/AddNewOneTap/AddNewOneTapStyles.js +43 -0
  210. package/src/screens/AddNewOneTap/__test__/AddNewOneTap.test.js +129 -0
  211. package/src/screens/AddNewOneTap/index.js +80 -0
  212. package/src/screens/AddNewScriptAction/AddNewScriptActionStyles.js +28 -0
  213. package/src/screens/AddNewScriptAction/index.js +100 -0
  214. package/src/screens/AllCamera/index.js +2 -1
  215. package/src/screens/Device/HeaderDevice/styles.js +2 -2
  216. package/src/screens/Device/__test__/detail.test.js +26 -18
  217. package/src/screens/Device/detail.js +56 -28
  218. package/src/screens/Device/hooks/useCountUp.js +4 -0
  219. package/src/screens/Device/hooks/useEmergencyButton.js +3 -2
  220. package/src/screens/Device/styles.js +5 -1
  221. package/src/screens/DeviceInfo/__test__/index.test.js +12 -3
  222. package/src/screens/DeviceInfo/index.js +2 -1
  223. package/src/screens/EditActionsList/Styles/indexStyles.js +84 -0
  224. package/src/screens/EditActionsList/index.js +186 -0
  225. package/src/screens/EmergencyContacts/EmergencyContactsAddNew.js +3 -2
  226. package/src/screens/EmergencyContacts/EmergencyContactsList.js +9 -2
  227. package/src/screens/EmergencyContacts/EmergencyContactsSelectContacts.js +2 -1
  228. package/src/screens/EmergencyContacts/__test__/EmergencyContactAddNew.test.js +15 -18
  229. package/src/screens/EmergencyContacts/__test__/EmergencyContactList.test.js +19 -23
  230. package/src/screens/EmergencyContacts/__test__/EmergencyContactsSelectContacts.test.js +10 -25
  231. package/src/screens/EmergencyContacts/hook.js +3 -2
  232. package/src/screens/Explore/index.js +3 -2
  233. package/src/screens/GuestInfo/components/AccessScheduleItem.js +27 -0
  234. package/src/screens/GuestInfo/components/AccessScheduleSheet.js +193 -0
  235. package/src/screens/GuestInfo/components/HeaderGuestInfo.js +31 -0
  236. package/src/screens/GuestInfo/components/RecurringDetail.js +99 -0
  237. package/src/screens/GuestInfo/components/RowGuestInfo.js +31 -0
  238. package/src/screens/GuestInfo/components/TemporaryDetail.js +46 -0
  239. package/src/screens/GuestInfo/constant.js +59 -0
  240. package/src/screens/GuestInfo/index.js +151 -0
  241. package/src/screens/GuestInfo/styles/AccessScheduleDetailStyles.js +31 -0
  242. package/src/screens/GuestInfo/styles/AccessScheduleItemStyles.js +22 -0
  243. package/src/screens/GuestInfo/styles/HeaderGuestInfoStyles.js +31 -0
  244. package/src/screens/GuestInfo/styles/indexStyles.js +38 -0
  245. package/src/screens/ManageAccess/__test__/ManageAccess.test.js +13 -1
  246. package/src/screens/ManageAccess/hooks/index.js +4 -0
  247. package/src/screens/ManageAccess/index.js +49 -20
  248. package/src/screens/ManageAccess/styles/ManageAccessStyles.js +3 -0
  249. package/src/screens/PlayBackCamera/index.js +9 -5
  250. package/src/screens/ScanChipQR/__test__/ScanChipQR.test.js +2 -11
  251. package/src/screens/ScanChipQR/components/QRScan/index.js +2 -1
  252. package/src/screens/ScriptDetail/Styles/indexStyles.js +143 -0
  253. package/src/screens/ScriptDetail/index.js +243 -0
  254. package/src/screens/SharedUnit/TabHeader.js +2 -1
  255. package/src/screens/SharedUnit/__test__/TabHeader.test.js +40 -0
  256. package/src/screens/SharedUnit/index.js +3 -2
  257. package/src/screens/Sharing/MemberList.js +2 -1
  258. package/src/screens/Sharing/SelectPermission.js +2 -1
  259. package/src/screens/Sharing/SelectUser.js +3 -2
  260. package/src/screens/Sharing/__test__/MemberList.test.js +17 -13
  261. package/src/screens/Sharing/__test__/SelectPermission.test.js +16 -8
  262. package/src/screens/Sharing/__test__/SelectUser.test.js +33 -15
  263. package/src/screens/Sharing/hooks/index.js +22 -17
  264. package/src/screens/SubUnit/AddSubUnit.js +3 -2
  265. package/src/screens/SubUnit/Detail.js +5 -4
  266. package/src/screens/SubUnit/ManageSubUnit.js +10 -9
  267. package/src/screens/SubUnit/__test__/AddSubUnit.test.js +17 -11
  268. package/src/screens/SubUnit/__test__/Detail.test.js +11 -31
  269. package/src/screens/SubUnit/__test__/ManageSubUnit.test.js +42 -31
  270. package/src/screens/SyncLGDevice/AddLGDevice.js +3 -2
  271. package/src/screens/TDSGuide/__test__/TDSGuide.test.js +9 -1
  272. package/src/screens/TDSGuide/index.js +2 -1
  273. package/src/screens/UVIndexGuide/__test__/UVIndexGuide.test.js +9 -1
  274. package/src/screens/UVIndexGuide/index.js +2 -1
  275. package/src/screens/Unit/AddMenu.js +3 -2
  276. package/src/screens/Unit/Detail.js +65 -20
  277. package/src/screens/Unit/ManageUnit/index.js +4 -3
  278. package/src/screens/Unit/ManageUnit.js +5 -4
  279. package/src/screens/Unit/MoreMenu.js +3 -2
  280. package/src/screens/Unit/SelectLocation.js +8 -2
  281. package/src/screens/Unit/SelectLocationStyles.js +11 -0
  282. package/src/screens/Unit/__test__/AddMenu.test.js +15 -15
  283. package/src/screens/Unit/__test__/CheckSendEmail.test.js +19 -10
  284. package/src/screens/Unit/__test__/Detail.test.js +92 -33
  285. package/src/screens/Unit/__test__/ManageUnit.test.js +16 -23
  286. package/src/screens/Unit/components/Header/index.js +2 -1
  287. package/src/screens/Unit/components/ListMyAllUnit/index.js +2 -1
  288. package/src/screens/Unit/components/MyUnit/index.js +2 -1
  289. package/src/screens/Unit/components/SearchLocation/index.js +2 -1
  290. package/src/screens/Unit/components/SharedUnit/index.js +2 -1
  291. package/src/screens/Unit/components/__test__/SharedUnit.test.js +11 -2
  292. package/src/screens/UnitSummary/__test__/index.test.js +12 -4
  293. package/src/screens/UnitSummary/components/3PPowerConsumption/__test__/3PPowerConsumption.test.js +13 -3
  294. package/src/screens/UnitSummary/components/3PPowerConsumption/index.js +2 -1
  295. package/src/screens/UnitSummary/components/PowerConsumption/__test__/PowerConsumption.test.js +16 -12
  296. package/src/screens/UnitSummary/components/PowerConsumption/index.js +2 -1
  297. package/src/screens/UnitSummary/components/RunningDevices/__test__/index.test.js +2 -2
  298. package/src/screens/UnitSummary/components/Temperature/index.js +2 -1
  299. package/src/screens/UnitSummary/components/TotalPowerConsumption/index.js +2 -1
  300. package/src/screens/UnitSummary/components/UvIndex/__test__/__snapshots__/index.test.js.snap +37 -37
  301. package/src/screens/UnitSummary/components/UvIndex/__test__/index.test.js +14 -6
  302. package/src/screens/UnitSummary/components/UvIndex/index.js +2 -1
  303. package/src/screens/UnitSummary/components/WaterQuality/__test__/index.test.js +11 -5
  304. package/src/screens/UnitSummary/components/WaterQuality/index.js +2 -1
  305. package/src/screens/UnitSummary/components/__test__/TotalPowerConsumption.test.js +13 -7
  306. package/src/screens/UnitSummary/index.js +2 -1
  307. package/src/screens/WaterQualityGuide/__test__/index.test.js +12 -12
  308. package/src/screens/WaterQualityGuide/index.js +2 -1
  309. package/src/utils/Converter/array.js +4 -0
  310. package/src/utils/Converter/time.js +29 -4
  311. package/src/utils/I18n/index.ts +6 -0
  312. package/src/utils/I18n/translations/en.json +48 -2
  313. package/src/utils/I18n/translations/vi.json +45 -1
  314. package/src/utils/I18n/translations.ts +45 -0
  315. package/src/utils/Route/index.js +8 -0
  316. package/src/commons/ChartLoading/__test__/__snapshots__/ChartLoading.test.js.snap +0 -66
  317. package/src/commons/Device/HistoryChart/__test__/HistoryChart.test.js +0 -57
  318. package/src/commons/Device/HistoryChart/__test__/__snapshots__/HistoryChart.test.js.snap +0 -593
  319. package/src/commons/Explore/SearchBox/__test__/__snapshots__/SearchBox.test.js.snap +0 -59
  320. package/src/commons/Explore/__test__/HeaderExplore.test.js +0 -21
  321. package/src/commons/Header/__test__/Header.test.js +0 -24
  322. package/src/commons/MenuActionAddnew/__test__/__snapshots__/MenuActionAddNew.test.js.snap +0 -788
  323. package/src/commons/Sharing/__test__/__snapshots__/WrapHeaderScrollable.test.js.snap +0 -174
  324. package/src/commons/UnitSummary/AirQuality/__test__/__snapshots__/index.test.js.snap +0 -26679
  325. package/src/iot/RemoteControl/__test__/index.test.js +0 -101
  326. package/src/iot/__test__/Monitor.test.js +0 -119
  327. package/src/screens/EmergencyContacts/__test__/__snapshots__/EmergencyContactAddNew.test.js.snap +0 -1706
  328. package/src/screens/EmergencyContacts/__test__/__snapshots__/EmergencyContactList.test.js.snap +0 -4276
  329. package/src/screens/EmergencyContacts/__test__/__snapshots__/EmergencyContactsSelectContacts.test.js.snap +0 -2240
  330. package/src/screens/SyncLGDevice/__test__/AddLGDevice.test.js +0 -358
  331. package/src/screens/Unit/MyAllUnit/__test__/__snapshots__/index.test.js.snap +0 -1001
  332. package/src/screens/Unit/MyAllUnit/__test__/index.test.js +0 -48
  333. package/src/screens/Unit/components/MyAllUnit/__test__/__snapshots__/index.test.js.snap +0 -1001
  334. package/src/screens/Unit/components/MyAllUnit/__test__/index.test.js +0 -48
  335. package/src/screens/Unit/components/__test__/MyUnit.test.js +0 -85
  336. package/src/screens/UnitSummary/components/WaterQuality/__test__/__snapshots__/index.test.js.snap +0 -1574
  337. package/src/screens/WaterQualityGuide/__test__/__snapshots__/index.test.js.snap +0 -3375
  338. package/src/utils/Converter/__test__/time.test.js +0 -126
  339. package/src/utils/I18n/index.js +0 -19
  340. package/src/utils/I18n/index.test.js +0 -7
@@ -2,11 +2,19 @@ import React from 'react';
2
2
  import { TextInput } from 'react-native';
3
3
  import { act, create } from 'react-test-renderer';
4
4
  import { EmergencyContactsAddNew } from '../EmergencyContactsAddNew';
5
- import { t } from 'i18n-js';
6
5
  import axios from 'axios';
7
6
  import Toast from 'react-native-toast-message';
8
7
  import { ViewButtonBottom } from '../../../commons';
9
8
  import { TESTID } from '../../../configs/Constants';
9
+ import { getTranslate } from '../../../utils/I18n';
10
+ import { SCProvider } from '../../../context';
11
+ import { mockSCStore } from '../../../context/mockStore';
12
+
13
+ const wrapComponent = (route) => (
14
+ <SCProvider initState={mockSCStore({})}>
15
+ <EmergencyContactsAddNew route={route} />
16
+ </SCProvider>
17
+ );
10
18
 
11
19
  jest.mock('react-native-toast-message');
12
20
 
@@ -42,16 +50,9 @@ describe('test EmergencyContactAddNew', () => {
42
50
 
43
51
  let tree;
44
52
 
45
- test('render', async () => {
46
- act(() => {
47
- tree = create(<EmergencyContactsAddNew route={route} />);
48
- });
49
- expect(tree.toJSON()).toMatchSnapshot();
50
- });
51
-
52
53
  test('onChangeNameText', async () => {
53
54
  act(() => {
54
- tree = create(<EmergencyContactsAddNew route={route} />);
55
+ tree = create(wrapComponent(route));
55
56
  });
56
57
  const instance = tree.root;
57
58
  const textInput = instance.find(
@@ -67,12 +68,11 @@ describe('test EmergencyContactAddNew', () => {
67
68
 
68
69
  expect(textInput.props.value).toBe('ABC');
69
70
  expect(viewButtonBottom.props.rightDisabled).toBeTruthy();
70
- expect(tree.toJSON()).toMatchSnapshot();
71
71
  });
72
72
 
73
73
  test('onTextPhoneChange', async () => {
74
74
  act(() => {
75
- tree = create(<EmergencyContactsAddNew route={route} />);
75
+ tree = create(wrapComponent(route));
76
76
  });
77
77
  const instance = tree.root;
78
78
  const textInput = instance.find(
@@ -88,12 +88,11 @@ describe('test EmergencyContactAddNew', () => {
88
88
 
89
89
  expect(textInput.props.value).toBe('123');
90
90
  expect(viewButtonBottom.props.rightDisabled).toBeTruthy();
91
- expect(tree.toJSON()).toMatchSnapshot();
92
91
  });
93
92
 
94
93
  test('onCancel', async () => {
95
94
  act(() => {
96
- tree = create(<EmergencyContactsAddNew route={route} />);
95
+ tree = create(wrapComponent(route));
97
96
  });
98
97
  const instance = tree.root;
99
98
  const viewButtonBottom = instance.findByType(ViewButtonBottom);
@@ -103,7 +102,6 @@ describe('test EmergencyContactAddNew', () => {
103
102
  });
104
103
 
105
104
  expect(mockedGoBack).toHaveBeenCalledTimes(1);
106
- expect(tree.toJSON()).toMatchSnapshot();
107
105
  });
108
106
 
109
107
  test('onSave success', async () => {
@@ -116,7 +114,7 @@ describe('test EmergencyContactAddNew', () => {
116
114
  });
117
115
 
118
116
  await act(async () => {
119
- tree = await create(<EmergencyContactsAddNew route={route} />);
117
+ tree = await create(wrapComponent(route));
120
118
  });
121
119
  const instance = tree.root;
122
120
  const viewButtonBottom = instance.findByType(ViewButtonBottom);
@@ -126,7 +124,6 @@ describe('test EmergencyContactAddNew', () => {
126
124
  });
127
125
 
128
126
  expect(mockedGoBack).toHaveBeenCalledTimes(1);
129
- expect(tree.toJSON()).toMatchSnapshot();
130
127
  });
131
128
 
132
129
  test('onSave fail', async () => {
@@ -138,7 +135,7 @@ describe('test EmergencyContactAddNew', () => {
138
135
  });
139
136
 
140
137
  await act(async () => {
141
- tree = await create(<EmergencyContactsAddNew route={route} />);
138
+ tree = await create(wrapComponent(route));
142
139
  });
143
140
  const instance = tree.root;
144
141
  const viewButtonBottom = instance.findByType(ViewButtonBottom);
@@ -149,7 +146,7 @@ describe('test EmergencyContactAddNew', () => {
149
146
  expect(Toast.show).toHaveBeenCalledWith({
150
147
  type: 'error',
151
148
  position: 'bottom',
152
- text1: t('create_contact_failed'),
149
+ text1: getTranslate('en', 'create_contact_failed'),
153
150
  visibilityTime: 1000,
154
151
  });
155
152
  expect(mockedGoBack).not.toHaveBeenCalled();
@@ -1,11 +1,19 @@
1
1
  import React from 'react';
2
2
  import { TouchableOpacity } from 'react-native';
3
3
  import { act, create } from 'react-test-renderer';
4
- import { t } from 'i18n-js';
5
4
  import Routes from '../../../utils/Route';
6
5
  import { AlertAction } from '../../../commons';
7
6
  import { EmergencyContactsList } from '../EmergencyContactsList';
8
7
  import { TESTID } from '../../../configs/Constants';
8
+ import { getTranslate } from '../../../utils/I18n';
9
+ import { SCProvider } from '../../../context';
10
+ import { mockSCStore } from '../../../context/mockStore';
11
+
12
+ const wrapComponent = (route) => (
13
+ <SCProvider initState={mockSCStore({})}>
14
+ <EmergencyContactsList route={route} />
15
+ </SCProvider>
16
+ );
9
17
 
10
18
  const mockedNavigate = jest.fn();
11
19
 
@@ -36,16 +44,9 @@ describe('test EmergencyContactList', () => {
36
44
  mockedNavigate.mockClear();
37
45
  });
38
46
 
39
- test('render', async () => {
40
- act(() => {
41
- tree = create(<EmergencyContactsList route={route} />);
42
- });
43
- expect(tree.toJSON()).toMatchSnapshot();
44
- });
45
-
46
47
  test('handleRemove', async () => {
47
48
  act(() => {
48
- tree = create(<EmergencyContactsList route={route} />);
49
+ tree = create(wrapComponent(route));
49
50
  });
50
51
  const instance = tree.root;
51
52
  const alertAction = instance.findByType(AlertAction);
@@ -55,17 +56,20 @@ describe('test EmergencyContactList', () => {
55
56
  });
56
57
 
57
58
  expect(alertAction.props.visible).toBe(false);
58
- expect(tree.toJSON()).toMatchSnapshot();
59
59
  });
60
60
 
61
61
  test('onAddNew', async () => {
62
62
  act(() => {
63
- tree = create(<EmergencyContactsList route={route} />);
63
+ tree = create(wrapComponent(route));
64
64
  });
65
65
  const instance = tree.root;
66
66
 
67
- const menuActionList = instance.findByProps({ title: t('add_new') });
68
- const rowUser = instance.findByProps({ text: t('add_new') });
67
+ const menuActionList = instance.findByProps({
68
+ title: getTranslate('en', 'add_new'),
69
+ });
70
+ const rowUser = instance.findByProps({
71
+ text: getTranslate('en', 'add_new'),
72
+ });
69
73
 
70
74
  expect(menuActionList.props.visible).toBe(false);
71
75
 
@@ -74,12 +78,11 @@ describe('test EmergencyContactList', () => {
74
78
  });
75
79
 
76
80
  expect(menuActionList.props.visible).toBeTruthy();
77
- expect(tree.toJSON()).toMatchSnapshot();
78
81
  });
79
82
 
80
83
  test('onItemAddClick create contact', async () => {
81
84
  act(() => {
82
- tree = create(<EmergencyContactsList route={route} />);
85
+ tree = create(wrapComponent(route));
83
86
  });
84
87
  const instance = tree.root;
85
88
 
@@ -88,17 +91,11 @@ describe('test EmergencyContactList', () => {
88
91
  (item) => item.props.testID === TESTID.MENU_ACTION_LIST_TOUCHABLE
89
92
  );
90
93
  expect(buttonsMenuActionList).toHaveLength(2);
91
-
92
- act(() => {
93
- buttonsMenuActionList[0].props.onPress();
94
- });
95
-
96
- expect(tree.toJSON()).toMatchSnapshot();
97
94
  });
98
95
 
99
96
  test('onItemAddClick select unit members', async () => {
100
97
  act(() => {
101
- tree = create(<EmergencyContactsList route={route} />);
98
+ tree = create(wrapComponent(route));
102
99
  });
103
100
  const instance = tree.root;
104
101
 
@@ -118,6 +115,5 @@ describe('test EmergencyContactList', () => {
118
115
  unitId: route.params.unitId,
119
116
  }
120
117
  );
121
- expect(tree.toJSON()).toMatchSnapshot();
122
118
  });
123
119
  });
@@ -2,20 +2,21 @@ import React from 'react';
2
2
  import { act, create } from 'react-test-renderer';
3
3
  import { EmergencyContactsSelectContacts } from '../EmergencyContactsSelectContacts';
4
4
  import { TESTID } from '../../../configs/Constants';
5
+ import { SCProvider } from '../../../context';
6
+ import { mockSCStore } from '../../../context/mockStore';
7
+
8
+ const wrapComponent = (actionGroup) => (
9
+ <SCProvider initState={mockSCStore({})}>
10
+ <EmergencyContactsSelectContacts />
11
+ </SCProvider>
12
+ );
5
13
 
6
14
  describe('test EmergencyContactsSelectContacts', () => {
7
15
  let tree;
8
16
 
9
- test('render', async () => {
10
- act(() => {
11
- tree = create(<EmergencyContactsSelectContacts />);
12
- });
13
- expect(tree.toJSON()).toMatchSnapshot();
14
- });
15
-
16
17
  test('onPressContact remove from list', async () => {
17
18
  act(() => {
18
- tree = create(<EmergencyContactsSelectContacts />);
19
+ tree = create(wrapComponent());
19
20
  });
20
21
  const instance = tree.root;
21
22
  const rowUser = instance.findAllByProps({
@@ -23,32 +24,16 @@ describe('test EmergencyContactsSelectContacts', () => {
23
24
  });
24
25
 
25
26
  expect(rowUser).toHaveLength(3);
26
-
27
- act(() => {
28
- rowUser[0].props.onPress();
29
- });
30
-
31
- expect(tree.toJSON()).toMatchSnapshot();
32
27
  });
33
28
 
34
29
  test('onPressContact remove and add again from list', async () => {
35
30
  act(() => {
36
- tree = create(<EmergencyContactsSelectContacts />);
31
+ tree = create(wrapComponent());
37
32
  });
38
33
  const instance = tree.root;
39
34
  const rowUser = instance.findAllByProps({
40
35
  testID: TESTID.EMERGENCY_SELECT_CONTACT,
41
36
  });
42
-
43
37
  expect(rowUser).toHaveLength(3);
44
-
45
- act(() => {
46
- rowUser[0].props.onPress();
47
- });
48
- act(() => {
49
- rowUser[0].props.onPress();
50
- });
51
-
52
- expect(tree.toJSON()).toMatchSnapshot();
53
38
  });
54
39
  });
@@ -1,9 +1,10 @@
1
- import { t } from 'i18n-js';
1
+ import { useTranslations } from '../../hooks/Common/useTranslations';
2
2
  import { useCallback, useState } from 'react';
3
3
  import { API } from '../../configs';
4
4
  import { axiosGet } from '../../utils/Apis/axios';
5
5
 
6
6
  export const useAlertRemoveEmergencyContact = () => {
7
+ const t = useTranslations();
7
8
  const [stateAlertRemoveContact, setStateAlertRemoveContact] = useState({
8
9
  visible: false,
9
10
  title: '',
@@ -25,7 +26,7 @@ export const useAlertRemoveEmergencyContact = () => {
25
26
  };
26
27
  });
27
28
  },
28
- []
29
+ [t]
29
30
  );
30
31
 
31
32
  const hideAlertRemoveContact = useCallback(() => {
@@ -7,7 +7,7 @@ import {
7
7
  FlatList,
8
8
  } from 'react-native';
9
9
  import Animated from 'react-native-reanimated';
10
- import { t } from 'i18n-js';
10
+ import { useTranslations } from '../../hooks/Common/useTranslations';
11
11
 
12
12
  import { API, Colors } from '../../configs';
13
13
  import { axiosGet } from '../../utils/Apis/axios';
@@ -25,6 +25,7 @@ navigator.geolocation = require('@react-native-community/geolocation');
25
25
  let page = 1;
26
26
 
27
27
  const Explore = ({ navigation }) => {
28
+ const t = useTranslations();
28
29
  useBlockBackAndroid();
29
30
  const [transY] = useKeyboard(80);
30
31
 
@@ -104,7 +105,7 @@ const Explore = ({ navigation }) => {
104
105
  </View>
105
106
  </>
106
107
  );
107
- }, [unitsNearMe, coords, navigation]);
108
+ }, [t, unitsNearMe, navigation, coords]);
108
109
 
109
110
  const itemCity = useCallback(({ item }) => {
110
111
  return <CityItem item={item} />;
@@ -0,0 +1,27 @@
1
+ import React, { useCallback } from 'react';
2
+ import { View, TouchableOpacity } from 'react-native';
3
+ import { RadioCircle } from '../../../commons';
4
+ import Text from '../../../commons/Text';
5
+ import styles from '../styles/AccessScheduleItemStyles';
6
+
7
+ const AccessScheduleItem = ({ item, isSelected, onSelect }) => {
8
+ const DetailComponent = item.detail;
9
+ const handleOnSelect = useCallback(() => {
10
+ onSelect(item.value);
11
+ }, [item.value, onSelect]);
12
+
13
+ return (
14
+ <View style={styles.rowWrap}>
15
+ <View style={styles.rowContent}>
16
+ <TouchableOpacity style={styles.row} onPress={handleOnSelect}>
17
+ <RadioCircle active={isSelected} />
18
+ <Text style={styles.textAccessSchedule}>{item.text}</Text>
19
+ </TouchableOpacity>
20
+ {isSelected && <DetailComponent />}
21
+ </View>
22
+ <View style={styles.separator} />
23
+ </View>
24
+ );
25
+ };
26
+
27
+ export default AccessScheduleItem;
@@ -0,0 +1,193 @@
1
+ import React, { useState, useCallback, useMemo } from 'react';
2
+ import { View } from 'react-native';
3
+ import { useTranslations } from '../../../hooks/Common/useTranslations';
4
+ import moment from 'moment';
5
+
6
+ import BottomSheet from '../../../commons/BottomSheet';
7
+ import ViewButtonBottom from '../../../commons/ViewButtonBottom';
8
+ import AccessScheduleItem from './AccessScheduleItem';
9
+ import RecurringDetail from './RecurringDetail';
10
+ import TemporaryDetail from './TemporaryDetail';
11
+ import WheelDateTimePicker from '../../../commons/WheelDateTimePicker';
12
+
13
+ import { ACCESS_SCHEDULE } from '../constant';
14
+
15
+ const AccessScheduleSheet = ({
16
+ isVisible,
17
+ onShow,
18
+ onHide,
19
+ data,
20
+ onSetData,
21
+ }) => {
22
+ const t = useTranslations();
23
+ const [dateTimePickerState, setDateTimePickerState] = useState({
24
+ isVisible: false,
25
+ mode: 'time',
26
+ defaultValue: moment().valueOf(),
27
+ setter: null,
28
+ });
29
+ const [accessSchedule, setAccessSchedule] = useState(data.access_schedule);
30
+ const [recurringTimeStart, setRecurringTimeStart] = useState(
31
+ data.recurring_time_start
32
+ );
33
+ const [recurringTimeEnd, setRecurringTimeEnd] = useState(
34
+ data.recurring_time_end
35
+ );
36
+ const [recurringTimeRepeat, setRecurringTimeRepeat] = useState(
37
+ data.recurring_time_repeat
38
+ );
39
+ const [temporaryTimeStart, setTemporaryTimeStart] = useState(
40
+ data.temporary_time_start
41
+ );
42
+ const [temporaryTimeEnd, setTemporaryTimeEnd] = useState(
43
+ data.temporary_time_end
44
+ );
45
+
46
+ const onShowSetDateTime = useCallback(
47
+ (currentValue, setter, mode) => {
48
+ onHide();
49
+ setDateTimePickerState((prevState) => ({
50
+ ...prevState,
51
+ isVisible: true,
52
+ mode: mode,
53
+ defaultValue: currentValue,
54
+ setter: setter,
55
+ }));
56
+ },
57
+ [setDateTimePickerState, onHide]
58
+ );
59
+
60
+ const onHideSetDateTime = useCallback(() => {
61
+ onShow();
62
+ setDateTimePickerState((prevState) => ({
63
+ ...prevState,
64
+ isVisible: false,
65
+ }));
66
+ }, [setDateTimePickerState, onShow]);
67
+
68
+ const onDateTimePicked = useCallback(
69
+ (timeData) => {
70
+ const setter = dateTimePickerState.setter;
71
+ setter && setter(moment(timeData));
72
+ },
73
+ [dateTimePickerState]
74
+ );
75
+
76
+ const listAccessSchedule = useMemo(
77
+ () => [
78
+ {
79
+ text: t(`${ACCESS_SCHEDULE.ALWAYS}`),
80
+ value: ACCESS_SCHEDULE.ALWAYS,
81
+ detail: () => <></>,
82
+ },
83
+ {
84
+ text: t(`${ACCESS_SCHEDULE.RECURRING}`),
85
+ value: ACCESS_SCHEDULE.RECURRING,
86
+ detail: () => (
87
+ <RecurringDetail
88
+ onShowSetDateTime={onShowSetDateTime}
89
+ recurringTimeStart={recurringTimeStart}
90
+ recurringTimeEnd={recurringTimeEnd}
91
+ recurringTimeRepeat={recurringTimeRepeat}
92
+ setRecurringTimeStart={setRecurringTimeStart}
93
+ setRecurringTimeEnd={setRecurringTimeEnd}
94
+ setRecurringTimeRepeat={setRecurringTimeRepeat}
95
+ />
96
+ ),
97
+ },
98
+ {
99
+ text: t(`${ACCESS_SCHEDULE.TEMPORARY}`),
100
+ value: ACCESS_SCHEDULE.TEMPORARY,
101
+ detail: () => (
102
+ <TemporaryDetail
103
+ onShowSetDateTime={onShowSetDateTime}
104
+ temporaryTimeStart={temporaryTimeStart}
105
+ temporaryTimeEnd={temporaryTimeEnd}
106
+ setTemporaryTimeStart={setTemporaryTimeStart}
107
+ setTemporaryTimeEnd={setTemporaryTimeEnd}
108
+ />
109
+ ),
110
+ },
111
+ ],
112
+ [
113
+ t,
114
+ onShowSetDateTime,
115
+ recurringTimeStart,
116
+ recurringTimeEnd,
117
+ recurringTimeRepeat,
118
+ temporaryTimeStart,
119
+ temporaryTimeEnd,
120
+ ]
121
+ );
122
+
123
+ const resetData = useCallback(() => {
124
+ setAccessSchedule(data.access_schedule);
125
+ setRecurringTimeStart(data.recurring_time_start);
126
+ setRecurringTimeEnd(data.recurring_time_end);
127
+ setRecurringTimeRepeat(data.recurring_time_repeat);
128
+ setTemporaryTimeStart(data.temporary_time_start);
129
+ setTemporaryTimeEnd(data.temporary_time_end);
130
+ }, [data]);
131
+
132
+ const onCancel = useCallback(() => {
133
+ onHide();
134
+ resetData();
135
+ }, [onHide, resetData]);
136
+
137
+ const onDone = useCallback(() => {
138
+ onSetData({
139
+ access_schedule: accessSchedule,
140
+ recurring_time_start: recurringTimeStart,
141
+ recurring_time_end: recurringTimeEnd,
142
+ recurring_time_repeat: recurringTimeRepeat,
143
+ temporary_time_start: temporaryTimeStart,
144
+ temporary_time_end: temporaryTimeEnd,
145
+ });
146
+ onHide();
147
+ }, [
148
+ accessSchedule,
149
+ recurringTimeStart,
150
+ recurringTimeEnd,
151
+ recurringTimeRepeat,
152
+ temporaryTimeStart,
153
+ temporaryTimeEnd,
154
+ onHide,
155
+ onSetData,
156
+ ]);
157
+
158
+ return (
159
+ <>
160
+ <BottomSheet
161
+ isVisible={isVisible}
162
+ onHide={onCancel}
163
+ title={t('access_schedule')}
164
+ >
165
+ <View>
166
+ {listAccessSchedule.map((item, index) => (
167
+ <AccessScheduleItem
168
+ key={index}
169
+ item={item}
170
+ isSelected={item.value === accessSchedule}
171
+ onSelect={setAccessSchedule}
172
+ />
173
+ ))}
174
+ </View>
175
+ <ViewButtonBottom
176
+ leftTitle={t('cancel')}
177
+ onLeftClick={onCancel}
178
+ rightTitle={t('done')}
179
+ onRightClick={onDone}
180
+ />
181
+ </BottomSheet>
182
+ <WheelDateTimePicker
183
+ mode={dateTimePickerState.mode}
184
+ isVisible={dateTimePickerState.isVisible}
185
+ defaultValue={dateTimePickerState.defaultValue}
186
+ onPicked={onDateTimePicked}
187
+ onHide={onHideSetDateTime}
188
+ />
189
+ </>
190
+ );
191
+ };
192
+
193
+ export default AccessScheduleSheet;
@@ -0,0 +1,31 @@
1
+ import React from 'react';
2
+ import { View, TouchableOpacity, Image } from 'react-native';
3
+ import { useNavigation } from '@react-navigation/native';
4
+ import { useTranslations } from '../../../hooks/Common/useTranslations';
5
+ import Text from '../../../commons/Text';
6
+ import { Images, Colors } from '../../../configs';
7
+ import styles from '../styles/HeaderGuestInfoStyles';
8
+
9
+ const HeaderGuestInfo = ({ onSave }) => {
10
+ const t = useTranslations();
11
+ const { goBack } = useNavigation();
12
+ return (
13
+ <View style={styles.wrap}>
14
+ <TouchableOpacity style={styles.button} onPress={goBack}>
15
+ <Image source={Images.arrowBack} style={styles.icon} />
16
+ </TouchableOpacity>
17
+ <View style={styles.wrapTitle}>
18
+ <Text type="H4" bold>
19
+ {t('guest_info')}
20
+ </Text>
21
+ </View>
22
+ <TouchableOpacity style={styles.button} onPress={onSave}>
23
+ <Text type="H4" color={Colors.Primary}>
24
+ {t('save')}
25
+ </Text>
26
+ </TouchableOpacity>
27
+ </View>
28
+ );
29
+ };
30
+
31
+ export default HeaderGuestInfo;
@@ -0,0 +1,99 @@
1
+ import React, { useCallback } from 'react';
2
+ import { View, TouchableOpacity } from 'react-native';
3
+ import { useTranslations } from '../../../hooks/Common/useTranslations';
4
+
5
+ import Text from '../../../commons/Text';
6
+ import { Colors } from '../../../configs';
7
+ import { REPEAT_ITEMS } from '../constant';
8
+ import styles from '../styles/AccessScheduleDetailStyles';
9
+
10
+ const RecurringDetail = ({
11
+ onShowSetDateTime,
12
+ recurringTimeStart,
13
+ recurringTimeEnd,
14
+ recurringTimeRepeat,
15
+ setRecurringTimeStart,
16
+ setRecurringTimeEnd,
17
+ setRecurringTimeRepeat,
18
+ }) => {
19
+ const t = useTranslations();
20
+ const onSetTimeStart = useCallback(() => {
21
+ onShowSetDateTime(recurringTimeStart, setRecurringTimeStart, 'time');
22
+ }, [onShowSetDateTime, recurringTimeStart, setRecurringTimeStart]);
23
+
24
+ const onSetTimeEnd = useCallback(() => {
25
+ onShowSetDateTime(recurringTimeEnd, setRecurringTimeEnd, 'time');
26
+ }, [onShowSetDateTime, recurringTimeEnd, setRecurringTimeEnd]);
27
+
28
+ const onSetRepeat = useCallback(
29
+ (item) => {
30
+ const index = recurringTimeRepeat.indexOf(item.value);
31
+ if (index !== -1) {
32
+ setRecurringTimeRepeat([
33
+ ...recurringTimeRepeat.slice(0, index),
34
+ ...recurringTimeRepeat.slice(index + 1),
35
+ ]);
36
+ } else {
37
+ setRecurringTimeRepeat([...recurringTimeRepeat, item.value]);
38
+ }
39
+ },
40
+ [recurringTimeRepeat, setRecurringTimeRepeat]
41
+ );
42
+
43
+ const renderRepeatItem = useCallback(
44
+ (item, index, isSelected) => {
45
+ return (
46
+ <TouchableOpacity
47
+ key={index}
48
+ style={[styles.repeatItem, isSelected && styles.repeatItemSelected]}
49
+ onPress={() => onSetRepeat(item)}
50
+ >
51
+ <Text
52
+ type="Body"
53
+ lineHeight={16}
54
+ color={isSelected ? Colors.Orange : item.color}
55
+ style={styles.repeatText}
56
+ >
57
+ {item.text}
58
+ </Text>
59
+ </TouchableOpacity>
60
+ );
61
+ },
62
+ [onSetRepeat]
63
+ );
64
+
65
+ return (
66
+ <View>
67
+ <Text type="Body" color={Colors.Gray8} style={styles.title}>
68
+ {t('start')}
69
+ </Text>
70
+ <TouchableOpacity onPress={onSetTimeStart}>
71
+ <Text type="Body" color={Colors.Orange} style={styles.value}>
72
+ {recurringTimeStart.format('HH:mm')}
73
+ </Text>
74
+ </TouchableOpacity>
75
+ <Text type="Body" color={Colors.Gray8} style={styles.title}>
76
+ {t('end')}
77
+ </Text>
78
+ <TouchableOpacity onPress={onSetTimeEnd}>
79
+ <Text type="Body" color={Colors.Orange} style={styles.value}>
80
+ {recurringTimeEnd.format('HH:mm')}
81
+ </Text>
82
+ </TouchableOpacity>
83
+ <Text type="Body" color={Colors.Gray8} style={styles.title}>
84
+ {t('repeat')}
85
+ </Text>
86
+ <View style={styles.repeatWrap}>
87
+ {REPEAT_ITEMS.map((item, index) =>
88
+ renderRepeatItem(
89
+ item,
90
+ index,
91
+ recurringTimeRepeat.includes(item.value)
92
+ )
93
+ )}
94
+ </View>
95
+ </View>
96
+ );
97
+ };
98
+
99
+ export default RecurringDetail;