import 'package:diplomaticquarterapp/config/config.dart'; import 'package:diplomaticquarterapp/config/size_config.dart'; import 'package:diplomaticquarterapp/core/service/AuthenticatedUserObject.dart'; import 'package:diplomaticquarterapp/core/viewModels/base_view_model.dart'; import 'package:diplomaticquarterapp/core/viewModels/project_view_model.dart'; import 'package:diplomaticquarterapp/pages/insurance/insurance_update_screen.dart'; import 'package:diplomaticquarterapp/pages/landing/landing_page.dart'; import 'package:diplomaticquarterapp/routes.dart'; import 'package:diplomaticquarterapp/uitl/translations_delegate_base.dart'; import 'package:diplomaticquarterapp/widgets/data_display/text.dart'; import 'package:diplomaticquarterapp/widgets/others/bottom_bar.dart'; import 'package:diplomaticquarterapp/widgets/progress_indicator/app_loader_widget.dart'; import 'package:diplomaticquarterapp/widgets/transitions/fade_page.dart'; import 'package:diplomaticquarterapp/widgets/robo-search/robosearch.dart'; import 'package:diplomaticquarterapp/widgets/robo-search/search.dart'; import 'package:flutter/material.dart'; import 'package:flutter_svg/flutter_svg.dart'; import 'package:font_awesome_flutter/font_awesome_flutter.dart'; import 'package:provider/provider.dart'; import '../../locator.dart'; import 'floating_button_search.dart'; import '../progress_indicator/app_loader_widget.dart'; import 'arrow_back.dart'; import 'network_base_view.dart'; import 'not_auh_page.dart'; class AppScaffold extends StatelessWidget { final String appBarTitle; final Widget body; final Widget bottomSheet; final bool isLoading; final bool isShowAppBar; final bool hasAppBarParam; final BaseViewModel baseViewModel; final bool isBottomBar; final Widget floatingActionButton; final String title; final String description; final String image; final bool isShowDecPage; final List infoList; AuthenticatedUserObject authenticatedUserObject = locator(); AppScaffold( {@required this.body, this.appBarTitle = '', this.isLoading = false, this.isShowAppBar = false, this.hasAppBarParam, this.bottomSheet, this.baseViewModel, this.floatingActionButton, this.title, this.description, this.isShowDecPage = true, this.isBottomBar, this.image, this.infoList}); @override Widget build(BuildContext context) { AppGlobal.context = context; return Scaffold( backgroundColor: Theme.of(context).scaffoldBackgroundColor, appBar: isShowAppBar ? AppBar( elevation: 0, backgroundColor: Theme.of(context).appBarTheme.color, textTheme: TextTheme( headline6: TextStyle(color: Colors.white, fontWeight: FontWeight.bold), ), title: Texts( authenticatedUserObject.isLogin || !isShowDecPage ? appBarTitle.toUpperCase() : TranslationBase.of(context).serviceInformationTitle, color: Colors.white, bold: true, ), leading: Builder( builder: (BuildContext context) { return ArrowBack(); }, ), centerTitle: true, actions: [ image != null ? InkWell( onTap: () => Navigator.push( context, FadePage( page: InsuranceUpdate(), ), ), child: Padding( padding: const EdgeInsets.all(8.0), child: Image.asset( image, height: SizeConfig.heightMultiplier * 5, width: SizeConfig.heightMultiplier * 5, color: Colors.white, ), ), ) : IconButton( icon: Icon(FontAwesomeIcons.home), color: Colors.white, onPressed: () { Navigator.pushAndRemoveUntil( context, MaterialPageRoute( builder: (context) => LandingPage()), (Route r) => false); }, ), ], ) : null, body: (!Provider.of(context, listen: false).isLogin && isShowDecPage) ? NotAutPage( title: appBarTitle, description: description, infoList: infoList, ) : baseViewModel != null ? NetworkBaseView( child: buildBodyWidget(), baseViewModel: baseViewModel, ) : buildBodyWidget(), bottomSheet: bottomSheet, //floatingActionButton: floatingActionButton ?? floatingActionButton, // bottomNavigationBar: // this.isBottomBar == true ? BottomBarSearch() : SizedBox() // floatingActionButton: FloatingSearchButton(), ); } buildAppLoaderWidget(bool isLoading) { return isLoading ? AppLoaderWidget() : Container(); } buildBodyWidget() { // return body; //Stack(children: [body, buildAppLoaderWidget(isLoading)]); return Stack(children: [ body, /*FloatingSearchButton()*/ ]); } }