import 'package:aku_community_manager/const/resource.dart'; import 'package:aku_community_manager/provider/anouncement_provider.dart'; import 'package:aku_community_manager/mock_models/all_model.dart'; import 'package:aku_community_manager/mock_models/decoration/decoration_model.dart'; import 'package:aku_community_manager/mock_models/fix/fix_model.dart'; import 'package:aku_community_manager/provider/app_provider.dart'; import 'package:aku_community_manager/provider/user_provider.dart'; import 'package:aku_community_manager/style/app_style.dart'; import 'package:aku_community_manager/tools/screen_tool.dart'; import 'package:aku_community_manager/tools/widget_tool.dart'; import 'package:aku_community_manager/ui/home/announcement/All_anouncement.dart'; import 'package:aku_community_manager/ui/home/business/business_page.dart'; import 'package:aku_community_manager/ui/home/messages/message.dart'; import 'package:aku_community_manager/ui/home/application/applications_page.dart'; import 'package:aku_community_manager/ui/home/personal_draw.dart'; import 'package:aku_community_manager/ui/home/search_workorder_page.dart'; import 'package:aku_community_manager/ui/login/login_page.dart'; import 'package:aku_community_manager/ui/sub_pages/business_and_fix/business_fix_card.dart'; import 'package:aku_community_manager/ui/sub_pages/decoration_manager/decoration_manager_card.dart'; import 'package:aku_community_manager/ui/sub_pages/visitor_manager/visitor_manager_page.dart'; import 'package:aku_community_manager/ui/sub_pages/business_and_fix/business_and_fix_page.dart'; import 'package:aku_community_manager/ui/tool_pages/scan_page.dart'; import 'package:aku_community_manager/ui/tool_pages/warning/warning_page.dart'; import 'package:aku_ui/aku_ui.dart'; import 'package:aku_ui/common_widgets/aku_material_button.dart'; import 'package:carousel_slider/carousel_slider.dart'; import 'package:flutter/material.dart'; import 'package:flutter/services.dart'; import 'package:flutter_screenutil/flutter_screenutil.dart'; import 'package:get/get.dart'; import 'package:provider/provider.dart'; class HomePage extends StatefulWidget { HomePage({Key key}) : super(key: key); @override _HomePageState createState() => _HomePageState(); } class _HomePageState extends State { ///自定义bar的菜单按钮 Widget _menuButton(String assetPath, String text, Widget page) { final appProvider = Provider.of(context); return Expanded( child: AkuButton( radius: 8.w, height: 75.w + 8.w + 33.w, onPressed: () { final userProvider = Provider.of(context, listen: false); if (userProvider.isSigned) { Get.to(page); if (text != '全部应用') appProvider.addRecentApp(AppApplication(text, assetPath, page)); } else Get.to(LoginPage()); }, child: Column( mainAxisAlignment: MainAxisAlignment.center, children: [ Image.asset( assetPath, height: 75.w, width: 75.w, ), SizedBox(height: 8.w), Text( text, style: TextStyle( color: Color(0xFF4A4B51), fontSize: 24.sp, fontWeight: FontWeight.bold, ), ) ], ), ), ); } ///底部信息栏卡片 Widget _card( int number, String text, Color color, int index, ) { return AkuButton( radius: 8.w, onPressed: () { Get.to(BusinessPage(initIndex: index)); }, color: Color(0xFFFFFFFF), child: Container( width: 342.5.w, height: 166.w, alignment: Alignment.center, child: Column( children: [ SizedBox( height: 32.w, ), Text( number == null ? '0' : number.toString(), style: TextStyle( color: color, fontSize: 40.sp, fontFamily: 'Bebas', ), ), SizedBox( height: 16.w, ), Text(text, style: TextStyle( color: AppStyle.minorTextColor, fontSize: 24.sp, fontWeight: FontWeight.bold)), Spacer(), ], )), ); } @override void initState() { super.initState(); SystemChrome.setSystemUIOverlayStyle(SystemUiOverlayStyle( statusBarColor: Colors.transparent, )); } int _currentIndicator = 0; @override Widget build(BuildContext context) { final userProvider = Provider.of(context); final _anouncementProvider = Provider.of(context); ScreenUtil.init(context, designSize: Size(750, 1334), allowFontScaling: true); return AnnotatedRegion( child: Scaffold( drawer: PersonalDraw(), backgroundColor: Color(0xFFF9F9F9), //自定义bar appBar: PreferredSize( preferredSize: Size(375.w, 430.w - 40.w + statusBarHeight), child: Container( height: 430.w - 40.w + ScreenUtil().statusBarHeight, width: double.infinity, decoration: BoxDecoration( gradient: LinearGradient( begin: Alignment.topCenter, end: Alignment.bottomCenter, colors: [ Color(0xFFFFDC6F), Color(0xFFFFC40C), ], ), borderRadius: BorderRadius.only(bottomRight: Radius.circular(32.w)), ), child: Column( crossAxisAlignment: CrossAxisAlignment.start, children: [ SizedBox(height: ScreenUtil().statusBarHeight), Container( height: 88.w, child: Row(children: [ SizedBox( width: 16.w, ), Container( margin: EdgeInsets.only(top: 8.w, bottom: 8.w), width: 72.w, height: 72.w, //头像按钮 child: Builder( builder: (BuildContext context) { return GestureDetector( onTap: () { Scaffold.of(context).openDrawer(); }, child: CircleAvatar( radius: 36.w, backgroundImage: userProvider.userInfoModel.avatar == null ? null : FileImage( userProvider.userInfoModel.avatar), backgroundColor: Colors.white, child: userProvider.isSigned ? userProvider.userInfoModel.avatar == null ? Icon(Icons.person_outline) : null : Icon(Icons.person), ), ); }, ), ), SizedBox(width: 16.w), Expanded( child: Container( margin: EdgeInsets.only(top: 8.w, bottom: 8.w), alignment: Alignment.center, height: 72.w, child: AkuButton( //搜索框按钮 color: Color(0xFFFFFFFF), onPressed: () { Get.to(SearchWorkOrderPage()); }, radius: 8.w, child: Row(children: [ AkuBox.w(21.w), Container( child: Column( children: [ SizedBox(height: 18.w), Image.asset(R.ASSETS_HOME_IC_SEARCH_PNG, width: 37.w, height: 37.w), ], ), ), SizedBox(width: 19.w), Text( '搜索工单订单号、手机', style: TextStyle( color: AppStyle.minorTextColor, fontSize: 28.sp, ), ), ]), ), ), ), SizedBox(width: 15.w), Container( margin: EdgeInsets.only(top: 5.w, bottom: 5.w), child: MaterialButton( materialTapTargetSize: MaterialTapTargetSize.shrinkWrap, //扫一扫按钮 height: double.infinity, minWidth: 78.w, padding: EdgeInsets.zero, onPressed: () { Get.to(ScanPage()); }, child: Column(children: [ Image.asset( R.ASSETS_HOME_IC_SCAN_PNG, height: 48.w, width: 48.w, ), Text( '扫一扫', style: TextStyle( color: AppStyle.primaryTextColor, fontSize: 20.sp, fontWeight: FontWeight.normal, ), ), ]), ), ), Container( margin: EdgeInsets.only(top: 5.w, bottom: 5.w), child: AkuMaterialButton( minWidth: 78.w, //消息按钮 height: double.infinity, onPressed: () { if (userProvider.isSigned) Get.to(Message()); else Get.to(LoginPage()); }, child: Column(children: [ Image.asset( R.ASSETS_HOME_IC_NEWS_PNG, height: 48.w, width: 48.w, ), Text( '消息', style: TextStyle( color: AppStyle.primaryTextColor, fontSize: 20.sp, ), ), ]), ), ), SizedBox(width: 17.w), ]), ), SizedBox(height: 24.w), GestureDetector( onTap: () { if (!userProvider.isSigned) Get.to(LoginPage()); }, child: Container( margin: EdgeInsets.only( left: 32.w, ), height: 67.w, child: Text( userProvider.isSigned ? 'HI,${userProvider.userInfoModel.nickName}' : '登录/注册', style: TextStyle( color: AppStyle.primaryTextColor, fontWeight: FontWeight.bold, fontSize: 48.sp, ), ), ), ), SizedBox(height: 16.w), Container( margin: EdgeInsets.only(left: 32.w, right: 32.w), width: double.infinity, height: 163.w, decoration: BoxDecoration( color: Color(0xFFFFFFFF), borderRadius: BorderRadius.circular(8.w), ), child: Row( mainAxisAlignment: MainAxisAlignment.spaceAround, children: [ _menuButton( R.ASSETS_HOME_IC_POLICE_PNG, '一键报警', WarningPage()), _menuButton( R.ASSETS_HOME_IC_VISITORS_PNG, '访客管理', VisitorManagerPage(), ), _menuButton( R.ASSETS_HOME_IC_SERVICE_PNG, '报事报修', BusinessAndFixPage(), ), _menuButton( R.ASSETS_HOME_IC_ALL_PNG, '全部应用', ApplicationPage()), ], ), ), ], ), ), ), body: ListView( padding: EdgeInsets.all(32.w), children: [ Container( //公告标题行 width: double.infinity, height: 45.w, child: Row( mainAxisAlignment: MainAxisAlignment.center, children: [ Text( '今日公告', style: TextStyle( color: Color(0xFF4A4B51), fontSize: 32.sp, fontWeight: FontWeight.bold, ), ), Spacer(), AkuButton( //全部公告按钮 onPressed: () { Get.to(AllAnouncement()); }, child: Row( children: [ Text( '全部公告', style: TextStyle( color: AppStyle.minorTextColor, fontSize: 24.sp, fontWeight: FontWeight.bold, ), ), Icon( Icons.arrow_forward_ios, size: 22.w, color: AppStyle.minorTextColor, ) ], ), ), ], ), ), SizedBox(height: 16.w), //公告栏 Container( color: Color(0xFFFFFFFF), width: double.infinity, height: 172.w, child: Stack(children: [ CarouselSlider( items: _anouncementProvider.anouncementCardModels .map((e) => AllAnouncementState.anounceCard(e)) .toList(), options: CarouselOptions( viewportFraction: 1.0, aspectRatio: 686 / 172, autoPlay: true, onPageChanged: (index, _) { setState(() { _currentIndicator = index; }); }, ), ), Positioned( top: 144.w, left: 0, bottom: 16.w, right: 0, child: Row( mainAxisSize: MainAxisSize.max, mainAxisAlignment: MainAxisAlignment.center, children: _anouncementProvider.anouncementCardModels.map((e) { int index = _anouncementProvider.anouncementCardModels.indexOf(e); return Container( width: 12.w, height: 12.w, margin: EdgeInsets.symmetric(horizontal: 12.w), decoration: BoxDecoration( shape: BoxShape.circle, color: _currentIndicator == index ? Color(0xFFFFC40C) : Color(0xFFE8E8E8), ), ); }).toList(), ), ), ]), ), SizedBox(height: 16.w), //待办事项标题行 !userProvider.isSigned ? SizedBox() : Row( children: [ Text( '待办事项', style: TextStyle( color: Color(0xFF4A4B51), fontSize: 32.sp, fontWeight: FontWeight.bold, ), ), Spacer(), AkuButton( padding: EdgeInsets.symmetric(vertical: 16.w), onPressed: () { Get.to(BusinessPage(initIndex: 3)); }, child: Row( children: [ Text( '全部事项', style: TextStyle( color: AppStyle.minorTextColor, fontSize: 24.sp, fontWeight: FontWeight.bold), ), Icon( Icons.arrow_forward_ios, size: 22.w, color: AppStyle.minorTextColor, ), ], ), ), ], ), SizedBox(height: 16.w), //待办事项栏 !userProvider.isSigned ? SizedBox() : Container( height: 480.w, child: ListView.separated( separatorBuilder: (context, index) { return AkuBox.w(16); }, scrollDirection: Axis.horizontal, itemBuilder: (context, index) { return Container( width: 526.w, child: Builder( builder: (context) { final item = AllModel(context).waitThings[index]; if (item is DecorationModel) { return DecorationManagerCard(model: item); } else if (item is FixModel) { return BusinessFixCard( model: item, homeDisplay: true); } else return SizedBox(); }, ), ); }, itemCount: AllModel(context).waitThings.length, ), //TODO listview ), SizedBox(height: 24.w), //底部信息栏 !userProvider.isSigned ? SizedBox() : Container( width: double.infinity, decoration: BoxDecoration( borderRadius: BorderRadius.circular(8.w), color: Colors.white, ), child: Column( children: [ Row( children: [ _card(AllModel(context).waitThings?.length, '未处理事项', Color(0xFFFF4E0D), 0), AkuDiveder().verticalDivider(166.5.w), _card(AllModel(context).processingThings?.length, '处理中事项', Color(0xFFFFC40C), 1), ], ), Row(children: [ AkuDiveder().horizontalDivider(343.w), AkuDiveder(isReverse: true).horizontalDivider(343.w) ]), Row( children: [ _card(AllModel(context).doneThings?.length, '已处理事项', Color(0xFF3F8FFE), 2), AkuDiveder(isReverse: true).verticalDivider( 166.5.w, ), _card(AllModel(context).allThings?.length, '全部事项', Color(0xFF333333), 3), ], ), ], ), ), ], ), ), value: SystemUiOverlayStyle.dark, ); } }