2023-03-22 11:38:18 +00:00
|
|
|
import 'package:auto_route/auto_route.dart';
|
2022-05-31 14:30:44 +00:00
|
|
|
import 'package:cubit_form/cubit_form.dart';
|
|
|
|
import 'package:easy_localization/easy_localization.dart';
|
|
|
|
import 'package:flutter/material.dart';
|
2024-02-09 11:07:03 +00:00
|
|
|
import 'package:selfprivacy/logic/bloc/devices/devices_bloc.dart';
|
2022-05-31 14:30:44 +00:00
|
|
|
import 'package:selfprivacy/logic/cubit/server_installation/server_installation_cubit.dart';
|
2024-12-06 15:59:10 +00:00
|
|
|
import 'package:selfprivacy/ui/atoms/list_tiles/section_title.dart';
|
2024-01-31 05:14:23 +00:00
|
|
|
import 'package:selfprivacy/ui/layouts/brand_hero_screen.dart';
|
2024-11-06 00:22:30 +00:00
|
|
|
import 'package:selfprivacy/ui/molecules/info_box/info_box.dart';
|
2024-12-06 15:59:10 +00:00
|
|
|
import 'package:selfprivacy/ui/molecules/list_items/device_item.dart';
|
|
|
|
import 'package:selfprivacy/ui/router/router.dart';
|
2022-05-31 14:30:44 +00:00
|
|
|
|
2023-03-22 11:38:18 +00:00
|
|
|
@RoutePage()
|
2024-12-06 15:59:10 +00:00
|
|
|
class DevicesPage extends StatefulWidget {
|
|
|
|
const DevicesPage({super.key});
|
2022-05-31 14:30:44 +00:00
|
|
|
|
|
|
|
@override
|
2024-12-06 15:59:10 +00:00
|
|
|
State<DevicesPage> createState() => _DevicesPageState();
|
2022-05-31 14:30:44 +00:00
|
|
|
}
|
|
|
|
|
2024-12-06 15:59:10 +00:00
|
|
|
class _DevicesPageState extends State<DevicesPage> {
|
2022-05-31 14:30:44 +00:00
|
|
|
@override
|
2022-06-05 19:36:32 +00:00
|
|
|
Widget build(final BuildContext context) {
|
2024-02-09 11:07:03 +00:00
|
|
|
final DevicesState devicesStatus = context.watch<DevicesBloc>().state;
|
2022-05-31 14:30:44 +00:00
|
|
|
|
|
|
|
return RefreshIndicator(
|
|
|
|
onRefresh: () async {
|
2024-02-09 11:07:03 +00:00
|
|
|
await context.read<DevicesBloc>().refresh();
|
2022-05-31 14:30:44 +00:00
|
|
|
},
|
|
|
|
child: BrandHeroScreen(
|
|
|
|
heroTitle: 'devices.main_screen.header'.tr(),
|
|
|
|
heroSubtitle: 'devices.main_screen.description'.tr(),
|
2024-12-06 15:59:10 +00:00
|
|
|
heroIcon: Icons.devices_outlined,
|
2022-05-31 14:30:44 +00:00
|
|
|
hasBackButton: true,
|
|
|
|
hasFlashButton: false,
|
2022-06-07 19:59:15 +00:00
|
|
|
children: [
|
2024-02-09 11:07:03 +00:00
|
|
|
if (devicesStatus is DevicesInitial) ...[
|
2022-06-07 19:59:15 +00:00
|
|
|
const Center(
|
|
|
|
heightFactor: 8,
|
2024-03-13 15:20:50 +00:00
|
|
|
child: CircularProgressIndicator.adaptive(),
|
2022-06-07 19:59:15 +00:00
|
|
|
),
|
|
|
|
],
|
2024-02-09 11:07:03 +00:00
|
|
|
if (devicesStatus is! DevicesInitial) ...[
|
2022-06-07 19:59:15 +00:00
|
|
|
_DevicesInfo(
|
|
|
|
devicesStatus: devicesStatus,
|
|
|
|
),
|
|
|
|
const SizedBox(height: 16),
|
|
|
|
OutlinedButton(
|
2024-12-06 15:59:10 +00:00
|
|
|
onPressed: () => context.pushRoute(const NewDeviceRoute()),
|
2022-06-07 19:59:15 +00:00
|
|
|
child: Text('devices.main_screen.authorize_new_device'.tr()),
|
|
|
|
),
|
|
|
|
const SizedBox(height: 16),
|
|
|
|
const Divider(height: 1),
|
|
|
|
const SizedBox(height: 16),
|
2022-09-15 21:08:32 +00:00
|
|
|
InfoBox(
|
|
|
|
text: 'devices.main_screen.tip'.tr(),
|
|
|
|
),
|
2022-06-07 19:59:15 +00:00
|
|
|
],
|
|
|
|
const SizedBox(height: 24),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
class _DevicesInfo extends StatelessWidget {
|
|
|
|
const _DevicesInfo({
|
|
|
|
required this.devicesStatus,
|
|
|
|
});
|
|
|
|
|
2024-02-09 11:07:03 +00:00
|
|
|
final DevicesState devicesStatus;
|
2022-06-07 19:59:15 +00:00
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(final BuildContext context) => Column(
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
2022-05-31 14:30:44 +00:00
|
|
|
children: [
|
2024-12-06 15:59:10 +00:00
|
|
|
SectionTitle(
|
|
|
|
title: 'devices.main_screen.this_device'.tr(),
|
2022-05-31 14:30:44 +00:00
|
|
|
),
|
2024-12-06 15:59:10 +00:00
|
|
|
DeviceItem(
|
2024-02-09 11:07:03 +00:00
|
|
|
device: devicesStatus.thisDevice,
|
|
|
|
),
|
2024-12-06 15:59:10 +00:00
|
|
|
const SizedBox(height: 8),
|
2022-05-31 14:30:44 +00:00
|
|
|
const Divider(height: 1),
|
2024-12-06 15:59:10 +00:00
|
|
|
const SizedBox(height: 8),
|
|
|
|
SectionTitle(
|
|
|
|
title: 'devices.main_screen.other_devices'.tr(),
|
2022-05-31 14:30:44 +00:00
|
|
|
),
|
2024-02-09 11:07:03 +00:00
|
|
|
if (devicesStatus is DevicesDeleting) ...[
|
2023-11-30 08:15:56 +00:00
|
|
|
const Center(
|
|
|
|
heightFactor: 4,
|
2024-03-13 15:20:50 +00:00
|
|
|
child: CircularProgressIndicator.adaptive(),
|
2023-11-30 08:15:56 +00:00
|
|
|
),
|
|
|
|
],
|
2024-02-09 11:07:03 +00:00
|
|
|
if (devicesStatus is! DevicesDeleting)
|
|
|
|
...devicesStatus.otherDevices.map(
|
2024-12-06 15:59:10 +00:00
|
|
|
(final device) => DeviceItem(
|
2024-02-09 11:07:03 +00:00
|
|
|
device: device,
|
|
|
|
),
|
|
|
|
),
|
2022-05-31 14:30:44 +00:00
|
|
|
],
|
2022-06-07 19:59:15 +00:00
|
|
|
);
|
2022-05-31 14:30:44 +00:00
|
|
|
}
|