import 'package:diplomaticquarterapp/config/config.dart'; import 'package:diplomaticquarterapp/config/size_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'; import 'package:diplomaticquarterapp/pages/pharmacies/product_detail.dart'; import 'package:diplomaticquarterapp/pages/pharmacies/screens/cart-order-page.dart'; class DetailPageScafold extends StatefulWidget { 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 bool isPharmacy; final String title; final String description; final String image; final bool isShowDecPage; final List infoList; final Color backgroundColor; final double preferredSize; final List appBarIcons; final PreferredSizeWidget appBarWidget; DetailPageScafold( {@required this.body, this.appBarTitle = '', this.isLoading = false, this.isShowAppBar = false, this.hasAppBarParam, this.bottomSheet, this.baseViewModel, this.floatingActionButton, this.isPharmacy = false, this.title, this.description, this.isShowDecPage = true, this.isBottomBar, this.backgroundColor, this.preferredSize = 0.0, this.appBarIcons, this.appBarWidget, this.image, this.infoList}); @override _DetailPageScafoldState createState() => _DetailPageScafoldState(); } class _DetailPageScafoldState extends State { AuthenticatedUserObject authenticatedUserObject = locator(); @override Widget build(BuildContext context) { AppGlobal.context = context; PreferredSizeWidget appBar; if (this.widget.appBarWidget == null) { PreferredSizeWidget appBarWidget = AppBarWidget( widget.appBarTitle, widget.appBarIcons, widget.isShowAppBar, isPharmacy: widget.isPharmacy, isShowDecPage: widget.isShowDecPage, image: widget.image, ); appBar = widget.preferredSize == 0 ? appBarWidget : PreferredSize( child: appBarWidget, preferredSize: Size.fromHeight(widget.preferredSize)); } else { appBar = this.widget.appBarWidget; } return Scaffold( backgroundColor: widget.backgroundColor ?? Theme.of(context).scaffoldBackgroundColor, appBar: appBar, body: (!Provider.of(context, listen: false).isLogin && widget.isShowDecPage) ? NotAutPage( title: widget.appBarTitle, description: widget.description, infoList: widget.infoList, ) : widget.baseViewModel != null ? NetworkBaseView( child: buildBodyWidget(), baseViewModel: widget.baseViewModel, ) : buildBodyWidget(), bottomSheet: widget.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: [ widget.body, /*FloatingSearchButton()*/ ]); } } class AppBarWidget extends StatelessWidget with PreferredSizeWidget { final AuthenticatedUserObject authenticatedUserObject = locator(); final String appBarTitle; final List appBarIcons; final bool isShowAppBar; final bool isPharmacy; final bool isShowDecPage; final String image; AppBarWidget(this.appBarTitle, this.appBarIcons, this.isShowAppBar, {this.isPharmacy = true, this.isShowDecPage = true, this.image}); @override Widget build(BuildContext context) { return buildAppBar(context); } Widget buildAppBar(BuildContext context) { return isShowAppBar ? AppBar( elevation: 0, backgroundColor:Colors.white, // isPharmacy ? Colors.green : 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 GestureDetector( behavior: HitTestBehavior.opaque, onTap:()=> Navigator.pop(context), child: Icon(Icons.arrow_back_ios, color: Colors.grey), ); }, ), centerTitle: true, actions: [ isPharmacy ? IconButton( icon: Icon(Icons.shopping_cart), color: Colors.grey, onPressed: () { Navigator.push( context, MaterialPageRoute(builder: (context) => CartOrderPage()), ); // Navigator.of(context) // .popUntil(ModalRoute.withName('/')); }) : Container(), 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.grey, ), ), ) : IconButton( icon: Icon(FontAwesomeIcons.ellipsisV), color: Colors.grey, onPressed: () { settingModalBottomSheet(context); }, ), if (appBarIcons != null) ...appBarIcons ], ) : Container( height: 0, width: 0, ); } @override Size get preferredSize => Size(double.maxFinite, 60); }