mirror of
https://git.selfprivacy.org/kherel/selfprivacy.org.app.git
synced 2025-01-08 00:51:20 +00:00
refactor(ui): Add skeletons to the Devices page
This commit is contained in:
parent
65ec990410
commit
52b2d0f51e
|
@ -6,6 +6,7 @@ import 'package:flutter_bloc/flutter_bloc.dart';
|
||||||
import 'package:selfprivacy/config/get_it_config.dart';
|
import 'package:selfprivacy/config/get_it_config.dart';
|
||||||
import 'package:selfprivacy/logic/api_maps/generic_result.dart';
|
import 'package:selfprivacy/logic/api_maps/generic_result.dart';
|
||||||
import 'package:selfprivacy/logic/models/json/api_token.dart';
|
import 'package:selfprivacy/logic/models/json/api_token.dart';
|
||||||
|
import 'package:selfprivacy/utils/fake_data.dart';
|
||||||
|
|
||||||
part 'devices_event.dart';
|
part 'devices_event.dart';
|
||||||
part 'devices_state.dart';
|
part 'devices_state.dart';
|
||||||
|
|
|
@ -7,17 +7,15 @@ sealed class DevicesState extends Equatable {
|
||||||
|
|
||||||
final int _hashCode;
|
final int _hashCode;
|
||||||
|
|
||||||
|
bool get isLoaded => _devices.isNotEmpty;
|
||||||
|
|
||||||
List<ApiToken> get _devices =>
|
List<ApiToken> get _devices =>
|
||||||
getIt<ApiConnectionRepository>().apiData.devices.data ?? const [];
|
getIt<ApiConnectionRepository>().apiData.devices.data ?? const [];
|
||||||
|
|
||||||
List<ApiToken> get devices => _devices;
|
List<ApiToken> get devices => _devices;
|
||||||
ApiToken get thisDevice => _devices.firstWhere(
|
ApiToken get thisDevice => _devices.firstWhere(
|
||||||
(final device) => device.isCaller,
|
(final device) => device.isCaller,
|
||||||
orElse: () => ApiToken(
|
orElse: () => FakeSelfPrivacyData.thisDeviceToken,
|
||||||
name: 'Error fetching device',
|
|
||||||
isCaller: true,
|
|
||||||
date: DateTime.now(),
|
|
||||||
),
|
|
||||||
);
|
);
|
||||||
|
|
||||||
List<ApiToken> get otherDevices =>
|
List<ApiToken> get otherDevices =>
|
||||||
|
|
|
@ -9,6 +9,8 @@ import 'package:selfprivacy/ui/layouts/brand_hero_screen.dart';
|
||||||
import 'package:selfprivacy/ui/molecules/info_box/info_box.dart';
|
import 'package:selfprivacy/ui/molecules/info_box/info_box.dart';
|
||||||
import 'package:selfprivacy/ui/molecules/list_items/device_item.dart';
|
import 'package:selfprivacy/ui/molecules/list_items/device_item.dart';
|
||||||
import 'package:selfprivacy/ui/router/router.dart';
|
import 'package:selfprivacy/ui/router/router.dart';
|
||||||
|
import 'package:selfprivacy/utils/fake_data.dart';
|
||||||
|
import 'package:skeletonizer/skeletonizer.dart';
|
||||||
|
|
||||||
@RoutePage()
|
@RoutePage()
|
||||||
class DevicesPage extends StatefulWidget {
|
class DevicesPage extends StatefulWidget {
|
||||||
|
@ -77,8 +79,12 @@ class _DevicesInfo extends StatelessWidget {
|
||||||
SectionTitle(
|
SectionTitle(
|
||||||
title: 'devices.main_screen.this_device'.tr(),
|
title: 'devices.main_screen.this_device'.tr(),
|
||||||
),
|
),
|
||||||
DeviceItem(
|
Skeletonizer(
|
||||||
device: devicesStatus.thisDevice,
|
enabled:
|
||||||
|
devicesStatus.thisDevice == FakeSelfPrivacyData.thisDeviceToken,
|
||||||
|
child: DeviceItem(
|
||||||
|
device: devicesStatus.thisDevice,
|
||||||
|
),
|
||||||
),
|
),
|
||||||
const SizedBox(height: 8),
|
const SizedBox(height: 8),
|
||||||
const Divider(height: 1),
|
const Divider(height: 1),
|
||||||
|
@ -92,7 +98,17 @@ class _DevicesInfo extends StatelessWidget {
|
||||||
child: CircularProgressIndicator.adaptive(),
|
child: CircularProgressIndicator.adaptive(),
|
||||||
),
|
),
|
||||||
],
|
],
|
||||||
if (devicesStatus is! DevicesDeleting)
|
if (!devicesStatus.isLoaded)
|
||||||
|
...List.generate(
|
||||||
|
3,
|
||||||
|
(final index) => Skeletonizer(
|
||||||
|
enabled: true,
|
||||||
|
child: DeviceItem(
|
||||||
|
device: FakeSelfPrivacyData.otherDeviceToken,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
if (devicesStatus is! DevicesDeleting && devicesStatus.isLoaded)
|
||||||
...devicesStatus.otherDevices.map(
|
...devicesStatus.otherDevices.map(
|
||||||
(final device) => DeviceItem(
|
(final device) => DeviceItem(
|
||||||
device: device,
|
device: device,
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
import 'package:selfprivacy/logic/api_maps/rest_maps/dns_providers/desired_dns_record.dart';
|
import 'package:selfprivacy/logic/api_maps/rest_maps/dns_providers/desired_dns_record.dart';
|
||||||
|
import 'package:selfprivacy/logic/models/json/api_token.dart';
|
||||||
|
|
||||||
/// Fake data collections to fill skeletons
|
/// Fake data collections to fill skeletons
|
||||||
class FakeSelfPrivacyData {
|
class FakeSelfPrivacyData {
|
||||||
|
@ -28,4 +29,16 @@ class FakeSelfPrivacyData {
|
||||||
content: 'Some very very long text text text',
|
content: 'Some very very long text text text',
|
||||||
),
|
),
|
||||||
];
|
];
|
||||||
|
|
||||||
|
static final ApiToken thisDeviceToken = ApiToken(
|
||||||
|
name: 'Error fetching device',
|
||||||
|
isCaller: true,
|
||||||
|
date: DateTime.now(),
|
||||||
|
);
|
||||||
|
|
||||||
|
static final ApiToken otherDeviceToken = ApiToken(
|
||||||
|
name: 'Error fetching device',
|
||||||
|
isCaller: false,
|
||||||
|
date: DateTime.now(),
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue