|
|
|
@ -1,9 +1,8 @@
|
|
|
|
|
// Dart imports:
|
|
|
|
|
|
|
|
|
|
import 'package:aku_new_community/constants/application_objects.dart';
|
|
|
|
|
import 'package:aku_new_community/constants/saas_api.dart';
|
|
|
|
|
import 'package:aku_new_community/extensions/color_ext.dart';
|
|
|
|
|
import 'package:aku_new_community/model/common/img_model.dart';
|
|
|
|
|
import 'package:aku_new_community/gen/assets.gen.dart';
|
|
|
|
|
import 'package:aku_new_community/models/home/home_activity_model.dart';
|
|
|
|
|
import 'package:aku_new_community/models/home/home_announce_model.dart';
|
|
|
|
|
import 'package:aku_new_community/models/home/home_swiper_model.dart';
|
|
|
|
@ -12,29 +11,31 @@ import 'package:aku_new_community/pages/one_alarm/widget/alarm_page.dart';
|
|
|
|
|
import 'package:aku_new_community/pages/visitor_access_page/visitor_access_page.dart';
|
|
|
|
|
import 'package:aku_new_community/provider/app_provider.dart';
|
|
|
|
|
import 'package:aku_new_community/ui/community/activity/activity_card.dart';
|
|
|
|
|
import 'package:aku_new_community/ui/community/activity/activity_detail_page.dart';
|
|
|
|
|
import 'package:aku_new_community/ui/community/activity/activity_list_page.dart';
|
|
|
|
|
import 'package:aku_new_community/ui/community/community_func.dart';
|
|
|
|
|
import 'package:aku_new_community/ui/community/notice/notice_detail_page.dart';
|
|
|
|
|
import 'package:aku_new_community/ui/home/home_notification.dart';
|
|
|
|
|
import 'package:aku_new_community/ui/home/home_title.dart';
|
|
|
|
|
import 'package:aku_new_community/ui/home/public_infomation/public_information_detail_page.dart';
|
|
|
|
|
import 'package:aku_new_community/ui/manager/advice/advice_page.dart';
|
|
|
|
|
import 'package:aku_new_community/ui/market/search/good_detail_page.dart';
|
|
|
|
|
import 'package:aku_new_community/ui/search/bee_search.dart';
|
|
|
|
|
import 'package:aku_new_community/utils/headers.dart';
|
|
|
|
|
import 'package:aku_new_community/utils/login_util.dart';
|
|
|
|
|
import 'package:aku_new_community/widget/animated/OverlayWidget.dart';
|
|
|
|
|
import 'package:aku_new_community/widget/beeImageNetwork.dart';
|
|
|
|
|
import 'package:aku_new_community/widget/bee_divider.dart';
|
|
|
|
|
import 'package:aku_new_community/widget/others/rectIndicator.dart';
|
|
|
|
|
import 'package:aku_new_community/widget/others/user_tool.dart';
|
|
|
|
|
import 'package:aku_new_community/widget/views/bee_gradient_divider.dart';
|
|
|
|
|
import 'package:badges/badges.dart';
|
|
|
|
|
import 'package:bot_toast/bot_toast.dart';
|
|
|
|
|
import 'package:cached_network_image/cached_network_image.dart';
|
|
|
|
|
import 'package:card_swiper/card_swiper.dart';
|
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
|
import 'package:flutter/services.dart';
|
|
|
|
|
import 'package:flutter_easyrefresh/easy_refresh.dart';
|
|
|
|
|
import 'package:get/get.dart';
|
|
|
|
|
import 'package:jpush_flutter/jpush_flutter.dart';
|
|
|
|
|
import 'package:palette_generator/palette_generator.dart';
|
|
|
|
|
import 'package:power_logger/power_logger.dart';
|
|
|
|
|
import 'package:provider/provider.dart';
|
|
|
|
|
import 'package:url_launcher/url_launcher.dart';
|
|
|
|
@ -69,7 +70,6 @@ class _HomePageState extends State<HomePage>
|
|
|
|
|
List<HomeSwiperModel> _swiperModels = [];
|
|
|
|
|
|
|
|
|
|
SwiperController _swiperController = SwiperController();
|
|
|
|
|
ValueNotifier<Color> _barColor = ValueNotifier(Colors.transparent);
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
void initState() {
|
|
|
|
@ -85,14 +85,6 @@ class _HomePageState extends State<HomePage>
|
|
|
|
|
}
|
|
|
|
|
_scrollController = ScrollController();
|
|
|
|
|
_refreshController = EasyRefreshController();
|
|
|
|
|
_swiperController.addListener(() {
|
|
|
|
|
//由于先触发监听后,再执行onChangeIndex函数,所以_currentSwiperIndex会比当前index少1,用+1并求余的方式获得真正当前index;
|
|
|
|
|
if (_swiperModels.length <= 1) {
|
|
|
|
|
_swiperBarColor(0);
|
|
|
|
|
} else {
|
|
|
|
|
_swiperBarColor((_currentSwiperIndex + 1) % 3);
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
SystemChrome.setSystemUIOverlayStyle(
|
|
|
|
|
SystemUiOverlayStyle(statusBarColor: Colors.transparent));
|
|
|
|
|
}
|
|
|
|
@ -112,50 +104,20 @@ class _HomePageState extends State<HomePage>
|
|
|
|
|
commentCount = appProvider.messageCenterModel.commentCount ?? 0;
|
|
|
|
|
sysCount = appProvider.messageCenterModel.sysCount ?? 0;
|
|
|
|
|
sum = commentCount + sysCount;
|
|
|
|
|
var head = ValueListenableBuilder(
|
|
|
|
|
valueListenable: _barColor,
|
|
|
|
|
builder: (context, Color color, child) {
|
|
|
|
|
return Container(
|
|
|
|
|
padding: EdgeInsets.only(top: MediaQuery.of(context).padding.top),
|
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
|
border: Border.all(width: 0, color: color),
|
|
|
|
|
color: color,
|
|
|
|
|
),
|
|
|
|
|
width: double.infinity,
|
|
|
|
|
child: child,
|
|
|
|
|
);
|
|
|
|
|
},
|
|
|
|
|
child: Padding(
|
|
|
|
|
padding: EdgeInsets.symmetric(vertical: 16.w, horizontal: 16.w),
|
|
|
|
|
child: Row(crossAxisAlignment: CrossAxisAlignment.center, children: [
|
|
|
|
|
if (appProvider.location != null)
|
|
|
|
|
Padding(
|
|
|
|
|
padding: const EdgeInsets.only(right: 5),
|
|
|
|
|
child: Image.asset(
|
|
|
|
|
R.ASSETS_ICONS_ICON_MAIN_LOCATION_PNG,
|
|
|
|
|
width: 32.w,
|
|
|
|
|
height: 32.w,
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
Text(
|
|
|
|
|
appProvider.location?['city'] == null
|
|
|
|
|
? ''
|
|
|
|
|
: appProvider.location?['city'] as String? ?? '',
|
|
|
|
|
style: TextStyle(
|
|
|
|
|
fontWeight: FontWeight.w600,
|
|
|
|
|
fontSize: 24.sp,
|
|
|
|
|
color: Color(0xff333333),
|
|
|
|
|
),
|
|
|
|
|
textAlign: TextAlign.center,
|
|
|
|
|
),
|
|
|
|
|
Text(
|
|
|
|
|
'(${appProvider.weatherType} ${appProvider.weatherTemp}℃)',
|
|
|
|
|
style: TextStyle(
|
|
|
|
|
fontSize: 24.sp,
|
|
|
|
|
color: Color(0xff999999),
|
|
|
|
|
),
|
|
|
|
|
textAlign: TextAlign.center,
|
|
|
|
|
var head = Padding(
|
|
|
|
|
padding: EdgeInsets.only(
|
|
|
|
|
top: MediaQuery.of(context).padding.top + 20.w,
|
|
|
|
|
right: 32.w,
|
|
|
|
|
left: 32.w,
|
|
|
|
|
bottom: 20.w),
|
|
|
|
|
child: Row(crossAxisAlignment: CrossAxisAlignment.center, children: [
|
|
|
|
|
if (appProvider.location != null)
|
|
|
|
|
Image.asset(
|
|
|
|
|
Assets.home.icLocation.path,
|
|
|
|
|
width: 48.w,
|
|
|
|
|
height: 48.w,
|
|
|
|
|
),
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
|
Spacer(),
|
|
|
|
|
// GestureDetector(
|
|
|
|
|
// onTap: () {
|
|
|
|
@ -188,20 +150,82 @@ class _HomePageState extends State<HomePage>
|
|
|
|
|
child: Image.asset(R.ASSETS_ICONS_ICON_MAIN_MESSAGE_PNG,
|
|
|
|
|
height: 40.w, width: 40.w),
|
|
|
|
|
)),
|
|
|
|
|
=======
|
|
|
|
|
16.wb,
|
|
|
|
|
Text(
|
|
|
|
|
appProvider.location?['city'] == null
|
|
|
|
|
? ''
|
|
|
|
|
: appProvider.location?['city'] as String? ?? '',
|
|
|
|
|
style: TextStyle(
|
|
|
|
|
fontWeight: FontWeight.w600,
|
|
|
|
|
fontSize: 28.sp,
|
|
|
|
|
color: Color(0xff333333),
|
|
|
|
|
),
|
|
|
|
|
]),
|
|
|
|
|
),
|
|
|
|
|
textAlign: TextAlign.center,
|
|
|
|
|
),
|
|
|
|
|
Text(
|
|
|
|
|
'(${appProvider.weatherType} ${appProvider.weatherTemp}℃)',
|
|
|
|
|
style: TextStyle(
|
|
|
|
|
fontSize: 28.sp,
|
|
|
|
|
color: Color(0xff999999),
|
|
|
|
|
>>>>>>> b09ea45bd7aafc589e5c65d5846bf3243066ee5d
|
|
|
|
|
),
|
|
|
|
|
textAlign: TextAlign.center,
|
|
|
|
|
),
|
|
|
|
|
Spacer(),
|
|
|
|
|
GestureDetector(
|
|
|
|
|
onTap: () {
|
|
|
|
|
Get.to(() => BeeSearch());
|
|
|
|
|
},
|
|
|
|
|
child:
|
|
|
|
|
Image.asset(Assets.home.icSearch.path, height: 48.w, width: 48.w),
|
|
|
|
|
),
|
|
|
|
|
20.wb,
|
|
|
|
|
Badge(
|
|
|
|
|
elevation: 0,
|
|
|
|
|
badgeColor: Color(0xFFCF2525),
|
|
|
|
|
padding: sum > 9 ? EdgeInsets.all(2.w) : EdgeInsets.all(5.w),
|
|
|
|
|
showBadge: appProvider.messageCenterModel.commentCount != 0 ||
|
|
|
|
|
appProvider.messageCenterModel.sysCount != 0,
|
|
|
|
|
position: BadgePosition.topEnd(
|
|
|
|
|
top: 8.w,
|
|
|
|
|
end: -4.w,
|
|
|
|
|
),
|
|
|
|
|
badgeContent: Text(
|
|
|
|
|
(sum > 99 ? 99 : sum).toString(),
|
|
|
|
|
style: TextStyle(color: Colors.white, fontSize: 20.sp),
|
|
|
|
|
),
|
|
|
|
|
child: GestureDetector(
|
|
|
|
|
onTap: () {
|
|
|
|
|
if (LoginUtil.isNotLogin) return;
|
|
|
|
|
Get.to(() => MessageCenterPage());
|
|
|
|
|
},
|
|
|
|
|
child: Image.asset(Assets.home.icMessage.path,
|
|
|
|
|
height: 48.w, width: 48.w),
|
|
|
|
|
)),
|
|
|
|
|
]),
|
|
|
|
|
);
|
|
|
|
|
return AnnotatedRegion<SystemUiOverlayStyle>(
|
|
|
|
|
value: SystemUiOverlayStyle.dark,
|
|
|
|
|
child: Scaffold(
|
|
|
|
|
extendBody: true,
|
|
|
|
|
extendBodyBehindAppBar: true,
|
|
|
|
|
body: Stack(
|
|
|
|
|
children: [
|
|
|
|
|
EasyRefresh(
|
|
|
|
|
backgroundColor: Color(0xFFFDE019),
|
|
|
|
|
appBar: PreferredSize(
|
|
|
|
|
preferredSize:
|
|
|
|
|
Size.fromHeight(MediaQuery.of(context).padding.top + 88.w),
|
|
|
|
|
child: head),
|
|
|
|
|
body: SafeArea(
|
|
|
|
|
child: Container(
|
|
|
|
|
height: MediaQuery.of(context).size.height,
|
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
|
borderRadius:
|
|
|
|
|
BorderRadius.vertical(top: Radius.circular(32.w)),
|
|
|
|
|
color: Color(0xFFF9F9F9)),
|
|
|
|
|
clipBehavior: Clip.antiAliasWithSaveLayer,
|
|
|
|
|
child: EasyRefresh(
|
|
|
|
|
controller: _refreshController,
|
|
|
|
|
header: BeeBallPauseHeader(bgColor: _barColor),
|
|
|
|
|
header: MaterialHeader(),
|
|
|
|
|
firstRefresh: true,
|
|
|
|
|
onRefresh: () async {
|
|
|
|
|
_activityItemModels = await CommunityFunc.activityList();
|
|
|
|
@ -211,137 +235,104 @@ class _HomePageState extends State<HomePage>
|
|
|
|
|
setState(() {});
|
|
|
|
|
},
|
|
|
|
|
child: CustomScrollView(
|
|
|
|
|
shrinkWrap: true,
|
|
|
|
|
controller: _scrollController,
|
|
|
|
|
slivers: [
|
|
|
|
|
SliverToBoxAdapter(
|
|
|
|
|
child: Column(
|
|
|
|
|
mainAxisSize: MainAxisSize.min,
|
|
|
|
|
children: [
|
|
|
|
|
head,
|
|
|
|
|
HomeSwiper(), //要做点击事件
|
|
|
|
|
// SizedBox(height: 100.w),
|
|
|
|
|
Container(
|
|
|
|
|
padding: EdgeInsets.only(top: 24.w, bottom: 32.w),
|
|
|
|
|
child: getFunction(), //ApplicationView(),
|
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
|
color: Colors.white,
|
|
|
|
|
boxShadow: const <BoxShadow>[
|
|
|
|
|
BoxShadow(
|
|
|
|
|
color: Color(0x14000000),
|
|
|
|
|
blurRadius: 0,
|
|
|
|
|
offset: Offset(0.0, 2.0),
|
|
|
|
|
spreadRadius: 0.1)
|
|
|
|
|
],
|
|
|
|
|
borderRadius: BorderRadius.only(
|
|
|
|
|
bottomLeft: Radius.circular(28),
|
|
|
|
|
bottomRight: Radius.circular(28))),
|
|
|
|
|
)
|
|
|
|
|
//ApplicationBox(child: ApplicationView()),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
child: HomeSwiper(),
|
|
|
|
|
),
|
|
|
|
|
SliverToBoxAdapter(
|
|
|
|
|
child: Container(
|
|
|
|
|
height: 40,
|
|
|
|
|
margin: EdgeInsets.only(
|
|
|
|
|
left: 32.w, right: 32.w, top: 24.w),
|
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
|
color: Colors.white,
|
|
|
|
|
borderRadius: BorderRadius.all(Radius.circular(8)),
|
|
|
|
|
boxShadow: const <BoxShadow>[
|
|
|
|
|
BoxShadow(
|
|
|
|
|
color: Color(0x14000000),
|
|
|
|
|
blurRadius: 4,
|
|
|
|
|
spreadRadius: 0.5)
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
child: HomeNotification(items: _boardItemModels)),
|
|
|
|
|
margin: EdgeInsets.symmetric(horizontal: 32.w),
|
|
|
|
|
padding:
|
|
|
|
|
EdgeInsets.only(top: 20.w, left: 0.w, right: 0.w),
|
|
|
|
|
child: _applications(), //ApplicationView(),
|
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
|
color: Colors.white,
|
|
|
|
|
borderRadius: BorderRadius.circular(16.w),
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
SliverToBoxAdapter(
|
|
|
|
|
child: Row(
|
|
|
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
|
|
|
children: [
|
|
|
|
|
GestureDetector(
|
|
|
|
|
child: Container(
|
|
|
|
|
margin: EdgeInsets.only(top: 24.w),
|
|
|
|
|
padding: EdgeInsets.only(left: 32.w, top: 24.w),
|
|
|
|
|
width: 140,
|
|
|
|
|
height: 150,
|
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
|
image: DecorationImage(
|
|
|
|
|
fit: BoxFit.fill,
|
|
|
|
|
image:
|
|
|
|
|
AssetImage(R.ASSETS_IMAGES_CARD_YELLOW_PNG),
|
|
|
|
|
)),
|
|
|
|
|
child: Column(
|
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
|
|
|
children: [
|
|
|
|
|
Text(
|
|
|
|
|
'访客邀请',
|
|
|
|
|
style: TextStyle(
|
|
|
|
|
color: Color(0xD9000000),
|
|
|
|
|
fontSize: 26.sp,
|
|
|
|
|
fontWeight: FontWeight.bold),
|
|
|
|
|
),
|
|
|
|
|
10.hb,
|
|
|
|
|
Text(
|
|
|
|
|
'一键分享',
|
|
|
|
|
style: TextStyle(
|
|
|
|
|
color: Color(0x73000000),
|
|
|
|
|
fontSize: 20.sp,
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
Text(
|
|
|
|
|
'让拜访不再是难事',
|
|
|
|
|
style: TextStyle(
|
|
|
|
|
color: Color(0x73000000),
|
|
|
|
|
fontSize: 20.sp,
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
Spacer(),
|
|
|
|
|
Image.asset(
|
|
|
|
|
R.ASSETS_ICONS_ICON_MAIN_INVITE_PNG,
|
|
|
|
|
width: 100.w,
|
|
|
|
|
height: 100.w,
|
|
|
|
|
child: Container(
|
|
|
|
|
width: 686.w,
|
|
|
|
|
height: 320.w,
|
|
|
|
|
clipBehavior: Clip.antiAliasWithSaveLayer,
|
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
|
color: Colors.white,
|
|
|
|
|
borderRadius: BorderRadius.circular(16.w)),
|
|
|
|
|
margin: EdgeInsets.all(32.w),
|
|
|
|
|
child: Row(
|
|
|
|
|
children: [
|
|
|
|
|
Expanded(
|
|
|
|
|
flex: 2,
|
|
|
|
|
child: GestureDetector(
|
|
|
|
|
child: Container(
|
|
|
|
|
padding:
|
|
|
|
|
EdgeInsets.only(left: 34.w, top: 40.w),
|
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
|
borderRadius: BorderRadius.circular(16.w),
|
|
|
|
|
image: DecorationImage(
|
|
|
|
|
fit: BoxFit.fill,
|
|
|
|
|
image: AssetImage(
|
|
|
|
|
Assets.home.imgFkyq.path),
|
|
|
|
|
)),
|
|
|
|
|
child: Column(
|
|
|
|
|
crossAxisAlignment:
|
|
|
|
|
CrossAxisAlignment.start,
|
|
|
|
|
children: [
|
|
|
|
|
Text(
|
|
|
|
|
'访客邀请',
|
|
|
|
|
style: TextStyle(
|
|
|
|
|
color: Color(0xD9000000),
|
|
|
|
|
fontSize: 28.sp,
|
|
|
|
|
fontWeight: FontWeight.bold),
|
|
|
|
|
),
|
|
|
|
|
10.hb,
|
|
|
|
|
Text(
|
|
|
|
|
'让拜访更加便捷',
|
|
|
|
|
style: TextStyle(
|
|
|
|
|
color: Color(0x73000000),
|
|
|
|
|
fontSize: 20.sp,
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
30.hb,
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
onTap: () {
|
|
|
|
|
Get.to(() => VisitorAccessPage());
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
onTap: () {
|
|
|
|
|
Get.to(VisitorAccessPage());
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
25.wb,
|
|
|
|
|
Container(
|
|
|
|
|
margin: EdgeInsets.only(top: 24.w),
|
|
|
|
|
child: Column(
|
|
|
|
|
children: [
|
|
|
|
|
GestureDetector(
|
|
|
|
|
child: Container(
|
|
|
|
|
width: 190,
|
|
|
|
|
height: 69,
|
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
|
image: DecorationImage(
|
|
|
|
|
fit: BoxFit.fill,
|
|
|
|
|
image: AssetImage(
|
|
|
|
|
R.ASSETS_IMAGES_CARD_PINK_PNG),
|
|
|
|
|
)),
|
|
|
|
|
child: Row(
|
|
|
|
|
mainAxisAlignment:
|
|
|
|
|
MainAxisAlignment.start,
|
|
|
|
|
children: [
|
|
|
|
|
20.wb,
|
|
|
|
|
Column(
|
|
|
|
|
BeeGradientDivider.vertical(),
|
|
|
|
|
Expanded(
|
|
|
|
|
flex: 3,
|
|
|
|
|
child: Column(
|
|
|
|
|
children: [
|
|
|
|
|
Expanded(
|
|
|
|
|
flex: 1,
|
|
|
|
|
child: GestureDetector(
|
|
|
|
|
child: Container(
|
|
|
|
|
width: double.infinity,
|
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
|
borderRadius:
|
|
|
|
|
BorderRadius.circular(16.w),
|
|
|
|
|
image: DecorationImage(
|
|
|
|
|
fit: BoxFit.cover,
|
|
|
|
|
image: AssetImage(
|
|
|
|
|
Assets.home.imgYjbj.path),
|
|
|
|
|
)),
|
|
|
|
|
padding: EdgeInsets.only(
|
|
|
|
|
left: 32.w, top: 40.w),
|
|
|
|
|
child: Column(
|
|
|
|
|
crossAxisAlignment:
|
|
|
|
|
CrossAxisAlignment.start,
|
|
|
|
|
children: [
|
|
|
|
|
20.hb,
|
|
|
|
|
Text(
|
|
|
|
|
'一键报警',
|
|
|
|
|
style: TextStyle(
|
|
|
|
|
color: Color(0xD9000000),
|
|
|
|
|
fontSize: 26.sp,
|
|
|
|
|
fontSize: 28.sp,
|
|
|
|
|
fontWeight: FontWeight.bold),
|
|
|
|
|
),
|
|
|
|
|
10.hb,
|
|
|
|
@ -354,46 +345,37 @@ class _HomePageState extends State<HomePage>
|
|
|
|
|
),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
Spacer(),
|
|
|
|
|
Image.asset(
|
|
|
|
|
R.ASSETS_ICONS_ICON_MAIN_POLICE_PNG,
|
|
|
|
|
width: 98.w,
|
|
|
|
|
height: 98.w,
|
|
|
|
|
),
|
|
|
|
|
20.wb,
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
onTap: () {
|
|
|
|
|
Get.to(() => AlarmPage());
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
onTap: () {
|
|
|
|
|
Get.to(AlarmPage());
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
GestureDetector(
|
|
|
|
|
child: Container(
|
|
|
|
|
margin: EdgeInsets.only(top: 20.w),
|
|
|
|
|
width: 190,
|
|
|
|
|
height: 69,
|
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
|
image: DecorationImage(
|
|
|
|
|
fit: BoxFit.fill,
|
|
|
|
|
image: AssetImage(
|
|
|
|
|
R.ASSETS_IMAGES_CARD_BLUE_PNG),
|
|
|
|
|
)),
|
|
|
|
|
child: Row(
|
|
|
|
|
mainAxisAlignment:
|
|
|
|
|
MainAxisAlignment.start,
|
|
|
|
|
children: [
|
|
|
|
|
20.wb,
|
|
|
|
|
Column(
|
|
|
|
|
BeeGradientDivider.horizontal(),
|
|
|
|
|
Expanded(
|
|
|
|
|
flex: 1,
|
|
|
|
|
child: GestureDetector(
|
|
|
|
|
child: Container(
|
|
|
|
|
padding: EdgeInsets.only(
|
|
|
|
|
top: 40.w, left: 32.w),
|
|
|
|
|
width: double.infinity,
|
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
|
borderRadius:
|
|
|
|
|
BorderRadius.circular(16.w),
|
|
|
|
|
image: DecorationImage(
|
|
|
|
|
fit: BoxFit.cover,
|
|
|
|
|
image: AssetImage(
|
|
|
|
|
Assets.home.imgJyzx.path),
|
|
|
|
|
)),
|
|
|
|
|
child: Column(
|
|
|
|
|
crossAxisAlignment:
|
|
|
|
|
CrossAxisAlignment.start,
|
|
|
|
|
children: [
|
|
|
|
|
20.hb,
|
|
|
|
|
Text(
|
|
|
|
|
'建议咨询',
|
|
|
|
|
style: TextStyle(
|
|
|
|
|
color: Color(0xD9000000),
|
|
|
|
|
fontSize: 26.sp,
|
|
|
|
|
fontSize: 28.sp,
|
|
|
|
|
fontWeight: FontWeight.bold),
|
|
|
|
|
),
|
|
|
|
|
10.hb,
|
|
|
|
@ -406,72 +388,74 @@ class _HomePageState extends State<HomePage>
|
|
|
|
|
),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
Spacer(),
|
|
|
|
|
Image.asset(
|
|
|
|
|
R.ASSETS_ICONS_ICON_MAIN_CONSULT_PNG,
|
|
|
|
|
width: 98.w,
|
|
|
|
|
height: 98.w,
|
|
|
|
|
),
|
|
|
|
|
20.wb,
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
onTap: () {
|
|
|
|
|
Get.to(AdvicePage(
|
|
|
|
|
type: AdviceType.SUGGESTION));
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
onTap: () {
|
|
|
|
|
Get.to(AdvicePage(
|
|
|
|
|
type: AdviceType.SUGGESTION));
|
|
|
|
|
},
|
|
|
|
|
)
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
)
|
|
|
|
|
],
|
|
|
|
|
)
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
)
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
SliverToBoxAdapter(
|
|
|
|
|
child: Column(
|
|
|
|
|
children: [
|
|
|
|
|
HomeTitle(
|
|
|
|
|
title: '社区活动',
|
|
|
|
|
suffixTitle: '查看全部',
|
|
|
|
|
onTap: () => Get.to(() => ActivityListPage()),
|
|
|
|
|
),
|
|
|
|
|
_activityItemModels == []
|
|
|
|
|
? SizedBox()
|
|
|
|
|
: Container(
|
|
|
|
|
height: 480.w,
|
|
|
|
|
padding: EdgeInsets.only(left: 32.w),
|
|
|
|
|
child: ListView.separated(
|
|
|
|
|
padding: EdgeInsets.zero,
|
|
|
|
|
separatorBuilder: (context, index) {
|
|
|
|
|
return SizedBox(
|
|
|
|
|
width: 16.w,
|
|
|
|
|
);
|
|
|
|
|
},
|
|
|
|
|
scrollDirection: Axis.horizontal,
|
|
|
|
|
itemBuilder: (context, index) {
|
|
|
|
|
return Container(
|
|
|
|
|
width: 500.w,
|
|
|
|
|
child: Builder(
|
|
|
|
|
builder: (context) {
|
|
|
|
|
return ActivityCard(
|
|
|
|
|
model:
|
|
|
|
|
_activityItemModels[index]);
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
);
|
|
|
|
|
},
|
|
|
|
|
itemCount: _activityItemModels.length,
|
|
|
|
|
child: Container(
|
|
|
|
|
padding: EdgeInsets.all(32.w),
|
|
|
|
|
margin: EdgeInsets.symmetric(horizontal: 32.w),
|
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
|
color: Colors.white,
|
|
|
|
|
borderRadius: BorderRadius.circular(16.w)),
|
|
|
|
|
child: Column(
|
|
|
|
|
children: [
|
|
|
|
|
HomeTitle(
|
|
|
|
|
title: '社区活动',
|
|
|
|
|
suffixTitle: '查看全部',
|
|
|
|
|
onTap: () => Get.to(() => ActivityListPage()),
|
|
|
|
|
),
|
|
|
|
|
24.hb,
|
|
|
|
|
_activityItemModels == []
|
|
|
|
|
? SizedBox()
|
|
|
|
|
: Container(
|
|
|
|
|
height: 460.w,
|
|
|
|
|
child: ListView.separated(
|
|
|
|
|
padding: EdgeInsets.zero,
|
|
|
|
|
separatorBuilder: (context, index) {
|
|
|
|
|
return SizedBox(
|
|
|
|
|
width: 16.w,
|
|
|
|
|
);
|
|
|
|
|
},
|
|
|
|
|
scrollDirection: Axis.horizontal,
|
|
|
|
|
itemBuilder: (context, index) {
|
|
|
|
|
return Container(
|
|
|
|
|
width: 500.w,
|
|
|
|
|
child: Builder(
|
|
|
|
|
builder: (context) {
|
|
|
|
|
return ActivityCard(
|
|
|
|
|
model:
|
|
|
|
|
_activityItemModels[index]);
|
|
|
|
|
},
|
|
|
|
|
),
|
|
|
|
|
);
|
|
|
|
|
},
|
|
|
|
|
itemCount: _activityItemModels.length,
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
// : ActivityCard(model: _activityItemModel)
|
|
|
|
|
// .pSymmetric(h: 24.w, v: 24.w),
|
|
|
|
|
],
|
|
|
|
|
// : ActivityCard(model: _activityItemModel)
|
|
|
|
|
// .pSymmetric(h: 24.w, v: 24.w),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
)),
|
|
|
|
|
SliverToBoxAdapter(
|
|
|
|
|
child: 48.hb,
|
|
|
|
|
)
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
OverlayLivingBtnWidget()
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
));
|
|
|
|
|
}
|
|
|
|
@ -479,48 +463,46 @@ class _HomePageState extends State<HomePage>
|
|
|
|
|
Widget HomeSwiper() {
|
|
|
|
|
return Container(
|
|
|
|
|
width: double.infinity,
|
|
|
|
|
height: 320.w,
|
|
|
|
|
decoration:
|
|
|
|
|
BoxDecoration(border: Border.all(width: 0, color: _barColor.value)),
|
|
|
|
|
child: AspectRatio(
|
|
|
|
|
aspectRatio: 375 / 160,
|
|
|
|
|
child: Swiper(
|
|
|
|
|
key: UniqueKey(),
|
|
|
|
|
controller: _swiperController,
|
|
|
|
|
onIndexChanged: (index) async {
|
|
|
|
|
_currentSwiperIndex = index;
|
|
|
|
|
},
|
|
|
|
|
itemBuilder: (BuildContext context, int index) {
|
|
|
|
|
return getSwiperImage(_swiperModels[index]);
|
|
|
|
|
},
|
|
|
|
|
clipBehavior: Clip.antiAlias,
|
|
|
|
|
margin: EdgeInsets.all(32.w),
|
|
|
|
|
height: 248.w,
|
|
|
|
|
decoration: BoxDecoration(borderRadius: BorderRadius.circular(16.w)),
|
|
|
|
|
child: Swiper(
|
|
|
|
|
key: UniqueKey(),
|
|
|
|
|
controller: _swiperController,
|
|
|
|
|
onIndexChanged: (index) async {
|
|
|
|
|
_currentSwiperIndex = index;
|
|
|
|
|
},
|
|
|
|
|
itemBuilder: (BuildContext context, int index) {
|
|
|
|
|
return getSwiperImage(_swiperModels[index]);
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
pagination: SwiperPagination(
|
|
|
|
|
alignment: Alignment.bottomRight,
|
|
|
|
|
builder: SwiperCustomPagination(
|
|
|
|
|
builder: (BuildContext context, SwiperPluginConfig config) {
|
|
|
|
|
return RectIndicator(
|
|
|
|
|
position: config.activeIndex,
|
|
|
|
|
count: _swiperModels.length,
|
|
|
|
|
activeColor: Color(0x99FFFFFF),
|
|
|
|
|
color: Color(0xD9FFFFFF),
|
|
|
|
|
//未选中 指示器颜色,选中的颜色key为Color
|
|
|
|
|
width: 4,
|
|
|
|
|
//指示器宽度
|
|
|
|
|
activeWidth: 14,
|
|
|
|
|
//选中的指示器宽度
|
|
|
|
|
radius: 4,
|
|
|
|
|
//指示器圆角角度
|
|
|
|
|
height: 4,
|
|
|
|
|
); //指示器高度
|
|
|
|
|
})),
|
|
|
|
|
scrollDirection: Axis.horizontal,
|
|
|
|
|
// control: new SwiperControl(),
|
|
|
|
|
autoplay: true,
|
|
|
|
|
onTap: (index) {
|
|
|
|
|
swiperNavigate(_swiperModels[index]);
|
|
|
|
|
},
|
|
|
|
|
itemCount: _swiperModels.length,
|
|
|
|
|
),
|
|
|
|
|
pagination: SwiperPagination(
|
|
|
|
|
alignment: Alignment.bottomRight,
|
|
|
|
|
builder: SwiperCustomPagination(
|
|
|
|
|
builder: (BuildContext context, SwiperPluginConfig config) {
|
|
|
|
|
return RectIndicator(
|
|
|
|
|
position: config.activeIndex,
|
|
|
|
|
count: _swiperModels.length,
|
|
|
|
|
activeColor: Color(0x99FFFFFF),
|
|
|
|
|
color: Color(0xD9FFFFFF),
|
|
|
|
|
//未选中 指示器颜色,选中的颜色key为Color
|
|
|
|
|
width: 4,
|
|
|
|
|
//指示器宽度
|
|
|
|
|
activeWidth: 14,
|
|
|
|
|
//选中的指示器宽度
|
|
|
|
|
radius: 4,
|
|
|
|
|
//指示器圆角角度
|
|
|
|
|
height: 4,
|
|
|
|
|
); //指示器高度
|
|
|
|
|
})),
|
|
|
|
|
scrollDirection: Axis.horizontal,
|
|
|
|
|
// control: new SwiperControl(),
|
|
|
|
|
autoplay: true,
|
|
|
|
|
onTap: (index) {
|
|
|
|
|
swiperNavigate(_swiperModels[index]);
|
|
|
|
|
},
|
|
|
|
|
itemCount: _swiperModels.length,
|
|
|
|
|
),
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
@ -531,41 +513,49 @@ class _HomePageState extends State<HomePage>
|
|
|
|
|
launch(model.customizeUrl ?? '');
|
|
|
|
|
break;
|
|
|
|
|
case 2:
|
|
|
|
|
Get.to(GoodDetailPage(goodId: model.id));
|
|
|
|
|
model.associationId == null
|
|
|
|
|
? null
|
|
|
|
|
: Get.to(() => GoodDetailPage(
|
|
|
|
|
goodId: model.associationId!,
|
|
|
|
|
));
|
|
|
|
|
break;
|
|
|
|
|
case 3:
|
|
|
|
|
// Get.to(page)
|
|
|
|
|
model.associationId == null
|
|
|
|
|
? null
|
|
|
|
|
: Get.to(() => PublicInformationDetailPage(
|
|
|
|
|
id: model.associationId!,
|
|
|
|
|
));
|
|
|
|
|
break;
|
|
|
|
|
case 4:
|
|
|
|
|
model.associationId == null
|
|
|
|
|
? null
|
|
|
|
|
: Get.to(() => NoticeDetailPage(
|
|
|
|
|
id: model.associationId!,
|
|
|
|
|
));
|
|
|
|
|
break;
|
|
|
|
|
case 5:
|
|
|
|
|
model.associationId == null
|
|
|
|
|
? null
|
|
|
|
|
: Get.to(() => ActivityDetailPage(
|
|
|
|
|
id: model.associationId!,
|
|
|
|
|
));
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
BotToast.showText(text: '类型错误');
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Future _swiperBarColor(int index) async {
|
|
|
|
|
if (_swiperModels.isNotEmpty) {
|
|
|
|
|
var color =
|
|
|
|
|
await PaletteGenerator.fromImageProvider(CachedNetworkImageProvider(
|
|
|
|
|
SAASAPI.image(ImgModel.first(_swiperModels[index].imgList)),
|
|
|
|
|
));
|
|
|
|
|
_barColor.value = color.dominantColor?.color ?? Colors.transparent;
|
|
|
|
|
} else {
|
|
|
|
|
_barColor.value = Colors.transparent;
|
|
|
|
|
() {};
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Widget getSwiperImage(HomeSwiperModel swiperModel) {
|
|
|
|
|
return Container(
|
|
|
|
|
clipBehavior: Clip.antiAliasWithSaveLayer,
|
|
|
|
|
decoration: BoxDecoration(borderRadius: BorderRadius.circular(16.w)),
|
|
|
|
|
child: BeeImageNetwork(
|
|
|
|
|
imgs: swiperModel.imgList ?? [],
|
|
|
|
|
),
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Widget getFunction() {
|
|
|
|
|
Widget _applications() {
|
|
|
|
|
return Column(
|
|
|
|
|
children: [
|
|
|
|
|
Row(
|
|
|
|
@ -578,45 +568,52 @@ class _HomePageState extends State<HomePage>
|
|
|
|
|
getFunctionBtn(AO.fromRaw('智慧养老')),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
32.hb,
|
|
|
|
|
24.hb,
|
|
|
|
|
Row(
|
|
|
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.center,
|
|
|
|
|
children: [
|
|
|
|
|
getFunctionBtn(AO.fromRaw('周边服务')),
|
|
|
|
|
getFunctionBtn(AO.fromRaw('小蜜蜂任务', replaceTitle: '任务发布')),
|
|
|
|
|
getFunctionBtn(AO.fromRaw('任务发布', replaceTitle: '任务发布')),
|
|
|
|
|
getFunctionBtn(AO.fromRaw('邻家宠物')),
|
|
|
|
|
getFunctionBtn(AO.fromRaw('全部应用')),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
44.hb,
|
|
|
|
|
BeeDivider.horizontal(),
|
|
|
|
|
10.hb,
|
|
|
|
|
HomeNotification(items: _boardItemModels),
|
|
|
|
|
10.hb,
|
|
|
|
|
],
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Widget getFunctionBtn(AO ao) {
|
|
|
|
|
return MaterialButton(
|
|
|
|
|
shape: StadiumBorder(),
|
|
|
|
|
padding: EdgeInsets.zero,
|
|
|
|
|
onPressed: () {
|
|
|
|
|
if (LoginUtil.isNotLogin) return;
|
|
|
|
|
// if (!LoginUtil.haveRoom(ao.title)) return;
|
|
|
|
|
if (ao.page == null) {
|
|
|
|
|
BotToast.showText(text: '该功能正在准备上线中,敬请期待', align: Alignment(0, 0.5));
|
|
|
|
|
} else {
|
|
|
|
|
Get.to(ao.page);
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
child: Column(
|
|
|
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
|
|
|
children: [
|
|
|
|
|
Image.asset(
|
|
|
|
|
ao.path,
|
|
|
|
|
height: 80.w,
|
|
|
|
|
width: 80.w,
|
|
|
|
|
),
|
|
|
|
|
16.hb,
|
|
|
|
|
ao.title.text.size(22.sp).color(Color(0xA6000000)).bold.make(),
|
|
|
|
|
],
|
|
|
|
|
return Expanded(
|
|
|
|
|
flex: 1,
|
|
|
|
|
child: GestureDetector(
|
|
|
|
|
onTap: () {
|
|
|
|
|
if (LoginUtil.isNotLogin) return;
|
|
|
|
|
// if (!LoginUtil.haveRoom(ao.title)) return;
|
|
|
|
|
if (ao.page == null) {
|
|
|
|
|
BotToast.showText(
|
|
|
|
|
text: '该功能正在准备上线中,敬请期待', align: Alignment(0, 0.5));
|
|
|
|
|
} else {
|
|
|
|
|
Get.to(ao.page);
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
child: Column(
|
|
|
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
|
|
|
children: [
|
|
|
|
|
Image.asset(
|
|
|
|
|
ao.path,
|
|
|
|
|
height: 96.w,
|
|
|
|
|
width: 96.w,
|
|
|
|
|
),
|
|
|
|
|
8.hb,
|
|
|
|
|
ao.title.text.size(24.sp).color(Color(0xFF333333)).make(),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
),
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|