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.
149 lines
4.6 KiB
149 lines
4.6 KiB
import 'dart:convert'; |
|
|
|
import 'package:flutter/material.dart'; |
|
import 'package:huixiang/community/community_view/community_dynamic.dart'; |
|
import 'package:flutter_screenutil/flutter_screenutil.dart'; |
|
import 'package:huixiang/generated/l10n.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/view_widget/classic_header.dart'; |
|
import 'package:huixiang/view_widget/my_appbar.dart'; |
|
import 'package:huixiang/view_widget/my_footer.dart'; |
|
import 'package:pull_to_refresh/pull_to_refresh.dart'; |
|
|
|
class ReleasePage extends StatefulWidget { |
|
@override |
|
State<StatefulWidget> createState() { |
|
return _ReleasePage(); |
|
} |
|
} |
|
|
|
class _ReleasePage extends State<ReleasePage> { |
|
RefreshController refreshController = RefreshController(); |
|
ApiService? apiService; |
|
int pageNum = 0; |
|
String? userId; |
|
|
|
List<Article> articles = []; |
|
|
|
@override |
|
void initState() { |
|
super.initState(); |
|
|
|
_onRefresh(); |
|
} |
|
|
|
_onRefresh() async { |
|
pageNum = 0; |
|
setState(() {}); |
|
} |
|
|
|
queryCommunity() async { |
|
pageNum += 1; |
|
BaseData<PageInfo<ComunityComment>>? baseData = await apiService?.trendList({ |
|
"mid":"", |
|
"onlyFollow": false, |
|
"onlyMe": true, |
|
"pageNum": pageNum, |
|
"pageSize": 10, |
|
"searchKey": "" |
|
}).catchError((error) { |
|
refreshController.refreshFailed(); |
|
refreshController.loadFailed(); |
|
return Future.value(null); |
|
}); |
|
|
|
refreshController.refreshCompleted(); |
|
refreshController.loadComplete(); |
|
if (baseData?.isSuccess ?? false) { |
|
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.authorHeadImg = element.memberInfo?.avatar; |
|
article.authorName = element.memberInfo?.nickname; |
|
article.createTime = element.createTime; |
|
article.author = element.memberInfo?.mid; |
|
article.viewers = element.viewers; |
|
article.likes = element.likes; |
|
article.comments = element.comments; |
|
articles.add(article); |
|
}); |
|
// print("comments: ${comments.length}"); |
|
if ((int.tryParse("${baseData?.data?.total}") ?? 0) < (pageNum * 10)) { |
|
refreshController.loadNoData(); |
|
} |
|
} |
|
} |
|
|
|
@override |
|
Widget build(BuildContext context) { |
|
return FutureBuilder( |
|
future: queryCommunity(), |
|
builder: (context, position) { |
|
return Scaffold( |
|
appBar: MyAppBar( |
|
background: Color(0xFFFFFFFF), |
|
leadingColor: Colors.black, |
|
title: S.of(context).dongtai, |
|
titleColor: Colors.black, |
|
titleSize: 18.sp, |
|
), |
|
body: SmartRefresher( |
|
controller: refreshController, |
|
enablePullDown: true, |
|
enablePullUp: true, |
|
physics: BouncingScrollPhysics(), |
|
header: MyHeader(), |
|
footer:CustomFooter( |
|
builder: (context, mode) { |
|
return MyFooter(mode); |
|
}, |
|
), |
|
onRefresh: _onRefresh, |
|
onLoading: () { |
|
setState(() {}); |
|
}, |
|
child: ListView.builder( |
|
physics: NeverScrollableScrollPhysics(), |
|
itemBuilder: (context, position) { |
|
return InkWell( |
|
child: CommunityDynamic( |
|
articles[position], |
|
1, |
|
exitFull: (){setState(() { |
|
_onRefresh(); |
|
});}, |
|
removalDynamic: () { |
|
setState(() { |
|
_onRefresh(); |
|
}); |
|
}, |
|
), |
|
onTap: () { |
|
Navigator.of(context).pushNamed( |
|
'/router/community_details', |
|
arguments: { |
|
"businessId": articles[position].id,"userId":userId, |
|
}, |
|
).then((value) { |
|
_onRefresh(); |
|
}); |
|
}, |
|
); |
|
}, |
|
itemCount: articles.length, |
|
)), |
|
); |
|
}, |
|
); |
|
} |
|
}
|
|
|