You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

277 lines
9.5 KiB

import 'dart:convert';
import 'package:dio/dio.dart';
import 'package:flutter/material.dart';
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
import 'package:huixiang/community/community_view/community_dynamic.dart';
import 'package:huixiang/data/article.dart';
import 'package:huixiang/data/base_data.dart';
import 'package:huixiang/data/comunity_comment.dart';
import 'package:huixiang/data/page.dart';
import 'package:huixiang/retrofit/retrofit_api.dart';
import 'package:huixiang/utils/shared_preference.dart';
import 'package:huixiang/view_widget/classic_header.dart';
import 'package:huixiang/view_widget/my_footer.dart';
import 'package:huixiang/view_widget/no_data_view.dart';
import 'package:pull_to_refresh/pull_to_refresh.dart';
import 'package:flutter_screenutil/flutter_screenutil.dart';
import 'package:shared_preferences/shared_preferences.dart';
import '../utils/flutter_utils.dart';
import '../utils/font_weight.dart';
class CommunityChildPage extends StatefulWidget {
final String typeStr;
final Function onScroll;
final Function toRelease;
CommunityChildPage(Key key, this.typeStr, this.onScroll, this.toRelease)
: super(key: key);
@override
State<StatefulWidget> createState() {
return CommunityChildPageState();
}
}
class CommunityChildPageState extends State<CommunityChildPage>
with AutomaticKeepAliveClientMixin {
RefreshController refreshController = RefreshController();
ApiService? apiService;
int pageNum = 1;
String? userId;
bool isLoadMore = false;
bool isRefresh = true;
bool isLoadingData = false;
ScrollController sc = ScrollController();
List<Article> articles = [];
int _currentIndex = 0;
@override
void initState() {
super.initState();
sc.addListener(() {
widget.onScroll();
if (sc.offset >= 500) {
_currentIndex =1;
} else if(sc.offset <= 500) {
_currentIndex = 0;
}
});
onRefresh();
}
onRefresh() async {
setState(() {});
}
///动态列表
Future queryCommunity({String? searchKey}) async {
if (!isRefresh) {
isRefresh = true;
return;
}
if (isLoadingData) {
return;
}
isLoadingData = true;
userId = SharedInstance.instance.userId;
apiService = ApiService(Dio(),
context: context,
token: SharedInstance.instance.token,
showLoading: false,
);
if (isLoadMore) {
pageNum += 1;
isLoadMore = false;
} else if (searchKey == null) pageNum = 1;
BaseData<PageInfo<ComunityComment>>? baseData = await apiService?.trendList({
"mid": "",
"onlyFollow": widget.typeStr == "关注" ? true : false,
"onlyMe": false,
"pageNum": searchKey == null ? pageNum : 1,
"pageSize": 10,
"searchKey": searchKey ?? ""
}).catchError((error) {
SmartDialog.showToast(
AppUtils.dioErrorTypeToString(error.type),
alignment: Alignment.center,
);
refreshController.refreshFailed();
return BaseData<PageInfo<ComunityComment>>()..isSuccess = false;
});
refreshController.refreshCompleted();
if (baseData?.isSuccess ?? false) {
if (baseData?.data?.list?.isNotEmpty ?? false) {
if (searchKey != null) {
articles.forEach((element) {
if (element.id == searchKey) {
element.content = jsonEncode(baseData?.data?.list?[0].subjectInfo);
element.mainTitle = baseData?.data?.list?[0].subject;
element.followed = baseData?.data?.list?[0].selfFollow;
element.liked = baseData?.data?.list?[0].selfLike;
element.authorHeadImg = baseData?.data?.list?[0].memberInfo?.avatar;
element.authorName = baseData?.data?.list?[0].memberInfo?.nickname;
element.location = baseData?.data?.list?[0].location;
element.createTime = baseData?.data?.list?[0].createTime;
element.author = baseData?.data?.list?[0].memberInfo?.mid;
element.viewers = baseData?.data?.list?[0].viewers;
element.likes = baseData?.data?.list?[0].likes;
element.comments = baseData?.data?.list?[0].comments;
this.isRefresh = false;
}
});
setState(() {});
} else {
if (pageNum == 1) {
articles.clear();
}
baseData!.data!.list!.forEach((element) {
var article = Article();
article.id = element.id;
article.content = jsonEncode(element.subjectInfo);
article.mainTitle = element.subject;
article.followed = element.selfFollow;
article.liked = element.selfLike;
article.authorHeadImg = element.memberInfo?.avatar;
article.authorName = element.memberInfo?.nickname;
article.location = element.location;
article.createTime = element.createTime;
article.author = element.memberInfo?.mid;
article.viewers = element.viewers;
article.likes = element.likes;
article.comments = element.comments;
articles.add(article);
});
if ((int.tryParse(baseData.data!.total ?? "0") ?? 0) < (pageNum * 10)) {
refreshController.loadNoData();
}
}
}
}
isLoadingData = false;
}
@override
Widget build(BuildContext context) {
super.build(context);
return FutureBuilder(
future: queryCommunity(),
builder: (context, position) {
return Stack(
alignment: Alignment.bottomRight,
children: [
SmartRefresher(
controller: refreshController,
enablePullDown: true,
enablePullUp: articles.isNotEmpty,
physics: BouncingScrollPhysics(),
header: MyHeader(),
footer: CustomFooter(
builder: (context, mode) {
return MyFooter(mode);
},
),
onRefresh: onRefresh,
onLoading: () {
isLoadMore = true;
setState(() {});
},
child: (articles.isEmpty)
? NoDataView(
src: "assets/image/guan_zhu.webp",
isShowBtn: false,
text: "目前暂无添加关注,可在推荐中关注自己喜欢的人哦~",
fontSize: 16.sp,
margin: EdgeInsets.only(
top: 120.h, left: 60.w, right: 60.w,
),
)
: ListView.builder(
controller: sc,
shrinkWrap: true,
itemBuilder: (context, position) {
return InkWell(
child: CommunityDynamic(
articles[position],
0,
userId: userId,
isList: true,
exitFull: () {
queryCommunity(searchKey: articles[position].id);
},
removalDynamic: () {
queryCommunity().then((value) => setState(() {}));
},
),
onTap: () {
Navigator.of(context).pushNamed(
'/router/community_details',
arguments: {
"businessId": articles[position].id,
"userId": userId,
},
).then((value) {
queryCommunity(searchKey: articles[position].id);
});
// setState(() {});
},
);
},
itemCount: articles.length,
),
),
GestureDetector(
onTap: () {
widget.toRelease();
},
child: Container(
margin: EdgeInsets.only(bottom: 31, right: 14),
child: Image.asset(
"assets/image/fa_bu.webp",
width: 55,
height: 55,
),
),
),
if(_currentIndex == 1)
GestureDetector(
onTap: () {
sc.jumpTo(0);
setState(() {});
},
child: Container(
margin: EdgeInsets.only(bottom:120.h, right: 14.w),
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(100),
color: Colors.white,
),
height:48,
width: 48,
child: Column(
crossAxisAlignment: CrossAxisAlignment.center,
children: [
Icon(Icons.arrow_upward,size: 16,color: Color(0xFF808080),),
Text(
"顶部",
textAlign: TextAlign.center,
style: TextStyle(
color: Color(0xFF808080),
fontSize: 14.sp,
fontWeight: MyFontWeight.regular,
),
),
],
),
),
),
],
);
},
);
}
@override
bool get wantKeepAlive => true;
}