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.
Files changed (47) hide show
  1. package/lib/CyclingMode.js +1 -0
  2. package/lib/Device.js +1 -0
  3. package/lib/DeviceProtocol.js +1 -0
  4. package/lib/DeviceSupport.js +25 -8
  5. package/lib/ant/AntAdapter.js +1 -0
  6. package/lib/ant/AntScanner.js +24 -7
  7. package/lib/ant/antfe/AntFEAdapter.js +7 -7
  8. package/lib/ant/anthrm/AntHrmAdapter.js +1 -1
  9. package/lib/ant/antpwr/pwr-adapter.js +1 -1
  10. package/lib/ant/utils.js +3 -1
  11. package/lib/ble/ble-device.d.ts +10 -3
  12. package/lib/ble/ble-device.js +144 -32
  13. package/lib/ble/ble-interface.d.ts +22 -4
  14. package/lib/ble/ble-interface.js +224 -167
  15. package/lib/ble/ble.d.ts +20 -1
  16. package/lib/ble/ble.js +3 -1
  17. package/lib/ble/fm.d.ts +11 -1
  18. package/lib/ble/fm.js +109 -11
  19. package/lib/ble/hrm.d.ts +0 -1
  20. package/lib/ble/hrm.js +1 -4
  21. package/lib/ble/incyclist-protocol.js +24 -8
  22. package/lib/ble/pwr.d.ts +1 -1
  23. package/lib/ble/pwr.js +14 -4
  24. package/lib/calculations.js +1 -0
  25. package/lib/daum/DaumAdapter.js +29 -13
  26. package/lib/daum/SmartTrainerCyclingMode.js +1 -0
  27. package/lib/daum/classic/DaumClassicAdapter.js +1 -1
  28. package/lib/daum/classic/DaumClassicProtocol.js +23 -7
  29. package/lib/daum/classic/bike.js +26 -26
  30. package/lib/daum/classic/utils.js +1 -0
  31. package/lib/daum/constants.js +1 -0
  32. package/lib/daum/premium/DaumPremiumAdapter.js +1 -1
  33. package/lib/daum/premium/DaumPremiumProtocol.js +23 -7
  34. package/lib/daum/premium/bike.js +18 -17
  35. package/lib/daum/premium/utils.js +1 -0
  36. package/lib/kettler/comms.d.ts +1 -0
  37. package/lib/kettler/comms.js +2 -1
  38. package/lib/kettler/ergo-racer/adapter.js +25 -9
  39. package/lib/kettler/ergo-racer/protocol.d.ts +1 -1
  40. package/lib/kettler/ergo-racer/protocol.js +23 -7
  41. package/lib/modes/power-meter.js +1 -0
  42. package/lib/simulator/Simulator.d.ts +1 -1
  43. package/lib/simulator/Simulator.js +24 -7
  44. package/lib/types/route.js +1 -0
  45. package/lib/types/user.js +1 -0
  46. package/lib/utils.js +3 -1
  47. 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 true; }
140
- isHrm() { return false; }
141
- isPower() { return true; }
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;
@@ -1,5 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.solveCubic = exports.IllegalArgumentException = void 0;
3
4
  const g = 9.80665;
4
5
  const rho = 1.2041;
5
6
  const cwABike = {
@@ -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
  };
@@ -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;
@@ -1,5 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.BIKE_TRAINING_STATE = exports.BIKE_INTERFACE = exports.ACTUAL_BIKE_TYPE = void 0;
3
4
  exports.ACTUAL_BIKE_TYPE = {
4
5
  ALLROUND: 'allround',
5
6
  RACE: 'race',
@@ -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 {