|
|
@ -1,13 +1,11 @@
|
|
|
|
// Dart imports:
|
|
|
|
// Dart imports:
|
|
|
|
|
|
|
|
|
|
|
|
import 'package:aku_new_community/const/resource.dart';
|
|
|
|
|
|
|
|
import 'package:aku_new_community/constants/api.dart';
|
|
|
|
import 'package:aku_new_community/constants/api.dart';
|
|
|
|
import 'package:aku_new_community/constants/application_objects.dart';
|
|
|
|
import 'package:aku_new_community/constants/application_objects.dart';
|
|
|
|
import 'package:aku_new_community/model/common/img_model.dart';
|
|
|
|
import 'package:aku_new_community/model/common/img_model.dart';
|
|
|
|
import 'package:aku_new_community/model/community/activity_item_model.dart';
|
|
|
|
import 'package:aku_new_community/model/community/activity_item_model.dart';
|
|
|
|
import 'package:aku_new_community/model/community/board_model.dart';
|
|
|
|
import 'package:aku_new_community/model/community/board_model.dart';
|
|
|
|
import 'package:aku_new_community/model/community/swiper_model.dart';
|
|
|
|
import 'package:aku_new_community/model/community/swiper_model.dart';
|
|
|
|
import 'package:aku_new_community/pages/home/widget/animate_app_bar.dart';
|
|
|
|
|
|
|
|
import 'package:aku_new_community/pages/message_center_page/message_center_page.dart';
|
|
|
|
import 'package:aku_new_community/pages/message_center_page/message_center_page.dart';
|
|
|
|
import 'package:aku_new_community/pages/one_alarm/widget/alarm_page.dart';
|
|
|
|
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/pages/visitor_access_page/visitor_access_page.dart';
|
|
|
@ -27,18 +25,16 @@ 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/others/user_tool.dart';
|
|
|
|
import 'package:badges/badges.dart';
|
|
|
|
import 'package:badges/badges.dart';
|
|
|
|
import 'package:bot_toast/bot_toast.dart';
|
|
|
|
import 'package:bot_toast/bot_toast.dart';
|
|
|
|
import 'package:flutter/cupertino.dart';
|
|
|
|
import 'package:cached_network_image/cached_network_image.dart';
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
|
|
|
|
import 'package:flutter/services.dart';
|
|
|
|
import 'package:flutter_easyrefresh/easy_refresh.dart';
|
|
|
|
import 'package:flutter_easyrefresh/easy_refresh.dart';
|
|
|
|
import 'package:flutter_screenutil/flutter_screenutil.dart';
|
|
|
|
|
|
|
|
import 'package:flutter_swiper_null_safety/flutter_swiper_null_safety.dart';
|
|
|
|
import 'package:flutter_swiper_null_safety/flutter_swiper_null_safety.dart';
|
|
|
|
import 'package:get/get.dart';
|
|
|
|
import 'package:get/get.dart';
|
|
|
|
import 'package:jpush_flutter/jpush_flutter.dart';
|
|
|
|
import 'package:jpush_flutter/jpush_flutter.dart';
|
|
|
|
|
|
|
|
import 'package:palette_generator/palette_generator.dart';
|
|
|
|
import 'package:power_logger/power_logger.dart';
|
|
|
|
import 'package:power_logger/power_logger.dart';
|
|
|
|
import 'package:provider/provider.dart';
|
|
|
|
import 'package:provider/provider.dart';
|
|
|
|
import 'package:velocity_x/velocity_x.dart';
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import 'widget/home_search.dart';
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class HomePage extends StatefulWidget {
|
|
|
|
class HomePage extends StatefulWidget {
|
|
|
|
HomePage({Key? key}) : super(key: key);
|
|
|
|
HomePage({Key? key}) : super(key: key);
|
|
|
@ -66,6 +62,9 @@ class _HomePageState extends State<HomePage>
|
|
|
|
List<ActivityItemModel> _activityItemModels = [];
|
|
|
|
List<ActivityItemModel> _activityItemModels = [];
|
|
|
|
List<BoardItemModel> _boardItemModels = [];
|
|
|
|
List<BoardItemModel> _boardItemModels = [];
|
|
|
|
List<SwiperModel> _swiperModels = [];
|
|
|
|
List<SwiperModel> _swiperModels = [];
|
|
|
|
|
|
|
|
SwiperController _swiperController = SwiperController();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ValueNotifier<Color> _barColor = ValueNotifier(Colors.transparent);
|
|
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
@override
|
|
|
|
void initState() {
|
|
|
|
void initState() {
|
|
|
@ -81,12 +80,15 @@ class _HomePageState extends State<HomePage>
|
|
|
|
}
|
|
|
|
}
|
|
|
|
_scrollController = ScrollController();
|
|
|
|
_scrollController = ScrollController();
|
|
|
|
_refreshController = EasyRefreshController();
|
|
|
|
_refreshController = EasyRefreshController();
|
|
|
|
|
|
|
|
SystemChrome.setSystemUIOverlayStyle(
|
|
|
|
|
|
|
|
SystemUiOverlayStyle(statusBarColor: Colors.transparent));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
@override
|
|
|
|
void dispose() {
|
|
|
|
void dispose() {
|
|
|
|
_refreshController.dispose();
|
|
|
|
_refreshController.dispose();
|
|
|
|
_scrollController?.dispose();
|
|
|
|
_scrollController?.dispose();
|
|
|
|
|
|
|
|
_swiperController.dispose();
|
|
|
|
super.dispose();
|
|
|
|
super.dispose();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -97,11 +99,51 @@ class _HomePageState extends State<HomePage>
|
|
|
|
commentCount = appProvider.messageCenterModel.commentCount ?? 0;
|
|
|
|
commentCount = appProvider.messageCenterModel.commentCount ?? 0;
|
|
|
|
sysCount = appProvider.messageCenterModel.sysCount ?? 0;
|
|
|
|
sysCount = appProvider.messageCenterModel.sysCount ?? 0;
|
|
|
|
sum = commentCount + sysCount;
|
|
|
|
sum = commentCount + sysCount;
|
|
|
|
return Scaffold(
|
|
|
|
var head = ValueListenableBuilder(
|
|
|
|
extendBodyBehindAppBar: true,
|
|
|
|
valueListenable: _barColor,
|
|
|
|
appBar: AnimateAppBar(
|
|
|
|
builder: (context, Color color, child) {
|
|
|
|
scrollController: _scrollController,
|
|
|
|
return Container(
|
|
|
|
actions: [
|
|
|
|
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,
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
Spacer(),
|
|
|
|
GestureDetector(
|
|
|
|
GestureDetector(
|
|
|
|
onTap: () {
|
|
|
|
onTap: () {
|
|
|
|
Get.to(() => BeeSearch());
|
|
|
|
Get.to(() => BeeSearch());
|
|
|
@ -134,27 +176,23 @@ class _HomePageState extends State<HomePage>
|
|
|
|
height: 40.w, width: 40.w),
|
|
|
|
height: 40.w, width: 40.w),
|
|
|
|
)),
|
|
|
|
)),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
],
|
|
|
|
]),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
// floatingActionButton: FloatingActionButton(
|
|
|
|
);
|
|
|
|
//
|
|
|
|
return AnnotatedRegion<SystemUiOverlayStyle>(
|
|
|
|
// child: Container(
|
|
|
|
value: SystemUiOverlayStyle.dark,
|
|
|
|
// decoration: BoxDecoration(
|
|
|
|
child: Scaffold(
|
|
|
|
// image: DecorationImage(
|
|
|
|
extendBody: true,
|
|
|
|
// fit: BoxFit.fill,
|
|
|
|
extendBodyBehindAppBar: true,
|
|
|
|
// image:
|
|
|
|
|
|
|
|
// AssetImage(R.ASSETS_ICONS_ICON_MAIN_OPEN_PNG),)
|
|
|
|
|
|
|
|
// ),
|
|
|
|
|
|
|
|
// ),
|
|
|
|
|
|
|
|
// onPressed: (){
|
|
|
|
|
|
|
|
// print('FloatingActionButton');
|
|
|
|
|
|
|
|
// },
|
|
|
|
|
|
|
|
// ),
|
|
|
|
|
|
|
|
body: Stack(
|
|
|
|
body: Stack(
|
|
|
|
children: [
|
|
|
|
children: [
|
|
|
|
EasyRefresh(
|
|
|
|
Column(
|
|
|
|
|
|
|
|
children: [
|
|
|
|
|
|
|
|
head,
|
|
|
|
|
|
|
|
Flexible(
|
|
|
|
|
|
|
|
child: EasyRefresh(
|
|
|
|
controller: _refreshController,
|
|
|
|
controller: _refreshController,
|
|
|
|
header: MaterialHeader(),
|
|
|
|
header: BeeBallPauseHeader(bgColor: _barColor),
|
|
|
|
firstRefresh: true,
|
|
|
|
firstRefresh: true,
|
|
|
|
onRefresh: () async {
|
|
|
|
onRefresh: () async {
|
|
|
|
//_activityItemModel = await CommunityFunc.activity();
|
|
|
|
//_activityItemModel = await CommunityFunc.activity();
|
|
|
@ -171,12 +209,11 @@ class _HomePageState extends State<HomePage>
|
|
|
|
child: Column(
|
|
|
|
child: Column(
|
|
|
|
mainAxisSize: MainAxisSize.min,
|
|
|
|
mainAxisSize: MainAxisSize.min,
|
|
|
|
children: [
|
|
|
|
children: [
|
|
|
|
HomeSearch(),
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
HomeSwiper(), //要做点击事件
|
|
|
|
HomeSwiper(), //要做点击事件
|
|
|
|
// SizedBox(height: 100.w),
|
|
|
|
// SizedBox(height: 100.w),
|
|
|
|
Container(
|
|
|
|
Container(
|
|
|
|
padding: EdgeInsets.only(top: 24.w, bottom: 32.w),
|
|
|
|
padding:
|
|
|
|
|
|
|
|
EdgeInsets.only(top: 24.w, bottom: 32.w),
|
|
|
|
child: getFunction(), //ApplicationView(),
|
|
|
|
child: getFunction(), //ApplicationView(),
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
color: Colors.white,
|
|
|
|
color: Colors.white,
|
|
|
@ -198,11 +235,12 @@ class _HomePageState extends State<HomePage>
|
|
|
|
SliverToBoxAdapter(
|
|
|
|
SliverToBoxAdapter(
|
|
|
|
child: Container(
|
|
|
|
child: Container(
|
|
|
|
height: 40,
|
|
|
|
height: 40,
|
|
|
|
margin:
|
|
|
|
margin: EdgeInsets.only(
|
|
|
|
EdgeInsets.only(left: 32.w, right: 32.w, top: 24.w),
|
|
|
|
left: 32.w, right: 32.w, top: 24.w),
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
color: Colors.white,
|
|
|
|
color: Colors.white,
|
|
|
|
borderRadius: BorderRadius.all(Radius.circular(8)),
|
|
|
|
borderRadius:
|
|
|
|
|
|
|
|
BorderRadius.all(Radius.circular(8)),
|
|
|
|
boxShadow: const <BoxShadow>[
|
|
|
|
boxShadow: const <BoxShadow>[
|
|
|
|
BoxShadow(
|
|
|
|
BoxShadow(
|
|
|
|
color: Color(0x14000000),
|
|
|
|
color: Color(0x14000000),
|
|
|
@ -219,16 +257,19 @@ class _HomePageState extends State<HomePage>
|
|
|
|
GestureDetector(
|
|
|
|
GestureDetector(
|
|
|
|
child: Container(
|
|
|
|
child: Container(
|
|
|
|
margin: EdgeInsets.only(top: 24.w),
|
|
|
|
margin: EdgeInsets.only(top: 24.w),
|
|
|
|
padding: EdgeInsets.only(left: 32.w, top: 24.w),
|
|
|
|
padding:
|
|
|
|
|
|
|
|
EdgeInsets.only(left: 32.w, top: 24.w),
|
|
|
|
width: 140,
|
|
|
|
width: 140,
|
|
|
|
height: 150,
|
|
|
|
height: 150,
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
image: DecorationImage(
|
|
|
|
image: DecorationImage(
|
|
|
|
fit: BoxFit.fill,
|
|
|
|
fit: BoxFit.fill,
|
|
|
|
image: AssetImage(R.ASSETS_IMAGES_CARD_YELLOW_PNG),
|
|
|
|
image: AssetImage(
|
|
|
|
|
|
|
|
R.ASSETS_IMAGES_CARD_YELLOW_PNG),
|
|
|
|
)),
|
|
|
|
)),
|
|
|
|
child: Column(
|
|
|
|
child: Column(
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
|
|
crossAxisAlignment:
|
|
|
|
|
|
|
|
CrossAxisAlignment.start,
|
|
|
|
children: [
|
|
|
|
children: [
|
|
|
|
Text(
|
|
|
|
Text(
|
|
|
|
'访客邀请',
|
|
|
|
'访客邀请',
|
|
|
@ -278,11 +319,12 @@ class _HomePageState extends State<HomePage>
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
image: DecorationImage(
|
|
|
|
image: DecorationImage(
|
|
|
|
fit: BoxFit.fill,
|
|
|
|
fit: BoxFit.fill,
|
|
|
|
image:
|
|
|
|
image: AssetImage(
|
|
|
|
AssetImage(R.ASSETS_IMAGES_CARD_PINK_PNG),
|
|
|
|
R.ASSETS_IMAGES_CARD_PINK_PNG),
|
|
|
|
)),
|
|
|
|
)),
|
|
|
|
child: Row(
|
|
|
|
child: Row(
|
|
|
|
mainAxisAlignment: MainAxisAlignment.start,
|
|
|
|
mainAxisAlignment:
|
|
|
|
|
|
|
|
MainAxisAlignment.start,
|
|
|
|
children: [
|
|
|
|
children: [
|
|
|
|
20.wb,
|
|
|
|
20.wb,
|
|
|
|
Column(
|
|
|
|
Column(
|
|
|
@ -295,7 +337,8 @@ class _HomePageState extends State<HomePage>
|
|
|
|
style: TextStyle(
|
|
|
|
style: TextStyle(
|
|
|
|
color: Color(0xD9000000),
|
|
|
|
color: Color(0xD9000000),
|
|
|
|
fontSize: 26.sp,
|
|
|
|
fontSize: 26.sp,
|
|
|
|
fontWeight: FontWeight.bold),
|
|
|
|
fontWeight:
|
|
|
|
|
|
|
|
FontWeight.bold),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
10.hb,
|
|
|
|
10.hb,
|
|
|
|
Text(
|
|
|
|
Text(
|
|
|
@ -329,11 +372,12 @@ class _HomePageState extends State<HomePage>
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
decoration: BoxDecoration(
|
|
|
|
image: DecorationImage(
|
|
|
|
image: DecorationImage(
|
|
|
|
fit: BoxFit.fill,
|
|
|
|
fit: BoxFit.fill,
|
|
|
|
image:
|
|
|
|
image: AssetImage(
|
|
|
|
AssetImage(R.ASSETS_IMAGES_CARD_BLUE_PNG),
|
|
|
|
R.ASSETS_IMAGES_CARD_BLUE_PNG),
|
|
|
|
)),
|
|
|
|
)),
|
|
|
|
child: Row(
|
|
|
|
child: Row(
|
|
|
|
mainAxisAlignment: MainAxisAlignment.start,
|
|
|
|
mainAxisAlignment:
|
|
|
|
|
|
|
|
MainAxisAlignment.start,
|
|
|
|
children: [
|
|
|
|
children: [
|
|
|
|
20.wb,
|
|
|
|
20.wb,
|
|
|
|
Column(
|
|
|
|
Column(
|
|
|
@ -346,7 +390,8 @@ class _HomePageState extends State<HomePage>
|
|
|
|
style: TextStyle(
|
|
|
|
style: TextStyle(
|
|
|
|
color: Color(0xD9000000),
|
|
|
|
color: Color(0xD9000000),
|
|
|
|
fontSize: 26.sp,
|
|
|
|
fontSize: 26.sp,
|
|
|
|
fontWeight: FontWeight.bold),
|
|
|
|
fontWeight:
|
|
|
|
|
|
|
|
FontWeight.bold),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
10.hb,
|
|
|
|
10.hb,
|
|
|
|
Text(
|
|
|
|
Text(
|
|
|
@ -369,7 +414,8 @@ class _HomePageState extends State<HomePage>
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
onTap: () {
|
|
|
|
onTap: () {
|
|
|
|
Get.to(AdvicePage(type: AdviceType.SUGGESTION));
|
|
|
|
Get.to(AdvicePage(
|
|
|
|
|
|
|
|
type: AdviceType.SUGGESTION));
|
|
|
|
},
|
|
|
|
},
|
|
|
|
)
|
|
|
|
)
|
|
|
|
],
|
|
|
|
],
|
|
|
@ -381,23 +427,6 @@ class _HomePageState extends State<HomePage>
|
|
|
|
SliverToBoxAdapter(
|
|
|
|
SliverToBoxAdapter(
|
|
|
|
child: Column(
|
|
|
|
child: Column(
|
|
|
|
children: [
|
|
|
|
children: [
|
|
|
|
// HomeTitle(
|
|
|
|
|
|
|
|
// title: '公共资讯',
|
|
|
|
|
|
|
|
// suffixTitle: '更多资讯',
|
|
|
|
|
|
|
|
// onTap: () async {
|
|
|
|
|
|
|
|
// final cancel = BotToast.showLoading();
|
|
|
|
|
|
|
|
// BaseModel model = await NetUtil().get(API.news.category);
|
|
|
|
|
|
|
|
// List<NewsCategoryModel>? category;
|
|
|
|
|
|
|
|
// if (model.status == true && model.data != null) {
|
|
|
|
|
|
|
|
// category = (model.data as List)
|
|
|
|
|
|
|
|
// .map((e) => NewsCategoryModel.fromJson(e))
|
|
|
|
|
|
|
|
// .toList();
|
|
|
|
|
|
|
|
// }
|
|
|
|
|
|
|
|
// cancel();
|
|
|
|
|
|
|
|
// Get.to(
|
|
|
|
|
|
|
|
// () => PublicInfomationPage(models: category ?? []));
|
|
|
|
|
|
|
|
// },
|
|
|
|
|
|
|
|
// ),
|
|
|
|
|
|
|
|
HomeTitle(
|
|
|
|
HomeTitle(
|
|
|
|
title: '社区活动',
|
|
|
|
title: '社区活动',
|
|
|
|
suffixTitle: '查看全部',
|
|
|
|
suffixTitle: '查看全部',
|
|
|
@ -422,7 +451,8 @@ class _HomePageState extends State<HomePage>
|
|
|
|
child: Builder(
|
|
|
|
child: Builder(
|
|
|
|
builder: (context) {
|
|
|
|
builder: (context) {
|
|
|
|
return ActivityCard(
|
|
|
|
return ActivityCard(
|
|
|
|
model: _activityItemModels[index]);
|
|
|
|
model: _activityItemModels[
|
|
|
|
|
|
|
|
index]);
|
|
|
|
},
|
|
|
|
},
|
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
);
|
|
|
@ -437,9 +467,13 @@ class _HomePageState extends State<HomePage>
|
|
|
|
],
|
|
|
|
],
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
],
|
|
|
|
|
|
|
|
),
|
|
|
|
OverlayLivingBtnWidget()
|
|
|
|
OverlayLivingBtnWidget()
|
|
|
|
],
|
|
|
|
],
|
|
|
|
),
|
|
|
|
),
|
|
|
|
|
|
|
|
),
|
|
|
|
);
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -447,10 +481,25 @@ class _HomePageState extends State<HomePage>
|
|
|
|
return Container(
|
|
|
|
return Container(
|
|
|
|
width: double.infinity,
|
|
|
|
width: double.infinity,
|
|
|
|
height: 320.w,
|
|
|
|
height: 320.w,
|
|
|
|
|
|
|
|
decoration:
|
|
|
|
|
|
|
|
BoxDecoration(border: Border.all(width: 0, color: _barColor.value)),
|
|
|
|
child: AspectRatio(
|
|
|
|
child: AspectRatio(
|
|
|
|
aspectRatio: 375 / 160,
|
|
|
|
aspectRatio: 375 / 160,
|
|
|
|
child: Swiper(
|
|
|
|
child: Swiper(
|
|
|
|
key: UniqueKey(),
|
|
|
|
key: UniqueKey(),
|
|
|
|
|
|
|
|
onIndexChanged: (index) async {
|
|
|
|
|
|
|
|
if (_swiperModels.isNotEmpty) {
|
|
|
|
|
|
|
|
var color = await PaletteGenerator.fromImageProvider(
|
|
|
|
|
|
|
|
CachedNetworkImageProvider(
|
|
|
|
|
|
|
|
API.image(
|
|
|
|
|
|
|
|
ImgModel.first(_swiperModels[index].voResourcesImgList)),
|
|
|
|
|
|
|
|
));
|
|
|
|
|
|
|
|
_barColor.value =
|
|
|
|
|
|
|
|
color.dominantColor?.color ?? Colors.transparent;
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
_barColor.value = Colors.transparent;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
itemBuilder: (BuildContext context, int index) {
|
|
|
|
itemBuilder: (BuildContext context, int index) {
|
|
|
|
return getSwiperImage(_swiperModels[index]);
|
|
|
|
return getSwiperImage(_swiperModels[index]);
|
|
|
|
},
|
|
|
|
},
|
|
|
@ -562,3 +611,62 @@ class _HomePageState extends State<HomePage>
|
|
|
|
@override
|
|
|
|
@override
|
|
|
|
bool get wantKeepAlive => true;
|
|
|
|
bool get wantKeepAlive => true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class BeeBallPauseHeader extends Header {
|
|
|
|
|
|
|
|
/// Key
|
|
|
|
|
|
|
|
final Key? key;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
final ValueNotifier<Color> bgColor;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
final LinkHeaderNotifier linkNotifier = LinkHeaderNotifier();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BeeBallPauseHeader({
|
|
|
|
|
|
|
|
this.key,
|
|
|
|
|
|
|
|
required this.bgColor,
|
|
|
|
|
|
|
|
bool enableHapticFeedback = true,
|
|
|
|
|
|
|
|
bool enableInfiniteRefresh = false,
|
|
|
|
|
|
|
|
}) : super(
|
|
|
|
|
|
|
|
extent: 70.0,
|
|
|
|
|
|
|
|
triggerDistance: 70.0,
|
|
|
|
|
|
|
|
float: false,
|
|
|
|
|
|
|
|
enableHapticFeedback: enableHapticFeedback,
|
|
|
|
|
|
|
|
enableInfiniteRefresh: enableInfiniteRefresh,
|
|
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
|
|
|
Widget contentBuilder(
|
|
|
|
|
|
|
|
BuildContext context,
|
|
|
|
|
|
|
|
RefreshMode refreshState,
|
|
|
|
|
|
|
|
double pulledExtent,
|
|
|
|
|
|
|
|
double refreshTriggerPullDistance,
|
|
|
|
|
|
|
|
double refreshIndicatorExtent,
|
|
|
|
|
|
|
|
AxisDirection axisDirection,
|
|
|
|
|
|
|
|
bool float,
|
|
|
|
|
|
|
|
Duration? completeDuration,
|
|
|
|
|
|
|
|
bool enableInfiniteRefresh,
|
|
|
|
|
|
|
|
bool success,
|
|
|
|
|
|
|
|
bool noMore) {
|
|
|
|
|
|
|
|
linkNotifier.contentBuilder(
|
|
|
|
|
|
|
|
context,
|
|
|
|
|
|
|
|
refreshState,
|
|
|
|
|
|
|
|
pulledExtent,
|
|
|
|
|
|
|
|
refreshTriggerPullDistance,
|
|
|
|
|
|
|
|
refreshIndicatorExtent,
|
|
|
|
|
|
|
|
axisDirection,
|
|
|
|
|
|
|
|
float,
|
|
|
|
|
|
|
|
completeDuration,
|
|
|
|
|
|
|
|
enableInfiniteRefresh,
|
|
|
|
|
|
|
|
success,
|
|
|
|
|
|
|
|
noMore);
|
|
|
|
|
|
|
|
return ValueListenableBuilder(
|
|
|
|
|
|
|
|
valueListenable: bgColor,
|
|
|
|
|
|
|
|
builder: (context, Color color, child) {
|
|
|
|
|
|
|
|
return BallPulseHeaderWidget(
|
|
|
|
|
|
|
|
key: key,
|
|
|
|
|
|
|
|
color: color.withBlue(128),
|
|
|
|
|
|
|
|
backgroundColor: color,
|
|
|
|
|
|
|
|
linkNotifier: linkNotifier,
|
|
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|