2022-08-06 14:13:28 +02:00
|
|
|
import 'package:flutter/material.dart';
|
2022-08-07 01:37:12 +02:00
|
|
|
import 'package:flutter_i18n/flutter_i18n.dart';
|
2022-08-06 14:13:28 +02:00
|
|
|
import 'package:google_fonts/google_fonts.dart';
|
2022-09-18 17:49:18 +02:00
|
|
|
import 'package:animations/animations.dart';
|
2022-08-16 15:06:56 +02:00
|
|
|
import 'package:revanced_manager/app/app.locator.dart';
|
2022-08-09 01:01:06 +02:00
|
|
|
import 'package:revanced_manager/ui/views/home/home_viewmodel.dart';
|
2022-08-21 12:47:44 +02:00
|
|
|
import 'package:revanced_manager/ui/widgets/homeView/available_updates_card.dart';
|
|
|
|
import 'package:revanced_manager/ui/widgets/homeView/installed_apps_card.dart';
|
|
|
|
import 'package:revanced_manager/ui/widgets/homeView/latest_commit_card.dart';
|
2022-09-06 15:39:15 +02:00
|
|
|
import 'package:revanced_manager/ui/widgets/shared/custom_chip.dart';
|
2022-09-02 15:35:25 +02:00
|
|
|
import 'package:revanced_manager/ui/widgets/shared/custom_sliver_app_bar.dart';
|
2022-08-06 14:13:28 +02:00
|
|
|
import 'package:stacked/stacked.dart';
|
|
|
|
|
|
|
|
class HomeView extends StatelessWidget {
|
|
|
|
const HomeView({Key? key}) : super(key: key);
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
2022-08-16 15:06:56 +02:00
|
|
|
return ViewModelBuilder<HomeViewModel>.reactive(
|
|
|
|
disposeViewModel: false,
|
2022-09-12 01:35:41 +02:00
|
|
|
onModelReady: (model) => model.initialize(context),
|
2022-08-16 15:06:56 +02:00
|
|
|
viewModelBuilder: () => locator<HomeViewModel>(),
|
2022-08-06 14:13:28 +02:00
|
|
|
builder: (context, model, child) => Scaffold(
|
2022-09-11 03:01:06 +02:00
|
|
|
body: RefreshIndicator(
|
|
|
|
color: Theme.of(context).colorScheme.secondary,
|
|
|
|
backgroundColor: Theme.of(context).colorScheme.secondaryContainer,
|
2022-09-12 01:35:41 +02:00
|
|
|
onRefresh: () => model.forceRefresh(context),
|
2022-09-11 03:01:06 +02:00
|
|
|
child: CustomScrollView(
|
|
|
|
slivers: <Widget>[
|
|
|
|
CustomSliverAppBar(
|
2022-09-19 17:24:31 +02:00
|
|
|
isMainView: true,
|
2022-09-11 03:01:06 +02:00
|
|
|
title: I18nText(
|
|
|
|
'homeView.widgetTitle',
|
|
|
|
child: Text(
|
|
|
|
'',
|
|
|
|
style: GoogleFonts.inter(
|
|
|
|
color: Theme.of(context).textTheme.headline6!.color,
|
|
|
|
),
|
2022-08-06 14:13:28 +02:00
|
|
|
),
|
2022-08-24 14:22:36 +02:00
|
|
|
),
|
|
|
|
),
|
2022-09-11 03:01:06 +02:00
|
|
|
SliverPadding(
|
2022-09-12 18:30:44 +02:00
|
|
|
padding: const EdgeInsets.all(20.0),
|
2022-09-11 03:01:06 +02:00
|
|
|
sliver: SliverList(
|
|
|
|
delegate: SliverChildListDelegate.fixed(
|
|
|
|
<Widget>[
|
|
|
|
I18nText(
|
|
|
|
'homeView.updatesSubtitle',
|
|
|
|
child: Text(
|
|
|
|
'',
|
|
|
|
style: Theme.of(context).textTheme.headline6!,
|
|
|
|
),
|
2022-08-07 01:37:12 +02:00
|
|
|
),
|
2022-09-11 03:01:06 +02:00
|
|
|
const SizedBox(height: 10),
|
|
|
|
LatestCommitCard(
|
|
|
|
onPressed: () =>
|
|
|
|
model.showUpdateConfirmationDialog(context),
|
2022-08-16 15:06:56 +02:00
|
|
|
),
|
2022-09-11 03:01:06 +02:00
|
|
|
const SizedBox(height: 23),
|
|
|
|
I18nText(
|
|
|
|
'homeView.patchedSubtitle',
|
|
|
|
child: Text(
|
|
|
|
'',
|
|
|
|
style: Theme.of(context).textTheme.headline6!,
|
2022-08-24 14:22:36 +02:00
|
|
|
),
|
2022-09-11 03:01:06 +02:00
|
|
|
),
|
|
|
|
const SizedBox(height: 8),
|
|
|
|
Row(
|
|
|
|
children: <Widget>[
|
|
|
|
DashboardChip(
|
2022-10-19 23:15:48 +02:00
|
|
|
label: I18nText('homeView.installed'),
|
|
|
|
isSelected: !model.showUpdatableApps,
|
2022-09-11 03:01:06 +02:00
|
|
|
onSelected: (value) {
|
2022-10-19 23:15:48 +02:00
|
|
|
model.toggleUpdatableApps(false);
|
2022-09-11 03:01:06 +02:00
|
|
|
},
|
|
|
|
),
|
|
|
|
const SizedBox(width: 10),
|
|
|
|
DashboardChip(
|
2022-10-19 23:15:48 +02:00
|
|
|
label: I18nText('homeView.updatesAvailable'),
|
|
|
|
isSelected: model.showUpdatableApps,
|
2022-09-11 03:01:06 +02:00
|
|
|
onSelected: (value) {
|
2022-10-19 23:15:48 +02:00
|
|
|
model.toggleUpdatableApps(true);
|
2022-09-11 03:01:06 +02:00
|
|
|
},
|
|
|
|
)
|
|
|
|
],
|
|
|
|
),
|
|
|
|
const SizedBox(height: 14),
|
2022-09-18 17:49:18 +02:00
|
|
|
PageTransitionSwitcher(
|
|
|
|
transitionBuilder:
|
|
|
|
(child, primaryAnimation, secondaryAnimation) {
|
|
|
|
return FadeThroughTransition(
|
|
|
|
animation: primaryAnimation,
|
|
|
|
secondaryAnimation: secondaryAnimation,
|
|
|
|
fillColor: Colors.transparent,
|
|
|
|
child: child,
|
|
|
|
);
|
|
|
|
},
|
|
|
|
layoutBuilder: (entries) {
|
|
|
|
return Stack(
|
|
|
|
alignment: Alignment.topCenter,
|
|
|
|
children: entries,
|
|
|
|
);
|
|
|
|
},
|
|
|
|
child: model.showUpdatableApps
|
|
|
|
? AvailableUpdatesCard()
|
|
|
|
: InstalledAppsCard(),
|
|
|
|
),
|
2022-09-11 03:01:06 +02:00
|
|
|
],
|
|
|
|
),
|
2022-08-24 14:22:36 +02:00
|
|
|
),
|
2022-08-06 14:13:28 +02:00
|
|
|
),
|
2022-09-11 03:01:06 +02:00
|
|
|
],
|
|
|
|
),
|
2022-08-06 14:13:28 +02:00
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|