summaryrefslogtreecommitdiff
path: root/lib/widgets/device_details.dart
blob: 17319f4d82441da76147e641a3a085221d0c363b (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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
// 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:ui';

import 'package:uvok_epaper_badge/model/badge_motive_selection_factory.dart';
import 'package:uvok_epaper_badge/model/device/device.dart';
import 'package:flutter/material.dart';
import 'package:logger/logger.dart';
import 'package:uvok_epaper_badge/model/connection/device_connection.dart';
import 'package:uvok_epaper_badge/model/motive_selection/badge_motive_selection.dart';
import 'package:uvok_epaper_badge/view_model/badge_motive_view_model.dart';
import 'package:uvok_epaper_badge/widgets/badge_motive_list.dart';

var logger = Logger();

class DeviceDetailsScreen extends StatefulWidget {
  final Device device;
  final DeviceConnection deviceConnection;

  final BadgeMotiveSelection _motiveSelection;

  DeviceDetailsScreen({
    super.key,
    required this.device,
    required this.deviceConnection,
  }) : _motiveSelection =
           BadgeMotiveSelectionFactory.createBadgeMotiveSelection(device);

  @override
  State<StatefulWidget> createState() {
    return DeviceDetailsState();
  }
}

class DeviceDetailsState extends State<DeviceDetailsScreen> {
  late final AppLifecycleListener appLL;

  /// Whether the back button should be active.
  bool backActive = false;

  DeviceDetailsState() {
    appLL = AppLifecycleListener(
      onExitRequested: () async {
        logger.i("Exit requested");
        dispose();
        return AppExitResponse.exit;
      },
    );
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        backgroundColor: Theme.of(context).colorScheme.inversePrimary,
        title: Text("Device details"),
      ),
      body: Center(
        child: ValueListenableBuilder(
          valueListenable: widget.deviceConnection.status,
          builder: (connCtx, ConnectionStatus value, child) {
            return Column(
              spacing: 20,
              children: [
                SizedBox(height: 20),
                Text("Connection state: ${value.toString()}"),
                BadgeMotiveList(
                  motiveVM: BadgeMotiveViewModel(
                    motivSelect: widget._motiveSelection,
                  ),
                ),
              ],
            );
          },
        ),
      ),
    );
  }

  @override
  void initState() {
    super.initState();
    _doConnect();
  }

  @override
  void deactivate() {
    logger.i("(widget deactivate)");
    // widget.device.disconnect().ignore();
    super.deactivate();
  }

  @override
  void dispose() {
    logger.i("(widget dispose)");
    widget.deviceConnection.disconnect().ignore();
    super.dispose();
  }

  void _doConnect() async {
    try {
      logger.i("Try to connect...");
      await widget.deviceConnection.connect();
    } catch (e) {
      logger.e(e);
      await widget.deviceConnection.disconnect();
    } finally {
      backActive = true;
    }
  }
}