@ray-js/robot-data-stream 0.0.13-beta-5 → 0.0.13-beta-7
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.
- package/lib/api/index.d.ts +12 -2
- package/lib/api/index.js +172 -1
- package/lib/api/p2pApi.d.ts +27 -8
- package/lib/api/p2pApi.js +169 -271
- package/lib/api/sweeperP2p.d.ts +23 -49
- package/lib/api/sweeperP2p.js +248 -311
- package/lib/constant.d.ts +52 -0
- package/lib/constant.js +54 -0
- package/lib/index.d.ts +1 -10
- package/lib/index.js +2 -165
- package/lib/mqtt/createCommonOptions.d.ts +56 -15
- package/lib/mqtt/createCommonOptions.js +44 -8
- package/lib/mqtt/index.d.ts +2 -1
- package/lib/mqtt/index.js +2 -1
- package/lib/mqtt/mqttProvider.d.ts +23 -15
- package/lib/mqtt/mqttProvider.js +63 -26
- package/lib/mqtt/promise.js +8 -3
- package/lib/mqtt/type/index.d.ts +14 -0
- package/lib/mqtt/type/index.js +14 -0
- package/lib/mqtt/type/requestType.d.ts +8 -0
- package/lib/mqtt/type/requestType.js +10 -0
- package/lib/mqtt/useDevInfo.d.ts +2 -7
- package/lib/mqtt/useDevInfo.js +25 -9
- package/lib/mqtt/useHistoryMap.d.ts +13 -21
- package/lib/mqtt/useHistoryMap.js +82 -32
- package/lib/mqtt/usePartDivision.d.ts +5 -7
- package/lib/mqtt/usePartDivision.js +41 -16
- package/lib/mqtt/usePartMerge.d.ts +5 -7
- package/lib/mqtt/usePartMerge.js +36 -18
- package/lib/mqtt/usePassword.js +59 -28
- package/lib/mqtt/useQuiteHours.d.ts +9 -24
- package/lib/mqtt/useQuiteHours.js +95 -52
- package/lib/mqtt/useResetMap.d.ts +10 -7
- package/lib/mqtt/useResetMap.js +40 -11
- package/lib/mqtt/useRoomProperty.js +23 -16
- package/lib/mqtt/useSchedule.d.ts +17 -4
- package/lib/mqtt/useSchedule.js +101 -49
- package/lib/mqtt/useSelectRoomClean.d.ts +20 -16
- package/lib/mqtt/useSelectRoomClean.js +145 -49
- package/lib/mqtt/useSpotClean.d.ts +3 -3
- package/lib/mqtt/useSpotClean.js +72 -50
- package/lib/mqtt/useVirtualArea.d.ts +6 -9
- package/lib/mqtt/useVirtualArea.js +112 -42
- package/lib/mqtt/useVirtualWall.d.ts +13 -10
- package/lib/mqtt/useVirtualWall.js +97 -34
- package/lib/mqtt/useVoice.d.ts +3 -6
- package/lib/mqtt/useVoice.js +73 -33
- package/lib/mqtt/useWifiMap.d.ts +8 -0
- package/lib/mqtt/useWifiMap.js +53 -0
- package/lib/mqtt/useZoneClean.d.ts +13 -13
- package/lib/mqtt/useZoneClean.js +149 -76
- package/lib/ttt/index.d.ts +153 -0
- package/lib/ttt/index.js +458 -0
- package/lib/utils/index.d.ts +20 -1
- package/lib/utils/index.js +19 -0
- package/package.json +1 -1
- package/lib/mqtt/myError.d.ts +0 -4
- package/lib/mqtt/myError.js +0 -6
package/lib/mqtt/useSchedule.js
CHANGED
|
@@ -8,39 +8,51 @@ import { SingletonContext } from './mqttProvider';
|
|
|
8
8
|
import { encodeDeviceTimer0x30 } from '@ray-js/robot-protocol';
|
|
9
9
|
import { CISTERN_MAP, CLEAN_MODE_MAP, SUCTION_MAP } from '../constant';
|
|
10
10
|
|
|
11
|
-
//
|
|
11
|
+
// 定时任务项
|
|
12
12
|
|
|
13
|
+
// 定时任务数据
|
|
14
|
+
|
|
15
|
+
// 定时任务响应类型
|
|
16
|
+
|
|
17
|
+
// 请求定时数据函数类型定义
|
|
18
|
+
|
|
19
|
+
// 设置定时数据函数类型定义
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* 自定义 Hook,用于定时任务
|
|
23
|
+
* @param devId 设备ID
|
|
24
|
+
* @returns 包含 requestSchedule 和 setSchedule 函数的对象
|
|
25
|
+
*/
|
|
13
26
|
export const useSchedule = devId => {
|
|
14
27
|
const {
|
|
15
28
|
useMqtt,
|
|
16
29
|
devices,
|
|
17
30
|
commandVersion
|
|
18
31
|
} = useContext(SingletonContext);
|
|
19
|
-
|
|
32
|
+
/**
|
|
33
|
+
* 请求定时数据
|
|
34
|
+
* @param message 可选参数,包含版本号
|
|
35
|
+
* @returns Promise<ScheduleResponse> 响应结果
|
|
36
|
+
*/
|
|
20
37
|
|
|
21
|
-
|
|
38
|
+
/**
|
|
39
|
+
* 设置定时数据
|
|
40
|
+
* @param message 定时任务数据
|
|
41
|
+
* @returns Promise<ScheduleResponse> 响应结果
|
|
42
|
+
*/
|
|
22
43
|
|
|
23
44
|
return {
|
|
24
45
|
requestSchedule: function () {
|
|
25
46
|
let message = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {
|
|
26
47
|
version: '1.0.0'
|
|
27
48
|
};
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
});
|
|
33
|
-
ty.device.sendMqttMessage(params);
|
|
34
|
-
const {
|
|
35
|
-
taskId
|
|
36
|
-
} = params.message;
|
|
37
|
-
return normalResolve(ScheduleEnum.query, taskId);
|
|
38
|
-
},
|
|
39
|
-
setSchedule: message => {
|
|
40
|
-
if (useMqtt) {
|
|
49
|
+
if (!useMqtt) {
|
|
50
|
+
return Promise.reject(new Error('useMqtt is not used'));
|
|
51
|
+
}
|
|
52
|
+
try {
|
|
41
53
|
const params = createSetCommonParams({
|
|
42
54
|
deviceId: devId,
|
|
43
|
-
reqType: ScheduleEnum.
|
|
55
|
+
reqType: ScheduleEnum.query,
|
|
44
56
|
message
|
|
45
57
|
});
|
|
46
58
|
ty.device.sendMqttMessage(params);
|
|
@@ -48,39 +60,79 @@ export const useSchedule = devId => {
|
|
|
48
60
|
taskId
|
|
49
61
|
} = params.message;
|
|
50
62
|
return normalResolve(ScheduleEnum.query, taskId);
|
|
63
|
+
} catch (error) {
|
|
64
|
+
return Promise.reject(error instanceof Error ? error : new Error('Failed to request schedule'));
|
|
65
|
+
}
|
|
66
|
+
},
|
|
67
|
+
setSchedule: message => {
|
|
68
|
+
// 参数验证
|
|
69
|
+
if (!message || typeof message.num !== 'number') {
|
|
70
|
+
throw new Error('message.num is required and must be a number');
|
|
71
|
+
}
|
|
72
|
+
if (!Array.isArray(message.list)) {
|
|
73
|
+
throw new Error('message.list is required and must be an array');
|
|
74
|
+
}
|
|
75
|
+
if (message.num !== message.list.length) {
|
|
76
|
+
throw new Error('message.num must equal message.list.length');
|
|
77
|
+
}
|
|
78
|
+
try {
|
|
79
|
+
if (useMqtt) {
|
|
80
|
+
const params = createSetCommonParams({
|
|
81
|
+
deviceId: devId,
|
|
82
|
+
reqType: ScheduleEnum.set,
|
|
83
|
+
message
|
|
84
|
+
});
|
|
85
|
+
ty.device.sendMqttMessage(params);
|
|
86
|
+
const {
|
|
87
|
+
taskId
|
|
88
|
+
} = params.message;
|
|
89
|
+
return normalResolve(ScheduleEnum.query, taskId);
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
// 非 MQTT 模式:使用命令传输
|
|
93
|
+
const command = encodeDeviceTimer0x30({
|
|
94
|
+
version: commandVersion,
|
|
95
|
+
number: message.num,
|
|
96
|
+
list: message.list.map(_ref => {
|
|
97
|
+
let {
|
|
98
|
+
active,
|
|
99
|
+
suctions,
|
|
100
|
+
sweepMopModes,
|
|
101
|
+
ids,
|
|
102
|
+
cleanCounts,
|
|
103
|
+
cycle,
|
|
104
|
+
cisterns,
|
|
105
|
+
time
|
|
106
|
+
} = _ref;
|
|
107
|
+
return {
|
|
108
|
+
effectiveness: active,
|
|
109
|
+
cleanMode: CLEAN_MODE_MAP[sweepMopModes[0]],
|
|
110
|
+
fanLevel: SUCTION_MAP[suctions[0]],
|
|
111
|
+
waterLevel: CISTERN_MAP[cisterns[0]],
|
|
112
|
+
time: {
|
|
113
|
+
hour: time[0],
|
|
114
|
+
minute: time[1]
|
|
115
|
+
},
|
|
116
|
+
week: cycle,
|
|
117
|
+
sweepCount: cleanCounts[0],
|
|
118
|
+
roomIds: ids,
|
|
119
|
+
roomNum: ids.length
|
|
120
|
+
};
|
|
121
|
+
})
|
|
122
|
+
});
|
|
123
|
+
devices.common.model.actions.device_timer.set(command);
|
|
124
|
+
return Promise.resolve({
|
|
125
|
+
success: true,
|
|
126
|
+
errCode: 0,
|
|
127
|
+
reqType: ScheduleEnum.query,
|
|
128
|
+
version: commandVersion,
|
|
129
|
+
taskId: `${Date.now()}`,
|
|
130
|
+
list: message.list,
|
|
131
|
+
num: message.num
|
|
132
|
+
});
|
|
133
|
+
} catch (error) {
|
|
134
|
+
throw error instanceof Error ? error : new Error('Failed to set schedule');
|
|
51
135
|
}
|
|
52
|
-
const command = encodeDeviceTimer0x30({
|
|
53
|
-
version: commandVersion,
|
|
54
|
-
number: message.num,
|
|
55
|
-
list: message.list.map(_ref => {
|
|
56
|
-
let {
|
|
57
|
-
active,
|
|
58
|
-
suctions,
|
|
59
|
-
sweepMopModes,
|
|
60
|
-
ids,
|
|
61
|
-
cleanCounts,
|
|
62
|
-
cycle,
|
|
63
|
-
cisterns,
|
|
64
|
-
time
|
|
65
|
-
} = _ref;
|
|
66
|
-
return {
|
|
67
|
-
effectiveness: active,
|
|
68
|
-
cleanMode: CLEAN_MODE_MAP[sweepMopModes[0]],
|
|
69
|
-
fanLevel: SUCTION_MAP[suctions[0]],
|
|
70
|
-
waterLevel: CISTERN_MAP[cisterns[0]],
|
|
71
|
-
time: {
|
|
72
|
-
hour: time[0],
|
|
73
|
-
minute: time[1]
|
|
74
|
-
},
|
|
75
|
-
week: cycle,
|
|
76
|
-
sweepCount: cleanCounts[0],
|
|
77
|
-
roomIds: ids,
|
|
78
|
-
roomNum: ids.length
|
|
79
|
-
};
|
|
80
|
-
})
|
|
81
|
-
});
|
|
82
|
-
devices.common.model.actions.device_timer.set(command);
|
|
83
|
-
return Promise.resolve();
|
|
84
136
|
}
|
|
85
137
|
};
|
|
86
138
|
};
|
|
@@ -1,26 +1,30 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
version: string;
|
|
4
|
-
success: boolean;
|
|
5
|
-
errCode: number;
|
|
6
|
-
taskId: string;
|
|
7
|
-
ids: number[];
|
|
8
|
-
suctions?: string[];
|
|
9
|
-
cisterns?: string[];
|
|
10
|
-
cleanCounts?: number[];
|
|
11
|
-
yMops?: number[];
|
|
12
|
-
sweepMopModes?: string[];
|
|
13
|
-
};
|
|
14
|
-
type TSetRoomClean = (rooms: {
|
|
1
|
+
import { BaseResponse, RoomCleanSetEnum } from './type';
|
|
2
|
+
interface RoomInfo {
|
|
15
3
|
roomId: number;
|
|
16
4
|
suction?: string;
|
|
17
5
|
cistern: string;
|
|
18
6
|
cleanTimes?: number;
|
|
19
7
|
yMop?: number;
|
|
20
8
|
sweepMopMode?: string;
|
|
21
|
-
}
|
|
9
|
+
}
|
|
10
|
+
interface RoomCleanResponse extends BaseResponse {
|
|
11
|
+
reqType: RoomCleanSetEnum.query;
|
|
12
|
+
ids: number[];
|
|
13
|
+
suctions?: string[];
|
|
14
|
+
cisterns?: string[];
|
|
15
|
+
cleanCounts?: number[];
|
|
16
|
+
yMops?: number[];
|
|
17
|
+
sweepMopModes?: string[];
|
|
18
|
+
}
|
|
19
|
+
type TSetRoomClean = (rooms: RoomInfo[]) => Promise<RoomCleanResponse>;
|
|
20
|
+
type TRequestSelectRoomClean = () => Promise<RoomCleanResponse>;
|
|
21
|
+
/**
|
|
22
|
+
* 自定义 Hook,用于选区清扫
|
|
23
|
+
* @param devId 设备ID
|
|
24
|
+
* @returns 包含 requestSelectRoomClean 和 setRoomClean 函数的对象
|
|
25
|
+
*/
|
|
22
26
|
export declare const useSelectRoomClean: (devId: string) => {
|
|
23
|
-
requestSelectRoomClean:
|
|
27
|
+
requestSelectRoomClean: TRequestSelectRoomClean;
|
|
24
28
|
setRoomClean: TSetRoomClean;
|
|
25
29
|
};
|
|
26
30
|
export {};
|
|
@@ -8,6 +8,20 @@ import { normalResolve } from './promise';
|
|
|
8
8
|
import { useContext } from 'react';
|
|
9
9
|
import { SingletonContext } from './mqttProvider';
|
|
10
10
|
import { encodeRoomClean0x14, requestRoomClean0x15 } from '@ray-js/robot-protocol';
|
|
11
|
+
|
|
12
|
+
// 房间信息
|
|
13
|
+
|
|
14
|
+
// 选区清扫响应类型
|
|
15
|
+
|
|
16
|
+
// 设置选区清扫函数类型定义
|
|
17
|
+
|
|
18
|
+
// 请求选区清扫函数类型定义
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* 自定义 Hook,用于选区清扫
|
|
22
|
+
* @param devId 设备ID
|
|
23
|
+
* @returns 包含 requestSelectRoomClean 和 setRoomClean 函数的对象
|
|
24
|
+
*/
|
|
11
25
|
export const useSelectRoomClean = devId => {
|
|
12
26
|
const {
|
|
13
27
|
useMqtt,
|
|
@@ -15,66 +29,148 @@ export const useSelectRoomClean = devId => {
|
|
|
15
29
|
devices
|
|
16
30
|
} = useContext(SingletonContext);
|
|
17
31
|
|
|
18
|
-
|
|
32
|
+
/**
|
|
33
|
+
* 请求选区清扫信息
|
|
34
|
+
* @returns Promise<RoomCleanResponse> 响应结果
|
|
35
|
+
*/
|
|
19
36
|
|
|
20
|
-
|
|
21
|
-
|
|
37
|
+
/**
|
|
38
|
+
* 设置选区清扫
|
|
39
|
+
* 选区清扫的清扫属性,当全局模式下使用全局的清扫属性,当自定义模式下,使用房间自定义的清扫属性
|
|
40
|
+
* @param rooms 房间信息数组
|
|
41
|
+
* @returns Promise<RoomCleanResponse> 响应结果
|
|
42
|
+
*/
|
|
22
43
|
|
|
23
44
|
return {
|
|
24
45
|
requestSelectRoomClean: () => {
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
46
|
+
try {
|
|
47
|
+
if (useMqtt) {
|
|
48
|
+
const params = createSetCommonParams({
|
|
49
|
+
deviceId: devId,
|
|
50
|
+
reqType: RoomCleanSetEnum.query
|
|
51
|
+
});
|
|
52
|
+
ty.device.sendMqttMessage(params);
|
|
53
|
+
const {
|
|
54
|
+
taskId
|
|
55
|
+
} = params.message;
|
|
56
|
+
return normalResolve(RoomCleanSetEnum.query, taskId);
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
// 非 MQTT 模式:使用命令传输
|
|
60
|
+
devices.common.model.actions.command_trans.set(requestRoomClean0x15({
|
|
61
|
+
version: commandVersion
|
|
62
|
+
}));
|
|
63
|
+
|
|
64
|
+
// 非 MQTT 模式下无法立即获取响应数据,返回默认响应
|
|
65
|
+
return Promise.resolve({
|
|
66
|
+
success: true,
|
|
67
|
+
errCode: 0,
|
|
68
|
+
reqType: RoomCleanSetEnum.query,
|
|
69
|
+
version: commandVersion,
|
|
70
|
+
taskId: `${Date.now()}`,
|
|
71
|
+
ids: [],
|
|
72
|
+
suctions: [],
|
|
73
|
+
cisterns: [],
|
|
74
|
+
cleanCounts: [],
|
|
75
|
+
yMops: [],
|
|
76
|
+
sweepMopModes: []
|
|
29
77
|
});
|
|
30
|
-
|
|
31
|
-
return
|
|
78
|
+
} catch (error) {
|
|
79
|
+
return Promise.reject(error instanceof Error ? error : new Error('Failed to request select room clean'));
|
|
32
80
|
}
|
|
33
|
-
return devices.common.model.actions.command_trans.set(requestRoomClean0x15({
|
|
34
|
-
version: commandVersion
|
|
35
|
-
}));
|
|
36
81
|
},
|
|
37
82
|
setRoomClean: rooms => {
|
|
38
|
-
|
|
39
|
-
if (
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
83
|
+
// 参数验证
|
|
84
|
+
if (!Array.isArray(rooms) || rooms.length === 0) {
|
|
85
|
+
throw new Error('rooms is required and must be a non-empty array');
|
|
86
|
+
}
|
|
87
|
+
rooms.forEach((room, index) => {
|
|
88
|
+
if (typeof room.roomId !== 'number') {
|
|
89
|
+
throw new Error(`rooms[${index}].roomId is required and must be a number`);
|
|
90
|
+
}
|
|
91
|
+
if (!room.cistern || typeof room.cistern !== 'string') {
|
|
92
|
+
throw new Error(`rooms[${index}].cistern is required and must be a string`);
|
|
93
|
+
}
|
|
94
|
+
});
|
|
95
|
+
try {
|
|
96
|
+
var _rooms$0$cleanTimes, _rooms$;
|
|
97
|
+
if (useMqtt) {
|
|
98
|
+
const ids = [];
|
|
99
|
+
const suctions = [];
|
|
100
|
+
const cisterns = [];
|
|
101
|
+
const cleanCounts = [];
|
|
102
|
+
const yMops = [];
|
|
103
|
+
const sweepMopModes = [];
|
|
104
|
+
rooms.forEach(room => {
|
|
105
|
+
var _room$suction, _room$cleanTimes, _room$yMop, _room$sweepMopMode;
|
|
106
|
+
ids.push(room.roomId);
|
|
107
|
+
suctions.push((_room$suction = room.suction) !== null && _room$suction !== void 0 ? _room$suction : '');
|
|
108
|
+
cisterns.push(room.cistern);
|
|
109
|
+
cleanCounts.push((_room$cleanTimes = room.cleanTimes) !== null && _room$cleanTimes !== void 0 ? _room$cleanTimes : 1);
|
|
110
|
+
yMops.push((_room$yMop = room.yMop) !== null && _room$yMop !== void 0 ? _room$yMop : -1);
|
|
111
|
+
sweepMopModes.push((_room$sweepMopMode = room.sweepMopMode) !== null && _room$sweepMopMode !== void 0 ? _room$sweepMopMode : 'only_sweep');
|
|
112
|
+
});
|
|
113
|
+
const params = createSetCommonParams({
|
|
114
|
+
deviceId: devId,
|
|
115
|
+
reqType: RoomCleanSetEnum.set,
|
|
116
|
+
message: {
|
|
117
|
+
ids,
|
|
118
|
+
suctions,
|
|
119
|
+
cisterns,
|
|
120
|
+
cleanCounts,
|
|
121
|
+
yMops,
|
|
122
|
+
sweepMopModes,
|
|
123
|
+
num: rooms.length
|
|
124
|
+
}
|
|
125
|
+
});
|
|
126
|
+
ty.device.sendMqttMessage(params);
|
|
127
|
+
const {
|
|
128
|
+
taskId
|
|
129
|
+
} = params.message;
|
|
130
|
+
return normalResolve(RoomCleanSetEnum.query, taskId);
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
// 非 MQTT 模式:使用命令传输
|
|
134
|
+
const command = encodeRoomClean0x14({
|
|
135
|
+
version: commandVersion,
|
|
136
|
+
roomIds: rooms.map(room => room.roomId),
|
|
137
|
+
cleanTimes: (_rooms$0$cleanTimes = (_rooms$ = rooms[0]) === null || _rooms$ === void 0 ? void 0 : _rooms$.cleanTimes) !== null && _rooms$0$cleanTimes !== void 0 ? _rooms$0$cleanTimes : 1
|
|
138
|
+
});
|
|
139
|
+
devices.common.model.actions.command_trans.set(command);
|
|
140
|
+
const ids = rooms.map(room => room.roomId);
|
|
141
|
+
const suctions = rooms.map(room => {
|
|
142
|
+
var _room$suction2;
|
|
143
|
+
return (_room$suction2 = room.suction) !== null && _room$suction2 !== void 0 ? _room$suction2 : '';
|
|
144
|
+
});
|
|
145
|
+
const cisterns = rooms.map(room => room.cistern);
|
|
146
|
+
const cleanCounts = rooms.map(room => {
|
|
147
|
+
var _room$cleanTimes2;
|
|
148
|
+
return (_room$cleanTimes2 = room.cleanTimes) !== null && _room$cleanTimes2 !== void 0 ? _room$cleanTimes2 : 1;
|
|
54
149
|
});
|
|
55
|
-
const
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
message: {
|
|
59
|
-
ids,
|
|
60
|
-
suctions,
|
|
61
|
-
cisterns,
|
|
62
|
-
cleanCounts,
|
|
63
|
-
yMops,
|
|
64
|
-
sweepMopModes,
|
|
65
|
-
num: rooms.length
|
|
66
|
-
}
|
|
150
|
+
const yMops = rooms.map(room => {
|
|
151
|
+
var _room$yMop2;
|
|
152
|
+
return (_room$yMop2 = room.yMop) !== null && _room$yMop2 !== void 0 ? _room$yMop2 : -1;
|
|
67
153
|
});
|
|
68
|
-
|
|
69
|
-
|
|
154
|
+
const sweepMopModes = rooms.map(room => {
|
|
155
|
+
var _room$sweepMopMode2;
|
|
156
|
+
return (_room$sweepMopMode2 = room.sweepMopMode) !== null && _room$sweepMopMode2 !== void 0 ? _room$sweepMopMode2 : 'only_sweep';
|
|
157
|
+
});
|
|
158
|
+
return Promise.resolve({
|
|
159
|
+
success: true,
|
|
160
|
+
errCode: 0,
|
|
161
|
+
reqType: RoomCleanSetEnum.query,
|
|
162
|
+
version: commandVersion,
|
|
163
|
+
taskId: `${Date.now()}`,
|
|
164
|
+
ids,
|
|
165
|
+
suctions,
|
|
166
|
+
cisterns,
|
|
167
|
+
cleanCounts,
|
|
168
|
+
yMops,
|
|
169
|
+
sweepMopModes
|
|
170
|
+
});
|
|
171
|
+
} catch (error) {
|
|
172
|
+
throw error instanceof Error ? error : new Error('Failed to set room clean');
|
|
70
173
|
}
|
|
71
|
-
const command = encodeRoomClean0x14({
|
|
72
|
-
version: commandVersion,
|
|
73
|
-
roomIds: rooms.map(room => room.roomId),
|
|
74
|
-
cleanTimes: (_rooms$0$cleanTimes = (_rooms$ = rooms[0]) === null || _rooms$ === void 0 ? void 0 : _rooms$.cleanTimes) !== null && _rooms$0$cleanTimes !== void 0 ? _rooms$0$cleanTimes : 1
|
|
75
|
-
});
|
|
76
|
-
devices.common.model.actions.command_trans.set(command);
|
|
77
|
-
return Promise.resolve();
|
|
78
174
|
}
|
|
79
175
|
};
|
|
80
176
|
};
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import { RoomPreference } from './type';
|
|
1
|
+
import { BaseResponse, RoomPreference } from './type';
|
|
2
2
|
import { Point } from '@ray-js/robot-protocol';
|
|
3
|
-
type Response = Partial<Pick<RoomPreference, 'suctions' | 'cisterns' | 'cleanCounts' | 'yMops' | 'sweepMopModes'>> & {
|
|
3
|
+
type Response = BaseResponse & Partial<Pick<RoomPreference, 'suctions' | 'cisterns' | 'cleanCounts' | 'yMops' | 'sweepMopModes'>> & {
|
|
4
4
|
polygons: string[];
|
|
5
5
|
names?: string[];
|
|
6
6
|
};
|
|
7
7
|
type TSetSpotClean = (message: Partial<Pick<RoomPreference, 'suctions' | 'cisterns' | 'cleanCounts' | 'yMops' | 'sweepMopModes'>> & {
|
|
8
8
|
spots: Point[];
|
|
9
9
|
origin?: Point;
|
|
10
|
-
}) => Promise<Response
|
|
10
|
+
}) => Promise<Response>;
|
|
11
11
|
/**
|
|
12
12
|
* 定点清扫
|
|
13
13
|
* @returns
|
package/lib/mqtt/useSpotClean.js
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import "core-js/modules/esnext.iterator.map.js";
|
|
1
2
|
// 定点清扫
|
|
2
3
|
|
|
3
4
|
import { isArray } from 'lodash-es';
|
|
@@ -38,59 +39,80 @@ export const useSpotClean = devId => {
|
|
|
38
39
|
spots,
|
|
39
40
|
origin
|
|
40
41
|
} = message;
|
|
41
|
-
if (
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
if (cleanCounts && !isArray(cleanCounts)) {
|
|
60
|
-
return Promise.reject(new Error('cleanCounts is illegal'));
|
|
61
|
-
}
|
|
62
|
-
if (yMops && !isArray(yMops)) {
|
|
63
|
-
return Promise.reject(new Error('yMops is illegal'));
|
|
64
|
-
}
|
|
65
|
-
if (sweepMopModes && !isArray(sweepMopModes)) {
|
|
66
|
-
return Promise.reject(new Error('sweepMopModes is illegal'));
|
|
67
|
-
}
|
|
68
|
-
if (num !== suctions.length || num !== cisterns.length || num !== cleanCounts.length || num !== yMops.length || num !== sweepMopModes.length) {
|
|
69
|
-
return Promise.reject(new Error('The length of the parameters is inconsistent'));
|
|
70
|
-
}
|
|
71
|
-
const params = createSetCommonParams({
|
|
72
|
-
deviceId: devId,
|
|
73
|
-
reqType: SpotCleanEnum.set,
|
|
74
|
-
message: {
|
|
75
|
-
num,
|
|
76
|
-
polygons: [pointsToString(spots, origin)],
|
|
77
|
-
suctions,
|
|
78
|
-
cisterns,
|
|
79
|
-
cleanCounts,
|
|
80
|
-
yMops,
|
|
81
|
-
sweepMopModes
|
|
42
|
+
if (!origin || typeof origin.x !== 'number' || typeof origin.y !== 'number') {
|
|
43
|
+
throw new Error('origin is required and must be a valid Point object with x and y properties');
|
|
44
|
+
}
|
|
45
|
+
try {
|
|
46
|
+
if (useMqtt) {
|
|
47
|
+
const num = spots.length;
|
|
48
|
+
const {
|
|
49
|
+
suctions = new Array(num).fill(''),
|
|
50
|
+
cisterns = new Array(num).fill(''),
|
|
51
|
+
cleanCounts = new Array(num).fill(1),
|
|
52
|
+
yMops = new Array(num).fill(-1),
|
|
53
|
+
sweepMopModes = new Array(num).fill('only_sweep')
|
|
54
|
+
} = message;
|
|
55
|
+
if (suctions && !isArray(suctions)) {
|
|
56
|
+
throw new Error('suctions is illegal');
|
|
57
|
+
}
|
|
58
|
+
if (cisterns && !isArray(cisterns)) {
|
|
59
|
+
throw new Error('cisterns is illegal');
|
|
82
60
|
}
|
|
61
|
+
if (cleanCounts && !isArray(cleanCounts)) {
|
|
62
|
+
throw new Error('cleanCounts is illegal');
|
|
63
|
+
}
|
|
64
|
+
if (yMops && !isArray(yMops)) {
|
|
65
|
+
throw new Error('yMops is illegal');
|
|
66
|
+
}
|
|
67
|
+
if (sweepMopModes && !isArray(sweepMopModes)) {
|
|
68
|
+
throw new Error('sweepMopModes is illegal');
|
|
69
|
+
}
|
|
70
|
+
if (num !== suctions.length || num !== cisterns.length || num !== cleanCounts.length || num !== yMops.length || num !== sweepMopModes.length) {
|
|
71
|
+
throw new Error('The length of the parameters is inconsistent');
|
|
72
|
+
}
|
|
73
|
+
const params = createSetCommonParams({
|
|
74
|
+
deviceId: devId,
|
|
75
|
+
reqType: SpotCleanEnum.set,
|
|
76
|
+
message: {
|
|
77
|
+
num,
|
|
78
|
+
polygons: spots.map(spot => pointsToString([spot], origin)),
|
|
79
|
+
suctions,
|
|
80
|
+
cisterns,
|
|
81
|
+
cleanCounts,
|
|
82
|
+
yMops,
|
|
83
|
+
sweepMopModes
|
|
84
|
+
}
|
|
85
|
+
});
|
|
86
|
+
ty.device.sendMqttMessage(params);
|
|
87
|
+
const {
|
|
88
|
+
taskId
|
|
89
|
+
} = params.message;
|
|
90
|
+
return normalResolve(SpotCleanEnum.query, taskId);
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
// 非 MQTT 模式:使用命令传输
|
|
94
|
+
const command = encodeSpotClean0x16({
|
|
95
|
+
version: commandVersion,
|
|
96
|
+
origin,
|
|
97
|
+
point: spots[0]
|
|
83
98
|
});
|
|
84
|
-
|
|
85
|
-
return
|
|
99
|
+
devices.common.model.actions.command_trans.set(command);
|
|
100
|
+
return Promise.resolve({
|
|
101
|
+
success: true,
|
|
102
|
+
errCode: 0,
|
|
103
|
+
reqType: SpotCleanEnum.query,
|
|
104
|
+
version: commandVersion,
|
|
105
|
+
taskId: `${Date.now()}`,
|
|
106
|
+
polygons: spots.map(spot => pointsToString([spot], origin)),
|
|
107
|
+
suctions: message.suctions,
|
|
108
|
+
cisterns: message.cisterns,
|
|
109
|
+
cleanCounts: message.cleanCounts,
|
|
110
|
+
yMops: message.yMops,
|
|
111
|
+
sweepMopModes: message.sweepMopModes
|
|
112
|
+
});
|
|
113
|
+
} catch (error) {
|
|
114
|
+
throw error instanceof Error ? error : new Error('Failed to set spot clean');
|
|
86
115
|
}
|
|
87
|
-
const command = encodeSpotClean0x16({
|
|
88
|
-
version: commandVersion,
|
|
89
|
-
origin,
|
|
90
|
-
point: spots[0]
|
|
91
|
-
});
|
|
92
|
-
devices.common.model.actions.command_trans.set(command);
|
|
93
|
-
return Promise.resolve();
|
|
94
116
|
}
|
|
95
117
|
};
|
|
96
118
|
};
|
|
@@ -1,21 +1,18 @@
|
|
|
1
|
+
import { BaseResponse, VirtualAreaEnum } from './type';
|
|
1
2
|
import { Point, VirtualArea } from '@ray-js/robot-protocol';
|
|
2
|
-
|
|
3
|
-
reqType:
|
|
4
|
-
version: string;
|
|
3
|
+
interface VirtualAreaResponse extends BaseResponse {
|
|
4
|
+
reqType: VirtualAreaEnum.query;
|
|
5
5
|
num: number;
|
|
6
6
|
modes: number[];
|
|
7
7
|
polygons: string[];
|
|
8
8
|
names: string[];
|
|
9
9
|
mapId: number;
|
|
10
|
-
|
|
11
|
-
errCode: number;
|
|
12
|
-
taskId: string;
|
|
13
|
-
};
|
|
10
|
+
}
|
|
14
11
|
type TSetVirtualArea = (message: {
|
|
15
12
|
data: VirtualArea[];
|
|
16
13
|
origin: Point;
|
|
17
|
-
}) => Promise<
|
|
18
|
-
type TRequestVirtualArea = () => Promise<
|
|
14
|
+
}) => Promise<VirtualAreaResponse>;
|
|
15
|
+
type TRequestVirtualArea = () => Promise<VirtualAreaResponse>;
|
|
19
16
|
export declare const useVirtualArea: (devId: string) => {
|
|
20
17
|
requestVirtualArea: TRequestVirtualArea;
|
|
21
18
|
setVirtualArea: TSetVirtualArea;
|