@ray-js/robot-data-stream 0.0.13-beta-7 → 0.0.13-beta-8

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 (55) hide show
  1. package/lib/api/index.d.ts +2 -12
  2. package/lib/api/index.js +1 -172
  3. package/lib/api/p2pApi.d.ts +8 -27
  4. package/lib/api/p2pApi.js +271 -169
  5. package/lib/api/sweeperP2p.d.ts +54 -21
  6. package/lib/api/sweeperP2p.js +324 -245
  7. package/lib/constant.d.ts +0 -52
  8. package/lib/constant.js +0 -54
  9. package/lib/index.d.ts +11 -1
  10. package/lib/index.js +166 -2
  11. package/lib/mqtt/createCommonOptions.d.ts +15 -56
  12. package/lib/mqtt/createCommonOptions.js +8 -44
  13. package/lib/mqtt/mqttProvider.d.ts +15 -23
  14. package/lib/mqtt/mqttProvider.js +26 -63
  15. package/lib/mqtt/myError.d.ts +4 -0
  16. package/lib/mqtt/myError.js +6 -0
  17. package/lib/mqtt/promise.js +3 -8
  18. package/lib/mqtt/type/index.d.ts +0 -9
  19. package/lib/mqtt/type/index.js +0 -8
  20. package/lib/mqtt/type/requestType.d.ts +0 -3
  21. package/lib/mqtt/type/requestType.js +0 -4
  22. package/lib/mqtt/useDevInfo.d.ts +7 -2
  23. package/lib/mqtt/useDevInfo.js +9 -25
  24. package/lib/mqtt/useHistoryMap.d.ts +21 -13
  25. package/lib/mqtt/useHistoryMap.js +32 -82
  26. package/lib/mqtt/usePartDivision.d.ts +7 -5
  27. package/lib/mqtt/usePartDivision.js +16 -41
  28. package/lib/mqtt/usePartMerge.d.ts +7 -5
  29. package/lib/mqtt/usePartMerge.js +18 -36
  30. package/lib/mqtt/usePassword.js +28 -59
  31. package/lib/mqtt/useQuiteHours.d.ts +24 -9
  32. package/lib/mqtt/useQuiteHours.js +52 -95
  33. package/lib/mqtt/useResetMap.d.ts +7 -10
  34. package/lib/mqtt/useResetMap.js +11 -40
  35. package/lib/mqtt/useRoomProperty.js +16 -23
  36. package/lib/mqtt/useSchedule.d.ts +4 -17
  37. package/lib/mqtt/useSchedule.js +49 -101
  38. package/lib/mqtt/useSelectRoomClean.d.ts +16 -20
  39. package/lib/mqtt/useSelectRoomClean.js +49 -145
  40. package/lib/mqtt/useSpotClean.d.ts +3 -3
  41. package/lib/mqtt/useSpotClean.js +51 -71
  42. package/lib/mqtt/useVirtualArea.d.ts +9 -6
  43. package/lib/mqtt/useVirtualArea.js +42 -112
  44. package/lib/mqtt/useVirtualWall.d.ts +10 -13
  45. package/lib/mqtt/useVirtualWall.js +34 -97
  46. package/lib/mqtt/useVoice.d.ts +6 -3
  47. package/lib/mqtt/useVoice.js +33 -73
  48. package/lib/mqtt/useWifiMap.js +18 -34
  49. package/lib/mqtt/useZoneClean.d.ts +13 -13
  50. package/lib/mqtt/useZoneClean.js +76 -149
  51. package/lib/utils/index.d.ts +1 -20
  52. package/lib/utils/index.js +0 -19
  53. package/package.json +1 -1
  54. package/lib/ttt/index.d.ts +0 -153
  55. package/lib/ttt/index.js +0 -458
@@ -1,5 +1,6 @@
1
1
  import "core-js/modules/esnext.iterator.map.js";
2
2
  // 虚拟墙数据
3
+
3
4
  import { useContext } from 'react';
4
5
  import { createSetCommonParams } from './createCommonOptions';
5
6
  import { normalResolve } from './promise';
@@ -7,20 +8,6 @@ import { VirtualWallEnum } from './type';
7
8
  import { SingletonContext } from './mqttProvider';
8
9
  import { encodeVirtualWall0x12, requestVirtualWall0x13 } from '@ray-js/robot-protocol';
9
10
  import { pointsToString } from '../utils';
10
-
11
- // 虚拟墙响应类型
12
-
13
- // 设置虚拟墙参数类型
14
-
15
- // 请求虚拟墙函数类型定义
16
-
17
- // 设置虚拟墙函数类型定义
18
-
19
- /**
20
- * 自定义 Hook,用于虚拟墙管理
21
- * @param devId 设备ID
22
- * @returns 包含 requestVirtualWall 和 setVirtualWall 函数的对象
23
- */
24
11
  export const useVirtualWall = devId => {
25
12
  const {
26
13
  useMqtt,
@@ -28,106 +15,56 @@ export const useVirtualWall = devId => {
28
15
  devices
29
16
  } = useContext(SingletonContext);
30
17
 
31
- /**
32
- * 请求虚拟墙数据
33
- * @returns Promise<VirtualWallResponse> 响应结果
34
- */
18
+ // 请求虚拟墙数据
35
19
 
36
20
  /**
37
21
  * 设置虚拟墙数据
38
- * @param params 包含虚拟墙设置参数的对象
39
- * @param params.data 虚拟墙的点数组
40
- * @param params.origin 原点坐标
41
- * @returns Promise<VirtualWallResponse> 响应结果
22
+ * @param message 包含虚拟墙设置参数的对象
23
+ * @param message.points 虚拟墙的点数组
24
+ * @param message.num 虚拟墙的数量(可选)
25
+ * @param message.mode 虚拟墙的模式数组(可选)
26
+ * @returns Promise<Response> 响应结果
42
27
  */
43
28
 
44
29
  return {
45
30
  requestVirtualWall: () => {
46
- try {
47
- if (useMqtt) {
48
- const params = createSetCommonParams({
49
- deviceId: devId,
50
- reqType: VirtualWallEnum.query
51
- });
52
- ty.device.sendMqttMessage(params);
53
- const {
54
- taskId
55
- } = params.message;
56
- return normalResolve(VirtualWallEnum.query, taskId);
57
- }
58
-
59
- // 非 MQTT 模式:使用命令传输
60
- devices.common.model.actions.command_trans.set(requestVirtualWall0x13({
61
- version: commandVersion
62
- }));
63
-
64
- // 非 MQTT 模式下无法立即获取响应数据,返回默认响应
65
- return Promise.resolve({
66
- success: true,
67
- errCode: 0,
68
- reqType: VirtualWallEnum.query,
69
- version: commandVersion,
70
- taskId: `${Date.now()}`,
71
- num: 0,
72
- modes: [],
73
- points: [],
74
- mapId: 0
31
+ if (useMqtt) {
32
+ const params = createSetCommonParams({
33
+ deviceId: devId,
34
+ reqType: VirtualWallEnum.query
75
35
  });
76
- } catch (error) {
77
- return Promise.reject(error instanceof Error ? error : new Error('Failed to request virtual wall'));
36
+ ty.device.sendMqttMessage(params);
37
+ return normalResolve(VirtualWallEnum.query, params.message.taskId);
78
38
  }
39
+ return devices.common.model.actions.command_trans.set(requestVirtualWall0x13({
40
+ version: commandVersion
41
+ }));
79
42
  },
80
43
  setVirtualWall: _ref => {
81
44
  let {
82
45
  data,
83
46
  origin
84
47
  } = _ref;
85
- // 参数验证
86
- if (!Array.isArray(data) || data.length === 0) {
87
- throw new Error('data is required and must be a non-empty array');
88
- }
89
- if (!origin || typeof origin.x !== 'number' || typeof origin.y !== 'number') {
90
- throw new Error('origin is required and must be a valid Point object with x and y properties');
91
- }
92
- try {
93
- if (useMqtt) {
94
- const params = createSetCommonParams({
95
- deviceId: devId,
96
- reqType: VirtualWallEnum.set,
97
- message: {
98
- points: data.map(points => pointsToString(points, origin)),
99
- num: data.length,
100
- mode: new Array(data.length).fill('0')
101
- }
102
- });
103
- ty.device.sendMqttMessage(params);
104
- const {
105
- taskId
106
- } = params.message;
107
- return normalResolve(VirtualWallEnum.query, taskId);
108
- }
109
-
110
- // 非 MQTT 模式:使用命令传输
111
- const command = encodeVirtualWall0x12({
112
- version: commandVersion,
113
- origin,
114
- walls: data
115
- });
116
- devices.common.model.actions.command_trans.set(command);
117
- return Promise.resolve({
118
- success: true,
119
- errCode: 0,
120
- reqType: VirtualWallEnum.query,
121
- version: commandVersion,
122
- taskId: `${Date.now()}`,
123
- num: data.length,
124
- modes: new Array(data.length).fill(0),
125
- points: data.map(points => pointsToString(points, origin)),
126
- mapId: 0
48
+ if (useMqtt) {
49
+ const params = createSetCommonParams({
50
+ deviceId: devId,
51
+ reqType: VirtualWallEnum.set,
52
+ message: {
53
+ points: data.map(points => pointsToString(points, origin)),
54
+ num: data.length,
55
+ mode: new Array(data.length).fill('0')
56
+ }
127
57
  });
128
- } catch (error) {
129
- throw error instanceof Error ? error : new Error('Failed to set virtual wall');
58
+ ty.device.sendMqttMessage(params);
59
+ return normalResolve(VirtualWallEnum.query, params.message.taskId);
130
60
  }
61
+ const command = encodeVirtualWall0x12({
62
+ version: commandVersion,
63
+ origin,
64
+ walls: data
65
+ });
66
+ devices.common.model.actions.command_trans.set(command);
67
+ return Promise.resolve();
131
68
  }
132
69
  };
133
70
  };
@@ -1,9 +1,12 @@
1
- import { BaseResponse, VoiceLanguageEnum } from './type';
2
- interface VoiceLanguageResponse extends BaseResponse {
3
- reqType: VoiceLanguageEnum.query;
1
+ interface VoiceLanguageResponse {
2
+ reqType: string;
3
+ version: string;
4
4
  id: number;
5
5
  schedule: number;
6
6
  status: number;
7
+ success: boolean;
8
+ errCode: number;
9
+ taskId: string;
7
10
  }
8
11
  type TSetVoice = (message: {
9
12
  id: number;
@@ -7,8 +7,6 @@ import { useContext } from 'react';
7
7
  import { SingletonContext } from './mqttProvider';
8
8
  import { encodeVoice0x34 } from '@ray-js/robot-protocol';
9
9
 
10
- // 语音语言响应类型
11
-
12
10
  // 设置语音语言函数类型定义
13
11
 
14
12
  // 请求当前使用的机器语音
@@ -21,100 +19,62 @@ import { encodeVoice0x34 } from '@ray-js/robot-protocol';
21
19
  export const useVoice = devId => {
22
20
  const {
23
21
  useMqtt,
24
- devices,
25
- commandVersion
22
+ devices
26
23
  } = useContext(SingletonContext);
27
24
  /**
28
25
  * 请求所有语音语言
29
- * @returns Promise<ty.GetVoiceListResponse> 响应结果
26
+ * @returns Promise<any> 响应结果
30
27
  */
31
28
 
32
29
  /**
33
30
  * 请求当前使用的语音语言
34
- * @returns Promise<VoiceLanguageResponse> 响应结果
31
+ * @returns Promise<any> 响应结果
35
32
  */
36
33
 
37
34
  /**
38
35
  * 设置语音语言
39
36
  * @param message 包含语音语言设置参数的对象
40
- * @returns Promise<VoiceLanguageResponse> 响应结果
37
+ * @returns Promise<Response> 响应结果
41
38
  */
42
39
 
43
40
  return {
44
41
  requestAllVoices: async () => {
45
- try {
46
- const res = await getVoiceList({
47
- devId: devId,
48
- offset: 0,
49
- limit: 100
50
- });
51
- return res;
52
- } catch (error) {
53
- throw error instanceof Error ? error : new Error('Failed to request all voices');
54
- }
42
+ const res = await getVoiceList({
43
+ devId: devId,
44
+ offset: 0,
45
+ limit: 100
46
+ });
47
+ return res;
55
48
  },
56
49
  requestVoiceInUse: () => {
57
- if (!useMqtt) {
58
- return Promise.reject(new Error('useMqtt is not used'));
59
- }
60
- try {
50
+ const params = createSetCommonParams({
51
+ deviceId: devId,
52
+ reqType: VoiceLanguageEnum.query
53
+ });
54
+ const {
55
+ taskId
56
+ } = params.message;
57
+ ty.device.sendMqttMessage(params);
58
+ return normalResolve(VoiceLanguageEnum.query, taskId);
59
+ },
60
+ setVoice: message => {
61
+ if (useMqtt) {
62
+ const sendData = _objectSpread(_objectSpread({}, message), {}, {
63
+ urlLen: message.url.length
64
+ });
61
65
  const params = createSetCommonParams({
62
66
  deviceId: devId,
63
- reqType: VoiceLanguageEnum.query
67
+ reqType: VoiceLanguageEnum.set,
68
+ message: sendData
64
69
  });
65
- const {
66
- taskId
67
- } = params.message;
68
70
  ty.device.sendMqttMessage(params);
69
- return normalResolve(VoiceLanguageEnum.query, taskId);
70
- } catch (error) {
71
- return Promise.reject(error instanceof Error ? error : new Error('Failed to request voice in use'));
72
- }
73
- },
74
- setVoice: message => {
75
- // 参数验证
76
- if (!message || typeof message.id !== 'number') {
77
- throw new Error('message.id is required and must be a number');
78
- }
79
- if (!message.url || typeof message.url !== 'string') {
80
- throw new Error('message.url is required and must be a string');
81
- }
82
- if (!message.md5 || typeof message.md5 !== 'string') {
83
- throw new Error('message.md5 is required and must be a string');
84
- }
85
- try {
86
- if (useMqtt) {
87
- const sendData = _objectSpread(_objectSpread({}, message), {}, {
88
- urlLen: message.url.length
89
- });
90
- const params = createSetCommonParams({
91
- deviceId: devId,
92
- reqType: VoiceLanguageEnum.set,
93
- message: sendData
94
- });
95
- ty.device.sendMqttMessage(params);
96
- const {
97
- taskId
98
- } = params.message;
99
- return normalResolve(VoiceLanguageEnum.query, taskId);
100
- }
101
-
102
- // 非 MQTT 模式:使用命令传输
103
- const command = encodeVoice0x34(message);
104
- devices.common.model.actions.voice_data.set(command);
105
- return Promise.resolve({
106
- success: true,
107
- errCode: 0,
108
- reqType: VoiceLanguageEnum.query,
109
- version: commandVersion,
110
- taskId: `${Date.now()}`,
111
- id: message.id,
112
- schedule: 0,
113
- status: 0
114
- });
115
- } catch (error) {
116
- throw error instanceof Error ? error : new Error('Failed to set voice');
71
+ return normalResolve(VoiceLanguageEnum.query, params.message.taskId);
117
72
  }
73
+ const command = encodeVoice0x34(message);
74
+ devices.common.model.actions.voice_data.set(command);
75
+ return Promise.resolve({
76
+ success: true
77
+ });
118
78
  }
119
79
  };
120
80
  };
@@ -8,46 +8,30 @@ export const useWifiMap = devId => {
8
8
  useMqtt
9
9
  } = useContext(SingletonContext);
10
10
 
11
- // 请求 WiFi 地图状态
11
+ // 请求密码状态
12
12
 
13
- // 设置 WiFi 地图
13
+ // 设置密码
14
14
 
15
15
  return {
16
16
  requestWifiMap: () => {
17
- if (!useMqtt) {
18
- return Promise.reject(new Error('useMqtt is not used'));
19
- }
20
- try {
21
- const params = createSetCommonParams({
22
- deviceId: devId,
23
- reqType: WifiMapEnum.query
24
- });
25
- ty.device.sendMqttMessage(params);
26
- const {
27
- taskId
28
- } = params.message;
29
- return normalResolve(WifiMapEnum.query, taskId);
30
- } catch (error) {
31
- return Promise.reject(error instanceof Error ? error : new Error('Failed to request WiFi map'));
32
- }
17
+ if (!useMqtt) return Promise.reject(new Error('useMqtt is not used'));
18
+ const params = createSetCommonParams({
19
+ deviceId: devId,
20
+ reqType: WifiMapEnum.query
21
+ });
22
+ ty.device.sendMqttMessage(params);
23
+ return normalResolve(WifiMapEnum.query, params.message.taskId);
33
24
  },
34
25
  setWifiMap: () => {
35
- try {
36
- const params = createSetCommonParams({
37
- deviceId: devId,
38
- reqType: WifiMapEnum.set,
39
- message: {
40
- taskId: String(Date.now())
41
- }
42
- });
43
- ty.device.sendMqttMessage(params);
44
- const {
45
- taskId
46
- } = params.message;
47
- return normalResolve(WifiMapEnum.rst, taskId);
48
- } catch (error) {
49
- throw error instanceof Error ? error : new Error('Failed to set WiFi map');
50
- }
26
+ const params = createSetCommonParams({
27
+ deviceId: devId,
28
+ reqType: WifiMapEnum.set,
29
+ message: {
30
+ taskId: String(Date.now())
31
+ }
32
+ });
33
+ ty.device.sendMqttMessage(params);
34
+ return normalResolve(WifiMapEnum.rst, params.message.taskId);
51
35
  }
52
36
  };
53
37
  };
@@ -1,28 +1,28 @@
1
- import { BaseResponse, ZoneCleanEnum, RoomPreference } from './type';
1
+ import { RoomPreference } from './type';
2
2
  import { Point, Zone } from '@ray-js/robot-protocol';
3
- interface ZoneCleanResponse extends BaseResponse {
4
- reqType: ZoneCleanEnum.query;
3
+ type Response = {
4
+ reqType: string;
5
+ version: string;
6
+ success: boolean;
7
+ errCode: number;
8
+ taskId: string;
5
9
  polygons: string[];
6
- names?: string[];
7
10
  suctions?: string[];
8
11
  cisterns?: string[];
9
12
  cleanCounts?: number[];
10
13
  yMops?: number[];
11
14
  sweepMopModes?: string[];
12
- }
13
- interface SetZoneCleanParams extends Partial<Pick<RoomPreference, 'suctions' | 'cisterns' | 'cleanCounts' | 'yMops' | 'sweepMopModes'>> {
15
+ };
16
+ type TSetZoneClean = (message: Partial<Pick<RoomPreference, 'suctions' | 'cisterns' | 'cleanCounts' | 'yMops' | 'sweepMopModes'>> & {
14
17
  zones: Zone[];
15
18
  origin: Point;
16
- }
17
- type TRequestZoneClean = () => Promise<ZoneCleanResponse>;
18
- type TSetZoneClean = (params: SetZoneCleanParams) => Promise<ZoneCleanResponse>;
19
+ }) => Promise<Response | void>;
19
20
  /**
20
- * 自定义 Hook,用于划区清扫
21
- * @param devId 设备ID
22
- * @returns 包含 requestZoneClean 和 setZoneClean 函数的对象
21
+ * 划区清扫
22
+ * @returns
23
23
  */
24
24
  export declare const useZoneClean: (devId: string) => {
25
- requestZoneClean: TRequestZoneClean;
25
+ requestZoneClean: () => Promise<Response>;
26
26
  setZoneClean: TSetZoneClean;
27
27
  };
28
28
  export {};