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/retrofit/data/article.dart'; import 'package:huixiang/retrofit/data/base_data.dart'; import 'package:huixiang/retrofit/data/comunity_comment.dart'; import 'package:huixiang/retrofit/data/page.dart'; import 'package:huixiang/retrofit/retrofit_api.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:shared_preferences/shared_preferences.dart'; import 'package:flutter_screenutil/flutter_screenutil.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 createState() { return CommunityChildPageState(); } } class CommunityChildPageState extends State 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
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(() {}); } ///动态列表 queryCommunity(String searchKey) async { if (!isRefresh) { isRefresh = true; return; } if (isLoadingData) { return; } isLoadingData = true; if (apiService == null) { SharedPreferences value = await SharedPreferences.getInstance(); userId = value.getString('userId'); apiService = ApiService(Dio(), context: context, token: value.getString("token"), showLoading: false); } if (isLoadMore) { pageNum += 1; isLoadMore = false; } else if (searchKey == null) pageNum = 1; BaseData> 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); if (searchKey == null) { refreshController.refreshFailed(); refreshController.loadFailed(); } }); if (searchKey == null) { refreshController.refreshCompleted(); refreshController.loadComplete(); } if (baseData.isSuccess) { if (searchKey != null) { if (baseData?.data?.list != null && baseData.data.list.isNotEmpty) 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); }); // comments.sort((a,b)=>b.createTime.compareTo(a.createTime)); // print("comments: ${comments.length}"); if (int.tryParse(baseData.data.total) < (pageNum * 10)) { refreshController.loadNoData(); } } } isLoadingData = false; } @override Widget build(BuildContext context) { super.build(context); return FutureBuilder( future: queryCommunity(null), builder: (context, position) { return Stack( alignment: Alignment.bottomRight, children: [ SmartRefresher( controller: refreshController, enablePullDown: true, enablePullUp: (articles == null || articles.length == 0) ? false:true, physics: BouncingScrollPhysics(), header: MyHeader(), footer: CustomFooter( builder: (context, mode) { return MyFooter(mode); }, ), onRefresh: onRefresh, onLoading: () { isLoadMore = true; setState(() {}); }, child: (articles == null || articles.length == 0) ? 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: () { // setState(() { // onRefresh(); // }); queryCommunity(articles[position].id); }, ), onTap: () { Navigator.of(context).pushNamed( '/router/community_details', arguments: { "businessId": articles[position].id, "userId": userId, }, ).then((value) { // onRefresh(); // setState(() {}); queryCommunity(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; }