incyclist-devices 1.4.26 → 1.4.29
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 +0 -1
- package/lib/Device.d.ts +1 -1
- package/lib/Device.js +2 -3
- package/lib/DeviceProtocol.d.ts +2 -1
- package/lib/DeviceProtocol.js +1 -1
- package/lib/DeviceSupport.d.ts +6 -1
- package/lib/DeviceSupport.js +17 -21
- package/lib/ant/AntAdapter.js +0 -1
- package/lib/ant/AntScanner.js +7 -20
- 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 +1 -3
- package/lib/ble/ble-device.d.ts +36 -0
- package/lib/ble/ble-device.js +174 -0
- package/lib/ble/ble-interface.d.ts +57 -0
- package/lib/ble/ble-interface.js +348 -0
- package/lib/ble/ble.d.ts +81 -0
- package/lib/ble/ble.js +51 -0
- package/lib/ble/hrm.d.ts +48 -0
- package/lib/ble/hrm.js +128 -0
- package/lib/ble/incyclist-protocol.d.ts +31 -0
- package/lib/ble/incyclist-protocol.js +109 -0
- package/lib/ble/pwr.d.ts +77 -0
- package/lib/ble/pwr.js +243 -0
- package/lib/calculations.js +0 -1
- package/lib/daum/DaumAdapter.d.ts +2 -2
- package/lib/daum/DaumAdapter.js +13 -25
- package/lib/daum/SmartTrainerCyclingMode.js +0 -1
- package/lib/daum/classic/DaumClassicAdapter.js +1 -1
- package/lib/daum/classic/DaumClassicProtocol.js +7 -19
- package/lib/daum/classic/bike.js +26 -26
- package/lib/daum/classic/utils.js +0 -1
- package/lib/daum/constants.js +0 -1
- package/lib/daum/premium/DaumPremiumAdapter.js +1 -1
- package/lib/daum/premium/DaumPremiumProtocol.js +7 -19
- package/lib/daum/premium/bike.js +17 -18
- package/lib/daum/premium/utils.js +0 -1
- package/lib/kettler/comms.js +1 -2
- package/lib/kettler/ergo-racer/adapter.js +9 -21
- package/lib/kettler/ergo-racer/protocol.js +7 -19
- package/lib/modes/power-meter.js +0 -1
- package/lib/simulator/Simulator.js +7 -20
- package/lib/types/route.js +0 -1
- package/lib/types/user.js +0 -1
- package/lib/utils.js +1 -3
- package/package.json +1 -1
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
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
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
19
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
20
|
+
};
|
|
21
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
22
|
+
const gd_eventlog_1 = require("gd-eventlog");
|
|
23
|
+
const DeviceProtocol_1 = __importStar(require("../DeviceProtocol"));
|
|
24
|
+
const DeviceRegistry_1 = __importDefault(require("../DeviceRegistry"));
|
|
25
|
+
const ble_1 = require("./ble");
|
|
26
|
+
const ble_interface_1 = __importDefault(require("./ble-interface"));
|
|
27
|
+
const hrm_1 = __importStar(require("./hrm"));
|
|
28
|
+
const pwr_1 = __importStar(require("./pwr"));
|
|
29
|
+
const supportedDeviceTypes = [hrm_1.default, pwr_1.default];
|
|
30
|
+
class BleProtocol extends DeviceProtocol_1.default {
|
|
31
|
+
constructor(binding) {
|
|
32
|
+
super();
|
|
33
|
+
const b = binding || BleProtocol._defaultBinding;
|
|
34
|
+
this.logger = new gd_eventlog_1.EventLogger('BLE');
|
|
35
|
+
this.ble = ble_interface_1.default.getInstance({ binding: b, logger: this.logger });
|
|
36
|
+
BleProtocol._instances.push(this);
|
|
37
|
+
}
|
|
38
|
+
static setDefaultBinding(binding) {
|
|
39
|
+
BleProtocol._defaultBinding = binding;
|
|
40
|
+
BleProtocol._instances.forEach((p) => {
|
|
41
|
+
if (p.ble && !p.ble.getBinding()) {
|
|
42
|
+
p.ble.setBinding(binding);
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
setBinding(binding) {
|
|
47
|
+
if (this.ble)
|
|
48
|
+
this.ble.setBinding(binding);
|
|
49
|
+
}
|
|
50
|
+
createDevice(bleDevice) {
|
|
51
|
+
const fromDevice = bleDevice instanceof ble_1.BleDeviceClass;
|
|
52
|
+
const profile = bleDevice instanceof ble_1.BleDeviceClass ? bleDevice.getProfile() : bleDevice.profile;
|
|
53
|
+
const props = () => {
|
|
54
|
+
const { id, name, address } = bleDevice;
|
|
55
|
+
return { id, name, address };
|
|
56
|
+
};
|
|
57
|
+
switch (profile.toLocaleLowerCase()) {
|
|
58
|
+
case 'hr':
|
|
59
|
+
case 'heartrate monitor':
|
|
60
|
+
return new hrm_1.HrmAdapter(fromDevice ? bleDevice : new hrm_1.default(props()), this);
|
|
61
|
+
case 'cp':
|
|
62
|
+
case 'power meter':
|
|
63
|
+
return new pwr_1.PwrAdapter(fromDevice ? bleDevice : new pwr_1.default(props()), this);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
getName() { return 'BLE'; }
|
|
67
|
+
getInterfaces() { return [DeviceProtocol_1.INTERFACE.BLE]; }
|
|
68
|
+
isBike() { return true; }
|
|
69
|
+
isHrm() { return true; }
|
|
70
|
+
isPower() { return true; }
|
|
71
|
+
add(settings) {
|
|
72
|
+
this.logger.logEvent({ message: 'adding device', settings });
|
|
73
|
+
const device = this.createDevice(settings);
|
|
74
|
+
return device;
|
|
75
|
+
}
|
|
76
|
+
scan(props) {
|
|
77
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
78
|
+
try {
|
|
79
|
+
this.ble.on('device', (bleDevice) => {
|
|
80
|
+
if (props && props.onDeviceFound) {
|
|
81
|
+
const device = this.createDevice(bleDevice);
|
|
82
|
+
props.onDeviceFound(device, this);
|
|
83
|
+
}
|
|
84
|
+
});
|
|
85
|
+
this.logger.logEvent({ message: 'scan started' });
|
|
86
|
+
yield this.ble.scan({ deviceTypes: supportedDeviceTypes });
|
|
87
|
+
if (props && props.onScanFinished) {
|
|
88
|
+
props.onScanFinished(props.id);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
catch (err) {
|
|
92
|
+
this.logger.logEvent({ message: 'error', error: err.message });
|
|
93
|
+
}
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
stopScan() {
|
|
97
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
98
|
+
yield this.ble.stopScan();
|
|
99
|
+
return;
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
isScanning() {
|
|
103
|
+
return this.ble.isScanning();
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
exports.default = BleProtocol;
|
|
107
|
+
BleProtocol._defaultBinding = undefined;
|
|
108
|
+
BleProtocol._instances = [];
|
|
109
|
+
DeviceRegistry_1.default.register(new BleProtocol());
|
package/lib/ble/pwr.d.ts
ADDED
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { BleDevice } from './ble-device';
|
|
3
|
+
import BleInterface from './ble-interface';
|
|
4
|
+
import BleProtocol from './incyclist-protocol';
|
|
5
|
+
import { BleDeviceClass } from './ble';
|
|
6
|
+
import DeviceAdapter, { DeviceData } from '../Device';
|
|
7
|
+
import { DeviceProtocol } from '../DeviceProtocol';
|
|
8
|
+
import { EventLogger } from 'gd-eventlog';
|
|
9
|
+
import CyclingMode from '../CyclingMode';
|
|
10
|
+
import { IncyclistBikeData } from '../CyclingMode';
|
|
11
|
+
declare type PowerData = {
|
|
12
|
+
instantaneousPower?: number;
|
|
13
|
+
balance?: number;
|
|
14
|
+
accTorque?: number;
|
|
15
|
+
time: number;
|
|
16
|
+
rpm: number;
|
|
17
|
+
raw?: Buffer;
|
|
18
|
+
};
|
|
19
|
+
declare type CrankData = {
|
|
20
|
+
revolutions?: number;
|
|
21
|
+
time?: number;
|
|
22
|
+
cntUpdateMissing?: number;
|
|
23
|
+
};
|
|
24
|
+
export default class BleCyclingPowerDevice extends BleDevice {
|
|
25
|
+
static services: string[];
|
|
26
|
+
static characteristics: string[];
|
|
27
|
+
instantaneousPower: number;
|
|
28
|
+
balance: number;
|
|
29
|
+
accTorque: number;
|
|
30
|
+
rpm: number;
|
|
31
|
+
timeOffset: number;
|
|
32
|
+
time: number;
|
|
33
|
+
currentCrankData: CrankData;
|
|
34
|
+
prevCrankData: CrankData;
|
|
35
|
+
constructor(props?: any);
|
|
36
|
+
getProfile(): string;
|
|
37
|
+
getServiceUUids(): string[];
|
|
38
|
+
parseCrankData(crankData: any): {
|
|
39
|
+
rpm: number;
|
|
40
|
+
time: any;
|
|
41
|
+
};
|
|
42
|
+
parsePower(data: Buffer): PowerData;
|
|
43
|
+
onData(characteristic: string, data: Buffer): void;
|
|
44
|
+
write(characteristic: any, data: any): Promise<boolean>;
|
|
45
|
+
read(characteristic: any): Promise<Buffer>;
|
|
46
|
+
reset(): void;
|
|
47
|
+
}
|
|
48
|
+
export declare class PwrAdapter extends DeviceAdapter {
|
|
49
|
+
device: BleCyclingPowerDevice;
|
|
50
|
+
ignore: boolean;
|
|
51
|
+
ble: BleInterface;
|
|
52
|
+
protocol: DeviceProtocol;
|
|
53
|
+
paused: boolean;
|
|
54
|
+
logger: EventLogger;
|
|
55
|
+
mode: CyclingMode;
|
|
56
|
+
distanceInternal: number;
|
|
57
|
+
constructor(device: BleDeviceClass, protocol: BleProtocol);
|
|
58
|
+
isBike(): boolean;
|
|
59
|
+
isHrm(): boolean;
|
|
60
|
+
isPower(): boolean;
|
|
61
|
+
getProfile(): string;
|
|
62
|
+
getName(): string;
|
|
63
|
+
getDisplayName(): string;
|
|
64
|
+
getCyclingMode(): CyclingMode;
|
|
65
|
+
getDefaultCyclingMode(): CyclingMode;
|
|
66
|
+
getPort(): string;
|
|
67
|
+
setIgnoreBike(ignore: any): void;
|
|
68
|
+
setIgnorePower(ignore: any): void;
|
|
69
|
+
onDeviceData(deviceData: PowerData): void;
|
|
70
|
+
mapData(deviceData: PowerData): IncyclistBikeData;
|
|
71
|
+
transformData(bikeData: IncyclistBikeData): DeviceData;
|
|
72
|
+
start(props?: any): Promise<any>;
|
|
73
|
+
stop(): Promise<boolean>;
|
|
74
|
+
pause(): Promise<boolean>;
|
|
75
|
+
resume(): Promise<boolean>;
|
|
76
|
+
}
|
|
77
|
+
export {};
|
package/lib/ble/pwr.js
ADDED
|
@@ -0,0 +1,243 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
const ble_device_1 = require("./ble-device");
|
|
16
|
+
const ble_interface_1 = __importDefault(require("./ble-interface"));
|
|
17
|
+
const Device_1 = __importDefault(require("../Device"));
|
|
18
|
+
const gd_eventlog_1 = require("gd-eventlog");
|
|
19
|
+
const power_meter_1 = __importDefault(require("../modes/power-meter"));
|
|
20
|
+
class BleCyclingPowerDevice extends ble_device_1.BleDevice {
|
|
21
|
+
constructor(props) {
|
|
22
|
+
super(props);
|
|
23
|
+
this.instantaneousPower = undefined;
|
|
24
|
+
this.balance = undefined;
|
|
25
|
+
this.accTorque = undefined;
|
|
26
|
+
this.rpm = undefined;
|
|
27
|
+
this.timeOffset = 0;
|
|
28
|
+
this.time = undefined;
|
|
29
|
+
this.currentCrankData = undefined;
|
|
30
|
+
this.prevCrankData = undefined;
|
|
31
|
+
}
|
|
32
|
+
getProfile() {
|
|
33
|
+
return 'cp';
|
|
34
|
+
}
|
|
35
|
+
getServiceUUids() {
|
|
36
|
+
return BleCyclingPowerDevice.services;
|
|
37
|
+
}
|
|
38
|
+
parseCrankData(crankData) {
|
|
39
|
+
if (!this.prevCrankData)
|
|
40
|
+
this.prevCrankData = { revolutions: 0, time: 0, cntUpdateMissing: -1 };
|
|
41
|
+
const c = this.currentCrankData = crankData;
|
|
42
|
+
const p = this.prevCrankData;
|
|
43
|
+
let rpm = this.rpm;
|
|
44
|
+
let hasUpdate = c.time !== p.time;
|
|
45
|
+
if (hasUpdate) {
|
|
46
|
+
let time = c.time - p.time;
|
|
47
|
+
let revs = c.revolutions - p.revolutions;
|
|
48
|
+
if (c.time < p.time) {
|
|
49
|
+
time += 0x10000;
|
|
50
|
+
this.timeOffset += 0x10000;
|
|
51
|
+
}
|
|
52
|
+
if (c.revolutions < p.revolutions)
|
|
53
|
+
revs += 0x10000;
|
|
54
|
+
rpm = 1024 * 60 * revs / time;
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
if (p.cntUpdateMissing < 0 || p.cntUpdateMissing > 2) {
|
|
58
|
+
rpm = 0;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
const cntUpdateMissing = p.cntUpdateMissing;
|
|
62
|
+
this.prevCrankData = this.currentCrankData;
|
|
63
|
+
if (hasUpdate)
|
|
64
|
+
this.prevCrankData.cntUpdateMissing = 0;
|
|
65
|
+
else
|
|
66
|
+
this.prevCrankData.cntUpdateMissing = cntUpdateMissing + 1;
|
|
67
|
+
return { rpm, time: this.timeOffset + c.time };
|
|
68
|
+
}
|
|
69
|
+
parsePower(data) {
|
|
70
|
+
try {
|
|
71
|
+
let offset = 4;
|
|
72
|
+
const flags = data.readUInt16LE(0);
|
|
73
|
+
this.instantaneousPower = data.readUInt16LE(2);
|
|
74
|
+
if (flags & 0x1)
|
|
75
|
+
this.balance = data.readUInt8(offset++);
|
|
76
|
+
if (flags & 0x4) {
|
|
77
|
+
this.accTorque = data.readUInt16LE(offset);
|
|
78
|
+
offset += 2;
|
|
79
|
+
}
|
|
80
|
+
if (flags & 0x20) {
|
|
81
|
+
const crankData = {
|
|
82
|
+
revolutions: data.readUInt16LE(offset),
|
|
83
|
+
time: data.readUInt16LE(offset + 2)
|
|
84
|
+
};
|
|
85
|
+
const { rpm, time } = this.parseCrankData(crankData);
|
|
86
|
+
this.rpm = rpm;
|
|
87
|
+
this.time = time;
|
|
88
|
+
offset += 4;
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
catch (err) {
|
|
92
|
+
}
|
|
93
|
+
const { instantaneousPower, balance, accTorque, rpm, time } = this;
|
|
94
|
+
return { instantaneousPower, balance, accTorque, rpm, time, raw: data };
|
|
95
|
+
}
|
|
96
|
+
onData(characteristic, data) {
|
|
97
|
+
if (characteristic.toLocaleLowerCase() === '2a63') {
|
|
98
|
+
const res = this.parsePower(data);
|
|
99
|
+
this.emit('data', res);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
write(characteristic, data) {
|
|
103
|
+
console.log('write', characteristic, data);
|
|
104
|
+
return Promise.resolve(true);
|
|
105
|
+
}
|
|
106
|
+
read(characteristic) {
|
|
107
|
+
console.log('read', characteristic);
|
|
108
|
+
return Promise.resolve(Buffer.from([]));
|
|
109
|
+
}
|
|
110
|
+
reset() {
|
|
111
|
+
this.instantaneousPower = undefined;
|
|
112
|
+
this.balance = undefined;
|
|
113
|
+
this.accTorque = undefined;
|
|
114
|
+
this.rpm = undefined;
|
|
115
|
+
this.timeOffset = 0;
|
|
116
|
+
this.time = undefined;
|
|
117
|
+
this.currentCrankData = undefined;
|
|
118
|
+
this.prevCrankData = undefined;
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
exports.default = BleCyclingPowerDevice;
|
|
122
|
+
BleCyclingPowerDevice.services = ['1818'];
|
|
123
|
+
BleCyclingPowerDevice.characteristics = ['2a63', '2a65', '2a5d', '2a3c'];
|
|
124
|
+
ble_interface_1.default.register('BleCyclingPowerDevice', 'cp', BleCyclingPowerDevice, BleCyclingPowerDevice.services);
|
|
125
|
+
class PwrAdapter extends Device_1.default {
|
|
126
|
+
constructor(device, protocol) {
|
|
127
|
+
super(protocol);
|
|
128
|
+
this.ignore = false;
|
|
129
|
+
this.paused = false;
|
|
130
|
+
this.distanceInternal = 0;
|
|
131
|
+
this.device = device;
|
|
132
|
+
this.ble = protocol.ble;
|
|
133
|
+
this.mode = this.getDefaultCyclingMode();
|
|
134
|
+
this.logger = new gd_eventlog_1.EventLogger('Ble-CP');
|
|
135
|
+
}
|
|
136
|
+
isBike() { return true; }
|
|
137
|
+
isHrm() { return false; }
|
|
138
|
+
isPower() { return true; }
|
|
139
|
+
getProfile() {
|
|
140
|
+
return 'Power Meter';
|
|
141
|
+
}
|
|
142
|
+
getName() {
|
|
143
|
+
return `${this.device.name}`;
|
|
144
|
+
}
|
|
145
|
+
getDisplayName() {
|
|
146
|
+
const { name, instantaneousPower: power } = this.device;
|
|
147
|
+
const powerStr = power ? ` (${power})` : '';
|
|
148
|
+
return `${name}${powerStr}`;
|
|
149
|
+
}
|
|
150
|
+
getCyclingMode() {
|
|
151
|
+
if (!this.mode)
|
|
152
|
+
this.mode = this.getDefaultCyclingMode();
|
|
153
|
+
return this.mode;
|
|
154
|
+
}
|
|
155
|
+
getDefaultCyclingMode() {
|
|
156
|
+
return new power_meter_1.default(this);
|
|
157
|
+
}
|
|
158
|
+
getPort() {
|
|
159
|
+
return 'ble';
|
|
160
|
+
}
|
|
161
|
+
setIgnoreBike(ignore) {
|
|
162
|
+
this.ignore = ignore;
|
|
163
|
+
}
|
|
164
|
+
setIgnorePower(ignore) {
|
|
165
|
+
this.ignore = ignore;
|
|
166
|
+
}
|
|
167
|
+
onDeviceData(deviceData) {
|
|
168
|
+
this.logger.logEvent({ message: 'onDeviceData', data: deviceData });
|
|
169
|
+
let incyclistData = this.mapData(deviceData);
|
|
170
|
+
incyclistData = this.getCyclingMode().updateData(incyclistData);
|
|
171
|
+
const data = this.transformData(incyclistData);
|
|
172
|
+
if (this.onDataFn && !this.ignore && !this.paused)
|
|
173
|
+
this.onDataFn(data);
|
|
174
|
+
}
|
|
175
|
+
mapData(deviceData) {
|
|
176
|
+
const data = {
|
|
177
|
+
isPedalling: false,
|
|
178
|
+
power: 0,
|
|
179
|
+
pedalRpm: 0,
|
|
180
|
+
speed: 0,
|
|
181
|
+
heartrate: 0,
|
|
182
|
+
distanceInternal: 0,
|
|
183
|
+
slope: undefined,
|
|
184
|
+
time: undefined
|
|
185
|
+
};
|
|
186
|
+
data.power = (deviceData.instantaneousPower !== undefined ? deviceData.instantaneousPower : data.power);
|
|
187
|
+
data.pedalRpm = (deviceData.rpm !== undefined ? deviceData.rpm : data.pedalRpm);
|
|
188
|
+
data.time = (deviceData.time !== undefined ? deviceData.time : data.time);
|
|
189
|
+
data.isPedalling = data.pedalRpm > 0 || (data.pedalRpm === undefined && data.power > 0);
|
|
190
|
+
return data;
|
|
191
|
+
}
|
|
192
|
+
transformData(bikeData) {
|
|
193
|
+
if (this.ignore) {
|
|
194
|
+
return {};
|
|
195
|
+
}
|
|
196
|
+
if (bikeData === undefined)
|
|
197
|
+
return;
|
|
198
|
+
let distance = 0;
|
|
199
|
+
if (this.distanceInternal !== undefined && bikeData.distanceInternal !== undefined) {
|
|
200
|
+
distance = Math.round(bikeData.distanceInternal - this.distanceInternal);
|
|
201
|
+
}
|
|
202
|
+
if (bikeData.distanceInternal !== undefined)
|
|
203
|
+
this.distanceInternal = bikeData.distanceInternal;
|
|
204
|
+
let data = {
|
|
205
|
+
speed: bikeData.speed,
|
|
206
|
+
slope: bikeData.slope,
|
|
207
|
+
power: bikeData.power !== undefined ? Math.round(bikeData.power) : undefined,
|
|
208
|
+
cadence: bikeData.pedalRpm !== undefined ? Math.round(bikeData.pedalRpm) : undefined,
|
|
209
|
+
distance,
|
|
210
|
+
timestamp: Date.now()
|
|
211
|
+
};
|
|
212
|
+
return data;
|
|
213
|
+
}
|
|
214
|
+
start(props) {
|
|
215
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
216
|
+
this.logger.logEvent({ message: 'start requested', props });
|
|
217
|
+
try {
|
|
218
|
+
const bleDevice = yield this.ble.connectDevice(this.device);
|
|
219
|
+
if (bleDevice) {
|
|
220
|
+
this.device = bleDevice;
|
|
221
|
+
bleDevice.on('data', (data) => {
|
|
222
|
+
this.onDeviceData(data);
|
|
223
|
+
});
|
|
224
|
+
return true;
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
catch (err) {
|
|
228
|
+
this.logger.logEvent({ message: 'start result: error', error: err.message });
|
|
229
|
+
return false;
|
|
230
|
+
}
|
|
231
|
+
});
|
|
232
|
+
}
|
|
233
|
+
stop() {
|
|
234
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
235
|
+
this.distanceInternal = 0;
|
|
236
|
+
this.device.reset();
|
|
237
|
+
return this.device.disconnect();
|
|
238
|
+
});
|
|
239
|
+
}
|
|
240
|
+
pause() { this.paused = true; return Promise.resolve(true); }
|
|
241
|
+
resume() { this.paused = false; return Promise.resolve(true); }
|
|
242
|
+
}
|
|
243
|
+
exports.PwrAdapter = PwrAdapter;
|
package/lib/calculations.js
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { EventLogger } from 'gd-eventlog';
|
|
2
2
|
import CyclingMode, { IncyclistBikeData } from '../CyclingMode';
|
|
3
|
-
import
|
|
3
|
+
import IncyclistDevice, { Bike, DeviceAdapter, DeviceData } from '../Device';
|
|
4
4
|
import { User } from '../types/user';
|
|
5
5
|
interface DaumAdapter {
|
|
6
6
|
getCurrentBikeData(): Promise<any>;
|
|
7
7
|
}
|
|
8
|
-
export default class DaumAdapterBase extends
|
|
8
|
+
export default class DaumAdapterBase extends IncyclistDevice implements DeviceAdapter, DaumAdapter, Bike {
|
|
9
9
|
bike: any;
|
|
10
10
|
ignoreHrm: boolean;
|
|
11
11
|
ignoreBike: boolean;
|
package/lib/daum/DaumAdapter.js
CHANGED
|
@@ -1,23 +1,4 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
-
}) : (function(o, m, k, k2) {
|
|
6
|
-
if (k2 === undefined) k2 = k;
|
|
7
|
-
o[k2] = m[k];
|
|
8
|
-
}));
|
|
9
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
10
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
11
|
-
}) : function(o, v) {
|
|
12
|
-
o["default"] = v;
|
|
13
|
-
});
|
|
14
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
15
|
-
if (mod && mod.__esModule) return mod;
|
|
16
|
-
var result = {};
|
|
17
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
18
|
-
__setModuleDefault(result, mod);
|
|
19
|
-
return result;
|
|
20
|
-
};
|
|
21
2
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
22
3
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
23
4
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
@@ -27,6 +8,13 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
27
8
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
28
9
|
});
|
|
29
10
|
};
|
|
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
|
+
};
|
|
30
18
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
31
19
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
32
20
|
};
|
|
@@ -312,16 +300,16 @@ class DaumAdapterBase extends Device_1.default {
|
|
|
312
300
|
return;
|
|
313
301
|
let distance = 0;
|
|
314
302
|
if (this.distanceInternal !== undefined && this.cyclingData.distanceInternal !== undefined) {
|
|
315
|
-
distance =
|
|
303
|
+
distance = utils_1.intVal(this.cyclingData.distanceInternal - this.distanceInternal);
|
|
316
304
|
}
|
|
317
305
|
if (this.cyclingData.distanceInternal !== undefined)
|
|
318
306
|
this.distanceInternal = this.cyclingData.distanceInternal;
|
|
319
307
|
let data = {
|
|
320
|
-
speed:
|
|
321
|
-
slope:
|
|
322
|
-
power:
|
|
323
|
-
cadence:
|
|
324
|
-
heartrate:
|
|
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),
|
|
325
313
|
distance,
|
|
326
314
|
timestamp: Date.now(),
|
|
327
315
|
deviceTime: this.cyclingData.time,
|
|
@@ -3,7 +3,6 @@ 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;
|
|
7
6
|
const gd_eventlog_1 = require("gd-eventlog");
|
|
8
7
|
const CyclingMode_1 = require("../CyclingMode");
|
|
9
8
|
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
|
|
89
|
+
return 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,23 +1,4 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
-
}) : (function(o, m, k, k2) {
|
|
6
|
-
if (k2 === undefined) k2 = k;
|
|
7
|
-
o[k2] = m[k];
|
|
8
|
-
}));
|
|
9
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
10
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
11
|
-
}) : function(o, v) {
|
|
12
|
-
o["default"] = v;
|
|
13
|
-
});
|
|
14
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
15
|
-
if (mod && mod.__esModule) return mod;
|
|
16
|
-
var result = {};
|
|
17
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
18
|
-
__setModuleDefault(result, mod);
|
|
19
|
-
return result;
|
|
20
|
-
};
|
|
21
2
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
22
3
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
23
4
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
@@ -27,6 +8,13 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
27
8
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
28
9
|
});
|
|
29
10
|
};
|
|
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
|
+
};
|
|
30
18
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
31
19
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
32
20
|
};
|