import 'package:flutter/material.dart'; import 'package:flutter_i18n/flutter_i18n.dart'; import 'package:revanced_manager/ui/widgets/appSelectorView/installed_app_item.dart'; import 'package:revanced_manager/ui/widgets/shared/search_bar.dart'; import 'package:revanced_manager/ui/widgets/appSelectorView/app_skeleton_loader.dart'; import 'package:stacked/stacked.dart' hide SkeletonLoader; import 'package:revanced_manager/ui/views/app_selector/app_selector_viewmodel.dart'; class AppSelectorView extends StatefulWidget { const AppSelectorView({Key? key}) : super(key: key); @override State createState() => _AppSelectorViewState(); } class _AppSelectorViewState extends State { String _query = ''; @override Widget build(BuildContext context) { return ViewModelBuilder.reactive( onModelReady: (model) => model.initialize(), viewModelBuilder: () => AppSelectorViewModel(), builder: (context, model, child) => Scaffold( resizeToAvoidBottomInset: false, floatingActionButton: FloatingActionButton.extended( label: I18nText('appSelectorView.storageButton'), icon: const Icon(Icons.sd_storage), onPressed: () { model.selectAppFromStorage(context); Navigator.of(context).pop(); }, ), body: SafeArea( child: Padding( padding: const EdgeInsets.symmetric(vertical: 4.0, horizontal: 12.0), child: Column( children: [ SearchBar( showSelectIcon: false, hintText: FlutterI18n.translate( context, 'appSelectorView.searchBarHint', ), onQueryChanged: (searchQuery) { setState(() { _query = searchQuery; }); }, ), const SizedBox(height: 12), Expanded( child: model.noApps ? Center( child: I18nText('appSelectorCard.noAppsLabel'), ) : model.apps.isEmpty ? const AppSkeletonLoader() : ListView( padding: const EdgeInsets.only(bottom: 80), children: model .getFilteredApps(_query) .map((app) => InkWell( onTap: () { model.selectApp(app); Navigator.of(context).pop(); }, child: InstalledAppItem( name: app.appName, pkgName: app.packageName, icon: app.icon, ), )) .toList(), ), ), ], ), ), ), ), ); } }