// import 'package:flutter/material.dart'; // import 'package:flutter_svg/flutter_svg.dart'; // import 'package:shared_preferences/shared_preferences.dart'; // import 'package:tangheem/api/tangheem_user_api_client.dart'; // import 'package:tangheem/app_state/app_state.dart'; // import 'package:tangheem/classes/colors.dart'; // import 'package:tangheem/classes/consts.dart'; // import 'package:tangheem/classes/utils.dart'; // import 'package:tangheem/models/navigation_model.dart'; // import 'package:tangheem/models/quick_links_model.dart'; // import 'package:tangheem/ui/screens/bookmark_screen.dart'; // import 'package:tangheem/ui/screens/content_info_screen.dart'; // import 'package:tangheem/ui/screens/login_screen.dart'; // import 'package:tangheem/ui/screens/pdf_viewer_screen.dart'; // import 'package:url_launcher/url_launcher.dart'; // // class CommonAppbar extends StatefulWidget { // final bool showDrawer; // final Widget child; // final bool isFirst; // // CommonAppbar({Key key, this.showDrawer = false, @required this.child, this.isFirst = false}) : super(key: key); // // @override // _CommonAppbarState createState() { // return _CommonAppbarState(); // } // } // // class _CommonAppbarState extends State { // final GlobalKey _scaffoldKey = new GlobalKey(); // List quickLinks = []; // List navigationList = []; // // @override // void initState() { // super.initState(); // getPrefs(); // getNavigation(); // getQuickLinks(); // //getCopyRight(); // } // // // void getCopyRight() async { // // if (AppState().getContentInfoModel == null) { // // try { // // var model = await TangheemUserApiClient().getContentInfo(3); // // var contentList = model?.data ?? []; // // if (contentList.length > 0) { // // _copyRight = contentList.first; // // AppState().setContentInfoModel(_copyRight); // // } // // } catch (ex) {} // // } else { // // _copyRight = AppState().getContentInfoModel; // // } // // setState(() {}); // // } // // void getNavigation() async { // if (AppState().getNavigationModel?.data == null) { // try { // var model = await TangheemUserApiClient().getNavigation(); // navigationList = model?.data ?? []; // navigationList.sort((a, b) => a.orderNo.compareTo(b.orderNo)); // AppState().setNavigationModel(model); // } catch (ex) {} // } else { // navigationList = AppState().getNavigationModel.data; // } // setState(() {}); // } // // void getQuickLinks() async { // if (widget.showDrawer) { // try { // quickLinks = (await TangheemUserApiClient().quickLinks())?.data ?? []; // quickLinks = quickLinks.where((element) => element.position == "down").toList(); // quickLinks.sort((a, b) => a.orderNo.compareTo(b.orderNo)); // } catch (ex) {} // setState(() {}); // } // } // // int fontSize; // SharedPreferences prefs; // // void getPrefs() async { // prefs = await SharedPreferences.getInstance(); // fontSize = prefs.getInt(GlobalConsts.fontZoomSize) ?? 18; // } // // @override // void dispose() { // super.dispose(); // } // // @override // Widget build(BuildContext context) { // return Scaffold( // key: widget.showDrawer ? _scaffoldKey : null, // drawer: widget.showDrawer ? drawerView() : null, // resizeToAvoidBottomInset: true, // drawerScrimColor: Colors.black.withOpacity(.3), // body: SafeArea( // child: Column( // children: [ // Container( // color: Colors.white, // height: 100, // padding: EdgeInsets.only(top: 8, bottom: 8, right: 16), // child: Row( // crossAxisAlignment: CrossAxisAlignment.center, // children: [ // if (!widget.isFirst) // IconButton( // icon: Icon(widget.showDrawer ? Icons.menu : Icons.arrow_back_ios, color: ColorConsts.textGrey), // padding: EdgeInsets.only(left: 16), // onPressed: () { // if (widget.showDrawer) { // _scaffoldKey.currentState.openDrawer(); // } else { // Navigator.pop(context); // } // }, // ), // Expanded(child: SizedBox()), // Hero( // tag: "logo", // child: SvgPicture.asset( // "assets/logos/tangheem_logo.svg", // height: 100, // width: 100, // alignment: Alignment.centerRight, // ), // ) // ], // ), // ), // Expanded( // child: Directionality(textDirection: TextDirection.rtl, child: widget.child), // ), // ], // ), // ), // ); // } // // Widget drawerView() { // var height = MediaQuery.of(context).padding.top; // return Drawer( // elevation: 0, // child: Container( // color: Colors.white, // child: SafeArea( // bottom: true, // top: false, // right: false, // left: false, // maintainBottomViewPadding: true, // child: Builder( // builder: (context) { // bool isPortrait = MediaQuery.of(context).orientation == Orientation.portrait; // Widget listContents = ListView.builder( // shrinkWrap: true, // physics: BouncingScrollPhysics(), // padding: EdgeInsets.only(left: 24, right: 24), // itemCount: navigationList.length, // itemBuilder: (context, index) { // String icon = "assets/icons/${navigationList[index].mobileFontIcon}.svg"; // var subList = navigationList.where((element) => element.parentId == navigationList[index].navigationId).toList(); // return Column( // mainAxisSize: MainAxisSize.min, // children: [ // if (navigationList[index].parentId == 1) // myListItem(icon, navigationList[index].navigationText, navigationList[index].orderNo == 1 ? true : false, onTap: () { // String url = navigationList[index]?.mobileNavigationUrl ?? ""; // if (url.isEmpty || url.length < 2) { // return; // } // Navigator.pushNamed(context, url, arguments: null); // }), // for (var subItem in subList) // Container( // width: double.infinity, // child: Row( // children: [ // Expanded( // child: myListItem("assets/icons/${subItem.mobileFontIcon}.svg", subItem.navigationText, false, onTap: () { // String url = subItem.mobileNavigationUrl ?? ""; // if (url.isEmpty) { // return; // } // var contentId; // if (subItem.mobileNavigationUrl == "/introduction") { // url = ContentInfoScreen.routeName; // contentId = 2; // } else if (subItem.mobileNavigationUrl == "/encyclopedia") { // url = ContentInfoScreen.routeName; // contentId = 1; // } else if (subItem.mobileNavigationUrl == "/tangheempdf") { // url = PdfListScreen.routeName; // contentId = 8; // } // Navigator.pushNamed(context, url, arguments: contentId); // }), // ), // Container( // height: 40, // margin: EdgeInsets.only(right: 17, left: 10), // child: VerticalDivider(color: ColorConsts.primaryBlack, thickness: .7, width: 1), // ), // ], // ), // ) // ], // ); // }); // if (isPortrait) { // listContents = Expanded(child: listContents); // } // List list = [ // Container( // height: 100 + height, // padding: EdgeInsets.only(left: 0, top: height), // alignment: Alignment.centerLeft, // child: IconButton( // icon: Icon(Icons.clear, color: ColorConsts.textGrey), // onPressed: () { // if (_scaffoldKey.currentState.isDrawerOpen) { // Navigator.pop(context); // } // }, // ), // ), // Container( // margin: EdgeInsets.only(top: 8, bottom: 16), // padding: EdgeInsets.only(left: 16, right: 16), // child: Row( // mainAxisAlignment: MainAxisAlignment.spaceEvenly, // children: [ // commonIconButton("assets/icons/bookmark.svg", () { // Navigator.pushNamed(context, BookmarkScreen.routeName); // }), // commonIconButton("assets/icons/increase_size.svg", () { // if (fontSize >= 36) { // Utils.showToast("وصل حجم الخط إلى الحد الأقصى للحجم"); // return; // } // fontSize += 2; // prefs.setInt(GlobalConsts.fontZoomSize, fontSize); // Utils.showToast("زيادة حجم الخط"); // }), // commonIconButton("assets/icons/reduce_size.svg", () { // if (fontSize <= 12) { // Utils.showToast("وصل حجم الخط إلى الحد الأدنى للحجم"); // return; // } // fontSize -= 2; // prefs.setInt(GlobalConsts.fontZoomSize, fontSize); // Utils.showToast("تم تقليل حجم الخط"); // }), // commonIconButton("assets/icons/user_logged.svg", () { // if (AppState().isUserLogin) { // Utils.showToast("أنت بالفعل تسجيل الدخول"); // return; // } // Navigator.pushNamed(context, LoginScreen.routeName); // }), // ], // ), // ), // listContents, // Container( // margin: EdgeInsets.only(top: 16, bottom: 12), // padding: EdgeInsets.only(left: 32, right: 32), // child: Row( // children: [ // for (QuickLinksData _quickLink in quickLinks) // commonIconButton(ApiConsts.baseUrl + _quickLink.exposeFilePath, () { //for live production server // // commonIconButton( _quickLink.exposeFilePath, () { // _launchURL(_quickLink.imageUrl); // }, size: 35, isAsset: false), // ], // ), // ), // Padding( // padding: EdgeInsets.only(left: 32, right: 32, bottom: 8), // child: Row( // crossAxisAlignment: CrossAxisAlignment.center, // mainAxisAlignment: MainAxisAlignment.center, // children: [ // Text( // "Powered by Cloud Solutions", // maxLines: 1, // textAlign: TextAlign.right, // style: TextStyle(fontSize: 14, color: Colors.black87), // ), // SizedBox(width: 8), // SvgPicture.asset("assets/logos/cloud_logo.svg", width: 30, height: 30) // ], // ), // ) // ]; // return isPortrait ? Column(children: list) : ListView(children: list); // }, // ), // ), // ), // ); // } // // void _launchURL(String _url) async => await canLaunch(_url) ? await launch(_url) : throw 'Could not launch $_url'; // // Widget commonIconButton(String icon, VoidCallback onPressed, {double size, bool isAsset = true}) { // return Expanded( // child: IconButton( // padding: EdgeInsets.zero, // icon: isAsset ? SvgPicture.asset(icon, height: size ?? 25, width: size ?? 30) : Image.network(icon, height: size ?? 25, width: size ?? 30), // onPressed: () { // Navigator.pop(context); // Future.delayed(Duration(milliseconds: 200), () => onPressed()); // }), // ); // } // // Widget myListItem(String icon, String title, bool isSelected, {VoidCallback onTap}) { // return InkWell( // onTap: () { // Navigator.pop(context); // if (onTap != null) { // Future.delayed(Duration(milliseconds: 200), () => onTap()); // } // }, // child: Container( // height: 40, // padding: EdgeInsets.only(left: 8, right: 8), // alignment: Alignment.centerRight, // decoration: BoxDecoration( // borderRadius: BorderRadius.circular(6), // gradient: isSelected // ? LinearGradient( // stops: [0.0, 0.5], // begin: Alignment.topCenter, // end: Alignment.bottomCenter, // colors: [ColorConsts.gradientPink, ColorConsts.gradientOrange], // ) // : null, // ), // child: Row( // mainAxisSize: MainAxisSize.min, // children: [ // Text( // title, // style: TextStyle(fontSize: 14, color: isSelected ? Colors.white : ColorConsts.textGrey), // ), // SizedBox(width: 8), // SvgPicture.asset(icon, height: 20, width: 20, color: isSelected ? Colors.white : ColorConsts.textGrey), // ], // ), // ), // ); // } // }