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

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 (123) hide show
  1. package/assets/images/Illustrations.svg +83 -0
  2. package/assets/images/{WeatherChange.svg → ValueChange.svg} +0 -0
  3. package/index.js +2 -0
  4. package/package.json +3 -1
  5. package/src/Images/Common/file.png +0 -0
  6. package/src/Images/Common/fullscreen.png +0 -0
  7. package/src/commons/ActionGroup/OnOffTemplate/index.js +5 -0
  8. package/src/commons/ActionGroup/__test__/NumberUpDownTemplate.test.js +294 -0
  9. package/src/commons/ActionGroup/__test__/NumberUpDownTemplateWithNullConfigValue.test.js +60 -0
  10. package/src/commons/AlertAction/__test__/AlertAction.test.js +6 -6
  11. package/src/commons/AlertAction/index.js +2 -0
  12. package/src/commons/Automate/ItemAutomate.js +7 -1
  13. package/src/commons/Automate/__test__/ItemAutomate.test.js +16 -0
  14. package/src/commons/Automate/__test__/ItemScriptAction.test.js +16 -0
  15. package/src/commons/BackDefault/__test__/BackDefault.test.js +21 -0
  16. package/src/commons/BottomScrollPicker/index.js +5 -1
  17. package/src/commons/BottomSheet/index.js +10 -5
  18. package/src/commons/ButtonPopup/__test__/__snapshots__/ButtonPopup.test.js.snap +2 -0
  19. package/src/commons/ButtonPopup/index.js +2 -0
  20. package/src/commons/Calendar/index.js +72 -0
  21. package/src/commons/Calendar/styles.js +11 -0
  22. package/src/commons/Device/ItemAddNew/index.js +2 -2
  23. package/src/commons/Explore/__test__/HeaderExplore.test.js +25 -0
  24. package/src/commons/Explore/__test__/LocationItem.test.js +31 -0
  25. package/src/commons/Header/HeaderCustom.js +7 -3
  26. package/src/commons/HeaderAni/index.js +31 -3
  27. package/src/commons/HorizontalPicker/index.js +134 -0
  28. package/src/commons/HorizontalPicker/styles.js +56 -0
  29. package/src/commons/Modal/__test__/ModalBottom.test.js +39 -0
  30. package/src/commons/RowItem/__test__/RowItem.test.js +16 -0
  31. package/src/commons/RowItem/index.js +61 -0
  32. package/src/commons/RowItem/styles.js +53 -0
  33. package/src/commons/Sharing/WrapHeaderScrollable.js +78 -74
  34. package/src/commons/SubUnit/OneTap/ItemOneTap.js +73 -69
  35. package/src/commons/SubUnit/OneTap/__test__/SubUnitAutomate.test.js +47 -1
  36. package/src/commons/SubUnit/OneTap/index.js +2 -2
  37. package/src/commons/Unit/__test__/SharedUnit.test.js +330 -0
  38. package/src/commons/WheelDateTimePicker/index.js +16 -8
  39. package/src/commons/index.js +2 -0
  40. package/src/configs/API.js +5 -1
  41. package/src/configs/Constants.js +18 -3
  42. package/src/configs/Theme.js +20 -0
  43. package/src/context/SCContext.tsx +2 -2
  44. package/src/context/mockStore.ts +3 -1
  45. package/src/hooks/Common/__test__/useStatusbar.test.js +28 -0
  46. package/src/navigations/AutomateStack.js +45 -0
  47. package/src/navigations/UnitStack.js +33 -14
  48. package/src/navigations/utils.js +8 -0
  49. package/src/screens/AddNewAction/Components/LoadingSelectAction.js +40 -0
  50. package/src/screens/AddNewAction/Components/index.js +3 -0
  51. package/src/screens/AddNewAction/SelectAction.js +147 -62
  52. package/src/screens/AddNewAction/{SelectDevice.js → SelectSensorDevices.js} +42 -12
  53. package/src/screens/AddNewAction/SetupSensor.js +221 -0
  54. package/src/screens/AddNewAction/Styles/SelectActionStyles.js +43 -5
  55. package/src/screens/AddNewAction/Styles/{SelectDeviceStyles.js → SelectSensorDevicesStyles.js} +0 -0
  56. package/src/screens/AddNewAction/Styles/SetupSensorStyles.js +76 -0
  57. package/src/screens/AddNewAction/__test__/SelectAction.test.js +0 -19
  58. package/src/screens/AddNewAction/__test__/{SelectDevice.test.js → SelectSensorDevices.test.js} +3 -3
  59. package/src/screens/AddNewAction/__test__/SetupSensor.test.js +125 -0
  60. package/src/screens/AddNewAutoSmart/__test__/AddNewAutoSmart.test.js +69 -12
  61. package/src/screens/AddNewAutoSmart/index.js +42 -14
  62. package/src/screens/AddNewOneTap/AddNewOneTapStyles.js +4 -3
  63. package/src/screens/AddNewOneTap/__test__/AddNewOneTap.test.js +1 -0
  64. package/src/screens/AddNewOneTap/index.js +7 -4
  65. package/src/screens/AllCamera/__test__/index.test.js +103 -0
  66. package/src/screens/Automate/Components/Loading.js +64 -0
  67. package/src/screens/Automate/Styles/indexStyles.js +64 -0
  68. package/src/screens/Automate/__test__/Loading.test.js +16 -0
  69. package/src/screens/Automate/__test__/index.test.js +93 -0
  70. package/src/screens/Automate/index.js +148 -0
  71. package/src/screens/Device/__test__/detail.test.js +64 -0
  72. package/src/screens/Device/detail.js +17 -7
  73. package/src/screens/EditActionsList/index.js +2 -2
  74. package/src/screens/GuestInfo/__test__/index.test.js +176 -0
  75. package/src/screens/GuestInfo/components/AccessScheduleItem.js +6 -1
  76. package/src/screens/GuestInfo/components/AccessScheduleSheet.js +26 -15
  77. package/src/screens/GuestInfo/components/HeaderGuestInfo.js +6 -1
  78. package/src/screens/GuestInfo/components/RecurringDetail.js +9 -2
  79. package/src/screens/GuestInfo/components/TemporaryDetail.js +9 -2
  80. package/src/screens/GuestInfo/constant.js +2 -2
  81. package/src/screens/GuestInfo/index.js +4 -5
  82. package/src/screens/PlayBackCamera/Timer.js +1 -1
  83. package/src/screens/ScriptDetail/Styles/indexStyles.js +14 -0
  84. package/src/screens/ScriptDetail/__test__/index.test.js +119 -0
  85. package/src/screens/ScriptDetail/hooks/index.js +55 -0
  86. package/src/screens/ScriptDetail/index.js +124 -23
  87. package/src/screens/SelectUnit/Styles/indexStyles.js +55 -0
  88. package/src/screens/SelectUnit/__test__/index.test.js +85 -0
  89. package/src/screens/SelectUnit/index.js +100 -0
  90. package/src/screens/SetSchedule/__test__/index.test.js +97 -0
  91. package/src/screens/SetSchedule/components/RepeatOptionsPopup.js +56 -0
  92. package/src/screens/SetSchedule/components/RowItem.js +27 -0
  93. package/src/screens/SetSchedule/components/SelectWeekday.js +65 -0
  94. package/src/screens/SetSchedule/index.js +139 -0
  95. package/src/screens/SetSchedule/styles/RepeatOptionsPopupStyles.js +22 -0
  96. package/src/screens/SetSchedule/styles/RowItemStyles.js +29 -0
  97. package/src/screens/SetSchedule/styles/SelectWeekdayStyles.js +26 -0
  98. package/src/screens/{AddNewScriptAction/AddNewScriptActionStyles.js → SetSchedule/styles/indexStyles.js} +6 -12
  99. package/src/screens/Sharing/__test__/MemberList.test.js +21 -28
  100. package/src/screens/SubUnit/EditSubUnit.js +274 -0
  101. package/src/screens/SubUnit/EditSubUnitStyles.js +119 -0
  102. package/src/screens/SubUnit/ManageSubUnit.js +112 -370
  103. package/src/screens/SubUnit/ManageSubUnitStyles.js +40 -0
  104. package/src/screens/SubUnit/__test__/EditSubUnit.test.js +427 -0
  105. package/src/screens/SubUnit/__test__/ManageSubUnit.test.js +42 -386
  106. package/src/screens/SubUnit/hooks/__test__/useManageSubUnit.test.js +85 -0
  107. package/src/screens/SubUnit/hooks/useManageSubUnit.js +35 -0
  108. package/src/screens/Unit/Detail.js +3 -2
  109. package/src/screens/Unit/ManageUnit.js +10 -0
  110. package/src/screens/Unit/components/SearchLocation/__test__/RowLocation.test.js +36 -0
  111. package/src/screens/Unit/components/__test__/MyUnit.test.js +35 -0
  112. package/src/screens/Unit/components/__test__/MyUnitDevice.test.js +32 -0
  113. package/src/screens/UnitSummary/components/__test__/UnitSummary.test.js +67 -0
  114. package/src/screens/UnitSummary/components/__test__/index.test.js +48 -0
  115. package/src/screens/UnitSummary/components/index.js +1 -37
  116. package/src/screens/UnitSummary/components/indexstyles.js +39 -0
  117. package/src/utils/Apis/axios.js +0 -4
  118. package/src/utils/I18n/translations/en.json +30 -4
  119. package/src/utils/I18n/translations/vi.json +29 -3
  120. package/src/utils/Route/index.js +6 -1
  121. package/src/utils/__test__/InitData.test.js +20 -0
  122. package/src/commons/Automate/ItemAddNewScriptAction.js +0 -30
  123. package/src/screens/AddNewScriptAction/index.js +0 -100
@@ -0,0 +1,274 @@
1
+ import React, { useState, useCallback, useEffect } from 'react';
2
+ import { View, TouchableOpacity, Image } from 'react-native';
3
+ import Modal from 'react-native-modal';
4
+ import { connect } from 'react-redux';
5
+ import { useIsFocused, useNavigation } from '@react-navigation/native';
6
+ import { useTranslations } from '../../hooks/Common/useTranslations';
7
+
8
+ import { Colors, API, Device } from '../../configs';
9
+ import { ToastBottomHelper } from '../../utils/Utils';
10
+ import {
11
+ axiosPatch,
12
+ axiosDelete,
13
+ createFormData,
14
+ } from '../../utils/Apis/axios';
15
+ import Routes from '../../utils/Route';
16
+ import useBoolean from '../../hooks/Common/useBoolean';
17
+
18
+ import { ImagePicker, Section } from '../../commons';
19
+ import AlertAction from '../../commons/AlertAction';
20
+ import _TextInput from '../../commons/Form/TextInput';
21
+ import ViewButtonBottom from '../../commons/ViewButtonBottom';
22
+ import Text from '../../commons/Text';
23
+ import { TESTID } from '../../configs/Constants';
24
+ import { IconOutline } from '@ant-design/icons-react-native';
25
+ import { useEmeragencyContacts } from './hooks/useEmergencyContacts';
26
+ import styles from './EditSubUnitStyles';
27
+
28
+ const EditSubUnit = ({ route }) => {
29
+ const { unit, station } = route.params;
30
+ const t = useTranslations();
31
+ const navigation = useNavigation();
32
+ const isFocused = useIsFocused();
33
+ const [resourcePath, setResourcePath] = useState({ uri: station.background });
34
+ const [
35
+ showModalRemoveSubUnit,
36
+ setShowModalRemoveSubUnit,
37
+ setHideModalRemoveSubUnit,
38
+ ] = useBoolean();
39
+ const [imageUrl, setImageUrl] = useState('');
40
+ const [showImagePicker, setShowImagePicker] = useState(false);
41
+
42
+ const [showEdit, setshowEdit, setHideEdit] = useBoolean();
43
+ const [inputName, setInputName] = useState(station.name);
44
+ const [newName, setNewName] = useState(station.name);
45
+
46
+ const group = station?.emergency_group;
47
+
48
+ const { listContacts, getListContacts } = useEmeragencyContacts();
49
+
50
+ useEffect(() => {
51
+ if (isFocused) {
52
+ group && getListContacts(group.id);
53
+ }
54
+ }, [getListContacts, group, isFocused]);
55
+
56
+ const onBack = useCallback(() => {
57
+ const { routes } = navigation.dangerouslyGetState();
58
+ const calledByRoute = routes[routes.length - 3].name;
59
+
60
+ switch (calledByRoute) {
61
+ case Routes.UnitDetail:
62
+ navigation.pop(2);
63
+ break;
64
+ default:
65
+ navigation.pop(3);
66
+ }
67
+ }, [navigation]);
68
+
69
+ const updateSubUnit = useCallback(
70
+ async (params, headers) => {
71
+ const { success, data } = await axiosPatch(
72
+ API.SUB_UNIT.MANAGE_SUB_UNIT(unit.id, station.id),
73
+ params,
74
+ headers
75
+ );
76
+
77
+ if (success) {
78
+ // dispatch(manageSubUnit(station.id, data));
79
+ setNewName(data.name);
80
+ ToastBottomHelper.success(t('text_rename_sub_unit_success'));
81
+ }
82
+ },
83
+ [unit.id, station.id, t]
84
+ );
85
+ const updateBackground = useCallback(
86
+ async (headers) => {
87
+ const formData = createFormData(imageUrl, ['background']);
88
+ const { success } = await axiosPatch(
89
+ API.SUB_UNIT.MANAGE_SUB_UNIT(unit.id, station.id),
90
+ formData,
91
+ headers
92
+ );
93
+ if (success) {
94
+ //dispatch(manageSubUnit(station.id, data));
95
+ ToastBottomHelper.success(t('text_change_background_sub_unit_success'));
96
+ }
97
+ },
98
+ [imageUrl, unit.id, station.id, t]
99
+ );
100
+
101
+ const onPressRemove = useCallback(() => {
102
+ setShowModalRemoveSubUnit();
103
+ }, [setShowModalRemoveSubUnit]);
104
+
105
+ const hideRemoveSubUnitModal = useCallback(() => {
106
+ setHideModalRemoveSubUnit();
107
+ }, [setHideModalRemoveSubUnit]);
108
+
109
+ const onRemoveSubUnit = useCallback(async () => {
110
+ setHideModalRemoveSubUnit();
111
+ const { success } = await axiosDelete(
112
+ API.SUB_UNIT.REMOVE_SUB_UNIT(unit.id, station.id)
113
+ );
114
+ if (success) {
115
+ //dispatch(removeSubUnit(station.id));
116
+ ToastBottomHelper.success(t('text_remove_sub_unit_success'));
117
+ onBack();
118
+ } else {
119
+ ToastBottomHelper.error(t('text_remove_sub_unit_fail'));
120
+ }
121
+ // eslint-disable-next-line react-hooks/exhaustive-deps
122
+ }, [setHideModalRemoveSubUnit, unit.id, station.id, t]);
123
+
124
+ const goRename = useCallback(() => {
125
+ updateSubUnit({ name: inputName }, {});
126
+ setHideEdit(true);
127
+ }, [setHideEdit, updateSubUnit, inputName]);
128
+
129
+ const onChangeName = useCallback((value) => {
130
+ setInputName(value);
131
+ }, []);
132
+
133
+ const selectFile = useCallback(() => {
134
+ setShowImagePicker(true);
135
+ }, [setShowImagePicker]);
136
+
137
+ useEffect(() => {
138
+ if (imageUrl) {
139
+ setResourcePath(imageUrl);
140
+ updateBackground({ headers: { 'Content-Type': 'multipart/form-data' } });
141
+ }
142
+ }, [imageUrl, updateBackground]);
143
+
144
+ const options = {
145
+ mediaType: 'photo',
146
+ maxWidth: 1024,
147
+ quality: 0.8,
148
+ includeBase64: Device.isIOS,
149
+ saveToPhotos: true,
150
+ };
151
+
152
+ const contactsName = listContacts.map((item) => item.name);
153
+ const onPressEmergencyContact = useCallback(() => {
154
+ navigation.navigate(Routes.EmergencyContactsStack, {
155
+ screen: Routes.EmergencyContactsList,
156
+ params: { unitId: unit.id, group },
157
+ });
158
+ }, [group, navigation, unit.id]);
159
+
160
+ return (
161
+ <View style={styles.container}>
162
+ <View style={styles.wraper}>
163
+ <Text semibold color={Colors.Black} style={styles.title}>
164
+ {t('edit_sub_unit')}
165
+ </Text>
166
+ <View style={styles.wraper}>
167
+ <View style={styles.subUnitData}>
168
+ <TouchableOpacity onPress={setshowEdit}>
169
+ <Text
170
+ testID={TESTID.MANAGE_SUB_UNIT_NAME}
171
+ style={[styles.textWraper, styles.subUnitName]}
172
+ >
173
+ {newName}
174
+ </Text>
175
+ </TouchableOpacity>
176
+ <TouchableOpacity
177
+ testID={TESTID.MANAGE_SUB_UNIT_SELECT_FILE_BUTTON}
178
+ onPress={selectFile}
179
+ style={[styles.backgroundContainer]}
180
+ >
181
+ <Text style={[styles.subUnitName, styles.textBackground]}>
182
+ {t('background')}
183
+ </Text>
184
+ <Image
185
+ style={styles.image}
186
+ source={{
187
+ uri: resourcePath.uri,
188
+ }}
189
+ resizeMode="cover"
190
+ />
191
+ </TouchableOpacity>
192
+ </View>
193
+ {group && (
194
+ <Section type={'border'}>
195
+ <TouchableOpacity
196
+ style={styles.buttonContacts}
197
+ onPress={onPressEmergencyContact}
198
+ >
199
+ <Text type={'H4'} color={Colors.Gray9}>
200
+ {t('emergency_contacts')}
201
+ </Text>
202
+ <IconOutline name={'right'} size={20} color={Colors.Gray8} />
203
+ </TouchableOpacity>
204
+ <Text
205
+ type={'Body'}
206
+ color={contactsName.length > 0 ? Colors.Primary : Colors.Gray6}
207
+ >
208
+ {contactsName.length > 0
209
+ ? contactsName.join(', ')
210
+ : t('no_contact')}
211
+ </Text>
212
+ </Section>
213
+ )}
214
+ <ImagePicker
215
+ showImagePicker={showImagePicker}
216
+ setShowImagePicker={setShowImagePicker}
217
+ setImageUrl={setImageUrl}
218
+ optionsCapture={options}
219
+ />
220
+ <TouchableOpacity
221
+ testID={TESTID.MANAGE_SUB_UNIT_REMOVE_BUTTON}
222
+ onPress={onPressRemove}
223
+ style={styles.removeButton}
224
+ >
225
+ <Text style={styles.removeText}>{t('remove_sub_unit')}</Text>
226
+ </TouchableOpacity>
227
+ </View>
228
+ </View>
229
+ <Modal
230
+ testID={TESTID.MANAGE_SUB_UNIT_MODAL}
231
+ isVisible={showEdit}
232
+ onBackButtonPress={setHideEdit}
233
+ onBackdropPress={setHideEdit}
234
+ style={styles.modalContainer}
235
+ >
236
+ <View style={styles.popoverStyle}>
237
+ <View style={styles.modalWrapper}>
238
+ <View style={styles.modalHeader}>
239
+ <Text semibold style={styles.modalHeaderText}>
240
+ {t('rename_sub_unit')}
241
+ </Text>
242
+ </View>
243
+ <_TextInput
244
+ defaultValue={station.name}
245
+ onChange={onChangeName}
246
+ textInputStyle={styles.textInputStyle}
247
+ wrapStyle={styles.textInputWrapStyle}
248
+ selectionColor={Colors.Primary}
249
+ />
250
+
251
+ <ViewButtonBottom
252
+ leftTitle={t('cancel')}
253
+ onLeftClick={setHideEdit}
254
+ rightTitle={t('rename')}
255
+ onRightClick={goRename}
256
+ />
257
+ </View>
258
+ </View>
259
+ </Modal>
260
+ <AlertAction
261
+ visible={showModalRemoveSubUnit}
262
+ hideModal={hideRemoveSubUnitModal}
263
+ title={t('sub_unit_remove_name', { name: station.name })}
264
+ message={t('sub_unit_message_warning_remove')}
265
+ leftButtonTitle={t('cancel')}
266
+ rightButtonTitle={t('remove')}
267
+ leftButtonClick={hideRemoveSubUnitModal}
268
+ rightButtonClick={onRemoveSubUnit}
269
+ />
270
+ </View>
271
+ );
272
+ };
273
+
274
+ export default connect()(EditSubUnit);
@@ -0,0 +1,119 @@
1
+ import { StyleSheet } from 'react-native';
2
+ import { Colors } from '../../configs';
3
+ import { getBottomSpace } from 'react-native-iphone-x-helper';
4
+
5
+ export default StyleSheet.create({
6
+ container: {
7
+ flex: 1,
8
+ backgroundColor: Colors.Gray2,
9
+ },
10
+ wraper: {
11
+ flex: 1,
12
+ },
13
+ title: {
14
+ paddingLeft: 22,
15
+ fontSize: 24,
16
+ lineHeight: 32,
17
+ marginBottom: 16,
18
+ },
19
+ subUnitData: {
20
+ backgroundColor: Colors.White,
21
+ borderWidth: 1,
22
+ borderColor: Colors.Gray4,
23
+ borderRadius: 20,
24
+ padding: 16,
25
+ paddingTop: 8,
26
+ paddingBottom: 24,
27
+ marginBottom: 24,
28
+ },
29
+ textWraper: {
30
+ paddingTop: 16,
31
+ paddingBottom: 16,
32
+ borderBottomWidth: 0.5,
33
+ },
34
+ subUnitName: {
35
+ fontStyle: 'normal',
36
+ fontWeight: 'normal',
37
+ fontSize: 16,
38
+ lineHeight: 24,
39
+ color: Colors.Gray9,
40
+ },
41
+ removeButton: {
42
+ position: 'absolute',
43
+ bottom: 0,
44
+ borderWidth: 0,
45
+ alignSelf: 'center',
46
+ paddingBottom: 16 + getBottomSpace(),
47
+ },
48
+ removeText: {
49
+ fontSize: 16,
50
+ lineHeight: 24,
51
+ color: Colors.Gray6,
52
+ },
53
+ backgroundContainer: {
54
+ alignItems: 'center',
55
+ flexDirection: 'row',
56
+ borderBottomWidth: 0.5,
57
+ },
58
+ image: {
59
+ width: 40,
60
+ height: 40,
61
+ borderRadius: 40 / 2,
62
+ },
63
+ textBackground: {
64
+ flex: 1,
65
+ paddingTop: 16,
66
+ paddingBottom: 16,
67
+ },
68
+ //Modal
69
+ modalContainer: {
70
+ flex: 1,
71
+ margin: 0,
72
+ },
73
+ popoverStyle: {
74
+ width: '100%',
75
+ backgroundColor: Colors.White,
76
+ bottom: 0,
77
+ left: 0,
78
+ position: 'absolute',
79
+ borderRadius: 10,
80
+ },
81
+ modalWrapper: {
82
+ flex: 1,
83
+ flexDirection: 'column',
84
+ backgroundColor: Colors.White,
85
+ borderRadius: 10,
86
+ },
87
+ modalHeader: {
88
+ padding: 16,
89
+ backgroundColor: Colors.White,
90
+ borderBottomWidth: 1,
91
+ borderTopLeftRadius: 20,
92
+ borderTopRightRadius: 20,
93
+ borderColor: Colors.Gray4,
94
+ },
95
+ modalHeaderText: {
96
+ fontSize: 16,
97
+ lineHeight: 24,
98
+ color: Colors.Gray9,
99
+ },
100
+ textInputStyle: {
101
+ borderWidth: 0,
102
+ borderBottomWidth: 1,
103
+ borderBottomColor: Colors.Primary,
104
+ fontSize: 16,
105
+ marginLeft: 16,
106
+ marginRight: 16,
107
+ paddingHorizontal: 0,
108
+ },
109
+ textInputWrapStyle: {
110
+ marginTop: 0,
111
+ },
112
+ buttonContacts: {
113
+ marginTop: 8,
114
+ flexDirection: 'row',
115
+ paddingBottom: 20,
116
+ justifyContent: 'space-between',
117
+ alignItems: 'center',
118
+ },
119
+ });