incyclist-devices 1.5.11 → 1.5.13
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/LICENSE +0 -0
- package/lib/DeviceSupport.d.ts +36 -36
- package/lib/DeviceSupport.js +82 -82
- package/lib/ant/AntAdapter.d.ts +50 -50
- package/lib/ant/AntAdapter.js +109 -109
- package/lib/ant/AntScanner.d.ts +60 -60
- package/lib/ant/AntScanner.js +651 -651
- package/lib/ant/antfe/AntFEAdapter.d.ts +83 -83
- package/lib/ant/antfe/AntFEAdapter.js +652 -652
- package/lib/ant/antfe/ant-fe-adv-st-mode.d.ts +9 -9
- package/lib/ant/antfe/ant-fe-adv-st-mode.js +51 -51
- package/lib/ant/antfe/ant-fe-erg-mode.d.ts +6 -6
- package/lib/ant/antfe/ant-fe-erg-mode.js +14 -14
- package/lib/ant/antfe/ant-fe-st-mode.d.ts +5 -5
- package/lib/ant/antfe/ant-fe-st-mode.js +13 -13
- package/lib/ant/anthrm/AntHrmAdapter.d.ts +16 -16
- package/lib/ant/anthrm/AntHrmAdapter.js +130 -130
- package/lib/ant/antpwr/pwr-adapter.d.ts +49 -49
- package/lib/ant/antpwr/pwr-adapter.js +251 -251
- package/lib/ant/utils.d.ts +1 -1
- package/lib/ant/utils.js +23 -23
- package/lib/antv2/AntAdapter.d.ts +48 -0
- package/lib/antv2/AntAdapter.js +104 -0
- package/lib/antv2/adapter-factory.d.ts +11 -11
- package/lib/antv2/adapter-factory.js +40 -40
- package/lib/antv2/ant-binding.d.ts +13 -13
- package/lib/antv2/ant-binding.js +27 -27
- package/lib/antv2/ant-device.d.ts +51 -51
- package/lib/antv2/ant-device.js +115 -115
- package/lib/antv2/ant-interface.d.ts +37 -37
- package/lib/antv2/ant-interface.js +255 -255
- package/lib/antv2/fe.d.ts +29 -29
- package/lib/antv2/fe.js +262 -262
- package/lib/antv2/hr.d.ts +18 -18
- package/lib/antv2/hr.js +93 -93
- package/lib/antv2/incyclist-protocol.d.ts +37 -37
- package/lib/antv2/incyclist-protocol.js +126 -126
- package/lib/antv2/pwr.d.ts +28 -28
- package/lib/antv2/pwr.js +163 -163
- package/lib/antv2/sensor-factory.d.ts +5 -5
- package/lib/antv2/sensor-factory.js +20 -20
- package/lib/ble/ble-device.d.ts +63 -63
- package/lib/ble/ble-device.js +444 -444
- package/lib/ble/ble-erg-mode.d.ts +18 -18
- package/lib/ble/ble-erg-mode.js +132 -132
- package/lib/ble/ble-interface.d.ts +100 -100
- package/lib/ble/ble-interface.js +721 -721
- package/lib/ble/ble-peripheral.d.ts +36 -36
- package/lib/ble/ble-peripheral.js +200 -200
- package/lib/ble/ble-st-mode.d.ts +15 -15
- package/lib/ble/ble-st-mode.js +95 -95
- package/lib/ble/ble.d.ts +129 -129
- package/lib/ble/ble.js +86 -86
- package/lib/ble/consts.d.ts +14 -14
- package/lib/ble/consts.js +17 -17
- package/lib/ble/elite.d.ts +90 -90
- package/lib/ble/elite.js +322 -322
- package/lib/ble/fm.d.ts +125 -125
- package/lib/ble/fm.js +745 -745
- package/lib/ble/hrm.d.ts +48 -48
- package/lib/ble/hrm.js +134 -134
- package/lib/ble/incyclist-protocol.d.ts +31 -31
- package/lib/ble/incyclist-protocol.js +153 -153
- package/lib/ble/pwr.d.ts +89 -89
- package/lib/ble/pwr.js +321 -321
- package/lib/ble/tacx.d.ts +92 -90
- package/lib/ble/tacx.js +763 -731
- package/lib/ble/wahoo-kickr.d.ts +98 -98
- package/lib/ble/wahoo-kickr.js +496 -496
- package/lib/calculations.d.ts +13 -13
- package/lib/calculations.js +150 -150
- package/lib/cycling-mode.d.ts +76 -76
- package/lib/cycling-mode.js +79 -79
- package/lib/daum/DaumAdapter.d.ts +67 -66
- package/lib/daum/DaumAdapter.js +405 -396
- package/lib/daum/DaumPowerMeterCyclingMode.d.ts +8 -8
- package/lib/daum/DaumPowerMeterCyclingMode.js +21 -21
- package/lib/daum/ERGCyclingMode.d.ts +26 -26
- package/lib/daum/ERGCyclingMode.js +201 -201
- package/lib/daum/SmartTrainerCyclingMode.d.ts +41 -41
- package/lib/daum/SmartTrainerCyclingMode.js +344 -344
- package/lib/daum/classic/DaumClassicAdapter.d.ts +27 -22
- package/lib/daum/classic/DaumClassicAdapter.js +189 -183
- package/lib/daum/classic/DaumClassicCyclingMode.d.ts +13 -13
- package/lib/daum/classic/DaumClassicCyclingMode.js +97 -97
- package/lib/daum/classic/DaumClassicProtocol.d.ts +27 -27
- package/lib/daum/classic/DaumClassicProtocol.js +185 -185
- package/lib/daum/classic/bike.d.ts +68 -68
- package/lib/daum/classic/bike.js +467 -467
- package/lib/daum/classic/utils.d.ts +13 -13
- package/lib/daum/classic/utils.js +143 -143
- package/lib/daum/constants.d.ts +19 -19
- package/lib/daum/constants.js +22 -22
- package/lib/daum/premium/DaumClassicCyclingMode.d.ts +14 -14
- package/lib/daum/premium/DaumClassicCyclingMode.js +86 -86
- package/lib/daum/premium/DaumPremiumAdapter.d.ts +16 -16
- package/lib/daum/premium/DaumPremiumAdapter.js +163 -163
- package/lib/daum/premium/DaumPremiumProtocol.d.ts +32 -32
- package/lib/daum/premium/DaumPremiumProtocol.js +207 -207
- package/lib/daum/premium/bike.d.ts +127 -127
- package/lib/daum/premium/bike.js +904 -904
- package/lib/daum/premium/tcpserial.d.ts +33 -33
- package/lib/daum/premium/tcpserial.js +123 -123
- package/lib/daum/premium/utils.d.ts +62 -62
- package/lib/daum/premium/utils.js +376 -376
- package/lib/device.d.ts +92 -92
- package/lib/device.js +71 -71
- package/lib/kettler/comms.d.ts +59 -59
- package/lib/kettler/comms.js +242 -242
- package/lib/kettler/ergo-racer/ERGCyclingMode.d.ts +25 -25
- package/lib/kettler/ergo-racer/ERGCyclingMode.js +144 -144
- package/lib/kettler/ergo-racer/adapter.d.ts +101 -101
- package/lib/kettler/ergo-racer/adapter.js +639 -639
- package/lib/kettler/ergo-racer/protocol.d.ts +41 -41
- package/lib/kettler/ergo-racer/protocol.js +203 -203
- package/lib/modes/power-base.d.ts +20 -20
- package/lib/modes/power-base.js +70 -70
- package/lib/modes/power-meter.d.ts +20 -20
- package/lib/modes/power-meter.js +78 -78
- package/lib/modes/simulator.d.ts +29 -29
- package/lib/modes/simulator.js +140 -140
- package/lib/protocol.d.ts +74 -74
- package/lib/protocol.js +41 -41
- package/lib/registry.d.ts +8 -8
- package/lib/registry.js +33 -33
- package/lib/simulator/Simulator.d.ts +69 -69
- package/lib/simulator/Simulator.js +288 -288
- package/lib/types/command.d.ts +8 -8
- package/lib/types/command.js +2 -2
- package/lib/types/route.d.ts +24 -24
- package/lib/types/route.js +9 -9
- package/lib/types/user.d.ts +11 -11
- package/lib/types/user.js +9 -9
- package/lib/utils.d.ts +14 -14
- package/lib/utils.js +114 -114
- package/package.json +47 -47
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
import CyclingMode, { CyclingModeProperty, IncyclistBikeData, UpdateRequest } from "../cycling-mode";
|
|
2
|
-
import { DeviceAdapter } from "../device";
|
|
3
|
-
import PowerBasedCyclingModeBase from "../modes/power-base";
|
|
4
|
-
export default class BleERGCyclingMode extends PowerBasedCyclingModeBase implements CyclingMode {
|
|
5
|
-
static isERG: boolean;
|
|
6
|
-
prevRequest: UpdateRequest;
|
|
7
|
-
hasBikeUpdate: boolean;
|
|
8
|
-
chain: number[];
|
|
9
|
-
cassette: number[];
|
|
10
|
-
constructor(adapter: DeviceAdapter, props?: any);
|
|
11
|
-
getName(): string;
|
|
12
|
-
getDescription(): string;
|
|
13
|
-
getProperties(): CyclingModeProperty[];
|
|
14
|
-
getProperty(name: string): CyclingModeProperty;
|
|
15
|
-
getBikeInitRequest(): UpdateRequest;
|
|
16
|
-
sendBikeUpdate(request: UpdateRequest): UpdateRequest;
|
|
17
|
-
updateData(bikeData: IncyclistBikeData): any;
|
|
18
|
-
}
|
|
1
|
+
import CyclingMode, { CyclingModeProperty, IncyclistBikeData, UpdateRequest } from "../cycling-mode";
|
|
2
|
+
import { DeviceAdapter } from "../device";
|
|
3
|
+
import PowerBasedCyclingModeBase from "../modes/power-base";
|
|
4
|
+
export default class BleERGCyclingMode extends PowerBasedCyclingModeBase implements CyclingMode {
|
|
5
|
+
static isERG: boolean;
|
|
6
|
+
prevRequest: UpdateRequest;
|
|
7
|
+
hasBikeUpdate: boolean;
|
|
8
|
+
chain: number[];
|
|
9
|
+
cassette: number[];
|
|
10
|
+
constructor(adapter: DeviceAdapter, props?: any);
|
|
11
|
+
getName(): string;
|
|
12
|
+
getDescription(): string;
|
|
13
|
+
getProperties(): CyclingModeProperty[];
|
|
14
|
+
getProperty(name: string): CyclingModeProperty;
|
|
15
|
+
getBikeInitRequest(): UpdateRequest;
|
|
16
|
+
sendBikeUpdate(request: UpdateRequest): UpdateRequest;
|
|
17
|
+
updateData(bikeData: IncyclistBikeData): any;
|
|
18
|
+
}
|
package/lib/ble/ble-erg-mode.js
CHANGED
|
@@ -1,132 +1,132 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
const cycling_mode_1 = require("../cycling-mode");
|
|
7
|
-
const power_base_1 = __importDefault(require("../modes/power-base"));
|
|
8
|
-
const config = {
|
|
9
|
-
name: "ERG",
|
|
10
|
-
description: "Calculates speed based on power and slope. Power targets are set by workout or remain stable throughout the workout",
|
|
11
|
-
properties: [
|
|
12
|
-
{ key: 'bikeType', name: 'Bike Type', description: '', type: cycling_mode_1.CyclingModeProperyType.SingleSelect, options: ['Race', 'Mountain', 'Triathlon'], default: 'Race' },
|
|
13
|
-
{ key: 'startPower', name: 'Starting Power', description: 'Initial power in Watts at start of training', type: cycling_mode_1.CyclingModeProperyType.Integer, default: 50, min: 25, max: 800 },
|
|
14
|
-
]
|
|
15
|
-
};
|
|
16
|
-
const MIN_SPEED = 10;
|
|
17
|
-
class BleERGCyclingMode extends power_base_1.default {
|
|
18
|
-
constructor(adapter, props) {
|
|
19
|
-
super(adapter, props);
|
|
20
|
-
this.hasBikeUpdate = false;
|
|
21
|
-
this.initLogger('ERGMode');
|
|
22
|
-
}
|
|
23
|
-
getName() {
|
|
24
|
-
return config.name;
|
|
25
|
-
}
|
|
26
|
-
getDescription() {
|
|
27
|
-
return config.description;
|
|
28
|
-
}
|
|
29
|
-
getProperties() {
|
|
30
|
-
return config.properties;
|
|
31
|
-
}
|
|
32
|
-
getProperty(name) {
|
|
33
|
-
return config.properties.find(p => p.name === name);
|
|
34
|
-
}
|
|
35
|
-
getBikeInitRequest() {
|
|
36
|
-
const startPower = this.getSetting('startPower');
|
|
37
|
-
return { targetPower: startPower };
|
|
38
|
-
}
|
|
39
|
-
sendBikeUpdate(request) {
|
|
40
|
-
const getData = () => {
|
|
41
|
-
if (!this.data)
|
|
42
|
-
return {};
|
|
43
|
-
const { pedalRpm, slope, power, speed } = this.data;
|
|
44
|
-
return { pedalRpm, slope, power, speed };
|
|
45
|
-
};
|
|
46
|
-
this.logger.logEvent({ message: "processing update request", request, prev: this.prevRequest, data: getData() });
|
|
47
|
-
let newRequest = {};
|
|
48
|
-
try {
|
|
49
|
-
if (!request || request.reset || Object.keys(request).length === 0) {
|
|
50
|
-
this.prevRequest = {};
|
|
51
|
-
return request.reset ? { reset: true } : {};
|
|
52
|
-
}
|
|
53
|
-
const prevData = this.data || {};
|
|
54
|
-
if (request.slope !== undefined) {
|
|
55
|
-
if (!this.data)
|
|
56
|
-
this.data = {};
|
|
57
|
-
this.data.slope = request.slope;
|
|
58
|
-
}
|
|
59
|
-
delete request.slope;
|
|
60
|
-
if (request.targetPower !== undefined) {
|
|
61
|
-
delete request.refresh;
|
|
62
|
-
}
|
|
63
|
-
if (request.refresh) {
|
|
64
|
-
delete request.refresh;
|
|
65
|
-
newRequest.targetPower = this.prevRequest.targetPower;
|
|
66
|
-
}
|
|
67
|
-
if (request.maxPower !== undefined && request.minPower !== undefined && request.maxPower === request.minPower) {
|
|
68
|
-
request.targetPower = request.maxPower;
|
|
69
|
-
newRequest.targetPower = request.targetPower;
|
|
70
|
-
}
|
|
71
|
-
if (request.maxPower !== undefined) {
|
|
72
|
-
if (newRequest.targetPower !== undefined && newRequest.targetPower > request.maxPower) {
|
|
73
|
-
newRequest.targetPower = request.maxPower;
|
|
74
|
-
}
|
|
75
|
-
newRequest.maxPower = request.maxPower;
|
|
76
|
-
}
|
|
77
|
-
if (request.minPower !== undefined) {
|
|
78
|
-
if (newRequest.targetPower !== undefined && newRequest.targetPower < request.minPower) {
|
|
79
|
-
newRequest.targetPower = request.minPower;
|
|
80
|
-
}
|
|
81
|
-
newRequest.minPower = request.minPower;
|
|
82
|
-
if (prevData.power && prevData.power < request.minPower)
|
|
83
|
-
newRequest.targetPower = request.minPower;
|
|
84
|
-
}
|
|
85
|
-
this.prevRequest = JSON.parse(JSON.stringify(request));
|
|
86
|
-
}
|
|
87
|
-
catch (err) {
|
|
88
|
-
this.logger.logEvent({ message: "error", fn: 'sendBikeUpdate()', error: err.message || err, stack: err.stack });
|
|
89
|
-
}
|
|
90
|
-
return newRequest;
|
|
91
|
-
}
|
|
92
|
-
updateData(bikeData) {
|
|
93
|
-
const prevData = JSON.parse(JSON.stringify(this.data || {}));
|
|
94
|
-
const prevSpeed = prevData.speed;
|
|
95
|
-
const prevRequest = this.prevRequest || {};
|
|
96
|
-
const data = this.data || {};
|
|
97
|
-
const bikeType = this.getSetting('bikeType').toLowerCase();
|
|
98
|
-
try {
|
|
99
|
-
let power = bikeData.power || 0;
|
|
100
|
-
const slope = (prevData.slope !== undefined ? prevData.slope : prevRequest.slope || 0);
|
|
101
|
-
const distanceInternal = prevData.distanceInternal || 0;
|
|
102
|
-
const m = this.getWeight();
|
|
103
|
-
const t = this.getTimeSinceLastUpdate();
|
|
104
|
-
const { speed, distance } = this.calculateSpeedAndDistance(power, slope, m, t, { bikeType });
|
|
105
|
-
if (power === 0 && speed < MIN_SPEED) {
|
|
106
|
-
data.speed = Math.round(prevData.speed - 1) < 0 ? 0 : Math.round(prevData.speed - 1);
|
|
107
|
-
data.distanceInternal = distanceInternal + data.speed / 3.6 * t;
|
|
108
|
-
}
|
|
109
|
-
else {
|
|
110
|
-
data.speed = (power === 0 && speed < MIN_SPEED) ? 0 : speed;
|
|
111
|
-
data.distanceInternal = (power === 0 && speed < MIN_SPEED) ? distanceInternal : distanceInternal + distance;
|
|
112
|
-
}
|
|
113
|
-
data.power = Math.round(power);
|
|
114
|
-
data.slope = slope;
|
|
115
|
-
data.pedalRpm = bikeData.pedalRpm || 0;
|
|
116
|
-
if (data.time !== undefined && data.speed > 0)
|
|
117
|
-
data.time += t;
|
|
118
|
-
else
|
|
119
|
-
data.time = 0;
|
|
120
|
-
data.heartrate = bikeData.heartrate;
|
|
121
|
-
data.isPedalling = bikeData.isPedalling;
|
|
122
|
-
}
|
|
123
|
-
catch (err) {
|
|
124
|
-
this.logger.logEvent({ message: 'error', fn: 'updateData()', error: err.message || err });
|
|
125
|
-
}
|
|
126
|
-
this.logger.logEvent({ message: "updateData result", data, bikeData, prevRequest, prevSpeed });
|
|
127
|
-
this.data = data;
|
|
128
|
-
return data;
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
exports.default = BleERGCyclingMode;
|
|
132
|
-
BleERGCyclingMode.isERG = true;
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const cycling_mode_1 = require("../cycling-mode");
|
|
7
|
+
const power_base_1 = __importDefault(require("../modes/power-base"));
|
|
8
|
+
const config = {
|
|
9
|
+
name: "ERG",
|
|
10
|
+
description: "Calculates speed based on power and slope. Power targets are set by workout or remain stable throughout the workout",
|
|
11
|
+
properties: [
|
|
12
|
+
{ key: 'bikeType', name: 'Bike Type', description: '', type: cycling_mode_1.CyclingModeProperyType.SingleSelect, options: ['Race', 'Mountain', 'Triathlon'], default: 'Race' },
|
|
13
|
+
{ key: 'startPower', name: 'Starting Power', description: 'Initial power in Watts at start of training', type: cycling_mode_1.CyclingModeProperyType.Integer, default: 50, min: 25, max: 800 },
|
|
14
|
+
]
|
|
15
|
+
};
|
|
16
|
+
const MIN_SPEED = 10;
|
|
17
|
+
class BleERGCyclingMode extends power_base_1.default {
|
|
18
|
+
constructor(adapter, props) {
|
|
19
|
+
super(adapter, props);
|
|
20
|
+
this.hasBikeUpdate = false;
|
|
21
|
+
this.initLogger('ERGMode');
|
|
22
|
+
}
|
|
23
|
+
getName() {
|
|
24
|
+
return config.name;
|
|
25
|
+
}
|
|
26
|
+
getDescription() {
|
|
27
|
+
return config.description;
|
|
28
|
+
}
|
|
29
|
+
getProperties() {
|
|
30
|
+
return config.properties;
|
|
31
|
+
}
|
|
32
|
+
getProperty(name) {
|
|
33
|
+
return config.properties.find(p => p.name === name);
|
|
34
|
+
}
|
|
35
|
+
getBikeInitRequest() {
|
|
36
|
+
const startPower = this.getSetting('startPower');
|
|
37
|
+
return { targetPower: startPower };
|
|
38
|
+
}
|
|
39
|
+
sendBikeUpdate(request) {
|
|
40
|
+
const getData = () => {
|
|
41
|
+
if (!this.data)
|
|
42
|
+
return {};
|
|
43
|
+
const { pedalRpm, slope, power, speed } = this.data;
|
|
44
|
+
return { pedalRpm, slope, power, speed };
|
|
45
|
+
};
|
|
46
|
+
this.logger.logEvent({ message: "processing update request", request, prev: this.prevRequest, data: getData() });
|
|
47
|
+
let newRequest = {};
|
|
48
|
+
try {
|
|
49
|
+
if (!request || request.reset || Object.keys(request).length === 0) {
|
|
50
|
+
this.prevRequest = {};
|
|
51
|
+
return request.reset ? { reset: true } : {};
|
|
52
|
+
}
|
|
53
|
+
const prevData = this.data || {};
|
|
54
|
+
if (request.slope !== undefined) {
|
|
55
|
+
if (!this.data)
|
|
56
|
+
this.data = {};
|
|
57
|
+
this.data.slope = request.slope;
|
|
58
|
+
}
|
|
59
|
+
delete request.slope;
|
|
60
|
+
if (request.targetPower !== undefined) {
|
|
61
|
+
delete request.refresh;
|
|
62
|
+
}
|
|
63
|
+
if (request.refresh) {
|
|
64
|
+
delete request.refresh;
|
|
65
|
+
newRequest.targetPower = this.prevRequest.targetPower;
|
|
66
|
+
}
|
|
67
|
+
if (request.maxPower !== undefined && request.minPower !== undefined && request.maxPower === request.minPower) {
|
|
68
|
+
request.targetPower = request.maxPower;
|
|
69
|
+
newRequest.targetPower = request.targetPower;
|
|
70
|
+
}
|
|
71
|
+
if (request.maxPower !== undefined) {
|
|
72
|
+
if (newRequest.targetPower !== undefined && newRequest.targetPower > request.maxPower) {
|
|
73
|
+
newRequest.targetPower = request.maxPower;
|
|
74
|
+
}
|
|
75
|
+
newRequest.maxPower = request.maxPower;
|
|
76
|
+
}
|
|
77
|
+
if (request.minPower !== undefined) {
|
|
78
|
+
if (newRequest.targetPower !== undefined && newRequest.targetPower < request.minPower) {
|
|
79
|
+
newRequest.targetPower = request.minPower;
|
|
80
|
+
}
|
|
81
|
+
newRequest.minPower = request.minPower;
|
|
82
|
+
if (prevData.power && prevData.power < request.minPower)
|
|
83
|
+
newRequest.targetPower = request.minPower;
|
|
84
|
+
}
|
|
85
|
+
this.prevRequest = JSON.parse(JSON.stringify(request));
|
|
86
|
+
}
|
|
87
|
+
catch (err) {
|
|
88
|
+
this.logger.logEvent({ message: "error", fn: 'sendBikeUpdate()', error: err.message || err, stack: err.stack });
|
|
89
|
+
}
|
|
90
|
+
return newRequest;
|
|
91
|
+
}
|
|
92
|
+
updateData(bikeData) {
|
|
93
|
+
const prevData = JSON.parse(JSON.stringify(this.data || {}));
|
|
94
|
+
const prevSpeed = prevData.speed;
|
|
95
|
+
const prevRequest = this.prevRequest || {};
|
|
96
|
+
const data = this.data || {};
|
|
97
|
+
const bikeType = this.getSetting('bikeType').toLowerCase();
|
|
98
|
+
try {
|
|
99
|
+
let power = bikeData.power || 0;
|
|
100
|
+
const slope = (prevData.slope !== undefined ? prevData.slope : prevRequest.slope || 0);
|
|
101
|
+
const distanceInternal = prevData.distanceInternal || 0;
|
|
102
|
+
const m = this.getWeight();
|
|
103
|
+
const t = this.getTimeSinceLastUpdate();
|
|
104
|
+
const { speed, distance } = this.calculateSpeedAndDistance(power, slope, m, t, { bikeType });
|
|
105
|
+
if (power === 0 && speed < MIN_SPEED) {
|
|
106
|
+
data.speed = Math.round(prevData.speed - 1) < 0 ? 0 : Math.round(prevData.speed - 1);
|
|
107
|
+
data.distanceInternal = distanceInternal + data.speed / 3.6 * t;
|
|
108
|
+
}
|
|
109
|
+
else {
|
|
110
|
+
data.speed = (power === 0 && speed < MIN_SPEED) ? 0 : speed;
|
|
111
|
+
data.distanceInternal = (power === 0 && speed < MIN_SPEED) ? distanceInternal : distanceInternal + distance;
|
|
112
|
+
}
|
|
113
|
+
data.power = Math.round(power);
|
|
114
|
+
data.slope = slope;
|
|
115
|
+
data.pedalRpm = bikeData.pedalRpm || 0;
|
|
116
|
+
if (data.time !== undefined && data.speed > 0)
|
|
117
|
+
data.time += t;
|
|
118
|
+
else
|
|
119
|
+
data.time = 0;
|
|
120
|
+
data.heartrate = bikeData.heartrate;
|
|
121
|
+
data.isPedalling = bikeData.isPedalling;
|
|
122
|
+
}
|
|
123
|
+
catch (err) {
|
|
124
|
+
this.logger.logEvent({ message: 'error', fn: 'updateData()', error: err.message || err });
|
|
125
|
+
}
|
|
126
|
+
this.logger.logEvent({ message: "updateData result", data, bikeData, prevRequest, prevSpeed });
|
|
127
|
+
this.data = data;
|
|
128
|
+
return data;
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
exports.default = BleERGCyclingMode;
|
|
132
|
+
BleERGCyclingMode.isERG = true;
|
|
@@ -1,100 +1,100 @@
|
|
|
1
|
-
/// <reference types="node" />
|
|
2
|
-
import { EventLogger } from 'gd-eventlog';
|
|
3
|
-
import { BleInterfaceClass, ConnectProps, ScanProps, BleDeviceClass, BlePeripheral, BleBinding, BleCharacteristic, BleDeviceDescription } from './ble';
|
|
4
|
-
export interface ScanState {
|
|
5
|
-
isScanning: boolean;
|
|
6
|
-
isConnecting: boolean;
|
|
7
|
-
isBackgroundScan: boolean;
|
|
8
|
-
timeout?: NodeJS.Timeout;
|
|
9
|
-
}
|
|
10
|
-
export interface ConnectState {
|
|
11
|
-
isConnecting: boolean;
|
|
12
|
-
isConnected: boolean;
|
|
13
|
-
timeout?: NodeJS.Timeout;
|
|
14
|
-
isInitSuccess: boolean;
|
|
15
|
-
}
|
|
16
|
-
export interface PeripheralState {
|
|
17
|
-
isLoading: boolean;
|
|
18
|
-
isConfigured: boolean;
|
|
19
|
-
isInterrupted: boolean;
|
|
20
|
-
}
|
|
21
|
-
export interface BleDeviceInfo {
|
|
22
|
-
device: BleDeviceClass;
|
|
23
|
-
isConnected: boolean;
|
|
24
|
-
}
|
|
25
|
-
export interface BleDeviceClassInfo {
|
|
26
|
-
Class: typeof BleDeviceClass;
|
|
27
|
-
type: string;
|
|
28
|
-
services: string[];
|
|
29
|
-
id: string;
|
|
30
|
-
}
|
|
31
|
-
export interface PeripheralCacheItem {
|
|
32
|
-
address: string;
|
|
33
|
-
ts: number;
|
|
34
|
-
peripheral: BlePeripheral;
|
|
35
|
-
state?: PeripheralState;
|
|
36
|
-
characteristics?: BleCharacteristic[];
|
|
37
|
-
}
|
|
38
|
-
export default class BleInterface extends BleInterfaceClass {
|
|
39
|
-
scanState: ScanState;
|
|
40
|
-
connectState: ConnectState;
|
|
41
|
-
devices: BleDeviceInfo[];
|
|
42
|
-
peripheralCache: any[];
|
|
43
|
-
logger: EventLogger;
|
|
44
|
-
static deviceClasses: BleDeviceClassInfo[];
|
|
45
|
-
static _instance: BleInterface;
|
|
46
|
-
static getInstance(props?: {
|
|
47
|
-
binding?: BleBinding;
|
|
48
|
-
log?: boolean;
|
|
49
|
-
logger?: EventLogger;
|
|
50
|
-
}): BleInterface;
|
|
51
|
-
constructor(props?: {
|
|
52
|
-
binding?: BleBinding;
|
|
53
|
-
log?: boolean;
|
|
54
|
-
logger?: EventLogger;
|
|
55
|
-
});
|
|
56
|
-
static register(id: string, type: string, Class: typeof BleDeviceClass, services: string[]): void;
|
|
57
|
-
logEvent(event: any): void;
|
|
58
|
-
onStateChange(state: any): void;
|
|
59
|
-
onError(err: any): void;
|
|
60
|
-
connect(props?: ConnectProps): Promise<boolean>;
|
|
61
|
-
disconnect(): Promise<boolean>;
|
|
62
|
-
isConnected(): boolean;
|
|
63
|
-
getDevicesFromServices(deviceTypes: (typeof BleDeviceClass)[], services: string | string[]): (typeof BleDeviceClass)[];
|
|
64
|
-
getAllSupportedServices(): any[];
|
|
65
|
-
getAllSupportedDeviceTypes(): (typeof BleDeviceClass)[];
|
|
66
|
-
getServicesFromDeviceTypes(deviceTypes: (typeof BleDeviceClass)[]): string[];
|
|
67
|
-
getServicesFromDevice(device: BleDeviceClass): string[];
|
|
68
|
-
waitForConnectFinished(timeout: any): Promise<unknown>;
|
|
69
|
-
addPeripheralToCache(peripheral: any, props?: {}): void;
|
|
70
|
-
onDisconnect(peripheral: any): void;
|
|
71
|
-
getConnector(peripheral: BlePeripheral): any;
|
|
72
|
-
findPeripheral(peripheral: BlePeripheral | {
|
|
73
|
-
id?: string;
|
|
74
|
-
address?: string;
|
|
75
|
-
name?: string;
|
|
76
|
-
}): BlePeripheral;
|
|
77
|
-
getCharacteristics(peripheral: any): Promise<any>;
|
|
78
|
-
getDeviceClasses(peripheral: any, props?: {
|
|
79
|
-
deviceTypes?: (typeof BleDeviceClass)[];
|
|
80
|
-
profile?: string;
|
|
81
|
-
services?: string[];
|
|
82
|
-
}): (typeof BleDeviceClass)[];
|
|
83
|
-
createDevice(DeviceClass: (typeof BleDeviceClass), peripheral: BlePeripheral, characteristics?: BleCharacteristic[]): BleDeviceClass;
|
|
84
|
-
connectDevice(requested: BleDeviceClass | BleDeviceDescription, timeout?: number): Promise<BleDeviceClass>;
|
|
85
|
-
waitForScanFinished(timeout: any): Promise<unknown>;
|
|
86
|
-
getBestDeviceMatch(DeviceClasses: (typeof BleDeviceClass)[]): typeof BleDeviceClass;
|
|
87
|
-
scan(props: ScanProps): Promise<BleDeviceClass[]>;
|
|
88
|
-
stopScan(): Promise<boolean>;
|
|
89
|
-
isScanning(): boolean;
|
|
90
|
-
addConnectedDevice(device: BleDeviceClass): void;
|
|
91
|
-
addDeviceToCache(device: BleDeviceClass, isConnected: boolean): void;
|
|
92
|
-
findConnected(device: BleDeviceClass | BlePeripheral): BleDeviceClass;
|
|
93
|
-
findDeviceInCache(device: {
|
|
94
|
-
id?: string;
|
|
95
|
-
address?: string;
|
|
96
|
-
name?: string;
|
|
97
|
-
profile: string;
|
|
98
|
-
}): BleDeviceClass;
|
|
99
|
-
removeConnectedDevice(device: BleDeviceClass): void;
|
|
100
|
-
}
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { EventLogger } from 'gd-eventlog';
|
|
3
|
+
import { BleInterfaceClass, ConnectProps, ScanProps, BleDeviceClass, BlePeripheral, BleBinding, BleCharacteristic, BleDeviceDescription } from './ble';
|
|
4
|
+
export interface ScanState {
|
|
5
|
+
isScanning: boolean;
|
|
6
|
+
isConnecting: boolean;
|
|
7
|
+
isBackgroundScan: boolean;
|
|
8
|
+
timeout?: NodeJS.Timeout;
|
|
9
|
+
}
|
|
10
|
+
export interface ConnectState {
|
|
11
|
+
isConnecting: boolean;
|
|
12
|
+
isConnected: boolean;
|
|
13
|
+
timeout?: NodeJS.Timeout;
|
|
14
|
+
isInitSuccess: boolean;
|
|
15
|
+
}
|
|
16
|
+
export interface PeripheralState {
|
|
17
|
+
isLoading: boolean;
|
|
18
|
+
isConfigured: boolean;
|
|
19
|
+
isInterrupted: boolean;
|
|
20
|
+
}
|
|
21
|
+
export interface BleDeviceInfo {
|
|
22
|
+
device: BleDeviceClass;
|
|
23
|
+
isConnected: boolean;
|
|
24
|
+
}
|
|
25
|
+
export interface BleDeviceClassInfo {
|
|
26
|
+
Class: typeof BleDeviceClass;
|
|
27
|
+
type: string;
|
|
28
|
+
services: string[];
|
|
29
|
+
id: string;
|
|
30
|
+
}
|
|
31
|
+
export interface PeripheralCacheItem {
|
|
32
|
+
address: string;
|
|
33
|
+
ts: number;
|
|
34
|
+
peripheral: BlePeripheral;
|
|
35
|
+
state?: PeripheralState;
|
|
36
|
+
characteristics?: BleCharacteristic[];
|
|
37
|
+
}
|
|
38
|
+
export default class BleInterface extends BleInterfaceClass {
|
|
39
|
+
scanState: ScanState;
|
|
40
|
+
connectState: ConnectState;
|
|
41
|
+
devices: BleDeviceInfo[];
|
|
42
|
+
peripheralCache: any[];
|
|
43
|
+
logger: EventLogger;
|
|
44
|
+
static deviceClasses: BleDeviceClassInfo[];
|
|
45
|
+
static _instance: BleInterface;
|
|
46
|
+
static getInstance(props?: {
|
|
47
|
+
binding?: BleBinding;
|
|
48
|
+
log?: boolean;
|
|
49
|
+
logger?: EventLogger;
|
|
50
|
+
}): BleInterface;
|
|
51
|
+
constructor(props?: {
|
|
52
|
+
binding?: BleBinding;
|
|
53
|
+
log?: boolean;
|
|
54
|
+
logger?: EventLogger;
|
|
55
|
+
});
|
|
56
|
+
static register(id: string, type: string, Class: typeof BleDeviceClass, services: string[]): void;
|
|
57
|
+
logEvent(event: any): void;
|
|
58
|
+
onStateChange(state: any): void;
|
|
59
|
+
onError(err: any): void;
|
|
60
|
+
connect(props?: ConnectProps): Promise<boolean>;
|
|
61
|
+
disconnect(): Promise<boolean>;
|
|
62
|
+
isConnected(): boolean;
|
|
63
|
+
getDevicesFromServices(deviceTypes: (typeof BleDeviceClass)[], services: string | string[]): (typeof BleDeviceClass)[];
|
|
64
|
+
getAllSupportedServices(): any[];
|
|
65
|
+
getAllSupportedDeviceTypes(): (typeof BleDeviceClass)[];
|
|
66
|
+
getServicesFromDeviceTypes(deviceTypes: (typeof BleDeviceClass)[]): string[];
|
|
67
|
+
getServicesFromDevice(device: BleDeviceClass): string[];
|
|
68
|
+
waitForConnectFinished(timeout: any): Promise<unknown>;
|
|
69
|
+
addPeripheralToCache(peripheral: any, props?: {}): void;
|
|
70
|
+
onDisconnect(peripheral: any): void;
|
|
71
|
+
getConnector(peripheral: BlePeripheral): any;
|
|
72
|
+
findPeripheral(peripheral: BlePeripheral | {
|
|
73
|
+
id?: string;
|
|
74
|
+
address?: string;
|
|
75
|
+
name?: string;
|
|
76
|
+
}): BlePeripheral;
|
|
77
|
+
getCharacteristics(peripheral: any): Promise<any>;
|
|
78
|
+
getDeviceClasses(peripheral: any, props?: {
|
|
79
|
+
deviceTypes?: (typeof BleDeviceClass)[];
|
|
80
|
+
profile?: string;
|
|
81
|
+
services?: string[];
|
|
82
|
+
}): (typeof BleDeviceClass)[];
|
|
83
|
+
createDevice(DeviceClass: (typeof BleDeviceClass), peripheral: BlePeripheral, characteristics?: BleCharacteristic[]): BleDeviceClass;
|
|
84
|
+
connectDevice(requested: BleDeviceClass | BleDeviceDescription, timeout?: number): Promise<BleDeviceClass>;
|
|
85
|
+
waitForScanFinished(timeout: any): Promise<unknown>;
|
|
86
|
+
getBestDeviceMatch(DeviceClasses: (typeof BleDeviceClass)[]): typeof BleDeviceClass;
|
|
87
|
+
scan(props: ScanProps): Promise<BleDeviceClass[]>;
|
|
88
|
+
stopScan(): Promise<boolean>;
|
|
89
|
+
isScanning(): boolean;
|
|
90
|
+
addConnectedDevice(device: BleDeviceClass): void;
|
|
91
|
+
addDeviceToCache(device: BleDeviceClass, isConnected: boolean): void;
|
|
92
|
+
findConnected(device: BleDeviceClass | BlePeripheral): BleDeviceClass;
|
|
93
|
+
findDeviceInCache(device: {
|
|
94
|
+
id?: string;
|
|
95
|
+
address?: string;
|
|
96
|
+
name?: string;
|
|
97
|
+
profile: string;
|
|
98
|
+
}): BleDeviceClass;
|
|
99
|
+
removeConnectedDevice(device: BleDeviceClass): void;
|
|
100
|
+
}
|