Files
umbrix/lib/features/home/widget/home_page.dart

122 lines
4.2 KiB
Dart
Raw Normal View History

2024-02-09 12:02:52 +03:30
import 'dart:io';
2023-09-12 15:22:58 +03:30
import 'package:dartx/dartx.dart';
2023-07-06 17:18:41 +03:30
import 'package:flutter/material.dart';
2023-12-01 12:56:24 +03:30
import 'package:hiddify/core/app_info/app_info_provider.dart';
import 'package:hiddify/core/localization/translations.dart';
import 'package:hiddify/core/model/failures.dart';
2023-07-06 17:18:41 +03:30
import 'package:hiddify/core/router/router.dart';
import 'package:hiddify/features/common/nested_app_bar.dart';
2023-12-01 12:56:24 +03:30
import 'package:hiddify/features/home/widget/connection_button.dart';
import 'package:hiddify/features/home/widget/empty_profiles_home_body.dart';
2023-11-26 21:20:58 +03:30
import 'package:hiddify/features/profile/notifier/active_profile_notifier.dart';
import 'package:hiddify/features/profile/widget/profile_tile.dart';
2024-02-09 12:02:52 +03:30
import 'package:hiddify/features/proxy/active/active_proxy_footer.dart';
2023-07-06 17:18:41 +03:30
import 'package:hiddify/utils/utils.dart';
import 'package:hooks_riverpod/hooks_riverpod.dart';
import 'package:sliver_tools/sliver_tools.dart';
class HomePage extends HookConsumerWidget {
const HomePage({super.key});
@override
Widget build(BuildContext context, WidgetRef ref) {
final t = ref.watch(translationsProvider);
final hasAnyProfile = ref.watch(hasAnyProfileProvider);
final activeProfile = ref.watch(activeProfileProvider);
return Scaffold(
body: Stack(
alignment: Alignment.bottomCenter,
children: [
CustomScrollView(
slivers: [
NestedAppBar(
2023-11-10 15:35:44 +03:30
title: Text.rich(
TextSpan(
children: [
TextSpan(text: t.general.appTitle),
const TextSpan(text: " "),
const WidgetSpan(
child: AppVersionLabel(),
alignment: PlaceholderAlignment.middle,
),
],
),
2023-07-26 23:34:03 +03:30
),
2023-07-06 17:18:41 +03:30
actions: [
IconButton(
onPressed: () => const AddProfileRoute().push(context),
icon: const Icon(Icons.add_circle),
2023-08-24 22:19:36 +03:30
tooltip: t.profile.add.buttonText,
2023-07-06 17:18:41 +03:30
),
],
),
switch (activeProfile) {
AsyncData(value: final profile?) => MultiSliver(
children: [
2023-07-24 19:45:58 +03:30
ProfileTile(profile: profile, isMain: true),
2024-02-09 12:02:52 +03:30
SliverFillRemaining(
2023-07-06 17:18:41 +03:30
hasScrollBody: false,
2024-02-09 12:02:52 +03:30
child: Column(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
const Expanded(child: ConnectionButton()),
if (Platform.isAndroid) const ActiveProxyFooter(),
],
2023-07-06 17:18:41 +03:30
),
),
],
),
AsyncData() => switch (hasAnyProfile) {
AsyncData(value: true) =>
const EmptyActiveProfileHomeBody(),
_ => const EmptyProfilesHomeBody(),
},
AsyncError(:final error) =>
2023-10-04 18:06:48 +03:30
SliverErrorBodyPlaceholder(t.presentShortError(error)),
2023-07-06 17:18:41 +03:30
_ => const SliverToBoxAdapter(),
},
],
),
],
),
);
}
}
2023-07-26 23:34:03 +03:30
class AppVersionLabel extends HookConsumerWidget {
const AppVersionLabel({super.key});
@override
Widget build(BuildContext context, WidgetRef ref) {
2023-09-12 00:05:44 +03:30
final t = ref.watch(translationsProvider);
2023-07-26 23:34:03 +03:30
final theme = Theme.of(context);
2023-12-01 12:56:24 +03:30
final version = ref.watch(appInfoProvider).requireValue.presentVersion;
2023-09-12 15:22:58 +03:30
if (version.isBlank) return const SizedBox();
2023-07-26 23:34:03 +03:30
2023-09-12 00:05:44 +03:30
return Semantics(
label: t.about.version,
button: false,
child: Container(
decoration: BoxDecoration(
color: theme.colorScheme.secondaryContainer,
borderRadius: BorderRadius.circular(4),
),
padding: const EdgeInsets.symmetric(
horizontal: 4,
vertical: 1,
),
child: Text(
version,
2023-09-12 15:22:58 +03:30
textDirection: TextDirection.ltr,
2023-09-12 00:05:44 +03:30
style: theme.textTheme.bodySmall?.copyWith(
color: theme.colorScheme.onSecondaryContainer,
),
2023-07-26 23:34:03 +03:30
),
),
);
}
}