@eohjsc/react-native-smart-city 0.3.31 → 0.3.32

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 (351) hide show
  1. package/package.json +7 -5
  2. package/src/commons/Action/ItemQuickAction.js +2 -3
  3. package/src/commons/Action/__test__/ItemQuickAction.test.js +17 -9
  4. package/src/commons/ActionGroup/CurtainButtonTemplate.js +6 -6
  5. package/src/commons/ActionGroup/NumberUpDownActionTemplate.js +4 -4
  6. package/src/commons/ActionGroup/OnOffSmartLock/AutoLock/ButtonWrapper.js +5 -2
  7. package/src/commons/ActionGroup/OnOffSmartLock/AutoLock/__test__/index.test.js +10 -4
  8. package/src/commons/ActionGroup/OnOffSmartLock/AutoLock/index.js +4 -4
  9. package/src/commons/ActionGroup/OnOffSmartLock/OnOffSmartLock.js +2 -2
  10. package/src/commons/ActionGroup/OnOffSmartLock/PasscodeList/ItemPasscode.js +1 -1
  11. package/src/commons/ActionGroup/OnOffSmartLock/PasscodeList/__test__/index.test.js +2 -2
  12. package/src/commons/ActionGroup/OnOffSmartLock/PasscodeList/index.js +2 -2
  13. package/src/commons/ActionGroup/OnOffSmartLock/SetupGeneratePasscode/ButtonWrapper.js +2 -2
  14. package/src/commons/ActionGroup/OnOffSmartLock/SetupGeneratePasscode/__test__/index.test.js +12 -6
  15. package/src/commons/ActionGroup/OnOffSmartLock/SetupGeneratePasscode/index.js +8 -4
  16. package/src/commons/ActionGroup/OnOffTemplate/OnOffButtonTemplate.js +4 -6
  17. package/src/commons/ActionGroup/OneBigButtonTemplate.js +1 -1
  18. package/src/commons/ActionGroup/OptionsDropdownActionTemplate.js +10 -4
  19. package/src/commons/ActionGroup/SmartTiviActionTemplate/SmartTiviActionTemplate.js +25 -9
  20. package/src/commons/ActionGroup/SmartTiviActionTemplate/__test__/ControlPlay.test.js +13 -7
  21. package/src/commons/ActionGroup/SmartTiviActionTemplate/__test__/RectangleButton.test.js +9 -5
  22. package/src/commons/ActionGroup/SmartTiviActionTemplate/__test__/SmartTiviActionTemplate.test.js +25 -9
  23. package/src/commons/ActionGroup/SmartTiviActionTemplate/component/CircleButton.js +16 -6
  24. package/src/commons/ActionGroup/SmartTiviActionTemplate/component/ControlPlay.js +10 -4
  25. package/src/commons/ActionGroup/SmartTiviActionTemplate/component/RectangleButton.js +7 -3
  26. package/src/commons/ActionGroup/StatesGridActionTemplate.js +2 -2
  27. package/src/commons/ActionGroup/ThreeButtonTemplate.js +5 -5
  28. package/src/commons/ActionGroup/TwoButtonTemplate/index.js +4 -4
  29. package/src/commons/ActionGroup/__test__/NumberUpDownTemplate.test.js +7 -7
  30. package/src/commons/ActionGroup/__test__/OnOffSmartLock.test.js +3 -3
  31. package/src/commons/ActionGroup/__test__/OnOffTemplate.test.js +3 -3
  32. package/src/commons/ActionGroup/__test__/OptionsDropdownTemplate.test.js +9 -5
  33. package/src/commons/ActionGroup/__test__/index.test.js +5 -3
  34. package/src/commons/AlertAction/index.js +2 -2
  35. package/src/commons/Auth/AccountItem.js +9 -3
  36. package/src/commons/Auth/__test__/AccountItem.test.js +6 -3
  37. package/src/commons/Automate/ItemAutomate.js +13 -3
  38. package/src/commons/BackDefault/index.js +2 -2
  39. package/src/commons/BottomButtonView/index.js +4 -5
  40. package/src/commons/Button/index.js +0 -2
  41. package/src/commons/ButtonPopup/index.js +3 -3
  42. package/src/commons/Dashboard/MyPinnedSharedUnit/__test__/MyPinnedSharedUnit.test.js +3 -2
  43. package/src/commons/Dashboard/MyPinnedSharedUnit/index.js +4 -2
  44. package/src/commons/Dashboard/MyUnit/__test__/MyUnit.test.js +6 -3
  45. package/src/commons/Dashboard/MyUnit/index.js +5 -3
  46. package/src/commons/Device/ConnectedViewHeader.js +2 -2
  47. package/src/commons/Device/DeviceAlertStatus.js +2 -2
  48. package/src/commons/Device/DisconnectedView.js +2 -2
  49. package/src/commons/Device/Emergency/EmergencyButton.js +2 -2
  50. package/src/commons/Device/Emergency/__test__/EmergencyButton.test.js +3 -2
  51. package/src/commons/Device/FlatListItems.js +2 -2
  52. package/src/commons/Device/ItemAddNew/index.js +7 -12
  53. package/src/commons/Device/ItemDevice.js +16 -11
  54. package/src/commons/Device/SensorConnectedStatus.js +5 -2
  55. package/src/commons/Device/WindDirection/Compass/index.js +5 -2
  56. package/src/commons/Device/__test__/DeviceAlertStatus.test.js +8 -4
  57. package/src/commons/Device/__test__/FlatListItems.test.js +3 -2
  58. package/src/commons/Device/__test__/SensorConnectedStatus.test.js +4 -2
  59. package/src/commons/Explore/ActivityIndicator/index.js +5 -2
  60. package/src/commons/Explore/SearchBox/__test__/SearchBox.test.js +3 -3
  61. package/src/commons/Explore/SearchBox/index.js +2 -2
  62. package/src/commons/FieldTemplate/ChooseUserField/ChoosePopup.js +4 -4
  63. package/src/commons/FieldTemplate/ChooseUserField/__test__/index.test.js +11 -8
  64. package/src/commons/FieldTemplate/ChooseUserField/index.js +2 -2
  65. package/src/commons/FieldTemplate/PasscodeField/__test__/index.test.js +3 -2
  66. package/src/commons/FieldTemplate/PasscodeField/index.js +2 -2
  67. package/src/commons/FieldTemplate/ScheduleField/__test__/index.test.js +12 -7
  68. package/src/commons/Form/TextInput.js +2 -2
  69. package/src/commons/Form/TextInputPassword.js +2 -2
  70. package/src/commons/GroupCheckBox/__test__/GroupCheckBox.test.js +5 -3
  71. package/src/commons/GroupCheckBox/index.js +2 -2
  72. package/src/commons/HeaderAni/index.js +2 -3
  73. package/src/commons/MediaPlayerDetail/index.js +2 -2
  74. package/src/commons/MenuActionList/index.js +2 -2
  75. package/src/commons/MenuActionMore/index.js +2 -3
  76. package/src/commons/NavBar/index.js +2 -3
  77. package/src/commons/OneTapTemplate/NumberUpDownActionTemplate.js +11 -5
  78. package/src/commons/OneTapTemplate/OptionsDropdownActionTemplate.js +7 -3
  79. package/src/commons/OneTapTemplate/StatesGridActionTemplate.js +4 -2
  80. package/src/commons/OneTapTemplate/__test__/NumberUpDownActionTemplate.test.js +11 -8
  81. package/src/commons/OneTapTemplate/__test__/OptionsDropdownActionTemplate.test.js +9 -5
  82. package/src/commons/OneTapTemplate/__test__/StatesGridActionTemplate.test.js +5 -3
  83. package/src/commons/Popover/index.js +2 -13
  84. package/src/commons/PreventAccess/__test__/PreventAccess.test.js +5 -3
  85. package/src/commons/PreventAccess/index.js +3 -3
  86. package/src/commons/{Connecting → Processing}/__test__/Connecting.test.js +5 -4
  87. package/src/commons/Processing/index.js +93 -0
  88. package/src/commons/{Connecting → Processing}/styles.js +9 -1
  89. package/src/commons/SelectGateway/index.js +105 -0
  90. package/src/commons/SelectGateway/styles.js +55 -0
  91. package/src/commons/SelectSubUnit/__test__/SelectSubUnit.test.js +106 -0
  92. package/src/commons/SelectSubUnit/index.js +124 -0
  93. package/src/commons/SelectSubUnit/styles.js +55 -0
  94. package/src/commons/SelectUnit/__test__/SelectUnit.test.js +120 -0
  95. package/src/commons/SelectUnit/index.js +106 -0
  96. package/src/commons/SelectUnit/styles.js +54 -0
  97. package/src/commons/Sharing/WrapHeaderScrollable.js +2 -2
  98. package/src/commons/SubUnit/OneTap/ItemOneTap.js +4 -4
  99. package/src/commons/SubUnit/OneTap/__test__/SubUnitAutomate.test.js +25 -10
  100. package/src/commons/SubUnit/OneTap/index.js +9 -4
  101. package/src/commons/SubUnit/ShortDetail.js +11 -29
  102. package/src/commons/SubUnit/__test__/ShortDetail.test.js +15 -10
  103. package/src/commons/SummaryItem/index.js +2 -2
  104. package/src/commons/Unit/HeaderUnit/index.js +4 -5
  105. package/src/commons/Unit/SharedUnit.js +10 -8
  106. package/src/commons/Unit/__test__/HeaderUnit.test.js +13 -5
  107. package/src/commons/Unit/__test__/SharedUnit.test.js +30 -11
  108. package/src/commons/UnitSummary/AirQuality/__test__/index.test.js +13 -8
  109. package/src/commons/UnitSummary/AirQuality/index.js +7 -3
  110. package/src/commons/UnitSummary/TotalPowerBox.js +2 -2
  111. package/src/commons/UnitSummary/TotalPowerConsumption/index.js +2 -2
  112. package/src/commons/UnitSummary/__test__/TotalPowerBox.test.js +3 -2
  113. package/src/commons/UnitSummary/__test__/TotalPowerConsumption.test.js +4 -2
  114. package/src/commons/ViewButtonBottom/index.js +4 -4
  115. package/src/commons/WheelDateTimePicker/index.js +5 -3
  116. package/src/commons/WrapParallaxScrollView/index.js +2 -1
  117. package/src/configs/API.js +6 -14
  118. package/src/configs/AccessibilityLabel.js +608 -0
  119. package/src/configs/Constants.js +1 -604
  120. package/src/context/actionType.ts +7 -3
  121. package/src/context/mockStore.ts +6 -3
  122. package/src/context/reducer.ts +23 -8
  123. package/src/hoc/withRemoteControl.js +1 -0
  124. package/src/hooks/Common/index.js +2 -2
  125. package/src/hooks/Common/{useGGHomeDeviceConnected.js → useHomeAssistantDeviceConnected.js} +3 -3
  126. package/src/hooks/Common/usePopover.js +6 -1
  127. package/src/hooks/IoT/__test__/{useGGHomeConnection.test.js → useHomeAssistantConnection.test.js} +18 -18
  128. package/src/hooks/IoT/__test__/useRemoteControl.test.js +17 -12
  129. package/src/hooks/IoT/index.js +2 -2
  130. package/src/hooks/IoT/useHomeAssistantConnection.js +91 -0
  131. package/src/hooks/IoT/useRemoteControl.js +6 -6
  132. package/src/iot/RemoteControl/{GoogleHome.js → HomeAssistant.js} +21 -17
  133. package/src/iot/RemoteControl/LG.js +2 -1
  134. package/src/iot/RemoteControl/__test__/{GoogleHome.test.js → HomeAssistant.test.js} +30 -30
  135. package/src/navigations/AddDeviceStack.js +0 -14
  136. package/src/navigations/AddGatewayStack.js +51 -21
  137. package/src/navigations/Main.js +2 -2
  138. package/src/navigations/SmartIrStack.js +3 -3
  139. package/src/navigations/UnitStack.js +1 -1
  140. package/src/screens/AQIGuide/__test__/AQIGuide.test.js +5 -3
  141. package/src/screens/AQIGuide/index.js +5 -3
  142. package/src/screens/ActivityLog/FilterPopup.js +2 -2
  143. package/src/screens/ActivityLog/__test__/FilterPopup.test.js +2 -2
  144. package/src/screens/ActivityLog/__test__/index.test.js +3 -2
  145. package/src/screens/ActivityLog/index.js +3 -3
  146. package/src/screens/AddCommon/SelectSubUnit.js +44 -191
  147. package/src/screens/AddCommon/SelectUnit.js +51 -204
  148. package/src/screens/AddCommon/__test__/SelectSubUnit.test.js +7 -50
  149. package/src/screens/AddCommon/__test__/SelectUnit.test.js +28 -26
  150. package/src/screens/AddLocationMaps/__test__/index.test.js +13 -7
  151. package/src/screens/AddLocationMaps/index.js +3 -3
  152. package/src/screens/AddNewAction/Device/index.js +2 -2
  153. package/src/screens/AddNewAction/SelectAction.js +6 -6
  154. package/src/screens/AddNewAction/SelectSensorDevices.js +3 -3
  155. package/src/screens/AddNewAction/__test__/SelectAction.test.js +2 -2
  156. package/src/screens/AddNewAction/__test__/SelectSensorDevices.test.js +8 -3
  157. package/src/screens/AddNewAutoSmart/__test__/AddNewAutoSmart.test.js +11 -7
  158. package/src/screens/AddNewAutoSmart/index.js +9 -12
  159. package/src/screens/AddNewDevice/ConnectingDevices.js +1 -1
  160. package/src/screens/AddNewDevice/__test__/AddNewDevice.test.js +7 -4
  161. package/src/screens/AddNewDevice/index.js +4 -4
  162. package/src/screens/AddNewGateway/ConnectingDevice.js +40 -0
  163. package/src/screens/AddNewGateway/ConnectingModbusDevice.js +61 -0
  164. package/src/screens/AddNewGateway/ConnectingWifiDevice.js +70 -0
  165. package/src/screens/AddNewGateway/ConnectingZigbeeDevice.js +60 -0
  166. package/src/screens/AddNewGateway/PlugAndPlay/FirstWarning.js +21 -8
  167. package/src/screens/AddNewGateway/PlugAndPlay/__test__/FirstWarning.test.js +23 -4
  168. package/src/screens/AddNewGateway/RenameNewDevices.js +141 -0
  169. package/src/screens/AddNewGateway/RenameNewDevicesStyles.js +75 -0
  170. package/src/screens/AddNewGateway/ScanGatewayQR.js +57 -0
  171. package/src/screens/AddNewGateway/ScanModbusQR.js +53 -0
  172. package/src/screens/AddNewGateway/ScanWifiDeviceQR.js +55 -0
  173. package/src/screens/AddNewGateway/SelectDeviceSubUnit.js +31 -0
  174. package/src/screens/AddNewGateway/SelectDeviceType.js +52 -0
  175. package/src/screens/AddNewGateway/SelectDeviceUnit.js +29 -0
  176. package/src/screens/AddNewGateway/SelectModbusGateway.js +34 -0
  177. package/src/screens/AddNewGateway/SelectZigbeeGateway.js +34 -0
  178. package/src/screens/AddNewGateway/ShareWifiPassword.js +302 -0
  179. package/src/screens/AddNewGateway/ShareWifiPasswordStyles.js +44 -0
  180. package/src/screens/AddNewGateway/__test__/AddNewGateway.test.js +7 -4
  181. package/src/screens/AddNewGateway/__test__/ConnectingModbusDevice.test.js +63 -0
  182. package/src/screens/AddNewGateway/__test__/{SelectGateway.test.js → ConnectingWifiDevice.test.js} +15 -10
  183. package/src/screens/AddNewGateway/__test__/ConnectingZigbeeDevice.test.js +62 -0
  184. package/src/screens/AddNewGateway/__test__/RenameNewDevices.test.js +191 -0
  185. package/src/screens/AddNewGateway/__test__/ScanGatewayQR.test.js +73 -0
  186. package/src/screens/AddNewGateway/__test__/ScanModbusQR.test.js +75 -0
  187. package/src/screens/AddNewGateway/__test__/ScanWifiDeviceQR.test.js +73 -0
  188. package/src/screens/AddNewGateway/__test__/SelectDeviceSubUnit.test.js +47 -0
  189. package/src/screens/AddNewGateway/__test__/SelectDeviceType.test.js +89 -0
  190. package/src/screens/AddNewGateway/__test__/SelectDeviceUnit.test.js +48 -0
  191. package/src/screens/AddNewGateway/__test__/SelectModbusGateway.test.js +77 -0
  192. package/src/screens/AddNewGateway/__test__/SelectZigbeeGateway.test.js +77 -0
  193. package/src/screens/AddNewGateway/__test__/ShareWifiPassword.test.js +294 -0
  194. package/src/screens/AddNewGateway/hooks/__Tests__/index.test.js +1 -1
  195. package/src/screens/AddNewGateway/index.js +4 -4
  196. package/src/screens/AddNewOneTap/__test__/AddNewOneTap.test.js +5 -4
  197. package/src/screens/AddNewOneTap/index.js +4 -4
  198. package/src/screens/Automate/__test__/index.test.js +2 -2
  199. package/src/screens/Automate/index.js +6 -2
  200. package/src/screens/ConfirmUnitDeletion/__test__/ConfirmUnitDeletion.test.js +3 -2
  201. package/src/screens/ConfirmUnitDeletion/index.js +3 -3
  202. package/src/screens/Device/EditDevice/__test__/EditDevice.test.js +5 -5
  203. package/src/screens/Device/EditDevice/index.js +3 -3
  204. package/src/screens/Device/__test__/detail.test.js +38 -22
  205. package/src/screens/Device/components/SensorConnectStatusViewHeader.js +6 -6
  206. package/src/screens/Device/components/SensorDisplayItem.js +2 -2
  207. package/src/screens/Device/detail.js +28 -22
  208. package/src/screens/Device/hooks/useEvaluateValue.js +0 -2
  209. package/src/screens/DeviceInfo/__test__/index.test.js +8 -4
  210. package/src/screens/DeviceInfo/index.js +10 -6
  211. package/src/screens/Drawer/index.js +21 -9
  212. package/src/screens/EmergencyContacts/EmergencyContactsAddNew.js +8 -4
  213. package/src/screens/EmergencyContacts/EmergencyContactsList.js +1 -1
  214. package/src/screens/EmergencyContacts/EmergencyContactsSelectContacts.js +5 -3
  215. package/src/screens/EmergencyContacts/__test__/EmergencyContactAddNew.test.js +9 -5
  216. package/src/screens/EmergencyContacts/__test__/EmergencyContactList.test.js +7 -3
  217. package/src/screens/EmergencyContacts/__test__/EmergencyContactsSelectContacts.test.js +7 -3
  218. package/src/screens/EmergencySetting/__test__/DropDownItem.test.js +3 -2
  219. package/src/screens/EmergencySetting/components/DropDownItem.js +2 -2
  220. package/src/screens/EnterPassword/__test__/EnterPassword.test.js +6 -3
  221. package/src/screens/EnterPassword/index.js +5 -3
  222. package/src/screens/GuestInfo/__test__/index.test.js +18 -12
  223. package/src/screens/GuestInfo/components/AccessScheduleItem.js +2 -2
  224. package/src/screens/GuestInfo/components/AccessScheduleSheet.js +3 -3
  225. package/src/screens/GuestInfo/components/HeaderGuestInfo.js +2 -2
  226. package/src/screens/GuestInfo/components/RecurringDetail.js +4 -4
  227. package/src/screens/GuestInfo/components/TemporaryDetail.js +3 -3
  228. package/src/screens/GuestInfo/index.js +1 -1
  229. package/src/screens/HanetCamera/Detail.js +10 -4
  230. package/src/screens/HanetCamera/ManageAccess.js +4 -4
  231. package/src/screens/HanetCamera/MemberInfo.js +1 -1
  232. package/src/screens/HanetCamera/__test__/Detail.test.js +5 -3
  233. package/src/screens/HanetCamera/__test__/ManageAccess.test.js +10 -4
  234. package/src/screens/HanetCamera/__test__/MemberInfo.test.js +4 -2
  235. package/src/screens/HanetCamera/components/RequestFaceIDPopup.js +2 -2
  236. package/src/screens/ManageAccess/index.js +1 -1
  237. package/src/screens/MoveToAnotherSubUnit/__test__/index.test.js +4 -4
  238. package/src/screens/MoveToAnotherSubUnit/index.js +2 -2
  239. package/src/screens/PlayBackCamera/__test__/index.test.js +9 -6
  240. package/src/screens/PlayBackCamera/index.js +6 -6
  241. package/src/screens/ScanChipQR/components/QRScan/__test__/QRScan.test.js +1 -1
  242. package/src/screens/ScanChipQR/components/QRScan/index.js +10 -3
  243. package/src/screens/ScriptDetail/__test__/index.test.js +8 -4
  244. package/src/screens/ScriptDetail/index.js +7 -6
  245. package/src/screens/SelectUnit/__test__/index.test.js +4 -3
  246. package/src/screens/SelectUnit/index.js +3 -3
  247. package/src/screens/SetSchedule/index.js +1 -1
  248. package/src/screens/Sharing/Components/SensorItem.js +2 -2
  249. package/src/screens/Sharing/Components/__test__/SensorItem.test.js +4 -2
  250. package/src/screens/Sharing/InfoMemberUnit.js +7 -6
  251. package/src/screens/Sharing/MemberList.js +4 -4
  252. package/src/screens/Sharing/SelectPermission.js +9 -4
  253. package/src/screens/Sharing/SelectUser.js +9 -5
  254. package/src/screens/Sharing/__test__/InfoMemberUnit.test.js +3 -2
  255. package/src/screens/Sharing/__test__/SelectUser.test.js +7 -4
  256. package/src/screens/SideMenuDetail/__test__/index.test.js +11 -7
  257. package/src/screens/SideMenuDetail/index.js +2 -2
  258. package/src/screens/SmartIr/__test__/GroupButtonByType.test.js +4 -2
  259. package/src/screens/SmartIr/__test__/SelectDeviceType.test.js +5 -5
  260. package/src/screens/SmartIr/__test__/SmartIr.test.js +14 -6
  261. package/src/screens/SmartIr/components/GroupButtonByType/GroupButtonByType.js +4 -2
  262. package/src/screens/SmartIr/components/{SelectDeviceType.js → SelectIrDeviceType.js} +2 -2
  263. package/src/screens/SmartIr/index.js +1 -1
  264. package/src/screens/SubUnit/AddSubUnit.js +7 -3
  265. package/src/screens/SubUnit/Detail.js +6 -6
  266. package/src/screens/SubUnit/EditSubUnit.js +10 -6
  267. package/src/screens/SubUnit/ManageSubUnit.js +2 -2
  268. package/src/screens/SubUnit/__test__/AddSubUnit.test.js +6 -3
  269. package/src/screens/SubUnit/__test__/Detail.test.js +5 -3
  270. package/src/screens/SubUnit/__test__/EditSubUnit.test.js +9 -5
  271. package/src/screens/SubUnit/__test__/ManageSubUnit.test.js +3 -2
  272. package/src/screens/SyncLGDevice/AddLGDevice.js +4 -4
  273. package/src/screens/SyncLGDevice/__test__/AddLGDevice.test.js +7 -4
  274. package/src/screens/TDSGuide/__test__/TDSGuide.test.js +4 -2
  275. package/src/screens/TDSGuide/index.js +2 -2
  276. package/src/screens/Template/EditTemplate.js +2 -1
  277. package/src/screens/Template/__test__/detail.test.js +9 -1
  278. package/src/screens/Template/index.js +0 -1
  279. package/src/screens/UVIndexGuide/__test__/UVIndexGuide.test.js +3 -2
  280. package/src/screens/UVIndexGuide/index.js +2 -2
  281. package/src/screens/Unit/AddMenu.js +6 -20
  282. package/src/screens/Unit/ChooseLocation.js +1 -1
  283. package/src/screens/Unit/Detail.js +10 -10
  284. package/src/screens/Unit/ManageUnit.js +21 -15
  285. package/src/screens/Unit/MyAllUnit/index.js +1 -1
  286. package/src/screens/Unit/SelectAddToFavorites.js +7 -8
  287. package/src/screens/Unit/SelectAddress.js +4 -4
  288. package/src/screens/Unit/SmartAccountItem.js +3 -3
  289. package/src/screens/Unit/Station/__test__/index.test.js +1 -1
  290. package/src/screens/Unit/Station/index.js +2 -2
  291. package/src/screens/Unit/Summaries.js +2 -2
  292. package/src/screens/Unit/__test__/CheckSendEmail.test.js +6 -6
  293. package/src/screens/Unit/__test__/Detail.test.js +17 -12
  294. package/src/screens/Unit/__test__/ManageUnit.test.js +40 -18
  295. package/src/screens/Unit/__test__/SelectAddress.test.js +15 -8
  296. package/src/screens/Unit/__test__/SmartAccountItem.test.js +4 -3
  297. package/src/screens/Unit/components/AutomateScript/index.js +5 -2
  298. package/src/screens/Unit/components/ListMyAllUnit/index.js +1 -1
  299. package/src/screens/Unit/components/MyAllUnit/__test__/Header.test.js +9 -5
  300. package/src/screens/Unit/components/MyAllUnit/index.js +1 -1
  301. package/src/screens/Unit/components/MyUnitDevice/index.js +8 -5
  302. package/src/screens/Unit/components/SharedUnit/index.js +12 -6
  303. package/src/screens/Unit/components/__test__/MyUnitDevice.test.js +2 -2
  304. package/src/screens/Unit/components/__test__/SharedUnit.test.js +24 -9
  305. package/src/screens/Unit/hook/useUnitConnectRemoteDevices.js +25 -11
  306. package/src/screens/UnitSummary/__test__/index.test.js +4 -2
  307. package/src/screens/UnitSummary/components/3PPowerConsumption/__test__/3PPowerConsumption.test.js +4 -2
  308. package/src/screens/UnitSummary/components/3PPowerConsumption/index.js +2 -2
  309. package/src/screens/UnitSummary/components/PowerConsumption/__test__/PowerConsumption.test.js +4 -2
  310. package/src/screens/UnitSummary/components/PowerConsumption/index.js +2 -2
  311. package/src/screens/UnitSummary/components/RunningDevices/__test__/index.test.js +5 -4
  312. package/src/screens/UnitSummary/components/RunningDevices/index.js +6 -3
  313. package/src/screens/UnitSummary/components/TotalPowerBox/index.js +2 -2
  314. package/src/screens/UnitSummary/components/TotalPowerConsumption/index.js +2 -2
  315. package/src/screens/UnitSummary/components/__test__/TotalPowerBox.test.js +3 -2
  316. package/src/screens/UnitSummary/components/__test__/TotalPowerConsumption.test.js +4 -2
  317. package/src/screens/UnitSummary/index.js +10 -8
  318. package/src/screens/WaterQualityGuide/__test__/index.test.js +17 -12
  319. package/src/screens/WaterQualityGuide/index.js +26 -10
  320. package/src/utils/Apis/axios.js +1 -0
  321. package/src/utils/I18n/translations/en.json +9 -9
  322. package/src/utils/I18n/translations/vi.json +8 -8
  323. package/src/utils/Route/index.js +16 -10
  324. package/src/commons/Connecting/index.js +0 -67
  325. package/src/commons/ConnectingProcess/DeviceItem/DeviceItem.js +0 -28
  326. package/src/commons/ConnectingProcess/DeviceItem/DeviceItemStyles.js +0 -41
  327. package/src/commons/ConnectingProcess/__test__/Connecting.test.js +0 -163
  328. package/src/commons/ConnectingProcess/__test__/DeviceItem.test.js +0 -19
  329. package/src/commons/ConnectingProcess/index.js +0 -213
  330. package/src/commons/ConnectingProcess/styles.js +0 -69
  331. package/src/hooks/IoT/useGGHomeConnection.js +0 -91
  332. package/src/iot/RemoteControl/index.js +0 -55
  333. package/src/screens/AddNewDevice/ConnectDevices.js +0 -184
  334. package/src/screens/AddNewDevice/__test__/ConnectDevices.test.js +0 -131
  335. package/src/screens/AddNewGateway/ConnectedGateway.js +0 -139
  336. package/src/screens/AddNewGateway/ConnectingGateway.js +0 -137
  337. package/src/screens/AddNewGateway/PlugAndPlay/ConnectWifiWarning.js +0 -214
  338. package/src/screens/AddNewGateway/PlugAndPlay/GatewayWifiList.js +0 -319
  339. package/src/screens/AddNewGateway/PlugAndPlay/__test__/ConnectWifiWarning.test.js +0 -75
  340. package/src/screens/AddNewGateway/PlugAndPlay/__test__/GatewayWifiList.test.js +0 -130
  341. package/src/screens/AddNewGateway/SelectGateway.js +0 -133
  342. package/src/screens/AddNewGateway/SetupGatewayWifi.js +0 -207
  343. package/src/screens/AddNewGateway/__test__/ConnectedGateway.test.js +0 -71
  344. package/src/screens/AddNewGateway/__test__/ConnectingGateway.test.js +0 -96
  345. package/src/screens/AddNewGateway/__test__/SetupGateway.test.js +0 -120
  346. package/src/screens/ScanChipQR/__test__/ScanChipQR.test.js +0 -115
  347. package/src/screens/ScanChipQR/hooks/index.js +0 -120
  348. package/src/screens/ScanChipQR/index.js +0 -29
  349. package/src/screens/ScanSensorQR/__test__/ScanSensorQR.test.js +0 -111
  350. package/src/screens/ScanSensorQR/hooks/index.js +0 -40
  351. package/src/screens/ScanSensorQR/index.js +0 -39
@@ -5,8 +5,8 @@ import { useTranslations } from '../../hooks/Common/useTranslations';
5
5
  import { useDevicesStatus } from '../../hooks/Common';
6
6
  import { useWatchConfigs } from '../../hooks/IoT';
7
7
 
8
- import { Images, Device } from '../../configs';
9
- import { DEVICE_TYPE, TESTID } from '../../configs/Constants';
8
+ import { Device, Images } from '../../configs';
9
+ import { AccessibilityLabel, DEVICE_TYPE } from '../../configs/Constants';
10
10
  import { Section } from '../Section';
11
11
  import Text from '../Text';
12
12
  import ItemDevice from '../Device/ItemDevice';
@@ -16,12 +16,6 @@ import { standardizeCameraScreenSize } from '../../utils/Utils';
16
16
  import Routes from '../../utils/Route';
17
17
  import FastImage from 'react-native-fast-image';
18
18
  import MediaPlayerDetail from '../MediaPlayerDetail';
19
- import {
20
- keyPermission,
21
- OpenSetting,
22
- permitPermissionFunction,
23
- } from '../../utils/Permission/common';
24
- import { RESULTS } from 'react-native-permissions';
25
19
 
26
20
  const { standardizeWidth, standardizeHeight } = standardizeCameraScreenSize(
27
21
  Device.screenWidth - 32
@@ -70,8 +64,7 @@ const ShortDetailSubUnit = ({ unit, station }) => {
70
64
  height: standardizeHeight,
71
65
  },
72
66
  ]}
73
- testID={TESTID.SUB_UNIT_CAMERA_VIEW}
74
- accessibilityLabel={`${TESTID.SUB_UNIT_CAMERA_VIEW}-${station?.id}`}
67
+ accessibilityLabel={`${AccessibilityLabel.SUB_UNIT_CAMERA_VIEW}-${station?.id}`}
75
68
  >
76
69
  <MediaPlayerDetail
77
70
  uri={station.camera.uri}
@@ -97,7 +90,7 @@ const ShortDetailSubUnit = ({ unit, station }) => {
97
90
  style={styles.image}
98
91
  defaultSource={Images.BgDevice}
99
92
  resizeMode="cover"
100
- testID={TESTID.SUB_UNIT_BACKGROUND}
93
+ accessibilityLabel={AccessibilityLabel.SUB_UNIT_BACKGROUND}
101
94
  />
102
95
  </View>
103
96
  );
@@ -106,24 +99,13 @@ const ShortDetailSubUnit = ({ unit, station }) => {
106
99
  };
107
100
 
108
101
  const handleOnAddNew = () => {
109
- permitPermissionFunction(keyPermission.CAMERA, (res) => {
110
- if (res === RESULTS.GRANTED) {
111
- navigate(Routes.AddDeviceStack, {
112
- screen: Routes.ScanSensorQR,
113
- params: {
114
- station_id: station?.id,
115
- unit_id: unit.id,
116
- unit_name: unit.name,
117
- },
118
- });
119
- return;
120
- }
121
- if (res === RESULTS.BLOCKED) {
122
- OpenSetting(
123
- t('camera_request_permission'),
124
- t('camera_request_permission_des')
125
- );
126
- }
102
+ navigate(Routes.AddGatewayStack, {
103
+ screen: Routes.FirstWarning,
104
+ params: {
105
+ stationId: station?.id,
106
+ unitId: unit.id,
107
+ unitName: unit.name,
108
+ },
127
109
  });
128
110
  };
129
111
 
@@ -2,7 +2,7 @@ import React from 'react';
2
2
  import { Image, View } from 'react-native';
3
3
  import { act, create } from 'react-test-renderer';
4
4
  import mock from 'react-native-permissions/mock';
5
- import { TESTID } from '../../../configs/Constants';
5
+ import { AccessibilityLabel } from '../../../configs/Constants';
6
6
  import { SCProvider } from '../../../context';
7
7
  import { mockSCStore } from '../../../context/mockStore';
8
8
  import ShortDetailSubUnit from '../ShortDetail';
@@ -84,7 +84,8 @@ describe('test ShortDetail Subunit', () => {
84
84
  const instance = tree.root;
85
85
  const image = instance.findAllByType(Image);
86
86
  const imageBackground = image.find(
87
- (item) => item.props.testID === TESTID.SUB_UNIT_BACKGROUND
87
+ (item) =>
88
+ item.props.accessibilityLabel === AccessibilityLabel.SUB_UNIT_BACKGROUND
88
89
  );
89
90
  expect(imageBackground).not.toBeDefined();
90
91
  });
@@ -97,7 +98,8 @@ describe('test ShortDetail Subunit', () => {
97
98
  const instance = tree.root;
98
99
  const image = instance.findAllByType(Image);
99
100
  const imageBackground = image.find(
100
- (item) => item.props.testID === TESTID.SUB_UNIT_BACKGROUND
101
+ (item) =>
102
+ item.props.accessibilityLabel === AccessibilityLabel.SUB_UNIT_BACKGROUND
101
103
  );
102
104
  expect(imageBackground).not.toBeDefined();
103
105
  });
@@ -116,7 +118,9 @@ describe('test ShortDetail Subunit', () => {
116
118
  const instance = tree.root;
117
119
  const view = instance.findAllByType(View);
118
120
  const viewCamera = view.find(
119
- (item) => item.props.testID === TESTID.SUB_UNIT_CAMERA_VIEW
121
+ (item) =>
122
+ item.props.accessibilityLabel ===
123
+ `${AccessibilityLabel.SUB_UNIT_CAMERA_VIEW}-${props.station.id}`
120
124
  );
121
125
  expect(viewCamera).toBeDefined();
122
126
  });
@@ -150,7 +154,8 @@ describe('test ShortDetail Subunit', () => {
150
154
  const instance = tree.root;
151
155
  const itemDevice = instance.findAll(
152
156
  (item) =>
153
- item.props.testID === TESTID.SUB_UNIT_DEVICES && item.type === View
157
+ item.props.accessibilityLabel === AccessibilityLabel.SUB_UNIT_DEVICES &&
158
+ item.type === View
154
159
  );
155
160
  expect(itemDevice.length).toBe(0);
156
161
  });
@@ -165,12 +170,12 @@ describe('test ShortDetail Subunit', () => {
165
170
  buttonAddNew.props.onAddNew();
166
171
  });
167
172
  await mock.request(keyPermission.CAMERA);
168
- expect(mockedNavigate).toHaveBeenCalledWith(Routes.AddDeviceStack, {
169
- screen: Routes.ScanSensorQR,
173
+ expect(mockedNavigate).toHaveBeenCalledWith(Routes.AddGatewayStack, {
174
+ screen: Routes.FirstWarning,
170
175
  params: {
171
- station_id: props.station.id,
172
- unit_id: props.unit.id,
173
- unit_name: props.unit.name,
176
+ stationId: props.station.id,
177
+ unitId: props.unit.id,
178
+ unitName: props.unit.name,
174
179
  },
175
180
  });
176
181
  });
@@ -9,7 +9,7 @@ import Temperature from '../../../assets/images/Temperature.svg';
9
9
  import UVIndex from '../../../assets/images/UVIndex.svg';
10
10
  import WaterQuality from '../../../assets/images/WaterQuality.svg';
11
11
  import Device from '../../../assets/images/Device.svg';
12
- import { TESTID } from '../../configs/Constants';
12
+ import { AccessibilityLabel } from '../../configs/Constants';
13
13
 
14
14
  const SummaryItem = memo(({ item, goToSummary }) => {
15
15
  const Icon = (() => {
@@ -34,7 +34,7 @@ const SummaryItem = memo(({ item, goToSummary }) => {
34
34
  <TouchableOpacity
35
35
  onPress={() => goToSummary(item)}
36
36
  style={styles.wrapSummaryItem}
37
- accessibilityLabel={`${TESTID.UNIT_DETAIL_UNIT_SUMMARY_ITEM}-${item?.id}`}
37
+ accessibilityLabel={`${AccessibilityLabel.UNIT_DETAIL_UNIT_SUMMARY_ITEM}-${item?.id}`}
38
38
  >
39
39
  <View style={styles.summaryItem}>
40
40
  <Icon />
@@ -6,7 +6,7 @@ import { getStatusBarHeight } from 'react-native-iphone-x-helper';
6
6
 
7
7
  import { Colors, Device } from '../../../configs';
8
8
  import Text from '../../Text';
9
- import { TESTID } from '../../../configs/Constants';
9
+ import { AccessibilityLabel } from '../../../configs/Constants';
10
10
 
11
11
  const HeaderUnit = memo(
12
12
  ({
@@ -19,7 +19,7 @@ const HeaderUnit = memo(
19
19
  hideRightPlus,
20
20
  styleBoxTitle,
21
21
  bottomBorder,
22
- idButtonMore,
22
+ idButtonMore = AccessibilityLabel.HEADER_UNIT_BUTTON_MORE,
23
23
  }) => {
24
24
  const { goBack } = useNavigation();
25
25
  const buttonMoreRef = useRef(null);
@@ -43,7 +43,7 @@ const HeaderUnit = memo(
43
43
  return (
44
44
  <View style={[styles.container, bottomBorder && styles.bottomBorder]}>
45
45
  <TouchableOpacity
46
- testID={TESTID.HEADER_UNIT_BUTTON_BACK}
46
+ accessibilityLabel={AccessibilityLabel.HEADER_UNIT_BUTTON_BACK}
47
47
  style={styles.btnLeft}
48
48
  onPress={onPressBack}
49
49
  >
@@ -65,7 +65,7 @@ const HeaderUnit = memo(
65
65
  <View style={styles.boxRight}>
66
66
  {!hideRightPlus && (
67
67
  <TouchableOpacity
68
- testID={TESTID.HEADER_UNIT_BUTTON_ADD}
68
+ accessibilityLabel={AccessibilityLabel.HEADER_UNIT_BUTTON_ADD}
69
69
  style={styles.btnAdd}
70
70
  onPress={onPressAdd}
71
71
  >
@@ -77,7 +77,6 @@ const HeaderUnit = memo(
77
77
  </TouchableOpacity>
78
78
  )}
79
79
  <TouchableOpacity
80
- testID={TESTID.HEADER_UNIT_BUTTON_MORE}
81
80
  style={styles.btnMore}
82
81
  onPress={onPressMore}
83
82
  ref={buttonMoreRef}
@@ -9,7 +9,7 @@ import Routes from '../../utils/Route';
9
9
  import { axiosPost } from '../../utils/Apis/axios';
10
10
 
11
11
  import styles from './styles';
12
- import { TESTID } from '../../configs/Constants';
12
+ import { AccessibilityLabel } from '../../configs/Constants';
13
13
 
14
14
  const SharedUnit = ({
15
15
  item,
@@ -67,8 +67,7 @@ const SharedUnit = ({
67
67
  style={styles.row}
68
68
  key={item.id.toString()}
69
69
  onPress={goToDetail}
70
- testID={`${TESTID.TOUCH_SHARED_UNIT}-${item.id}`}
71
- accessibilityLabel={`${TESTID.TOUCH_SHARED_UNIT}-${item.id}`}
70
+ accessibilityLabel={`${AccessibilityLabel.TOUCH_SHARED_UNIT}-${item.id}`}
72
71
  >
73
72
  <Image
74
73
  source={{ uri: unit.icon }}
@@ -78,7 +77,10 @@ const SharedUnit = ({
78
77
  <View style={styles.ownerContainer}>
79
78
  <Text style={styles.name}>{unit.name}</Text>
80
79
  {unit.owner_name ? (
81
- <Text style={styles.textBy} testID={TESTID.SHARED_UNIT_OWN_BY}>
80
+ <Text
81
+ style={styles.textBy}
82
+ accessibilityLabel={AccessibilityLabel.SHARED_UNIT_OWN_BY}
83
+ >
82
84
  {t('text_by')}
83
85
  <Text style={styles.textOwner}>{unit.owner_name}</Text>
84
86
  </Text>
@@ -94,14 +96,14 @@ const SharedUnit = ({
94
96
  size={20}
95
97
  color={Colors.Blue10}
96
98
  onPress={removePinSharedUnit}
97
- testID={`${TESTID.ICON_REMOVE_PIN_SHARED_UNIT}-${item.id}`}
99
+ accessibilityLabel={`${AccessibilityLabel.ICON_REMOVE_PIN_SHARED_UNIT}-${item.id}`}
98
100
  />
99
101
  ) : (
100
102
  <IconOutline
101
103
  name="pushpin"
102
104
  size={20}
103
105
  onPress={addPinSharedUnit}
104
- testID={`${TESTID.ICON_ADD_PIN_SHARED_UNIT}-${item.id}`}
106
+ accessibilityLabel={`${AccessibilityLabel.ICON_ADD_PIN_SHARED_UNIT}-${item.id}`}
105
107
  />
106
108
  )}
107
109
  {item.is_star ? (
@@ -110,14 +112,14 @@ const SharedUnit = ({
110
112
  size={20}
111
113
  color={Colors.Yellow6}
112
114
  onPress={removeStarSharedUnit}
113
- testID={`${TESTID.ICON_REMOVE_STAR_SHARED_UNIT}-${item.id}`}
115
+ accessibilityLabel={`${AccessibilityLabel.ICON_REMOVE_STAR_SHARED_UNIT}-${item.id}`}
114
116
  />
115
117
  ) : (
116
118
  <IconOutline
117
119
  name="star"
118
120
  size={20}
119
121
  onPress={addStarSharedUnit}
120
- testID={`${TESTID.ICON_ADD_STAR_SHARED_UNIT}-${item.id}`}
122
+ accessibilityLabel={`${AccessibilityLabel.ICON_ADD_STAR_SHARED_UNIT}-${item.id}`}
121
123
  />
122
124
  )}
123
125
  </Fragment>
@@ -1,6 +1,6 @@
1
1
  import React from 'react';
2
2
  import { act, create } from 'react-test-renderer';
3
- import { TESTID } from '../../../configs/Constants';
3
+ import { AccessibilityLabel } from '../../../configs/Constants';
4
4
  import HeaderUnit from '../HeaderUnit/index';
5
5
 
6
6
  const mockedGoBack = jest.fn();
@@ -46,7 +46,9 @@ describe('Test HeaderUnit', () => {
46
46
  });
47
47
  const instance = tree.root;
48
48
  const item = instance.find(
49
- (el) => el.props.testID === TESTID.HEADER_UNIT_BUTTON_BACK
49
+ (el) =>
50
+ el.props.accessibilityLabel ===
51
+ AccessibilityLabel.HEADER_UNIT_BUTTON_BACK
50
52
  );
51
53
  expect(item.props.style).toEqual(style);
52
54
  await act(async () => {
@@ -68,7 +70,9 @@ describe('Test HeaderUnit', () => {
68
70
  });
69
71
  const instance = tree.root;
70
72
  const item = instance.find(
71
- (el) => el.props.testID === TESTID.HEADER_UNIT_BUTTON_BACK
73
+ (el) =>
74
+ el.props.accessibilityLabel ===
75
+ AccessibilityLabel.HEADER_UNIT_BUTTON_BACK
72
76
  );
73
77
  await act(async () => {
74
78
  item.props.onPress();
@@ -91,10 +95,14 @@ describe('Test HeaderUnit', () => {
91
95
  });
92
96
  const instance = tree.root;
93
97
  const buttonAdd = instance.find(
94
- (el) => el.props.testID === TESTID.HEADER_UNIT_BUTTON_ADD
98
+ (el) =>
99
+ el.props.accessibilityLabel ===
100
+ AccessibilityLabel.HEADER_UNIT_BUTTON_ADD
95
101
  );
96
102
  const buttonMore = instance.find(
97
- (el) => el.props.testID === TESTID.HEADER_UNIT_BUTTON_MORE
103
+ (el) =>
104
+ el.props.accessibilityLabel ===
105
+ AccessibilityLabel.HEADER_UNIT_BUTTON_MORE
98
106
  );
99
107
  await act(async () => {
100
108
  buttonAdd.props.onPress();
@@ -5,7 +5,7 @@ import { useNavigation } from '@react-navigation/native';
5
5
  import MockAdapter from 'axios-mock-adapter';
6
6
 
7
7
  import SharedUnit from '../SharedUnit';
8
- import { TESTID } from '../../../configs/Constants';
8
+ import { AccessibilityLabel } from '../../../configs/Constants';
9
9
  import { API } from '../../../configs';
10
10
  import Routes from '../../../utils/Route';
11
11
  import { SCProvider } from '../../../context';
@@ -72,16 +72,22 @@ describe('Test SharedUnit', () => {
72
72
  });
73
73
  const instance = tree.root;
74
74
  const touchSharedUnit = instance.find(
75
- (el) => el.props.testID === TESTID.TOUCH_SHARED_UNIT + '-69'
75
+ (el) =>
76
+ el.props.accessibilityLabel ===
77
+ AccessibilityLabel.TOUCH_SHARED_UNIT + '-69'
76
78
  );
77
79
  act(() => {
78
80
  touchSharedUnit.props.onPress();
79
81
  });
80
82
  const iconRemovePinSharedUnit = instance.findAll(
81
- (el) => el.props.testID === TESTID.ICON_REMOVE_PIN_SHARED_UNIT + '-69'
83
+ (el) =>
84
+ el.props.accessibilityLabel ===
85
+ AccessibilityLabel.ICON_REMOVE_PIN_SHARED_UNIT + '-69'
82
86
  );
83
87
  const iconAddPinSharedUnit = instance.find(
84
- (el) => el.props.testID === TESTID.ICON_ADD_PIN_SHARED_UNIT + '-69'
88
+ (el) =>
89
+ el.props.accessibilityLabel ===
90
+ AccessibilityLabel.ICON_ADD_PIN_SHARED_UNIT + '-69'
85
91
  );
86
92
  mock.onPost(API.UNIT.PIN_UNIT(3)).reply(200);
87
93
  act(() => {
@@ -92,7 +98,9 @@ describe('Test SharedUnit', () => {
92
98
  iconAddPinSharedUnit.props.onPress();
93
99
  });
94
100
  const iconAddStarSharedUnit = instance.find(
95
- (el) => el.props.testID === TESTID.ICON_ADD_STAR_SHARED_UNIT + '-69'
101
+ (el) =>
102
+ el.props.accessibilityLabel ===
103
+ AccessibilityLabel.ICON_ADD_STAR_SHARED_UNIT + '-69'
96
104
  );
97
105
  mock.onPost(API.UNIT.STAR_UNIT(3)).reply(200);
98
106
  act(() => {
@@ -121,7 +129,8 @@ describe('Test SharedUnit', () => {
121
129
  });
122
130
  const instance = tree.root;
123
131
  const ownerName = instance.findAll(
124
- (el) => el.props.testID === TESTID.SHARED_UNIT_OWN_BY
132
+ (el) =>
133
+ el.props.accessibilityLabel === AccessibilityLabel.SHARED_UNIT_OWN_BY
125
134
  );
126
135
 
127
136
  expect(ownerName).toHaveLength(0);
@@ -136,10 +145,14 @@ describe('Test SharedUnit', () => {
136
145
  const instance = tree.root;
137
146
 
138
147
  const iconAddPinSharedUnit = instance.findAll(
139
- (el) => el.props.testID === TESTID.ICON_ADD_PIN_SHARED_UNIT + '-69'
148
+ (el) =>
149
+ el.props.accessibilityLabel ===
150
+ AccessibilityLabel.ICON_ADD_PIN_SHARED_UNIT + '-69'
140
151
  );
141
152
  const iconStarUnit = instance.findAll(
142
- (el) => el.props.testID === TESTID.ICON_ADD_STAR_SHARED_UNIT + '-69'
153
+ (el) =>
154
+ el.props.accessibilityLabel ===
155
+ AccessibilityLabel.ICON_ADD_STAR_SHARED_UNIT + '-69'
143
156
  );
144
157
 
145
158
  expect(iconAddPinSharedUnit).toHaveLength(0);
@@ -156,7 +169,9 @@ describe('Test SharedUnit', () => {
156
169
  });
157
170
  const instance = tree.root;
158
171
  const iconRemovePinSharedUnit = instance.find(
159
- (el) => el.props.testID === TESTID.ICON_REMOVE_PIN_SHARED_UNIT + '-69'
172
+ (el) =>
173
+ el.props.accessibilityLabel ===
174
+ AccessibilityLabel.ICON_REMOVE_PIN_SHARED_UNIT + '-69'
160
175
  );
161
176
  mock.onPost(API.UNIT.UNPIN_UNIT(3)).reply(200);
162
177
  act(() => {
@@ -167,7 +182,9 @@ describe('Test SharedUnit', () => {
167
182
  iconRemovePinSharedUnit.props.onPress();
168
183
  });
169
184
  const iconRemoveStarSharedUnit = instance.find(
170
- (el) => el.props.testID === TESTID.ICON_REMOVE_STAR_SHARED_UNIT + '-69'
185
+ (el) =>
186
+ el.props.accessibilityLabel ===
187
+ AccessibilityLabel.ICON_REMOVE_STAR_SHARED_UNIT + '-69'
171
188
  );
172
189
  mock.onPost(API.UNIT.UNSTAR_UNIT(3)).reply(200);
173
190
  act(() => {
@@ -178,7 +195,9 @@ describe('Test SharedUnit', () => {
178
195
  iconRemoveStarSharedUnit.props.onPress();
179
196
  });
180
197
  const iconRemoveStar = instance.findAll(
181
- (el) => el.props.testID === TESTID.ICON_REMOVE_STAR_SHARED_UNIT + '-69'
198
+ (el) =>
199
+ el.props.accessibilityLabel ===
200
+ AccessibilityLabel.ICON_REMOVE_STAR_SHARED_UNIT + '-69'
182
201
  );
183
202
  expect(iconRemoveStar).toHaveLength(3);
184
203
  });
@@ -4,7 +4,7 @@ import { act, create } from 'react-test-renderer';
4
4
  import AirQuality from '../index';
5
5
  import { Section } from '../../../index';
6
6
  import Text from '../../../Text';
7
- import { TESTID } from '../../../../configs/Constants';
7
+ import { AccessibilityLabel } from '../../../../configs/Constants';
8
8
  import { SCProvider } from '../../../../context';
9
9
  import { mockSCStore } from '../../../../context/mockStore';
10
10
 
@@ -79,7 +79,8 @@ describe('Test AirQuality', () => {
79
79
  const instance = tree.root;
80
80
  const buttons = instance.findAll(
81
81
  (el) =>
82
- el.props.testID === TESTID.AIR_QUALITY_OUTDOOR_VALUE_TOUCH &&
82
+ el.props.accessibilityLabel ===
83
+ AccessibilityLabel.AIR_QUALITY_OUTDOOR_VALUE_TOUCH &&
83
84
  el.type === TouchableOpacity
84
85
  );
85
86
  expect(buttons).toHaveLength(3);
@@ -103,7 +104,8 @@ describe('Test AirQuality', () => {
103
104
  const instance = tree.root;
104
105
  const buttons = instance.findAll(
105
106
  (el) =>
106
- el.props.testID === TESTID.AIR_QUALITY_OUTDOOR_VALUE_TOUCH &&
107
+ el.props.accessibilityLabel ===
108
+ AccessibilityLabel.AIR_QUALITY_OUTDOOR_VALUE_TOUCH &&
107
109
  el.type === TouchableOpacity
108
110
  );
109
111
  expect(buttons).toHaveLength(3);
@@ -127,8 +129,8 @@ describe('Test AirQuality', () => {
127
129
  const instance = tree.root;
128
130
  const text = instance.find(
129
131
  (el) =>
130
- el.props.testID === TESTID.AIR_QUALITY_OUTDOOR_ADVICE_TEXT &&
131
- el.type === Text
132
+ el.props.accessibilityLabel ===
133
+ AccessibilityLabel.AIR_QUALITY_OUTDOOR_ADVICE_TEXT && el.type === Text
132
134
  );
133
135
  expect(text.props.children).toEqual('Amazing Good Chop');
134
136
  });
@@ -141,7 +143,8 @@ describe('Test AirQuality', () => {
141
143
  const instance = tree.root;
142
144
  const buttons = instance.findAll(
143
145
  (el) =>
144
- el.props.testID === TESTID.AIR_QUALITY_OUTDOOR_VALUE_TOUCH &&
146
+ el.props.accessibilityLabel ===
147
+ AccessibilityLabel.AIR_QUALITY_OUTDOOR_VALUE_TOUCH &&
145
148
  el.type === TouchableOpacity
146
149
  );
147
150
  expect(buttons).toHaveLength(2);
@@ -155,7 +158,8 @@ describe('Test AirQuality', () => {
155
158
  const instance = tree.root;
156
159
  const buttons = instance.findAll(
157
160
  (el) =>
158
- el.props.testID === TESTID.AIR_QUALITY_OUTDOOR_VALUE_TOUCH &&
161
+ el.props.accessibilityLabel ===
162
+ AccessibilityLabel.AIR_QUALITY_OUTDOOR_VALUE_TOUCH &&
159
163
  el.type === TouchableOpacity
160
164
  );
161
165
  expect(buttons).toHaveLength(2);
@@ -169,7 +173,8 @@ describe('Test AirQuality', () => {
169
173
  const instance = tree.root;
170
174
  const buttons = instance.findAll(
171
175
  (el) =>
172
- el.props.testID === TESTID.AIR_QUALITY_OUTDOOR_VALUE_TOUCH &&
176
+ el.props.accessibilityLabel ===
177
+ AccessibilityLabel.AIR_QUALITY_OUTDOOR_VALUE_TOUCH &&
173
178
  el.type === TouchableOpacity
174
179
  );
175
180
  expect(buttons).toHaveLength(2);
@@ -9,7 +9,7 @@ import Text from '../../../commons/Text';
9
9
  import ConfigHistoryChart from '../ConfigHistoryChart';
10
10
 
11
11
  import SegmentedRoundDisplay from './SegmentedRoundDisplay';
12
- import { TESTID } from '../../../configs/Constants';
12
+ import { AccessibilityLabel } from '../../../configs/Constants';
13
13
  import styles from './styles';
14
14
 
15
15
  const AirQuality = memo(({ summaryDetail }) => {
@@ -106,7 +106,9 @@ const AirQuality = memo(({ summaryDetail }) => {
106
106
  const borderWidth = active ? 0 : 1;
107
107
  return (
108
108
  <TouchableOpacity
109
- testID={TESTID.AIR_QUALITY_OUTDOOR_VALUE_TOUCH}
109
+ accessibilityLabel={
110
+ AccessibilityLabel.AIR_QUALITY_OUTDOOR_VALUE_TOUCH
111
+ }
110
112
  style={[
111
113
  styles.touchOption,
112
114
  {
@@ -149,7 +151,9 @@ const AirQuality = memo(({ summaryDetail }) => {
149
151
  style={[styles.boxDot, { backgroundColor: outdoorColor }]}
150
152
  />
151
153
  <Text
152
- testID={TESTID.AIR_QUALITY_OUTDOOR_ADVICE_TEXT}
154
+ accessibilityLabel={
155
+ AccessibilityLabel.AIR_QUALITY_OUTDOOR_ADVICE_TEXT
156
+ }
153
157
  color={Colors.Gray7}
154
158
  type="Body"
155
159
  >
@@ -2,7 +2,7 @@ import React, { memo } from 'react';
2
2
  import { View, StyleSheet } from 'react-native';
3
3
 
4
4
  import { Colors } from '../../configs';
5
- import { TESTID } from '../../configs/Constants';
5
+ import { AccessibilityLabel } from '../../configs/Constants';
6
6
  import Text from '../Text';
7
7
 
8
8
  const TotalPowerBox = memo(({ title, value, measure }) => {
@@ -13,7 +13,7 @@ const TotalPowerBox = memo(({ title, value, measure }) => {
13
13
  color={Colors.Gray8}
14
14
  size={14}
15
15
  style={styles.txtTotal}
16
- testID={TESTID.TOTAL_POWER_BOX_TITLE}
16
+ accessibilityLabel={AccessibilityLabel.TOTAL_POWER_BOX_TITLE}
17
17
  >
18
18
  {title}
19
19
  </Text>
@@ -5,7 +5,7 @@ import { useTranslations } from '../../../hooks/Common/useTranslations';
5
5
  import { Colors } from '../../../configs';
6
6
  import TotalPowerBox from '../TotalPowerBox';
7
7
  import Text from '../../Text';
8
- import { TESTID } from '../../../configs/Constants';
8
+ import { AccessibilityLabel } from '../../../configs/Constants';
9
9
 
10
10
  const TotalPowerConsumption = memo(({ time, total }) => {
11
11
  const t = useTranslations();
@@ -21,7 +21,7 @@ const TotalPowerConsumption = memo(({ time, total }) => {
21
21
  title={t('text_total_power_consumption')}
22
22
  value={total.value}
23
23
  measure={total.measure}
24
- testID={TESTID.TOTAL_POWER_CONSUMPTION}
24
+ accessibilityLabel={AccessibilityLabel.TOTAL_POWER_CONSUMPTION}
25
25
  />
26
26
  </View>
27
27
  );
@@ -1,7 +1,7 @@
1
1
  import TotalPowerBox from '../TotalPowerBox';
2
2
  import React from 'react';
3
3
  import renderer, { act } from 'react-test-renderer';
4
- import { TESTID } from '../../../configs/Constants';
4
+ import { AccessibilityLabel } from '../../../configs/Constants';
5
5
 
6
6
  describe('Test Total Power Box', () => {
7
7
  let tree;
@@ -12,7 +12,8 @@ describe('Test Total Power Box', () => {
12
12
  });
13
13
  const instance = tree.root;
14
14
  const item = instance.find(
15
- (el) => el.props.testID === TESTID.TOTAL_POWER_BOX_TITLE
15
+ (el) =>
16
+ el.props.accessibilityLabel === AccessibilityLabel.TOTAL_POWER_BOX_TITLE
16
17
  );
17
18
  expect(item.props.children).toBe('titleTest');
18
19
  });
@@ -1,7 +1,7 @@
1
1
  import TotalPowerConsumption from '../TotalPowerConsumption/index';
2
2
  import React from 'react';
3
3
  import renderer, { act } from 'react-test-renderer';
4
- import { TESTID } from '../../../configs/Constants';
4
+ import { AccessibilityLabel } from '../../../configs/Constants';
5
5
  import { SCProvider } from '../../../context';
6
6
  import { mockSCStore } from '../../../context/mockStore';
7
7
 
@@ -24,7 +24,9 @@ describe('Test Total Power Consumption', () => {
24
24
  });
25
25
  const instance = tree.root;
26
26
  const item = instance.find(
27
- (el) => el.props.testID === TESTID.TOTAL_POWER_CONSUMPTION
27
+ (el) =>
28
+ el.props.accessibilityLabel ===
29
+ AccessibilityLabel.TOTAL_POWER_CONSUMPTION
28
30
  );
29
31
  expect(item.props.value).toBe(10);
30
32
  });
@@ -3,7 +3,7 @@ import { StyleSheet, TouchableOpacity, View } from 'react-native';
3
3
 
4
4
  import { Colors } from '../../configs';
5
5
  import Text from '../../commons/Text';
6
- import { TESTID } from '../../configs/Constants';
6
+ import { AccessibilityLabel } from '../../configs/Constants';
7
7
 
8
8
  // this view support either 1 or 2 button
9
9
  const ViewButtonBottom = ({
@@ -18,7 +18,7 @@ const ViewButtonBottom = ({
18
18
  styleButtonRightText,
19
19
  styleButtonLeft,
20
20
  styleButtonRight,
21
- testIDPrefix = '',
21
+ accessibilityLabelPrefix = '',
22
22
  }) => {
23
23
  const useTwoButton = leftTitle && rightTitle;
24
24
 
@@ -34,7 +34,7 @@ const ViewButtonBottom = ({
34
34
  ]}
35
35
  onPress={onLeftClick}
36
36
  disabled={leftDisabled}
37
- testID={`${testIDPrefix}${TESTID.VIEW_BUTTON_BOTTOM_LEFT_BUTTON}`}
37
+ accessibilityLabel={`${accessibilityLabelPrefix}${AccessibilityLabel.VIEW_BUTTON_BOTTOM_LEFT_BUTTON}`}
38
38
  >
39
39
  <Text
40
40
  semibold
@@ -56,7 +56,7 @@ const ViewButtonBottom = ({
56
56
  ]}
57
57
  onPress={onRightClick}
58
58
  disabled={rightDisabled}
59
- testID={`${testIDPrefix}${TESTID.VIEW_BUTTON_BOTTOM_RIGHT_BUTTON}`}
59
+ accessibilityLabel={`${accessibilityLabelPrefix}${AccessibilityLabel.VIEW_BUTTON_BOTTOM_RIGHT_BUTTON}`}
60
60
  >
61
61
  <Text
62
62
  semibold
@@ -10,7 +10,7 @@ import ViewButtonBottom from '../ViewButtonBottom';
10
10
 
11
11
  import { getDateData } from '../../utils/Converter/time';
12
12
  import styles from './styles';
13
- import { TESTID } from '../../configs/Constants';
13
+ import { AccessibilityLabel } from '../../configs/Constants';
14
14
 
15
15
  const formatNumber = (number) => {
16
16
  return {
@@ -104,7 +104,7 @@ const WheelDateTimePicker = ({
104
104
 
105
105
  return (
106
106
  <BottomSheet
107
- testID={TESTID.WHEEL_DATE_TIME_PICKER}
107
+ accessibilityLabel={AccessibilityLabel.WHEEL_DATE_TIME_PICKER}
108
108
  isVisible={isVisible}
109
109
  onBackdropPress={onPickerCancel}
110
110
  onHide={onHide}
@@ -174,7 +174,9 @@ const WheelDateTimePicker = ({
174
174
  onLeftClick={onPickerCancel}
175
175
  rightTitle={t('done')}
176
176
  onRightClick={onDone}
177
- testIDPrefix={TESTID.WHEEL_DATE_TIME_PICKER_BUTTON}
177
+ accessibilityLabelPrefix={
178
+ AccessibilityLabel.WHEEL_DATE_TIME_PICKER_BUTTON
179
+ }
178
180
  />
179
181
  </BottomSheet>
180
182
  );