incyclist-devices 1.4.42 → 1.4.45
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/CyclingMode.js +1 -0
- package/lib/Device.js +1 -0
- package/lib/DeviceProtocol.js +1 -0
- package/lib/DeviceSupport.js +25 -8
- package/lib/ant/AntAdapter.js +1 -0
- package/lib/ant/AntScanner.js +24 -7
- package/lib/ant/antfe/AntFEAdapter.js +7 -7
- package/lib/ant/anthrm/AntHrmAdapter.js +1 -1
- package/lib/ant/antpwr/pwr-adapter.js +1 -1
- package/lib/ant/utils.js +3 -1
- package/lib/ble/ble-device.d.ts +10 -3
- package/lib/ble/ble-device.js +144 -32
- package/lib/ble/ble-interface.d.ts +22 -4
- package/lib/ble/ble-interface.js +224 -167
- package/lib/ble/ble.d.ts +20 -1
- package/lib/ble/ble.js +3 -1
- package/lib/ble/fm.d.ts +11 -1
- package/lib/ble/fm.js +109 -11
- package/lib/ble/hrm.d.ts +0 -1
- package/lib/ble/hrm.js +1 -4
- package/lib/ble/incyclist-protocol.js +24 -8
- package/lib/ble/pwr.d.ts +1 -1
- package/lib/ble/pwr.js +14 -4
- package/lib/calculations.js +1 -0
- package/lib/daum/DaumAdapter.js +29 -13
- package/lib/daum/SmartTrainerCyclingMode.js +1 -0
- package/lib/daum/classic/DaumClassicAdapter.js +1 -1
- package/lib/daum/classic/DaumClassicProtocol.js +23 -7
- package/lib/daum/classic/bike.js +26 -26
- package/lib/daum/classic/utils.js +1 -0
- package/lib/daum/constants.js +1 -0
- package/lib/daum/premium/DaumPremiumAdapter.js +1 -1
- package/lib/daum/premium/DaumPremiumProtocol.js +23 -7
- package/lib/daum/premium/bike.js +18 -17
- package/lib/daum/premium/utils.js +1 -0
- package/lib/kettler/comms.d.ts +1 -0
- package/lib/kettler/comms.js +2 -1
- package/lib/kettler/ergo-racer/adapter.js +25 -9
- package/lib/kettler/ergo-racer/protocol.d.ts +1 -1
- package/lib/kettler/ergo-racer/protocol.js +23 -7
- package/lib/modes/power-meter.js +1 -0
- package/lib/simulator/Simulator.d.ts +1 -1
- package/lib/simulator/Simulator.js +24 -7
- package/lib/types/route.js +1 -0
- package/lib/types/user.js +1 -0
- package/lib/utils.js +3 -1
- package/package.json +1 -1
package/lib/ble/fm.js
CHANGED
|
@@ -12,6 +12,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
12
12
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
13
|
};
|
|
14
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.FmAdapter = void 0;
|
|
15
16
|
const ble_device_1 = require("./ble-device");
|
|
16
17
|
const ble_interface_1 = __importDefault(require("./ble-interface"));
|
|
17
18
|
const Device_1 = __importDefault(require("../Device"));
|
|
@@ -33,17 +34,101 @@ const IndoorBikeDataFlag = {
|
|
|
33
34
|
ElapsedTimePresent: bit(11),
|
|
34
35
|
RemainingTimePresent: bit(12)
|
|
35
36
|
};
|
|
37
|
+
const FitnessMachineFeatureFlag = {
|
|
38
|
+
AverageSpeedSupported: bit(0),
|
|
39
|
+
CadenceSupported: bit(1),
|
|
40
|
+
TotalDistanceSupported: bit(2),
|
|
41
|
+
InclinationSupported: bit(3),
|
|
42
|
+
ElevationGainSupported: bit(4),
|
|
43
|
+
PaceSupported: bit(5),
|
|
44
|
+
StepCountSupported: bit(6),
|
|
45
|
+
ResistanceLevelSupported: bit(7),
|
|
46
|
+
StrideCountSupported: bit(8),
|
|
47
|
+
ExpendedEnergySupported: bit(9),
|
|
48
|
+
HeartRateMeasurementSupported: bit(10),
|
|
49
|
+
MetabolicEquivalentSupported: bit(11),
|
|
50
|
+
ElapsedTimeSupported: bit(12),
|
|
51
|
+
RemainingTimeSupported: bit(13),
|
|
52
|
+
PowerMeasurementSupported: bit(14),
|
|
53
|
+
ForceOnBeltAndPowerOutputSupported: bit(15),
|
|
54
|
+
UserDataRetentionSupported: bit(16)
|
|
55
|
+
};
|
|
56
|
+
const TargetSettingFeatureFlag = {
|
|
57
|
+
SpeedTargetSettingSupported: bit(0),
|
|
58
|
+
InclinationTargetSettingSupported: bit(1),
|
|
59
|
+
ResistanceTargetSettingSupported: bit(2),
|
|
60
|
+
PowerTargetSettingSupported: bit(3),
|
|
61
|
+
HeartRateTargetSettingSupported: bit(4),
|
|
62
|
+
TargetedExpendedEnergyConfigurationSupported: bit(5),
|
|
63
|
+
TargetedStepNumberConfigurationSupported: bit(6),
|
|
64
|
+
TargetedStrideNumberConfigurationSupported: bit(7),
|
|
65
|
+
TargetedDistanceConfigurationSupported: bit(8),
|
|
66
|
+
TargetedTrainingTimeConfigurationSupported: bit(9),
|
|
67
|
+
TargetedTimeInTwoHeartRateZonesConfigurationSupported: bit(10),
|
|
68
|
+
TargetedTimeInThreeHeartRateZonesConfigurationSupported: bit(11),
|
|
69
|
+
TargetedTimeInFiveHeartRateZonesConfigurationSupported: bit(12),
|
|
70
|
+
IndoorBikeSimulationParametersSupported: bit(13),
|
|
71
|
+
WheelCircumferenceConfigurationSupported: bit(14),
|
|
72
|
+
SpinDownControlSupported: bit(15),
|
|
73
|
+
TargetedCadenceConfigurationSupported: bit(16)
|
|
74
|
+
};
|
|
36
75
|
class BleFitnessMachineDevice extends ble_device_1.BleDevice {
|
|
37
76
|
constructor(props) {
|
|
38
77
|
super(props);
|
|
78
|
+
this.features = undefined;
|
|
39
79
|
this.data = {};
|
|
40
80
|
}
|
|
81
|
+
init() {
|
|
82
|
+
const _super = Object.create(null, {
|
|
83
|
+
init: { get: () => super.init }
|
|
84
|
+
});
|
|
85
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
86
|
+
try {
|
|
87
|
+
yield _super.init.call(this);
|
|
88
|
+
yield this.getFitnessMachineFeatures();
|
|
89
|
+
}
|
|
90
|
+
catch (err) {
|
|
91
|
+
return Promise.resolve(false);
|
|
92
|
+
}
|
|
93
|
+
});
|
|
94
|
+
}
|
|
41
95
|
getProfile() {
|
|
42
96
|
return 'Smart Trainer';
|
|
43
97
|
}
|
|
44
98
|
getServiceUUids() {
|
|
45
99
|
return BleFitnessMachineDevice.services;
|
|
46
100
|
}
|
|
101
|
+
isBike() {
|
|
102
|
+
return this.features !== undefined &&
|
|
103
|
+
(this.features.targetSettings & TargetSettingFeatureFlag.IndoorBikeSimulationParametersSupported) !== 0;
|
|
104
|
+
}
|
|
105
|
+
isPower() {
|
|
106
|
+
if (this.hasService('1818'))
|
|
107
|
+
return true;
|
|
108
|
+
if (this.features === undefined)
|
|
109
|
+
return false;
|
|
110
|
+
const { fitnessMachine } = this.features;
|
|
111
|
+
if (fitnessMachine & FitnessMachineFeatureFlag.PowerMeasurementSupported)
|
|
112
|
+
return true;
|
|
113
|
+
}
|
|
114
|
+
isHrm() {
|
|
115
|
+
return this.hasService('180d');
|
|
116
|
+
}
|
|
117
|
+
parseHrm(_data) {
|
|
118
|
+
const data = Buffer.from(_data);
|
|
119
|
+
try {
|
|
120
|
+
const flags = data.readUInt8(0);
|
|
121
|
+
if (flags % 1 === 0) {
|
|
122
|
+
this.data.heartrate = data.readUInt8(1);
|
|
123
|
+
}
|
|
124
|
+
else {
|
|
125
|
+
this.data.heartrate = data.readUInt16LE(1);
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
catch (err) {
|
|
129
|
+
}
|
|
130
|
+
return Object.assign(Object.assign({}, this.data), { raw: data.toString('hex') });
|
|
131
|
+
}
|
|
47
132
|
parseIndoorBikeData(_data) {
|
|
48
133
|
const data = Buffer.from(_data);
|
|
49
134
|
const flags = data.readUInt16LE(0);
|
|
@@ -53,7 +138,7 @@ class BleFitnessMachineDevice extends ble_device_1.BleDevice {
|
|
|
53
138
|
offset += 2;
|
|
54
139
|
}
|
|
55
140
|
if (flags & IndoorBikeDataFlag.AverageSpeedPresent) {
|
|
56
|
-
this.data.averageSpeed = data.readUInt16LE(offset);
|
|
141
|
+
this.data.averageSpeed = data.readUInt16LE(offset) / 100;
|
|
57
142
|
offset += 2;
|
|
58
143
|
}
|
|
59
144
|
if (flags & IndoorBikeDataFlag.InstantaneousCadence) {
|
|
@@ -61,7 +146,7 @@ class BleFitnessMachineDevice extends ble_device_1.BleDevice {
|
|
|
61
146
|
offset += 2;
|
|
62
147
|
}
|
|
63
148
|
if (flags & IndoorBikeDataFlag.AverageCadencePresent) {
|
|
64
|
-
this.data.averageCadence = data.readUInt16LE(offset);
|
|
149
|
+
this.data.averageCadence = data.readUInt16LE(offset) / 2;
|
|
65
150
|
offset += 2;
|
|
66
151
|
}
|
|
67
152
|
if (flags & IndoorBikeDataFlag.TotalDistancePresent) {
|
|
@@ -89,7 +174,7 @@ class BleFitnessMachineDevice extends ble_device_1.BleDevice {
|
|
|
89
174
|
offset += 2;
|
|
90
175
|
}
|
|
91
176
|
if (flags & IndoorBikeDataFlag.MetabolicEquivalentPresent) {
|
|
92
|
-
this.data.metabolicEquivalent = data.readUInt16LE(offset);
|
|
177
|
+
this.data.metabolicEquivalent = data.readUInt16LE(offset) / 10;
|
|
93
178
|
offset += 2;
|
|
94
179
|
}
|
|
95
180
|
if (flags & IndoorBikeDataFlag.ElapsedTimePresent) {
|
|
@@ -102,21 +187,34 @@ class BleFitnessMachineDevice extends ble_device_1.BleDevice {
|
|
|
102
187
|
}
|
|
103
188
|
return Object.assign(Object.assign({}, this.data), { raw: data.toString('hex') });
|
|
104
189
|
}
|
|
190
|
+
getFitnessMachineFeatures() {
|
|
191
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
192
|
+
if (this.features)
|
|
193
|
+
return this.features;
|
|
194
|
+
try {
|
|
195
|
+
const data = yield this.read('2acc');
|
|
196
|
+
this.features.fitnessMachine = data.readUInt32LE(0);
|
|
197
|
+
this.features.targetSettings = data.readUInt32LE(4);
|
|
198
|
+
}
|
|
199
|
+
catch (err) {
|
|
200
|
+
this.logEvent({ message: 'could not read FitnessMachineFeatures', error: err.message, stack: err.stack });
|
|
201
|
+
}
|
|
202
|
+
});
|
|
203
|
+
}
|
|
105
204
|
onData(characteristic, data) {
|
|
106
|
-
console.log(characteristic.toLocaleLowerCase(), data);
|
|
107
205
|
if (characteristic.toLocaleLowerCase() === '2ad2') {
|
|
108
206
|
const res = this.parseIndoorBikeData(data);
|
|
109
207
|
this.emit('data', res);
|
|
110
208
|
}
|
|
209
|
+
if (characteristic.toLocaleLowerCase() === '2a37') {
|
|
210
|
+
const res = this.parseHrm(data);
|
|
211
|
+
this.emit('data', res);
|
|
212
|
+
}
|
|
111
213
|
}
|
|
112
214
|
write(characteristic, data) {
|
|
113
215
|
console.log('write', characteristic, data);
|
|
114
216
|
return Promise.resolve(true);
|
|
115
217
|
}
|
|
116
|
-
read(characteristic) {
|
|
117
|
-
console.log('read', characteristic);
|
|
118
|
-
return Promise.resolve(Buffer.from([]));
|
|
119
|
-
}
|
|
120
218
|
reset() {
|
|
121
219
|
this.data = {};
|
|
122
220
|
}
|
|
@@ -136,9 +234,9 @@ class FmAdapter extends Device_1.default {
|
|
|
136
234
|
this.mode = this.getDefaultCyclingMode();
|
|
137
235
|
this.logger = new gd_eventlog_1.EventLogger('BLE-FM');
|
|
138
236
|
}
|
|
139
|
-
isBike() { return
|
|
140
|
-
isHrm() { return
|
|
141
|
-
isPower() { return
|
|
237
|
+
isBike() { return this.device.isBike(); }
|
|
238
|
+
isHrm() { return this.device.isHrm(); }
|
|
239
|
+
isPower() { return this.device.isPower(); }
|
|
142
240
|
getProfile() {
|
|
143
241
|
return 'Smart Trainer';
|
|
144
242
|
}
|
package/lib/ble/hrm.d.ts
CHANGED
|
@@ -22,7 +22,6 @@ export default class BleHrmDevice extends BleDevice {
|
|
|
22
22
|
parseHrm(_data: Uint8Array): HrmData;
|
|
23
23
|
onData(characteristic: string, data: Buffer): void;
|
|
24
24
|
write(characteristic: any, data: any): Promise<boolean>;
|
|
25
|
-
read(characteristic: any): Promise<Buffer>;
|
|
26
25
|
}
|
|
27
26
|
export declare class HrmAdapter extends DeviceAdapter {
|
|
28
27
|
device: BleHrmDevice;
|
package/lib/ble/hrm.js
CHANGED
|
@@ -12,6 +12,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
12
12
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
13
|
};
|
|
14
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.HrmAdapter = void 0;
|
|
15
16
|
const ble_device_1 = require("./ble-device");
|
|
16
17
|
const ble_interface_1 = __importDefault(require("./ble-interface"));
|
|
17
18
|
const Device_1 = __importDefault(require("../Device"));
|
|
@@ -59,10 +60,6 @@ class BleHrmDevice extends ble_device_1.BleDevice {
|
|
|
59
60
|
console.log('write', characteristic, data);
|
|
60
61
|
return Promise.resolve(true);
|
|
61
62
|
}
|
|
62
|
-
read(characteristic) {
|
|
63
|
-
console.log('read', characteristic);
|
|
64
|
-
return Promise.resolve(Buffer.from([]));
|
|
65
|
-
}
|
|
66
63
|
}
|
|
67
64
|
exports.default = BleHrmDevice;
|
|
68
65
|
BleHrmDevice.services = ['180d'];
|
|
@@ -1,4 +1,27 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
2
25
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
26
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
27
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
@@ -8,13 +31,6 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
8
31
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
32
|
});
|
|
10
33
|
};
|
|
11
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
12
|
-
if (mod && mod.__esModule) return mod;
|
|
13
|
-
var result = {};
|
|
14
|
-
if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];
|
|
15
|
-
result["default"] = mod;
|
|
16
|
-
return result;
|
|
17
|
-
};
|
|
18
34
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
19
35
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
20
36
|
};
|
|
@@ -88,7 +104,7 @@ class BleProtocol extends DeviceProtocol_1.default {
|
|
|
88
104
|
}
|
|
89
105
|
});
|
|
90
106
|
this.logger.logEvent({ message: 'scan started' });
|
|
91
|
-
yield this.ble.scan({ deviceTypes: supportedDeviceTypes });
|
|
107
|
+
yield this.ble.scan({ deviceTypes: supportedDeviceTypes, timeout: 20000 });
|
|
92
108
|
if (props && props.onScanFinished) {
|
|
93
109
|
props.onScanFinished(props.id);
|
|
94
110
|
}
|
package/lib/ble/pwr.d.ts
CHANGED
|
@@ -33,6 +33,7 @@ export default class BleCyclingPowerDevice extends BleDevice {
|
|
|
33
33
|
currentCrankData: CrankData;
|
|
34
34
|
prevCrankData: CrankData;
|
|
35
35
|
constructor(props?: any);
|
|
36
|
+
init(): Promise<boolean>;
|
|
36
37
|
getProfile(): string;
|
|
37
38
|
getServiceUUids(): string[];
|
|
38
39
|
parseCrankData(crankData: any): {
|
|
@@ -42,7 +43,6 @@ export default class BleCyclingPowerDevice extends BleDevice {
|
|
|
42
43
|
parsePower(_data: Uint8Array): PowerData;
|
|
43
44
|
onData(characteristic: string, data: Buffer): void;
|
|
44
45
|
write(characteristic: any, data: any): Promise<boolean>;
|
|
45
|
-
read(characteristic: any): Promise<Buffer>;
|
|
46
46
|
reset(): void;
|
|
47
47
|
}
|
|
48
48
|
export declare class PwrAdapter extends DeviceAdapter {
|
package/lib/ble/pwr.js
CHANGED
|
@@ -12,6 +12,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
12
12
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
13
|
};
|
|
14
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.PwrAdapter = void 0;
|
|
15
16
|
const ble_device_1 = require("./ble-device");
|
|
16
17
|
const ble_interface_1 = __importDefault(require("./ble-interface"));
|
|
17
18
|
const Device_1 = __importDefault(require("../Device"));
|
|
@@ -29,6 +30,19 @@ class BleCyclingPowerDevice extends ble_device_1.BleDevice {
|
|
|
29
30
|
this.currentCrankData = undefined;
|
|
30
31
|
this.prevCrankData = undefined;
|
|
31
32
|
}
|
|
33
|
+
init() {
|
|
34
|
+
const _super = Object.create(null, {
|
|
35
|
+
init: { get: () => super.init }
|
|
36
|
+
});
|
|
37
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
38
|
+
try {
|
|
39
|
+
yield _super.init.call(this);
|
|
40
|
+
}
|
|
41
|
+
catch (err) {
|
|
42
|
+
return Promise.resolve(false);
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
}
|
|
32
46
|
getProfile() {
|
|
33
47
|
return 'Power Meter';
|
|
34
48
|
}
|
|
@@ -104,10 +118,6 @@ class BleCyclingPowerDevice extends ble_device_1.BleDevice {
|
|
|
104
118
|
console.log('write', characteristic, data);
|
|
105
119
|
return Promise.resolve(true);
|
|
106
120
|
}
|
|
107
|
-
read(characteristic) {
|
|
108
|
-
console.log('read', characteristic);
|
|
109
|
-
return Promise.resolve(Buffer.from([]));
|
|
110
|
-
}
|
|
111
121
|
reset() {
|
|
112
122
|
this.instantaneousPower = undefined;
|
|
113
123
|
this.balance = undefined;
|
package/lib/calculations.js
CHANGED
package/lib/daum/DaumAdapter.js
CHANGED
|
@@ -1,4 +1,27 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
2
25
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
26
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
27
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
@@ -8,13 +31,6 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
8
31
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
32
|
});
|
|
10
33
|
};
|
|
11
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
12
|
-
if (mod && mod.__esModule) return mod;
|
|
13
|
-
var result = {};
|
|
14
|
-
if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];
|
|
15
|
-
result["default"] = mod;
|
|
16
|
-
return result;
|
|
17
|
-
};
|
|
18
34
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
19
35
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
20
36
|
};
|
|
@@ -300,16 +316,16 @@ class DaumAdapterBase extends Device_1.default {
|
|
|
300
316
|
return;
|
|
301
317
|
let distance = 0;
|
|
302
318
|
if (this.distanceInternal !== undefined && this.cyclingData.distanceInternal !== undefined) {
|
|
303
|
-
distance = utils_1.intVal(this.cyclingData.distanceInternal - this.distanceInternal);
|
|
319
|
+
distance = (0, utils_1.intVal)(this.cyclingData.distanceInternal - this.distanceInternal);
|
|
304
320
|
}
|
|
305
321
|
if (this.cyclingData.distanceInternal !== undefined)
|
|
306
322
|
this.distanceInternal = this.cyclingData.distanceInternal;
|
|
307
323
|
let data = {
|
|
308
|
-
speed: utils_1.floatVal(this.cyclingData.speed),
|
|
309
|
-
slope: utils_1.floatVal(this.cyclingData.slope),
|
|
310
|
-
power: utils_1.intVal(this.cyclingData.power),
|
|
311
|
-
cadence: utils_1.intVal(this.cyclingData.pedalRpm),
|
|
312
|
-
heartrate: utils_1.intVal(this.cyclingData.heartrate),
|
|
324
|
+
speed: (0, utils_1.floatVal)(this.cyclingData.speed),
|
|
325
|
+
slope: (0, utils_1.floatVal)(this.cyclingData.slope),
|
|
326
|
+
power: (0, utils_1.intVal)(this.cyclingData.power),
|
|
327
|
+
cadence: (0, utils_1.intVal)(this.cyclingData.pedalRpm),
|
|
328
|
+
heartrate: (0, utils_1.intVal)(this.cyclingData.heartrate),
|
|
313
329
|
distance,
|
|
314
330
|
timestamp: Date.now(),
|
|
315
331
|
deviceTime: this.cyclingData.time,
|
|
@@ -3,6 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.direction = void 0;
|
|
6
7
|
const gd_eventlog_1 = require("gd-eventlog");
|
|
7
8
|
const CyclingMode_1 = require("../CyclingMode");
|
|
8
9
|
const calculations_1 = __importDefault(require("../calculations"));
|
|
@@ -86,7 +86,7 @@ class DaumClassicAdapter extends DaumAdapter_1.default {
|
|
|
86
86
|
const { user } = props;
|
|
87
87
|
this.initData();
|
|
88
88
|
let startState = {};
|
|
89
|
-
return utils_1.runWithRetries(() => __awaiter(this, void 0, void 0, function* () {
|
|
89
|
+
return (0, utils_1.runWithRetries)(() => __awaiter(this, void 0, void 0, function* () {
|
|
90
90
|
try {
|
|
91
91
|
if (!this.bike.isConnected())
|
|
92
92
|
yield this.bike.saveConnect();
|
|
@@ -1,4 +1,27 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
2
25
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
26
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
27
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
@@ -8,13 +31,6 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
8
31
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
32
|
});
|
|
10
33
|
};
|
|
11
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
12
|
-
if (mod && mod.__esModule) return mod;
|
|
13
|
-
var result = {};
|
|
14
|
-
if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];
|
|
15
|
-
result["default"] = mod;
|
|
16
|
-
return result;
|
|
17
|
-
};
|
|
18
34
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
19
35
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
20
36
|
};
|
package/lib/daum/classic/bike.js
CHANGED
|
@@ -52,9 +52,9 @@ class Daum8008 {
|
|
|
52
52
|
}
|
|
53
53
|
getUserWeight() {
|
|
54
54
|
if (this.settings && this.settings.user && this.settings.user.weight)
|
|
55
|
-
return utils_1.getWeight(this.settings.user.weight);
|
|
55
|
+
return (0, utils_1.getWeight)(this.settings.user.weight);
|
|
56
56
|
else
|
|
57
|
-
return utils_1.getWeight();
|
|
57
|
+
return (0, utils_1.getWeight)();
|
|
58
58
|
}
|
|
59
59
|
getBikeWeight() {
|
|
60
60
|
if (this.settings && this.settings.weight) {
|
|
@@ -274,7 +274,7 @@ class Daum8008 {
|
|
|
274
274
|
};
|
|
275
275
|
this.queue.enqueue(cmdInfo);
|
|
276
276
|
if (this.queue.size() > 1)
|
|
277
|
-
this.logger.logEvent({ message: "sendCommand:adding:", cmd: logStr, hex: utils_1.hexstr(payload), queueSize: this.queue.size() });
|
|
277
|
+
this.logger.logEvent({ message: "sendCommand:adding:", cmd: logStr, hex: (0, utils_1.hexstr)(payload), queueSize: this.queue.size() });
|
|
278
278
|
if (this.bikeCmdWorker === undefined) {
|
|
279
279
|
this.startWorker();
|
|
280
280
|
}
|
|
@@ -293,7 +293,7 @@ class Daum8008 {
|
|
|
293
293
|
const parser = serialPort.pipe(new ByteLength({ length: expected }));
|
|
294
294
|
parser.on('data', (data) => {
|
|
295
295
|
let duration = Date.now() - this.cmdStart;
|
|
296
|
-
this.logger.logEvent({ message: "sendCommand:received:", duration, hex: utils_1.hexstr(data), port: this.getPort() });
|
|
296
|
+
this.logger.logEvent({ message: "sendCommand:received:", duration, hex: (0, utils_1.hexstr)(data), port: this.getPort() });
|
|
297
297
|
serialPort.unpipe();
|
|
298
298
|
if (callbackErr !== undefined) {
|
|
299
299
|
if (data[0] !== payload[0]) {
|
|
@@ -306,7 +306,7 @@ class Daum8008 {
|
|
|
306
306
|
callback(data);
|
|
307
307
|
done();
|
|
308
308
|
});
|
|
309
|
-
this.logger.logEvent({ message: "sendCommand:sending:", cmd: logStr, hex: utils_1.hexstr(payload), port: this.getPort() });
|
|
309
|
+
this.logger.logEvent({ message: "sendCommand:sending:", cmd: logStr, hex: (0, utils_1.hexstr)(payload), port: this.getPort() });
|
|
310
310
|
this.cmdCurrent.start = this.cmdStart = Date.now();
|
|
311
311
|
serialPort.write(payload);
|
|
312
312
|
}
|
|
@@ -321,53 +321,53 @@ class Daum8008 {
|
|
|
321
321
|
this.sendDaum8008Command(`checkCockpit(${bikeNo})`, [0x10, bikeNo], 3, (data) => resolve({ bike: data[1], version: data[2] }), (status, err) => {
|
|
322
322
|
if (status === 408)
|
|
323
323
|
return resolve({ bike: bikeNo, version: undefined });
|
|
324
|
-
reject(utils_1.buildError(status, err));
|
|
324
|
+
reject((0, utils_1.buildError)(status, err));
|
|
325
325
|
});
|
|
326
326
|
});
|
|
327
327
|
}
|
|
328
328
|
getAddress() {
|
|
329
329
|
return new Promise((resolve, reject) => {
|
|
330
|
-
this.sendDaum8008Command(`getAddress()`, [0x11], 2, (data) => resolve({ bike: data[1] }), (status, err) => reject(utils_1.buildError(status, err)));
|
|
330
|
+
this.sendDaum8008Command(`getAddress()`, [0x11], 2, (data) => resolve({ bike: data[1] }), (status, err) => reject((0, utils_1.buildError)(status, err)));
|
|
331
331
|
});
|
|
332
332
|
}
|
|
333
333
|
getVersion(bikeNo = 0) {
|
|
334
334
|
return new Promise((resolve, reject) => {
|
|
335
|
-
this.sendDaum8008Command(`getVersion(${bikeNo})`, [0x73, bikeNo], 11, (data) => resolve({ bike: data[1], serialNo: utils_1.hexstr(data, 2, 8), cockpit: utils_1.getCockpit(data[10]) }), (status, err) => reject(utils_1.buildError(status, err)));
|
|
335
|
+
this.sendDaum8008Command(`getVersion(${bikeNo})`, [0x73, bikeNo], 11, (data) => resolve({ bike: data[1], serialNo: (0, utils_1.hexstr)(data, 2, 8), cockpit: (0, utils_1.getCockpit)(data[10]) }), (status, err) => reject((0, utils_1.buildError)(status, err)));
|
|
336
336
|
});
|
|
337
337
|
}
|
|
338
338
|
resetDevice(bikeNo = 0) {
|
|
339
339
|
return new Promise((resolve, reject) => {
|
|
340
|
-
this.sendDaum8008Command(`resetDevice(${bikeNo})`, [0x12, bikeNo], 2, (data) => resolve({}), (status, err) => reject(utils_1.buildError(status, err)));
|
|
340
|
+
this.sendDaum8008Command(`resetDevice(${bikeNo})`, [0x12, bikeNo], 2, (data) => resolve({}), (status, err) => reject((0, utils_1.buildError)(status, err)));
|
|
341
341
|
});
|
|
342
342
|
}
|
|
343
343
|
startProg(bikeNo = 0) {
|
|
344
344
|
return new Promise((resolve, reject) => {
|
|
345
|
-
this.sendDaum8008Command(`startProg(${bikeNo})`, [0x21, bikeNo], 3, (data) => resolve({ bike: data[1], pedalling: data[2] > 0 }), (status, err) => reject(utils_1.buildError(status, err)));
|
|
345
|
+
this.sendDaum8008Command(`startProg(${bikeNo})`, [0x21, bikeNo], 3, (data) => resolve({ bike: data[1], pedalling: data[2] > 0 }), (status, err) => reject((0, utils_1.buildError)(status, err)));
|
|
346
346
|
});
|
|
347
347
|
}
|
|
348
348
|
stopProg(bikeNo = 0) {
|
|
349
349
|
return new Promise((resolve, reject) => {
|
|
350
|
-
this.sendDaum8008Command(`stopProg(${bikeNo})`, [0x22, bikeNo], 3, (data) => resolve({ bike: data[1], pedalling: data[2] !== 0 }), (status, err) => reject(utils_1.buildError(status, err)));
|
|
350
|
+
this.sendDaum8008Command(`stopProg(${bikeNo})`, [0x22, bikeNo], 3, (data) => resolve({ bike: data[1], pedalling: data[2] !== 0 }), (status, err) => reject((0, utils_1.buildError)(status, err)));
|
|
351
351
|
});
|
|
352
352
|
}
|
|
353
353
|
setProg(progNo = 0, bikeNo = 0) {
|
|
354
354
|
return new Promise((resolve, reject) => {
|
|
355
|
-
this.sendDaum8008Command(`setProg(${bikeNo},${progNo})`, [0x23, bikeNo, progNo], 4, (data) => resolve({ bike: data[1], progNo: data[2], pedalling: data[3] !== 0 }), (status, err) => reject(utils_1.buildError(status, err)));
|
|
355
|
+
this.sendDaum8008Command(`setProg(${bikeNo},${progNo})`, [0x23, bikeNo, progNo], 4, (data) => resolve({ bike: data[1], progNo: data[2], pedalling: data[3] !== 0 }), (status, err) => reject((0, utils_1.buildError)(status, err)));
|
|
356
356
|
});
|
|
357
357
|
}
|
|
358
358
|
setBikeType(bikeType, bikeNo = 0) {
|
|
359
|
-
const bikeVal = utils_1.getBikeType(bikeType);
|
|
359
|
+
const bikeVal = (0, utils_1.getBikeType)(bikeType);
|
|
360
360
|
return new Promise((resolve, reject) => {
|
|
361
|
-
this.sendDaum8008Command(`setBikeType(${bikeNo},${bikeType})`, [0x69, bikeNo, 0, 0, bikeVal], 3, (data) => resolve({}), (status, err) => reject(utils_1.buildError(status, err)));
|
|
361
|
+
this.sendDaum8008Command(`setBikeType(${bikeNo},${bikeType})`, [0x69, bikeNo, 0, 0, bikeVal], 3, (data) => resolve({}), (status, err) => reject((0, utils_1.buildError)(status, err)));
|
|
362
362
|
});
|
|
363
363
|
}
|
|
364
364
|
setPerson(user = {}, bikeNo = 0) {
|
|
365
365
|
const age = user.age !== undefined ? user.age : utils_1.DEFAULT_AGE;
|
|
366
|
-
const gender = utils_1.getGender(user.sex);
|
|
367
|
-
const length = utils_1.getLength(user.length);
|
|
366
|
+
const gender = (0, utils_1.getGender)(user.sex);
|
|
367
|
+
const length = (0, utils_1.getLength)(user.length);
|
|
368
368
|
const maxPower = this.settings.maxPower === undefined ? 800 : this.settings.maxPower;
|
|
369
369
|
const mUser = user.weight || this.getUserWeight();
|
|
370
|
-
const weight = utils_1.getWeight(mUser) + this.getBikeWeight();
|
|
370
|
+
const weight = (0, utils_1.getWeight)(mUser) + this.getBikeWeight();
|
|
371
371
|
var cmd = [0x24, bikeNo, 0];
|
|
372
372
|
cmd.push(age);
|
|
373
373
|
cmd.push(gender);
|
|
@@ -390,26 +390,26 @@ class Daum8008 {
|
|
|
390
390
|
if (data[i] === 0 || data[i] === 80)
|
|
391
391
|
return;
|
|
392
392
|
}
|
|
393
|
-
reject(utils_1.buildError(512, 'illegal response'));
|
|
393
|
+
reject((0, utils_1.buildError)(512, 'illegal response'));
|
|
394
394
|
ok = false;
|
|
395
395
|
}
|
|
396
396
|
});
|
|
397
397
|
if (ok)
|
|
398
398
|
resolve({ bike: data[1], age, gender, length, weight });
|
|
399
|
-
}, (status, err) => reject(utils_1.buildError(status, err)));
|
|
399
|
+
}, (status, err) => reject((0, utils_1.buildError)(status, err)));
|
|
400
400
|
});
|
|
401
401
|
}
|
|
402
402
|
runData(bikeNo = 0) {
|
|
403
403
|
return new Promise((resolve, reject) => {
|
|
404
404
|
this.sendDaum8008Command(`runData(${bikeNo})`, [0x40, bikeNo], 19, (data) => {
|
|
405
405
|
try {
|
|
406
|
-
const parsed = utils_1.parseRunData(data);
|
|
406
|
+
const parsed = (0, utils_1.parseRunData)(data);
|
|
407
407
|
resolve(parsed);
|
|
408
408
|
}
|
|
409
409
|
catch (e) {
|
|
410
|
-
reject(utils_1.buildError(500, e));
|
|
410
|
+
reject((0, utils_1.buildError)(500, e));
|
|
411
411
|
}
|
|
412
|
-
}, (status, err) => reject(utils_1.buildError(status, err)));
|
|
412
|
+
}, (status, err) => reject((0, utils_1.buildError)(status, err)));
|
|
413
413
|
});
|
|
414
414
|
}
|
|
415
415
|
setGear(gear, bikeNo = 0) {
|
|
@@ -419,7 +419,7 @@ class Daum8008 {
|
|
|
419
419
|
if (gear > 28)
|
|
420
420
|
gearVal = 28;
|
|
421
421
|
return new Promise((resolve, reject) => {
|
|
422
|
-
this.sendDaum8008Command(`setGear(${bikeNo},${gearVal})`, [0x53, bikeNo, gearVal], 3, (data) => resolve({ bike: data[1], gear: data[2] }), (status, err) => reject(utils_1.buildError(status, err)));
|
|
422
|
+
this.sendDaum8008Command(`setGear(${bikeNo},${gearVal})`, [0x53, bikeNo, gearVal], 3, (data) => resolve({ bike: data[1], gear: data[2] }), (status, err) => reject((0, utils_1.buildError)(status, err)));
|
|
423
423
|
});
|
|
424
424
|
}
|
|
425
425
|
setPower(power, bikeNo = 0) {
|
|
@@ -434,7 +434,7 @@ class Daum8008 {
|
|
|
434
434
|
if (power > 800)
|
|
435
435
|
powerRequest = 800;
|
|
436
436
|
const powerVal = Math.round(powerRequest / 5);
|
|
437
|
-
this.sendDaum8008Command(`setPower(${bikeNo},${power})`, [0x51, bikeNo, powerVal], 3, (data) => resolve({ bike: data[1], power: (data[2] * 5) }), (status, err) => reject(utils_1.buildError(status, err)));
|
|
437
|
+
this.sendDaum8008Command(`setPower(${bikeNo},${power})`, [0x51, bikeNo, powerVal], 3, (data) => resolve({ bike: data[1], power: (data[2] * 5) }), (status, err) => reject((0, utils_1.buildError)(status, err)));
|
|
438
438
|
});
|
|
439
439
|
}
|
|
440
440
|
setSlope(slope, bikeNo = 0) {
|
|
@@ -444,12 +444,12 @@ class Daum8008 {
|
|
|
444
444
|
return;
|
|
445
445
|
}
|
|
446
446
|
const cmd = [0x55, bikeNo];
|
|
447
|
-
const arr = utils_1.Float32ToIntArray(slope);
|
|
447
|
+
const arr = (0, utils_1.Float32ToIntArray)(slope);
|
|
448
448
|
cmd.push(arr[3]);
|
|
449
449
|
cmd.push(arr[2]);
|
|
450
450
|
cmd.push(arr[1]);
|
|
451
451
|
cmd.push(arr[0]);
|
|
452
|
-
this.sendDaum8008Command(`setSlope(${bikeNo},${slope})`, cmd, 6, (data) => resolve({ bike: data[1], slope: slope }), (status, err) => reject(utils_1.buildError(status, err)));
|
|
452
|
+
this.sendDaum8008Command(`setSlope(${bikeNo},${slope})`, cmd, 6, (data) => resolve({ bike: data[1], slope: slope }), (status, err) => reject((0, utils_1.buildError)(status, err)));
|
|
453
453
|
});
|
|
454
454
|
}
|
|
455
455
|
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Float32ToIntArray = exports.Float32ToHex = exports.hexstr = exports.buildError = exports.parseRunData = exports.getWeight = exports.getLength = exports.getGender = exports.getBikeType = exports.getCockpit = exports.DEFAULT_BIKE_WEIGHT = exports.DEFAULT_USER_WEIGHT = exports.DEFAULT_AGE = void 0;
|
|
3
4
|
exports.DEFAULT_AGE = 30;
|
|
4
5
|
exports.DEFAULT_USER_WEIGHT = 75;
|
|
5
6
|
exports.DEFAULT_BIKE_WEIGHT = 10;
|
package/lib/daum/constants.js
CHANGED
|
@@ -72,7 +72,7 @@ class DaumPremiumDevice extends DaumAdapter_1.default {
|
|
|
72
72
|
const route = opts.route;
|
|
73
73
|
var info = {};
|
|
74
74
|
this.initData();
|
|
75
|
-
return utils_1.runWithRetries(() => __awaiter(this, void 0, void 0, function* () {
|
|
75
|
+
return (0, utils_1.runWithRetries)(() => __awaiter(this, void 0, void 0, function* () {
|
|
76
76
|
if (this.isStopped())
|
|
77
77
|
return;
|
|
78
78
|
try {
|