@eohjsc/react-native-smart-city 0.6.2 → 0.7.3

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 (324) hide show
  1. package/README.md +3 -3
  2. package/android/build.gradle +7 -10
  3. package/package.json +53 -70
  4. package/src/commons/Action/__test__/ItemQuickAction.test.js +2 -2
  5. package/src/commons/ActionGroup/NumberUpDownActionTemplate.js +3 -3
  6. package/src/commons/ActionGroup/OnOffSmartLock/AutoLock/ButtonWrapper.js +3 -3
  7. package/src/commons/ActionGroup/OnOffSmartLock/PasscodeList/__test__/ItemPasscode.test.js +2 -2
  8. package/src/commons/ActionGroup/OnOffSmartLock/PasscodeList/__test__/index.test.js +3 -3
  9. package/src/commons/ActionGroup/OnOffSmartLock/PasscodeList/index.js +3 -3
  10. package/src/commons/ActionGroup/OnOffSmartLock/SetupGeneratePasscode/ButtonWrapper.js +2 -2
  11. package/src/commons/ActionGroup/OnOffSmartLock/SetupGeneratePasscode/__test__/index.test.js +0 -15
  12. package/src/commons/ActionGroup/OnOffTemplate/OnOffSimpleTemplate.js +2 -2
  13. package/src/commons/ActionGroup/OptionsDropdownActionTemplate.js +2 -2
  14. package/src/commons/ActionGroup/SmartTiviActionTemplate/SmartTiviActionTemplate.js +2 -2
  15. package/src/commons/ActionGroup/SmartTiviActionTemplate/component/CircleButton.js +5 -5
  16. package/src/commons/ActionGroup/SmartTiviActionTemplate/component/ControlPlay.js +5 -5
  17. package/src/commons/ActionGroup/TerminalBoxTemplate.js +2 -2
  18. package/src/commons/ActionGroup/TextBoxTemplate.js +2 -2
  19. package/src/commons/ActionGroup/ThreeButtonTemplate/__test__/ThreeButtonTemplate.test.js +4 -4
  20. package/src/commons/ActionGroup/TimerActionTemplate.js +4 -5
  21. package/src/commons/ActionGroup/TwoButtonTemplate/index.js +2 -2
  22. package/src/commons/ActionGroup/__test__/ColorPickerTemplate.test.js +4 -9
  23. package/src/commons/ActionGroup/__test__/NumberUpDownTemplate.test.js +2 -9
  24. package/src/commons/ActionGroup/__test__/OnOffButtonTemplate.test.js +4 -11
  25. package/src/commons/ActionGroup/__test__/OnOffSmartLock.test.js +2 -9
  26. package/src/commons/ActionGroup/__test__/OnOffTemplate.test.js +4 -18
  27. package/src/commons/ActionGroup/__test__/OneBigButtonTemplate.test.js +2 -2
  28. package/src/commons/ActionGroup/__test__/OptionsDropdownTemplate.test.js +1 -8
  29. package/src/commons/ActionGroup/__test__/StatesGridActionTemplate.test.js +0 -7
  30. package/src/commons/ActionGroup/__test__/SwitchButtonTemplate.test.js +4 -15
  31. package/src/commons/ActionGroup/__test__/TerminalBoxTemplate.test.js +0 -7
  32. package/src/commons/ActionGroup/__test__/TextBoxTemplate.test.js +1 -8
  33. package/src/commons/ActionGroup/__test__/TimerActionTemplate.test.js +8 -15
  34. package/src/commons/ActionGroup/__test__/TimerActionTemplateWithutConfigValue.test.js +2 -10
  35. package/src/commons/ActionGroup/__test__/TwoButtonTemplate.test.js +3 -20
  36. package/src/commons/ActionGroup/__test__/index.test.js +15 -23
  37. package/src/commons/ActionTemplate/__test__/index.test.js +2 -0
  38. package/src/commons/ActionTemplate/__test__/utils.js +21 -0
  39. package/src/commons/ActionTemplate/index.js +1 -2
  40. package/src/commons/BackDefault/index.js +2 -2
  41. package/src/commons/ButtonPopup/index.js +2 -2
  42. package/src/commons/Calendar/__test__/Calendar.test.js +0 -7
  43. package/src/commons/CircleButton/__test__/CircleButton.test.js +2 -2
  44. package/src/commons/Dashboard/MyPinnedSharedUnit/__test__/MyPinnedSharedUnit.test.js +11 -25
  45. package/src/commons/Dashboard/MyUnit/__test__/MyUnit.test.js +27 -20
  46. package/src/commons/Dashboard/MyUnit/index.js +0 -1
  47. package/src/commons/DateTimeRangeChange/DateTimeButton.js +2 -2
  48. package/src/commons/DateTimeRangeChange/__test__/DateTimeButton.test.js +4 -4
  49. package/src/commons/DateTimeRangeChange/index.js +2 -2
  50. package/src/commons/Device/ConnectedViewHeader.js +2 -2
  51. package/src/commons/Device/DisconnectedView.js +2 -2
  52. package/src/commons/Device/Emergency/EmergencyDetail.js +3 -3
  53. package/src/commons/Device/Emergency/__test__/EmergencyDetail.test.js +2 -2
  54. package/src/commons/Device/FlatListItems.js +3 -3
  55. package/src/commons/Device/Hanet/ItemHanetDevice.js +3 -3
  56. package/src/commons/Device/Hanet/ItemHanetDevice.test.js +3 -11
  57. package/src/commons/Device/ItemAddNew/index.js +2 -2
  58. package/src/commons/Device/ItemDevice.js +2 -2
  59. package/src/commons/Device/SonosSpeaker/index.js +3 -3
  60. package/src/commons/Device/WaterPurifierStatus/AlertStatusMachine.js +2 -2
  61. package/src/commons/Device/WaterQualitySensor/QualityIndicatorsItem.js +2 -6
  62. package/src/commons/DisplayChecking/index.js +2 -2
  63. package/src/commons/EmergencyButton/AlertSendConfirm.js +2 -2
  64. package/src/commons/EmergencyButton/AlertSent.js +6 -2
  65. package/src/commons/FieldTemplate/ChooseUserField/index.js +2 -2
  66. package/src/commons/FieldTemplate/PasscodeField/__test__/index.test.js +5 -5
  67. package/src/commons/FieldTemplate/ScheduleField/__test__/index.test.js +9 -9
  68. package/src/commons/Form/CurrencyInput.js +1 -15
  69. package/src/commons/GroupCheckBox/__test__/GroupCheckBox.test.js +1 -22
  70. package/src/commons/Header/HeaderCustom.js +8 -3
  71. package/src/commons/HeaderAni/index.js +2 -2
  72. package/src/commons/IconComponent/index.js +3 -3
  73. package/src/commons/MediaPlayerDetail/MediaPlayerFull.js +1 -1
  74. package/src/commons/MediaPlayerDetail/__test__/MediaPlayerFull.test.js +12 -48
  75. package/src/commons/MenuActionAddnew/__test__/MenuActionAddNew.test.js +1 -1
  76. package/src/commons/MenuActionList/__test__/MenuActionList.test.js +1 -0
  77. package/src/commons/NavBar/index.js +2 -2
  78. package/src/commons/OneTapTemplate/NumberUpDownActionTemplate.js +3 -3
  79. package/src/commons/PreventAccess/__test__/PreventAccess.test.js +1 -13
  80. package/src/commons/Processing/__test__/Connecting.test.js +3 -14
  81. package/src/commons/SearchLocation/index.js +3 -3
  82. package/src/commons/SelectActionCard/index.js +2 -2
  83. package/src/commons/SelectSubUnit/__test__/SelectSubUnit.test.js +1 -18
  84. package/src/commons/SelectSubUnit/index.js +2 -2
  85. package/src/commons/SelectUnit/__test__/SelectUnit.test.js +1 -13
  86. package/src/commons/Sharing/BtnRemoveMember.js +2 -2
  87. package/src/commons/Sharing/StationDevicePermissions.js +2 -2
  88. package/src/commons/Sharing/WrapHeaderScrollable.js +1 -1
  89. package/src/commons/Sharing/__test__/ButtonRemoveMember.test.js +2 -2
  90. package/src/commons/Sharing/__test__/DevicePermissionsCheckbox.test.js +1 -1
  91. package/src/commons/SubUnit/DeviceTemplate/ConfigAndEvaluation/ConfigAndEvaluation.js +2 -2
  92. package/src/commons/SubUnit/DeviceTemplate/ConfigValue/ConfigValue.js +2 -2
  93. package/src/commons/SubUnit/DeviceTemplate/EvaluationOverConfig/EvaluationOverConfig.js +2 -2
  94. package/src/commons/SubUnit/Item/index.js +3 -3
  95. package/src/commons/SubUnit/OneTap/ItemOneTap.js +2 -2
  96. package/src/commons/SubUnit/OneTap/__test__/SubUnitAutomate.test.js +11 -8
  97. package/src/commons/SubUnit/__test__/Favorites.test.js +1 -13
  98. package/src/commons/SubUnit/__test__/ShortDetail.test.js +5 -16
  99. package/src/commons/SummaryItem/index.js +22 -23
  100. package/src/commons/Tabbar/__test__/index.test.js +0 -11
  101. package/src/commons/Unit/HeaderUnit/index.js +84 -84
  102. package/src/commons/Unit/SharedUnit.js +7 -7
  103. package/src/commons/Unit/__test__/HeaderUnit.test.js +29 -52
  104. package/src/commons/Unit/__test__/SharedUnit.test.js +94 -105
  105. package/src/commons/UnitSummary/AirQuality/SegmentedRoundDisplay/index.js +11 -30
  106. package/src/commons/WrapParallaxScrollView/index.js +21 -50
  107. package/src/configs/API.js +1 -2
  108. package/src/hooks/Common/__test__/useAndroidTranslucentStatusBar.test.js +4 -15
  109. package/src/hooks/Common/useIsOwnerOfUnit.js +1 -1
  110. package/src/hooks/IoT/__test__/useRemoteControl.test.js +1 -1
  111. package/src/hooks/IoT/__test__/useWatchConfigs.test.js +6 -21
  112. package/src/iot/RemoteControl/HomeAssistant.js +1 -1
  113. package/src/iot/RemoteControl/__test__/Bluetooth.test.js +234 -232
  114. package/src/navigations/AddDeviceStack.js +2 -2
  115. package/src/navigations/AddGatewayStack.js +2 -2
  116. package/src/navigations/AddLGDeviceStack.js +2 -2
  117. package/src/navigations/AddMemberStack.js +2 -2
  118. package/src/navigations/AddSubUnitStack.js +2 -2
  119. package/src/navigations/AddUnitStack.js +2 -2
  120. package/src/navigations/AllGatewayStack.js +2 -2
  121. package/src/navigations/AutomateStack.js +4 -4
  122. package/src/navigations/EmergencyContactsStack.js +4 -4
  123. package/src/navigations/GatewayStack.js +2 -2
  124. package/src/navigations/HanetCameraStack.js +2 -2
  125. package/src/navigations/Main.js +2 -2
  126. package/src/navigations/NotificationStack.js +2 -2
  127. package/src/navigations/SharedStack.js +8 -6
  128. package/src/navigations/SmartAccountStack.js +2 -2
  129. package/src/navigations/SmartIrStack.js +2 -2
  130. package/src/navigations/SmartLockStack.js +2 -2
  131. package/src/navigations/SmartStack.js +2 -2
  132. package/src/navigations/TemplateStack.js +2 -2
  133. package/src/navigations/UnitStack.js +4 -12
  134. package/src/navigations/utils.js +1 -4
  135. package/src/screens/ActivityLog/hooks/index.js +7 -4
  136. package/src/screens/ActivityLog/index.js +2 -2
  137. package/src/screens/AddCommon/__test__/SelectSubUnit.test.js +4 -21
  138. package/src/screens/AddCommon/__test__/SelectUnit.test.js +7 -19
  139. package/src/screens/AddLocationMaps/__test__/index.test.js +3 -13
  140. package/src/screens/AddLocationMaps/index.js +11 -6
  141. package/src/screens/AddNewDevice/__test__/AddNewDevice.test.js +3 -20
  142. package/src/screens/AddNewGateway/PlugAndPlay/__test__/FirstWarning.test.js +11 -18
  143. package/src/screens/AddNewGateway/PlugAndPlay/__test__/ZigbeeDeviceConnectGuide.test.js +4 -21
  144. package/src/screens/AddNewGateway/RenameNewDevices.js +2 -2
  145. package/src/screens/AddNewGateway/__test__/AddNewGateway.test.js +3 -3
  146. package/src/screens/AddNewGateway/__test__/ConnectingModbusDevice.test.js +0 -17
  147. package/src/screens/AddNewGateway/__test__/ConnectingWifiDevice.test.js +4 -19
  148. package/src/screens/AddNewGateway/__test__/ConnectingWifiGuide.test.js +3 -15
  149. package/src/screens/AddNewGateway/__test__/ConnectingZigbeeDevice.test.js +31 -51
  150. package/src/screens/AddNewGateway/__test__/RenameNewDevices.test.js +9 -22
  151. package/src/screens/AddNewGateway/__test__/ScanGatewayQR.test.js +12 -19
  152. package/src/screens/AddNewGateway/__test__/ScanModbusQR.test.js +6 -16
  153. package/src/screens/AddNewGateway/__test__/ScanWifiDeviceQR.test.js +4 -15
  154. package/src/screens/AddNewGateway/__test__/SelectDeviceSubUnit.test.js +3 -3
  155. package/src/screens/AddNewGateway/__test__/SelectDeviceType.test.js +18 -10
  156. package/src/screens/AddNewGateway/__test__/SelectDeviceUnit.test.js +1 -1
  157. package/src/screens/AddNewGateway/__test__/SelectModbusGateway.test.js +12 -9
  158. package/src/screens/AddNewGateway/__test__/SelectZigbeeGateway.test.js +12 -9
  159. package/src/screens/AddNewGateway/__test__/ShareWifiPassword.test.js +7 -21
  160. package/src/screens/AllGateway/DetailConfigActionInternal/__test__/index.test.js +0 -20
  161. package/src/screens/AllGateway/DetailConfigActionModbus/__test__/index.test.js +7 -24
  162. package/src/screens/AllGateway/DeviceGatewayInfo/__test__/index.test.js +0 -17
  163. package/src/screens/AllGateway/DeviceInternalDetail/__test__/index.test.js +84 -100
  164. package/src/screens/AllGateway/DeviceModbusDetail/__test__/index.test.js +64 -82
  165. package/src/screens/AllGateway/DeviceZigbeeDetail/__test__/index.test.js +36 -55
  166. package/src/screens/AllGateway/GatewayConnectionMethods/__test__/index.test.js +9 -18
  167. package/src/screens/AllGateway/GatewayDetail/__test__/index.test.js +10 -37
  168. package/src/screens/AllGateway/GatewayInfo/__test__/index.test.js +7 -32
  169. package/src/screens/AllGateway/__test__/index.test.js +1 -14
  170. package/src/screens/AllGateway/components/GatewayItem/__test__/index.test.js +0 -12
  171. package/src/screens/AllGateway/components/TabPaneCT/__test__/index.test.js +1 -13
  172. package/src/screens/AllGateway/components/TabPaneCT/index.js +1 -1
  173. package/src/screens/AllGateway/hooks/__test__/index.test.js +1 -8
  174. package/src/screens/AllGateway/test-utils.js +1 -1
  175. package/src/screens/Automate/AddNewAction/NewActionWrapper.js +2 -2
  176. package/src/screens/Automate/AddNewAction/SetupConfigCondition.js +27 -28
  177. package/src/screens/Automate/AddNewAction/__test__/ChooseAction.test.js +3 -3
  178. package/src/screens/Automate/AddNewAction/__test__/ChooseConfig.test.js +8 -5
  179. package/src/screens/Automate/AddNewAction/__test__/SelectControlDevices.test.js +2 -2
  180. package/src/screens/Automate/AddNewAction/__test__/SelectMonitorDevices.test.js +1 -18
  181. package/src/screens/Automate/AddNewAction/__test__/SetupConfigCondition.test.js +17 -15
  182. package/src/screens/Automate/AddNewAutoSmart/__test__/AddNewAutoSmart.test.js +4 -4
  183. package/src/screens/Automate/EditActionsList/__tests__/UpdateActionScript.test.js +38 -55
  184. package/src/screens/Automate/EditActionsList/__tests__/UpdateDelayScript.test.js +0 -18
  185. package/src/screens/Automate/EditActionsList/__tests__/UpdateNotifyScript.test.js +1 -19
  186. package/src/screens/Automate/EditActionsList/__tests__/index.test.js +14 -11
  187. package/src/screens/Automate/OneTap/__test__/AddNewOneTap.test.js +3 -3
  188. package/src/screens/Automate/Scenario/__test__/AddNewOneTap.test.js +2 -2
  189. package/src/screens/Automate/ScriptDetail/Components/AddActionScript.js +2 -2
  190. package/src/screens/Automate/ScriptDetail/__test__/index.test.js +33 -25
  191. package/src/screens/Automate/ScriptDetail/index.js +6 -6
  192. package/src/screens/Automate/SetSchedule/__test__/index.test.js +4 -4
  193. package/src/screens/Automate/SetSchedule/components/RowItem.js +3 -3
  194. package/src/screens/Automate/Styles/indexStyles.js +6 -0
  195. package/src/screens/Automate/__test__/MultiUnits.test.js +7 -7
  196. package/src/screens/Automate/__test__/index.test.js +9 -34
  197. package/src/screens/Automate/index.js +50 -33
  198. package/src/screens/ChangePosition/__test__/index.test.js +1 -14
  199. package/src/screens/ConfirmUnitDeletion/__test__/ConfirmUnitDeletion.test.js +1 -23
  200. package/src/screens/Device/EditDevice/__test__/EditDevice.test.js +1 -11
  201. package/src/screens/Device/EditDevice/index.js +2 -2
  202. package/src/screens/Device/__test__/detail.test.js +11 -11
  203. package/src/screens/Device/__test__/sensorDisplayItem.test.js +0 -12
  204. package/src/screens/Device/detail.js +14 -12
  205. package/src/screens/Drawer/Drawer.test.js +3 -11
  206. package/src/screens/Drawer/index.js +3 -4
  207. package/src/screens/EmergencyContacts/EmergencyContactsList.js +4 -8
  208. package/src/screens/EmergencyContacts/EmergencyContactsSelectContacts.js +3 -3
  209. package/src/screens/EmergencyContacts/__test__/EmergencyContactAddNew.test.js +4 -17
  210. package/src/screens/EmergencyContacts/__test__/EmergencyContactList.test.js +3 -14
  211. package/src/screens/EmergencyContacts/__test__/EmergencyContactsSelectContacts.test.js +0 -10
  212. package/src/screens/EmergencySetting/components/DropDownItem.js +2 -2
  213. package/src/screens/EnterPassword/__test__/EnterPassword.test.js +4 -17
  214. package/src/screens/GuestInfo/__test__/index.test.js +0 -11
  215. package/src/screens/GuestInfo/components/RowGuestInfo.js +2 -2
  216. package/src/screens/GuestInfo/index.js +2 -2
  217. package/src/screens/HanetCamera/Detail.js +6 -2
  218. package/src/screens/HanetCamera/ManageAccess.js +3 -4
  219. package/src/screens/HanetCamera/MemberInfo.js +4 -4
  220. package/src/screens/HanetCamera/__test__/CaptureFaceID.test.js +2 -16
  221. package/src/screens/HanetCamera/__test__/Detail.test.js +1 -12
  222. package/src/screens/HanetCamera/__test__/ManageAccess.test.js +5 -16
  223. package/src/screens/HanetCamera/__test__/MemberInfo.test.js +5 -18
  224. package/src/screens/HanetCamera/components/RequestFaceIDPopup.js +2 -2
  225. package/src/screens/ManageAccess/__test__/ManageAccess.test.js +3 -19
  226. package/src/screens/ManageAccess/index.js +3 -3
  227. package/src/screens/MoveToAnotherSubUnit/__test__/index.test.js +7 -7
  228. package/src/screens/Notification/__test__/Notification.test.js +5 -15
  229. package/src/screens/Notification/__test__/NotificationItem.test.js +9 -19
  230. package/src/screens/Notification/index.js +5 -5
  231. package/src/screens/PlayBackCamera/__test__/index.test.js +13 -22
  232. package/src/screens/PlayBackCamera/index.js +2 -2
  233. package/src/screens/ScanChipQR/components/QRScan/__test__/QRScan.test.js +0 -11
  234. package/src/screens/ScanChipQR/components/QRScan/index.js +3 -3
  235. package/src/screens/SelectUnit/__test__/index.test.js +9 -29
  236. package/src/screens/SelectUnit/index.js +2 -2
  237. package/src/screens/SharedUnit/TabHeader.js +2 -2
  238. package/src/screens/SharedUnit/index.js +5 -0
  239. package/src/screens/Sharing/Components/EndDevice.js +3 -3
  240. package/src/screens/Sharing/SelectUser.js +5 -4
  241. package/src/screens/Sharing/UnitMemberList.js +7 -6
  242. package/src/screens/Sharing/__test__/InfoMemberUnit.test.js +9 -4
  243. package/src/screens/Sharing/__test__/SelectShareDevice.test.js +2 -15
  244. package/src/screens/Sharing/__test__/SelectUser.test.js +2 -22
  245. package/src/screens/Sharing/__test__/UnitMemberList.test.js +2 -2
  246. package/src/screens/Sharing/__test__/UpdateShareDevice.test.js +4 -17
  247. package/src/screens/Sharing/hooks/__test__/index.test.js +2 -13
  248. package/src/screens/SmartAccount/Connecting/index.js +0 -2
  249. package/src/screens/SmartAccount/ListDevice/__test__/ListDevice.test.js +3 -18
  250. package/src/screens/SmartAccount/SuccessfullyConnected/__test__/SuccessfullyConnected.test.js +11 -21
  251. package/src/screens/SmartAccount/SuccessfullyConnected/index.js +3 -4
  252. package/src/screens/SmartAccount/__test__/Connecting.test.js +30 -36
  253. package/src/screens/SmartAccount/__test__/SmartAccount.test.js +12 -21
  254. package/src/screens/SmartIr/__test__/GroupButtonByType.test.js +8 -17
  255. package/src/screens/SmartIr/__test__/SelectBrand.test.js +1 -11
  256. package/src/screens/SmartIr/__test__/SelectDeviceType.test.js +1 -12
  257. package/src/screens/SmartIr/__test__/SmartIr.test.js +3 -11
  258. package/src/screens/SmartIr/components/GroupButtonByType/GroupButtonByType.js +6 -5
  259. package/src/screens/SmartIr/components/SelectBrand.js +2 -2
  260. package/src/screens/SubUnit/AddSubUnit.js +1 -0
  261. package/src/screens/SubUnit/EditSubUnit.js +3 -2
  262. package/src/screens/SubUnit/ManageSubUnit.js +5 -5
  263. package/src/screens/SubUnit/__test__/AddSubUnit.test.js +9 -31
  264. package/src/screens/SubUnit/__test__/EditSubUnit.test.js +12 -30
  265. package/src/screens/SubUnit/__test__/ManageSubUnit.test.js +2 -2
  266. package/src/screens/SubUnit/hooks/__test__/useManageSubUnit.test.js +0 -12
  267. package/src/screens/SyncLGDevice/__test__/AddLGDevice.test.js +7 -20
  268. package/src/screens/Template/__test__/EditTemplate.test.js +4 -15
  269. package/src/screens/Template/__test__/GatewayList.test.js +0 -9
  270. package/src/screens/Template/__test__/detail.test.js +8 -8
  271. package/src/screens/Template/__test__/index.test.js +3 -14
  272. package/src/screens/Template/detail.js +2 -2
  273. package/src/screens/Unit/Detail.js +12 -53
  274. package/src/screens/Unit/SelectAddToFavorites.js +2 -2
  275. package/src/screens/Unit/SelectAddress.js +9 -4
  276. package/src/screens/Unit/SmartAccountItem.js +2 -2
  277. package/src/screens/Unit/Station/__test__/index.test.js +2 -2
  278. package/src/screens/Unit/Summaries.js +24 -29
  279. package/src/screens/Unit/__test__/AddMenu.test.js +5 -2
  280. package/src/screens/Unit/__test__/CheckSendEmail.test.js +0 -12
  281. package/src/screens/Unit/__test__/ChooseLocation.test.js +1 -4
  282. package/src/screens/Unit/__test__/Detail.test.js +14 -12
  283. package/src/screens/Unit/__test__/ManageUnit.test.js +2 -17
  284. package/src/screens/Unit/__test__/MoreMenu.test.js +1 -11
  285. package/src/screens/Unit/__test__/SelectAddToFavorites.test.js +3 -14
  286. package/src/screens/Unit/__test__/SelectAddress.test.js +4 -17
  287. package/src/screens/Unit/__test__/SmartAccount.test.js +14 -11
  288. package/src/screens/Unit/__test__/SmartAccountItem.test.js +0 -11
  289. package/src/screens/Unit/__test__/Summaries.test.js +2 -14
  290. package/src/screens/Unit/components/AutomateScript/index.js +2 -2
  291. package/src/screens/Unit/components/ButtonWrapper/index.js +3 -4
  292. package/src/screens/Unit/components/Header/index.js +5 -4
  293. package/src/screens/Unit/components/SharedUnit/index.js +5 -5
  294. package/src/screens/Unit/components/__test__/Header.test.js +1 -14
  295. package/src/screens/Unit/components/__test__/MyUnitDevice.test.js +1 -11
  296. package/src/screens/Unit/components/__test__/SharedUnit.test.js +1 -11
  297. package/src/screens/UnitSummary/__test__/index.test.js +51 -17
  298. package/src/screens/UnitSummary/components/3PPowerConsumption/__test__/3PPowerConsumption.test.js +8 -25
  299. package/src/screens/UnitSummary/components/AirQuality/__test__/index.test.js +1 -7
  300. package/src/screens/UnitSummary/components/AirQuality/index.js +8 -3
  301. package/src/screens/UnitSummary/components/PowerConsumption/__test__/PowerConsumption.test.js +0 -11
  302. package/src/screens/UnitSummary/components/RunningDevices/__test__/index.test.js +1 -16
  303. package/src/screens/UnitSummary/components/Temperature/index.js +5 -1
  304. package/src/screens/UnitSummary/components/UvIndex/__test__/index.test.js +0 -8
  305. package/src/screens/UnitSummary/components/UvIndex/index.js +6 -2
  306. package/src/screens/UnitSummary/components/WaterQuality/Item/index.js +2 -2
  307. package/src/screens/UnitSummary/components/WaterQuality/__test__/index.test.js +14 -18
  308. package/src/screens/UnitSummary/components/__test__/UnitSummary.test.js +8 -8
  309. package/src/screens/UnitSummary/index.js +4 -8
  310. package/src/utils/Apis/axios.js +4 -2
  311. package/src/utils/Converter/__test__/timer.test.js +8 -0
  312. package/src/utils/Functions/preloadImages.js +13 -14
  313. package/src/utils/Monitor.js +2 -3
  314. package/src/utils/Route/index.js +0 -1
  315. package/src/utils/Storage.js +1 -1
  316. package/src/commons/Device/WindSpeed/LinearChart/__test__/LinearChart.test.js +0 -48
  317. package/src/commons/Device/WindSpeed/LinearChart/index.js +0 -155
  318. package/src/screens/AddNewGateway/hooks/__Tests__/index.test.js +0 -27
  319. package/src/screens/AddNewGateway/hooks/index.js +0 -31
  320. package/src/screens/SubUnit/Detail.js +0 -150
  321. package/src/screens/SubUnit/__test__/Detail.test.js +0 -125
  322. package/src/screens/UnitSummary/components/Temperature/ChartAverage/index.js +0 -62
  323. package/src/screens/UnitSummary/components/Temperature/__test__/ChartAverage.test.js +0 -17
  324. package/src/utils/dateHelper/getTickValues.js +0 -22
@@ -12,17 +12,6 @@ const wrapComponent = (unit, summaryDetail) => (
12
12
  </SCProvider>
13
13
  );
14
14
 
15
- const mockedNavigate = jest.fn();
16
- jest.mock('@react-navigation/native', () => {
17
- return {
18
- ...jest.requireActual('@react-navigation/native'),
19
- useNavigation: () => ({
20
- navigate: mockedNavigate,
21
- }),
22
- useIsFocused: () => true,
23
- };
24
- });
25
-
26
15
  const mockConnectHomeAssistant = jest.fn();
27
16
  jest.mock('../../../../../hooks/IoT', () => {
28
17
  return {
@@ -34,10 +23,6 @@ jest.mock('../../../../../hooks/IoT', () => {
34
23
  });
35
24
 
36
25
  describe('test RunningDevices', () => {
37
- afterEach(() => {
38
- mockedNavigate.mockClear();
39
- });
40
-
41
26
  let list_svgMain = [
42
27
  '',
43
28
  'sensor',
@@ -128,7 +113,7 @@ describe('test RunningDevices', () => {
128
113
  await act(async () => {
129
114
  button[0].props.onPress();
130
115
  });
131
- expect(mockedNavigate).toBeCalledWith('DeviceDetail', {
116
+ expect(global.mockedNavigate).toBeCalledWith('DeviceDetail', {
132
117
  sensorData: summaryDetail.devices[0],
133
118
  station: 'station',
134
119
  title: undefined,
@@ -25,18 +25,21 @@ const Temperature = ({ summaryDetail }) => {
25
25
  () => [
26
26
  {
27
27
  id: temp,
28
+ key: 'temp',
28
29
  svgMain: <SvgTemperature />,
29
30
  title: `${t('text_temperature')}`,
30
31
  measure: '°C',
31
32
  },
32
33
  {
33
34
  id: humi,
35
+ key: 'humi',
34
36
  svgMain: <SvgHumidity />,
35
37
  title: `${t('text_humidity')}`,
36
38
  measure: '%',
37
39
  },
38
40
  {
39
41
  id: wind,
42
+ key: 'wind',
40
43
  svgMain: <SvgWind />,
41
44
  title: `${t('text_wind')}`,
42
45
  des: `${t('text_win_direction')}: ${windDirection || t('loading')}`,
@@ -44,6 +47,7 @@ const Temperature = ({ summaryDetail }) => {
44
47
  },
45
48
  {
46
49
  id: rain,
50
+ key: 'rain',
47
51
  svgMain: <SvgRain />,
48
52
  title: `${t('text_rain')}`,
49
53
  measure: '',
@@ -78,7 +82,7 @@ const Temperature = ({ summaryDetail }) => {
78
82
  <Today style={styles.textIndoor} />
79
83
  <View style={styles.boxTemperature}>
80
84
  {dataTemperature.map((item) => (
81
- <ItemTemperature {...item} key={item.id} />
85
+ <ItemTemperature {...item} key={item.key} />
82
86
  ))}
83
87
  </View>
84
88
  </Section>
@@ -9,14 +9,6 @@ import api from '../../../../../utils/Apis/axios';
9
9
 
10
10
  new MockAdapter(api.axiosInstance);
11
11
 
12
- jest.mock('@react-navigation/native', () => {
13
- return {
14
- ...jest.requireActual('@react-navigation/native'),
15
- useRoute: jest.fn(),
16
- useFocusEffect: (func) => func(),
17
- };
18
- });
19
-
20
12
  const wrapComponent = (data) => (
21
13
  <SCProvider initState={mockSCStore({})}>
22
14
  <UvIndex {...data} />
@@ -1,6 +1,6 @@
1
1
  import React, { memo, useMemo } from 'react';
2
2
  import { View } from 'react-native';
3
- import { IconOutline } from '@ant-design/icons-react-native';
3
+ import MaterialCommunityIcons from 'react-native-vector-icons/MaterialCommunityIcons';
4
4
  import { useTranslations } from '../../../../hooks/Common/useTranslations';
5
5
 
6
6
  import { Colors } from '../../../../configs';
@@ -37,7 +37,11 @@ const UvIndex = memo(({ summaryDetail }) => {
37
37
  <Today />
38
38
  <SegmentedRoundChart data={data} />
39
39
  <View style={styles.boxHealth}>
40
- <IconOutline name="alert" size={20} style={styles.iconMargin} />
40
+ <MaterialCommunityIcons
41
+ name="alert-circle-outline"
42
+ size={20}
43
+ style={styles.iconMargin}
44
+ />
41
45
  <Text
42
46
  semibold
43
47
  color={Colors.Gray9}
@@ -1,6 +1,6 @@
1
1
  import React, { memo } from 'react';
2
2
  import { View, StyleSheet, TouchableOpacity } from 'react-native';
3
- import { IconOutline } from '@ant-design/icons-react-native';
3
+ import AntDesign from 'react-native-vector-icons/AntDesign';
4
4
  import { useNavigation } from '@react-navigation/native';
5
5
 
6
6
  import Text from '../../../../../commons/Text';
@@ -23,7 +23,7 @@ const Item = memo(({ id, svgMain, title, measure, des, color, waterType }) => {
23
23
  <Text>{title}</Text>
24
24
  {waterType && (
25
25
  <TouchableOpacity onPress={goToDetail} style={styles.buttonInfo}>
26
- <IconOutline
26
+ <AntDesign
27
27
  style={styles.row}
28
28
  name="info-circle"
29
29
  size={20}
@@ -8,19 +8,9 @@ import { SCProvider } from '../../../../../context';
8
8
  import { mockSCStore } from '../../../../../context/mockStore';
9
9
  import MockAdapter from 'axios-mock-adapter';
10
10
  import api from '../../../../../utils/Apis/axios';
11
+ import { useNavigation } from '@react-navigation/native';
11
12
 
12
13
  new MockAdapter(api.axiosInstance);
13
- const mockNavigate = jest.fn();
14
- jest.mock('@react-navigation/native', () => {
15
- return {
16
- ...jest.requireActual('@react-navigation/native'),
17
- useRoute: jest.fn(),
18
- useNavigation: () => ({
19
- navigate: mockNavigate,
20
- }),
21
- useFocusEffect: (func) => func(),
22
- };
23
- });
24
14
 
25
15
  const wrapComponent = (data) => (
26
16
  <SCProvider initState={mockSCStore({})}>
@@ -29,10 +19,10 @@ const wrapComponent = (data) => (
29
19
  );
30
20
 
31
21
  describe('Test WaterQualityGuide', () => {
22
+ const { navigate } = useNavigation();
32
23
  let data;
33
24
  beforeEach(() => {
34
25
  Date.now = jest.fn(() => new Date('2021-01-24T12:00:00.000Z'));
35
- mockNavigate.mockClear();
36
26
  data = {
37
27
  summaryDetail: {
38
28
  ph_id: 1,
@@ -45,6 +35,7 @@ describe('Test WaterQualityGuide', () => {
45
35
  ph: 1,
46
36
  tur: 2,
47
37
  clo: 3,
38
+ temp: 4,
48
39
  },
49
40
  },
50
41
  };
@@ -83,25 +74,30 @@ describe('Test WaterQualityGuide', () => {
83
74
  await act(async () => {
84
75
  buttons[0].props.onPress();
85
76
  });
86
- expect(mockNavigate).toHaveBeenCalledTimes(1);
87
- expect(mockNavigate).toHaveBeenCalledWith(Routes.WaterQualityGuide, {
77
+ expect(navigate).toHaveBeenCalledTimes(1);
78
+ expect(navigate).toHaveBeenCalledWith(Routes.WaterQualityGuide, {
88
79
  waterType: 'turbidity',
89
80
  });
90
81
 
91
82
  await act(async () => {
92
83
  buttons[1].props.onPress();
93
84
  });
94
- expect(mockNavigate).toHaveBeenCalledTimes(2);
95
- expect(mockNavigate).toHaveBeenCalledWith(Routes.WaterQualityGuide, {
85
+ expect(navigate).toHaveBeenCalledTimes(2);
86
+ expect(navigate).toHaveBeenCalledWith(Routes.WaterQualityGuide, {
96
87
  waterType: 'ph',
97
88
  });
98
89
 
99
90
  await act(async () => {
100
91
  buttons[2].props.onPress();
101
92
  });
102
- expect(mockNavigate).toHaveBeenCalledTimes(3);
103
- expect(mockNavigate).toHaveBeenCalledWith(Routes.WaterQualityGuide, {
93
+ expect(navigate).toHaveBeenCalledTimes(3);
94
+ expect(navigate).toHaveBeenCalledWith(Routes.WaterQualityGuide, {
104
95
  waterType: 'clo',
105
96
  });
97
+
98
+ await act(async () => {
99
+ buttons[3].props.onPress();
100
+ });
101
+ expect(navigate).toHaveBeenCalledTimes(3); // not call navigate
106
102
  });
107
103
  });
@@ -22,8 +22,8 @@ describe('Test UnitSummary', () => {
22
22
  tree = await create(<UnitSummary {...defaultProps} index={0} />);
23
23
  });
24
24
  const instance = tree.root;
25
- const TouchableOpacities = instance.findAllByType(TouchableOpacity);
26
- expect(TouchableOpacities[0].props.style).toEqual([
25
+ const touchableOpacities = instance.findAllByType(TouchableOpacity);
26
+ expect(touchableOpacities[0].props.style).toEqual([
27
27
  styles.summaryContainer,
28
28
  { borderTopLeftRadius: 10 },
29
29
  ]);
@@ -34,8 +34,8 @@ describe('Test UnitSummary', () => {
34
34
  tree = await create(<UnitSummary {...defaultProps} index={1} />);
35
35
  });
36
36
  const instance = tree.root;
37
- const TouchableOpacities = instance.findAllByType(TouchableOpacity);
38
- expect(TouchableOpacities[0].props.style).toEqual([
37
+ const touchableOpacities = instance.findAllByType(TouchableOpacity);
38
+ expect(touchableOpacities[0].props.style).toEqual([
39
39
  styles.summaryContainer,
40
40
  { borderTopRightRadius: 10 },
41
41
  ]);
@@ -46,8 +46,8 @@ describe('Test UnitSummary', () => {
46
46
  tree = await create(<UnitSummary {...defaultProps} index={1} len={2} />);
47
47
  });
48
48
  const instance = tree.root;
49
- const TouchableOpacities = instance.findAllByType(TouchableOpacity);
50
- expect(TouchableOpacities[0].props.style).toEqual([
49
+ const touchableOpacities = instance.findAllByType(TouchableOpacity);
50
+ expect(touchableOpacities[0].props.style).toEqual([
51
51
  styles.summaryContainer,
52
52
  { borderBottomRightRadius: 10 },
53
53
  ]);
@@ -58,8 +58,8 @@ describe('Test UnitSummary', () => {
58
58
  tree = await create(<UnitSummary {...defaultProps} index={2} len={3} />);
59
59
  });
60
60
  const instance = tree.root;
61
- const TouchableOpacities = instance.findAllByType(TouchableOpacity);
62
- expect(TouchableOpacities[0].props.style).toEqual([
61
+ const touchableOpacities = instance.findAllByType(TouchableOpacity);
62
+ expect(touchableOpacities[0].props.style).toEqual([
63
63
  styles.summaryContainer,
64
64
  { borderBottomLeftRadius: 10 },
65
65
  ]);
@@ -2,7 +2,7 @@ import React, { memo, useCallback, useEffect, useState } from 'react';
2
2
  import { View, StyleSheet } from 'react-native';
3
3
  import { useNavigation } from '@react-navigation/native';
4
4
  import { TouchableOpacity } from 'react-native';
5
- import { IconOutline } from '@ant-design/icons-react-native';
5
+ import AntDesign from 'react-native-vector-icons/AntDesign';
6
6
  import moment from 'moment';
7
7
 
8
8
  import { useTranslations } from '../../hooks/Common/useTranslations';
@@ -129,9 +129,9 @@ const UnitSummary = memo(({ route }) => {
129
129
  fetchSummaryDetail();
130
130
  }, [fetchSummaryDetail, summary?.screen]);
131
131
 
132
- const onRefresh = useCallback(() => {
132
+ const onRefresh = useCallback(async () => {
133
133
  setLoading(true);
134
- fetchSummaryDetail();
134
+ await fetchSummaryDetail();
135
135
  }, [fetchSummaryDetail]);
136
136
 
137
137
  const { dataNotification } = useReceiveNotifications();
@@ -168,11 +168,7 @@ const UnitSummary = memo(({ route }) => {
168
168
  accessibilityLabel={AccessibilityLabel.UNIT_SUMMARY_GUIDE_TOUCH}
169
169
  onPress={() => navigation.navigate(GuideName)}
170
170
  >
171
- <IconOutline
172
- name="info-circle"
173
- size={27}
174
- color={Colors.Black}
175
- />
171
+ <AntDesign name="info-circle" size={27} color={Colors.Black} />
176
172
  </TouchableOpacity>
177
173
  </View>
178
174
  ) : null
@@ -17,7 +17,9 @@ const api = create({
17
17
 
18
18
  if (__DEV__ && process.env.NODE_ENV !== 'test') {
19
19
  api.axiosInstance.interceptors.request.use((request) => {
20
- console.log(`${request.method.toUpperCase()} ${request.url || ''}`);
20
+ console.log(
21
+ `${new Date()} ${request.method.toUpperCase()} ${request.url || ''}`
22
+ );
21
23
  if (process.env.DEBUG_AXIOS_DETAIL_REQUEST) {
22
24
  if (request.data) {
23
25
  console.log(JSON.stringify(request.data));
@@ -28,7 +30,7 @@ if (__DEV__ && process.env.NODE_ENV !== 'test') {
28
30
  });
29
31
 
30
32
  api.axiosInstance.interceptors.response.use((response) => {
31
- console.log(`${response.status} ${response.config.url}`);
33
+ console.log(`${new Date()} ${response.status} ${response.config.url}`);
32
34
  if (process.env.DEBUG_AXIOS_DETAIL_REQUEST) {
33
35
  console.log(response.data);
34
36
  }
@@ -17,6 +17,14 @@ describe('Test timer', () => {
17
17
  expect(result).toBe('1 seconds ago');
18
18
  });
19
19
 
20
+ it('Test timeDifference when previous is string', async () => {
21
+ result = await timeDifference(
22
+ new Date('2022-08-01T03:24:01'),
23
+ '2022-08-01T03:24:00'
24
+ );
25
+ expect(result).toBe('1 seconds ago');
26
+ });
27
+
20
28
  it('Test timeDifference when elapsed < msPerMinute and symbol=true', async () => {
21
29
  result = await timeDifference(
22
30
  new Date('2022-08-01T03:24:01'),
@@ -7,7 +7,7 @@ export const preloadImagesFromUnits = async (units, storeKey) => {
7
7
  const isFirstTime = await getData(storeKey);
8
8
  if (units?.length && !isFirstTime) {
9
9
  await storeData(storeKey, 'true');
10
- Promise.all(
10
+ const results = await Promise.all(
11
11
  units.map(async (item) => {
12
12
  const unitId =
13
13
  storeKey === STORAGE_KEY.IS_FIRST_TIME_LOAD_MY_UNITS
@@ -22,18 +22,17 @@ export const preloadImagesFromUnits = async (units, storeKey) => {
22
22
  return success && data;
23
23
  }
24
24
  })
25
- // eslint-disable-next-line promise/prefer-await-to-then
26
- ).then((results) => {
27
- const icons = results
28
- .map((item) => item?.stations?.map((i) => i?.background) || [])
29
- .flat()
30
- .filter(Boolean);
31
- FastImage.preload(
32
- icons.map((uri) => ({
33
- uri,
34
- priority: FastImage.priority.high,
35
- }))
36
- );
37
- });
25
+ );
26
+
27
+ const icons = results
28
+ .map((item) => item?.stations?.map((i) => i?.background) || [])
29
+ .flat()
30
+ .filter(Boolean);
31
+ FastImage.preload(
32
+ icons.map((uri) => ({
33
+ uri,
34
+ priority: FastImage.priority.high,
35
+ }))
36
+ );
38
37
  }
39
38
  };
@@ -1,9 +1,8 @@
1
1
  import { getPusher, destroyPusher } from './Pusher';
2
2
 
3
- // eslint-disable-next-line promise/prefer-await-to-callbacks
4
- export const watchNotificationData = (user, callback) => {
3
+ export const watchNotificationData = (user, handler) => {
5
4
  const channel = getPusher().subscribe(`private-user-${user.id}`);
6
- channel.bind('new-notification', callback);
5
+ channel.bind('new-notification', handler);
7
6
  };
8
7
 
9
8
  export const unwatchNotificationData = (user) => {
@@ -19,7 +19,6 @@ const Routes = {
19
19
  EditSubUnit: 'EditSubUnit',
20
20
  Language: 'Language',
21
21
  SubUnit: 'SubUnit',
22
- SubUnitDetail: 'SubUnitDetail',
23
22
  DeviceDetail: 'DeviceDetail',
24
23
  HanetCameraStack: 'HanetCameraStack',
25
24
  HanetCameraDetail: 'HanetCameraDetail',
@@ -1,4 +1,4 @@
1
- import AsyncStorage from '@react-native-community/async-storage';
1
+ import AsyncStorage from '@react-native-async-storage/async-storage';
2
2
 
3
3
  export const STORAGE_KEY = {
4
4
  FIREBASE_APP_CONFIG: 'app_config',
@@ -1,48 +0,0 @@
1
- import React from 'react';
2
- import Svg from 'react-native-svg';
3
- import LinearChart from '../';
4
- import renderer, { act } from 'react-test-renderer';
5
- import { SCProvider } from '../../../../../context';
6
- import { mockSCStore } from '../../../../../context/mockStore';
7
-
8
- Date.now = jest.fn(() => 1487076708000);
9
-
10
- const wrapComponent = (chartOptions, datasShow) => (
11
- <SCProvider initState={mockSCStore({})}>
12
- <LinearChart chartOptions={chartOptions} datasShow={datasShow} />
13
- </SCProvider>
14
- );
15
-
16
- describe('Test LinearChart', () => {
17
- let wrapper;
18
-
19
- it('LinearChart render', async () => {
20
- const chartOptions = {
21
- showAll: true,
22
- };
23
- const datasShow = [
24
- {
25
- data: [
26
- {
27
- x: 0,
28
- y: 1,
29
- },
30
- {
31
- x: 1,
32
- y: 2,
33
- },
34
- {
35
- x: 2,
36
- y: 3,
37
- },
38
- ],
39
- },
40
- ];
41
- await act(async () => {
42
- wrapper = renderer.create(wrapComponent(chartOptions, datasShow));
43
- });
44
- const instance = wrapper.root;
45
- const Svgs = instance.findAllByType(Svg);
46
- expect(Svgs).toHaveLength(1);
47
- });
48
- });
@@ -1,155 +0,0 @@
1
- import React, { memo } from 'react';
2
- import Svg, { G } from 'react-native-svg';
3
- import {
4
- VictoryLine,
5
- VictoryAxis,
6
- VictoryScatter,
7
- VictoryTooltip,
8
- } from 'victory-native';
9
- import { useTranslations } from '../../../../hooks/Common/useTranslations';
10
-
11
- import { Colors } from '../../../../configs';
12
- import ChartLoading from '../../../ChartLoading';
13
- import ValueBalloon from '../../../Device/WindSpeed/LinearChart/ValueBalloon';
14
- import { getMaxValueIndex } from '../../../../utils/chartHelper/getMaxValueIndex';
15
- import getTickValues from '../../../../utils/dateHelper/getTickValues';
16
-
17
- const LinearChart = memo(
18
- ({
19
- startTime,
20
- endTime,
21
- datasShow,
22
- configuration,
23
- datasColor,
24
- chartOptions,
25
- }) => {
26
- const t = useTranslations();
27
- const datas = chartOptions.showAll
28
- ? datasShow
29
- : datasShow.filter((item, index) => index === chartOptions.index);
30
- if (!datasShow[0].data) {
31
- return <ChartLoading />;
32
- }
33
- if (!datasShow[0].data.length) {
34
- return <ChartLoading message={t('no_data')} />;
35
- }
36
- const chartTick = getTickValues(datas[0], configuration).stringArr;
37
- const maxValue = getMaxValueIndex(datas[0].data);
38
-
39
- return (
40
- <Svg width={'100%'} height={300} style>
41
- <G x={-12} y={-12}>
42
- <VictoryAxis
43
- dependentAxis
44
- domain={[0, maxValue.max.y * 1.2]}
45
- offsetX={50}
46
- orientation="left"
47
- standalone={false}
48
- style={styleVerticalAxis}
49
- />
50
- <VictoryAxis
51
- crossAxis
52
- scale="time"
53
- standalone={false}
54
- style={styleHorizontalAxis}
55
- tickValues={chartTick}
56
- />
57
- {datas.map((item, index) => {
58
- const tickValues = getTickValues(item).arr;
59
- const maxValueLine = getMaxValueIndex(item.data);
60
- return (
61
- <G key={index.toString()}>
62
- <VictoryLine
63
- data={item.data}
64
- domain={{
65
- x: [tickValues[0], tickValues[tickValues.length - 1]],
66
- y: [0, maxValueLine.max.y * 1.2],
67
- }}
68
- style={{
69
- data: { stroke: item.color },
70
- }}
71
- interpolation="monotoneX"
72
- scale={{ x: 'time', y: 'linear' }}
73
- standalone={false}
74
- />
75
- </G>
76
- );
77
- })}
78
- {datas.map((item, index) => {
79
- const scatterValues = getTickValues(item).stringDataArr;
80
- const maxValueLine = getMaxValueIndex(item.data);
81
- return (
82
- <G key={index}>
83
- <VictoryScatter
84
- standalone={false}
85
- data={scatterValues}
86
- labels={(datum) => {
87
- if (item.measure === 'pH') {
88
- return `${item.measure} ${datum.y.toString()}`;
89
- }
90
- return `${datum.y.toString()} ${item.measure}`;
91
- }}
92
- labelComponent={
93
- <VictoryTooltip
94
- flyoutComponent={<ValueBalloon />}
95
- renderInPortal={false}
96
- />
97
- }
98
- domain={{ y: [0, maxValueLine.max.y * 1.2] }}
99
- samples={25}
100
- size={5}
101
- style={{ ...styleScatter, data: { fill: item.color } }}
102
- />
103
- </G>
104
- );
105
- })}
106
- </G>
107
- </Svg>
108
- );
109
- }
110
- );
111
-
112
- export default LinearChart;
113
-
114
- const styleVerticalAxis = {
115
- axis: { stroke: Colors.Gray4, strokeWidth: 1 },
116
- ticks: {
117
- size: 5,
118
- stroke: 'black',
119
- strokeWidth: 0,
120
- },
121
- tickLabels: {
122
- fill: Colors.Gray8,
123
- fontFamily: 'SFProDisplay-Regular',
124
- fontSize: 10,
125
- },
126
- grid: {
127
- fill: 'none',
128
- stroke: Colors.Gray4,
129
- strokeDasharray: '5,5',
130
- pointerEvents: 'painted',
131
- },
132
- };
133
-
134
- const styleHorizontalAxis = {
135
- axis: { stroke: 'black', strokeWidth: 0 },
136
- ticks: {
137
- size: 10,
138
- stroke: 'black',
139
- strokeWidth: 0,
140
- },
141
- tickLabels: {
142
- fill: Colors.Gray8,
143
- fontFamily: 'SFProDisplay-Regular',
144
- fontSize: 10,
145
- },
146
- };
147
-
148
- const styleScatter = {
149
- labels: {
150
- fill: Colors.White,
151
- padding: 14,
152
- fontFamily: 'SFProDisplay-Regular',
153
- fontSize: 12,
154
- },
155
- };
@@ -1,27 +0,0 @@
1
- import { act, renderHook } from '@testing-library/react-hooks';
2
- import MockAdapter from 'axios-mock-adapter';
3
- import api from '../../../../utils/Apis/axios';
4
- import { useConnectGateway } from '..';
5
-
6
- import { API } from '../../../../configs';
7
-
8
- const mock = new MockAdapter(api.axiosInstance);
9
- jest.mock('@react-navigation/native', () => {
10
- return {
11
- ...jest.requireActual('@react-navigation/native'),
12
- useNavigation: () => ({
13
- dangerouslyGetParent: () => ({
14
- dangerouslyGetState: jest.fn(),
15
- }),
16
- }),
17
- };
18
- });
19
- describe('Test useHomeAssistantConnection', () => {
20
- it('test connectGoogleHome all connected', async () => {
21
- const { result } = renderHook(() => useConnectGateway(1));
22
- await act(async () => {
23
- await result.current.onPressDone();
24
- });
25
- mock.onGet(API.UNIT.UNIT_DETAIL(1)).reply(200, {});
26
- });
27
- });
@@ -1,31 +0,0 @@
1
- import { useCallback } from 'react';
2
- import { useNavigation } from '@react-navigation/native';
3
- import { axiosGet } from '../../../utils/Apis/axios';
4
- import { API } from '../../../configs';
5
-
6
- const useConnectGateway = (unit_id) => {
7
- const navigation = useNavigation();
8
-
9
- const fetchDetails = useCallback(async () => {
10
- const { success: fetchSuccess, data: unit } = await axiosGet(
11
- API.UNIT.UNIT_DETAIL(unit_id),
12
- {},
13
- true
14
- );
15
- return { fetchSuccess, unit };
16
- }, [unit_id]);
17
-
18
- const onPressDone = useCallback(async () => {
19
- const { fetchSuccess } = await fetchDetails();
20
- if (!fetchSuccess) {
21
- return;
22
- }
23
- navigation.dangerouslyGetParent().pop();
24
- }, [fetchDetails, navigation]);
25
-
26
- return {
27
- onPressDone,
28
- };
29
- };
30
-
31
- export { useConnectGateway };