blob: 86429b6add52d9e4026218a798dea086adb20f46 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
|
// Copyright (C) 2025, uvok cheetah
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <https://www.gnu.org/licenses/>.
import 'dart:convert';
import 'package:universal_ble/universal_ble.dart';
import 'package:uvok_epaper_badge/model/badge_motive.dart';
import 'package:uvok_epaper_badge/model/device/universal_ble_device.dart';
import 'package:uvok_epaper_badge/model/motive_selection/badge_motive_selection.dart';
class UniversalBlueMotiveSelection implements BadgeMotiveSelection {
final UniversalBleDevice _device;
final String _badgeService = "ca260000-b4bb-46b2-bd06-b7b7a61ea990";
final String _currentMotiveCharacteristic =
"ca260001-b4bb-46b2-bd06-b7b7a61ea990";
final String _availableMotivesCharacteristic =
"ca260002-b4bb-46b2-bd06-b7b7a61ea990";
List<BadgeMotive> _cachedMotives = [];
UniversalBlueMotiveSelection({required UniversalBleDevice device})
: _device = device;
@override
Future<BadgeMotive> getCurrentMotive() async {
if (_cachedMotives.isEmpty) {
return BadgeMotive(-1, "No motives");
}
return BadgeMotive(-1, "Unspecified motive");
}
@override
Future<List<BadgeMotive>> getMotives() async {
bool gotMotives = false;
if (await _device.device.connectionState == BleConnectionState.connected) {
var c = await _device.device.getCharacteristic(
_availableMotivesCharacteristic,
service: _badgeService,
);
var val = await c.read();
var templates = ascii.decode(val);
_cachedMotives = templates
.split(";")
.where((s) => s.isNotEmpty)
.map((String s) {
List<String> parts = s.split("-");
if (parts.length != 2) {
return BadgeMotive(-1, "Invalid value");
}
return BadgeMotive(int.tryParse(parts[0]) ?? -1, parts[1]);
})
.toList(growable: false);
gotMotives = true;
}
if (!gotMotives) {
_cachedMotives = [BadgeMotive(-1, "Failed fetching motives")];
}
return _cachedMotives;
}
@override
Future<void> setCurrentMotive(BadgeMotive motive) async {}
}
|