refactor: migrate to stacked architecture.

* feat: mostly done stacked architecture.

* refactor: migration to stacked architecture.
This commit is contained in:
Aunali321
2022-08-06 17:43:28 +05:30
committed by GitHub
parent 0b58ce3dca
commit 769ff72f98
20 changed files with 825 additions and 267 deletions

View File

@ -1,92 +0,0 @@
import 'package:device_apps/device_apps.dart';
import 'package:flutter/material.dart';
import 'package:revanced_manager_flutter/ui/widgets/installed_app_item.dart';
import 'package:revanced_manager_flutter/ui/widgets/search_bar.dart';
class AppSelectorScreen extends StatefulWidget {
const AppSelectorScreen({Key? key}) : super(key: key);
@override
State<AppSelectorScreen> createState() => _AppSelectorScreenState();
}
class _AppSelectorScreenState extends State<AppSelectorScreen> {
List<Application> apps = [];
String query = '';
void getApps() async {
apps = await DeviceApps.getInstalledApplications();
setState(() {});
}
@override
void initState() {
getApps();
super.initState();
}
@override
Widget build(BuildContext context) {
return Scaffold(
body: SafeArea(
child: Padding(
padding: const EdgeInsets.symmetric(vertical: 4.0, horizontal: 12.0),
child: Column(
children: [
SearchBar(
onQueryChanged: (searchQuery) {
setState(() {
query = searchQuery;
});
},
),
if (query.isEmpty || query.length < 2)
apps.isEmpty
? const Center(
child: CircularProgressIndicator(),
)
: Expanded(
child: ListView.builder(
itemCount: apps.length,
itemBuilder: (context, index) {
//sort alphabetically
apps.sort((a, b) => a.appName.compareTo(b.appName));
return InstalledAppItem(
name: apps[index].appName,
pkgName: apps[index].packageName,
isSelected: false,
);
},
),
),
if (query.isNotEmpty)
apps.isEmpty
? const Center(
child: Text('No apps found'),
)
: Expanded(
child: ListView.builder(
itemCount: apps.length,
itemBuilder: (context, index) {
apps.sort((a, b) => a.appName.compareTo(b.appName));
if (apps[index].appName.toLowerCase().contains(
query.toLowerCase(),
)) {
return InstalledAppItem(
name: apps[index].appName,
pkgName: apps[index].packageName,
isSelected: false,
);
} else {
return SizedBox();
}
},
),
),
],
),
),
),
);
}
}

View File

@ -1,66 +0,0 @@
import 'package:flutter/material.dart';
import 'package:google_fonts/google_fonts.dart';
import 'package:revanced_manager_flutter/ui/widgets/available_updates_card.dart';
import 'package:revanced_manager_flutter/ui/widgets/installed_apps_card.dart';
import 'package:revanced_manager_flutter/ui/widgets/latest_commit_card.dart';
class HomeScreen extends StatelessWidget {
const HomeScreen({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return Scaffold(
body: SafeArea(
child: SingleChildScrollView(
child: Padding(
padding: const EdgeInsets.symmetric(
vertical: 0.0,
horizontal: 20.0,
),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Align(
alignment: Alignment.topRight,
child: IconButton(
onPressed: () {},
icon: const Icon(
Icons.more_vert,
),
),
),
const SizedBox(height: 60),
Text(
"Dashboard",
style: GoogleFonts.inter(
fontSize: 28,
),
),
const SizedBox(height: 23),
Text(
"ReVanced Updates",
style: GoogleFonts.inter(
fontSize: 18,
),
),
const SizedBox(height: 10),
const LatestCommitCard(),
const SizedBox(height: 14),
Text(
"Patched Applications",
style: GoogleFonts.inter(
fontSize: 18,
),
),
const SizedBox(height: 14),
const AvailableUpdatesCard(),
const SizedBox(height: 15),
const InstalledAppsCard(),
],
),
),
),
),
);
}
}

View File

@ -1,51 +0,0 @@
import 'package:flutter/material.dart';
import 'package:google_fonts/google_fonts.dart';
import 'package:revanced_manager_flutter/ui/screens/app_selector_screen.dart';
import 'package:revanced_manager_flutter/ui/widgets/app_selector_card.dart';
import 'package:revanced_manager_flutter/ui/widgets/patch_selector_card.dart';
class PatcherScreen extends StatelessWidget {
const PatcherScreen({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return Scaffold(
floatingActionButton: FloatingActionButton(
onPressed: () {},
child: const Icon(
Icons.build,
color: Colors.white,
),
),
body: SafeArea(
child: Padding(
padding: const EdgeInsets.symmetric(vertical: 12.0, horizontal: 12.0),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
const SizedBox(height: 12),
Text(
"Patcher",
style: GoogleFonts.inter(
fontSize: 28,
fontWeight: FontWeight.w500,
),
),
const SizedBox(height: 23),
AppSelectorCard(
onPressed: () {
Navigator.push(
context,
MaterialPageRoute(
builder: (context) => const AppSelectorScreen()));
},
),
const SizedBox(height: 16),
const PatchSelectorCard(),
],
),
),
),
);
}
}

View File

@ -0,0 +1,101 @@
import 'package:device_apps/device_apps.dart';
import 'package:flutter/material.dart';
import 'package:revanced_manager_flutter/ui/widgets/installed_app_item.dart';
import 'package:revanced_manager_flutter/ui/widgets/search_bar.dart';
import 'package:stacked/stacked.dart';
import 'app_selector_viewmodel.dart';
class AppSelectorView extends StatefulWidget {
const AppSelectorView({Key? key}) : super(key: key);
@override
State<AppSelectorView> createState() => _AppSelectorViewState();
}
class _AppSelectorViewState extends State<AppSelectorView> {
List<Application> apps = [];
String query = '';
void getApps() async {
apps = await DeviceApps.getInstalledApplications();
setState(() {});
}
@override
void initState() {
getApps();
super.initState();
}
@override
Widget build(BuildContext context) {
return ViewModelBuilder.reactive(
builder: (context, model, child) => Scaffold(
body: SafeArea(
child: Padding(
padding:
const EdgeInsets.symmetric(vertical: 4.0, horizontal: 12.0),
child: Column(
children: [
SearchBar(
onQueryChanged: (searchQuery) {
setState(() {
query = searchQuery;
});
},
),
if (query.isEmpty || query.length < 2)
apps.isEmpty
? const Center(
child: CircularProgressIndicator(),
)
: Expanded(
child: ListView.builder(
itemCount: apps.length,
itemBuilder: (context, index) {
//sort alphabetically
apps.sort(
(a, b) => a.appName.compareTo(b.appName));
return InstalledAppItem(
name: apps[index].appName,
pkgName: apps[index].packageName,
isSelected: false,
);
},
),
),
if (query.isNotEmpty)
apps.isEmpty
? const Center(
child: Text('No apps found'),
)
: Expanded(
child: ListView.builder(
itemCount: apps.length,
itemBuilder: (context, index) {
apps.sort(
(a, b) => a.appName.compareTo(b.appName));
if (apps[index].appName.toLowerCase().contains(
query.toLowerCase(),
)) {
return InstalledAppItem(
name: apps[index].appName,
pkgName: apps[index].packageName,
isSelected: false,
);
} else {
return SizedBox();
}
},
),
),
],
),
),
),
),
viewModelBuilder: () => AppSelectorViewModel(),
);
}
}

View File

@ -0,0 +1,15 @@
import 'package:device_apps/device_apps.dart';
import 'package:stacked/stacked.dart';
class AppSelectorViewModel extends BaseViewModel {
List<Application> apps = [];
String query = '';
void initialization() {
getApps();
}
void getApps() async {
apps = await DeviceApps.getInstalledApplications();
}
}

View File

@ -0,0 +1,71 @@
import 'package:flutter/material.dart';
import 'package:google_fonts/google_fonts.dart';
import 'package:revanced_manager_flutter/ui/widgets/available_updates_card.dart';
import 'package:revanced_manager_flutter/ui/widgets/installed_apps_card.dart';
import 'package:revanced_manager_flutter/ui/widgets/latest_commit_card.dart';
import 'package:stacked/stacked.dart';
import 'home_viewmodel.dart';
class HomeView extends StatelessWidget {
const HomeView({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return ViewModelBuilder.reactive(
builder: (context, model, child) => Scaffold(
body: SafeArea(
child: SingleChildScrollView(
child: Padding(
padding: const EdgeInsets.symmetric(
vertical: 0.0,
horizontal: 20.0,
),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Align(
alignment: Alignment.topRight,
child: IconButton(
onPressed: () {},
icon: const Icon(
Icons.more_vert,
),
),
),
const SizedBox(height: 60),
Text(
"Dashboard",
style: GoogleFonts.inter(
fontSize: 28,
),
),
const SizedBox(height: 23),
Text(
"ReVanced Updates",
style: GoogleFonts.inter(
fontSize: 18,
),
),
const SizedBox(height: 10),
const LatestCommitCard(),
const SizedBox(height: 14),
Text(
"Patched Applications",
style: GoogleFonts.inter(
fontSize: 18,
),
),
const SizedBox(height: 14),
const AvailableUpdatesCard(),
const SizedBox(height: 15),
const InstalledAppsCard(),
],
),
),
),
),
),
viewModelBuilder: () => HomeViewModel(),
);
}
}

View File

@ -0,0 +1,8 @@
import 'package:revanced_manager_flutter/app/app.locator.dart';
import 'package:revanced_manager_flutter/services/manager_api.dart';
import 'package:stacked/stacked.dart';
class HomeViewModel extends BaseViewModel {
Future downloadPatches() => locator<ManagerAPI>().downloadPatches();
Future downloadIntegrations() => locator<ManagerAPI>().downloadIntegrations();
}

View File

@ -0,0 +1,53 @@
import 'package:flutter/material.dart';
import 'package:google_fonts/google_fonts.dart';
import 'package:revanced_manager_flutter/ui/views/app_selector/app_selector_view.dart';
import 'package:revanced_manager_flutter/ui/widgets/app_selector_card.dart';
import 'package:revanced_manager_flutter/ui/widgets/patch_selector_card.dart';
import 'package:stacked/stacked.dart';
import 'patcher_viewmodel.dart';
class PatcherView extends StatelessWidget {
const PatcherView({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return ViewModelBuilder.reactive(
builder: (context, PatcherViewModel model, child) => Scaffold(
floatingActionButton: FloatingActionButton(
onPressed: () {},
child: const Icon(
Icons.build,
color: Colors.white,
),
),
body: SafeArea(
child: Padding(
padding:
const EdgeInsets.symmetric(vertical: 12.0, horizontal: 12.0),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
const SizedBox(height: 12),
Text(
"Patcher",
style: GoogleFonts.inter(
fontSize: 28,
fontWeight: FontWeight.w500,
),
),
const SizedBox(height: 23),
AppSelectorCard(
onPressed: model.navigateToAppSelector,
),
const SizedBox(height: 16),
const PatchSelectorCard(),
],
),
),
),
),
viewModelBuilder: () => PatcherViewModel(),
);
}
}

View File

@ -0,0 +1,12 @@
import 'package:revanced_manager_flutter/app/app.locator.dart';
import 'package:revanced_manager_flutter/app/app.router.dart';
import 'package:stacked/stacked.dart';
import 'package:stacked_services/stacked_services.dart';
class PatcherViewModel extends BaseViewModel {
final _naviagtionService = locator<NavigationService>();
void navigateToAppSelector() {
_naviagtionService.navigateTo(Routes.appSelectorView);
}
}

View File

@ -1,6 +1,6 @@
import 'package:flutter/material.dart';
import 'package:google_fonts/google_fonts.dart';
import 'package:revanced_manager_flutter/backend/api/github_api.dart';
import 'package:revanced_manager_flutter/services/github_api.dart';
import 'package:revanced_manager_flutter/constants.dart';
import 'package:revanced_manager_flutter/ui/widgets/patch_text_button.dart';