Signed-off-by: bggRGjQaUbCoE <githubaccount56556@proton.me>
This commit is contained in:
bggRGjQaUbCoE
2025-05-07 22:35:48 +08:00
parent fb22e5ab66
commit b28882cff5
6 changed files with 32 additions and 62 deletions

View File

@@ -2,6 +2,7 @@ import 'package:PiliPlus/http/api.dart';
import 'package:PiliPlus/http/constants.dart'; import 'package:PiliPlus/http/constants.dart';
import 'package:PiliPlus/http/init.dart'; import 'package:PiliPlus/http/init.dart';
import 'package:PiliPlus/http/loading_state.dart'; import 'package:PiliPlus/http/loading_state.dart';
import 'package:PiliPlus/models/common/dynamic/dynamics_type.dart';
import 'package:PiliPlus/models/dynamics/dyn_topic_feed/topic_card_list.dart'; import 'package:PiliPlus/models/dynamics/dyn_topic_feed/topic_card_list.dart';
import 'package:PiliPlus/models/dynamics/dyn_topic_top/top_details.dart'; import 'package:PiliPlus/models/dynamics/dyn_topic_top/top_details.dart';
import 'package:PiliPlus/models/dynamics/result.dart'; import 'package:PiliPlus/models/dynamics/result.dart';
@@ -15,20 +16,20 @@ import 'package:dio/dio.dart';
class DynamicsHttp { class DynamicsHttp {
static Future<LoadingState<DynamicsDataModel>> followDynamic({ static Future<LoadingState<DynamicsDataModel>> followDynamic({
String? type, DynamicsTabType type = DynamicsTabType.all,
String? offset, String? offset,
int? mid, int? mid,
}) async { }) async {
Map<String, dynamic> data = { Map<String, dynamic> data = {
'type': type ?? 'all', if (type == DynamicsTabType.up)
'host_mid': mid
else ...{
'type': type.name,
'timezone_offset': '-480', 'timezone_offset': '-480',
},
'offset': offset, 'offset': offset,
'features': 'itemOpusStyle,listOnlyfans' 'features': 'itemOpusStyle,listOnlyfans',
}; };
if (mid != -1) {
data['host_mid'] = mid;
data.remove('timezone_offset');
}
var res = await Request().get(Api.followDynamic, queryParameters: data); var res = await Request().get(Api.followDynamic, queryParameters: data);
if (res.data['code'] == 0) { if (res.data['code'] == 0) {
try { try {

View File

@@ -10,36 +10,3 @@ extension DynamicsTabTypeExt on DynamicsTabType {
String get values => const ['all', 'video', 'pgc', 'article', 'up'][index]; String get values => const ['all', 'video', 'pgc', 'article', 'up'][index];
String get labels => const ['全部', '投稿', '番剧', '专栏', 'UP'][index]; String get labels => const ['全部', '投稿', '番剧', '专栏', 'UP'][index];
} }
const List tabsConfig = [
{
'tag': 'all',
'value': DynamicsTabType.all,
'label': '全部',
'enabled': true,
},
{
'tag': 'video',
'value': DynamicsTabType.video,
'label': '投稿',
'enabled': true,
},
{
'tag': 'pgc',
'value': DynamicsTabType.pgc,
'label': '番剧',
'enabled': true,
},
{
'tag': 'article',
'value': DynamicsTabType.article,
'label': '专栏',
'enabled': true,
},
{
'tag': 'up',
'value': DynamicsTabType.up,
'label': 'UP',
'enabled': true,
},
];

View File

@@ -42,7 +42,7 @@ class DynamicsController extends GetxController
DynamicsTabController? get controller { DynamicsTabController? get controller {
try { try {
return Get.find<DynamicsTabController>( return Get.find<DynamicsTabController>(
tag: tabsConfig[tabController.index]['tag']); tag: DynamicsTabType.values[tabController.index].name);
} catch (_) { } catch (_) {
return null; return null;
} }
@@ -58,13 +58,14 @@ class DynamicsController extends GetxController
isLogin.value = userInfo != null; isLogin.value = userInfo != null;
tabController = TabController( tabController = TabController(
length: tabsConfig.length, length: DynamicsTabType.values.length,
vsync: this, vsync: this,
initialIndex: GStorage.setting initialIndex: GStorage.setting
.get(SettingBoxKey.defaultDynamicType, defaultValue: 0), .get(SettingBoxKey.defaultDynamicType, defaultValue: 0),
); );
tabsPageList = tabsPageList = DynamicsTabType.values
tabsConfig.map((e) => DynamicsTabPage(dynamicsType: e['tag'])).toList(); .map((e) => DynamicsTabPage(dynamicsType: e))
.toList();
queryFollowUp(); queryFollowUp();
} }

View File

@@ -1,9 +1,9 @@
import 'package:PiliPlus/http/dynamics.dart'; import 'package:PiliPlus/http/dynamics.dart';
import 'package:PiliPlus/http/loading_state.dart'; import 'package:PiliPlus/http/loading_state.dart';
import 'package:PiliPlus/http/msg.dart'; import 'package:PiliPlus/http/msg.dart';
import 'package:PiliPlus/models/common/dynamic/dynamics_type.dart';
import 'package:PiliPlus/models/dynamics/result.dart'; import 'package:PiliPlus/models/dynamics/result.dart';
import 'package:PiliPlus/pages/common/common_list_controller.dart'; import 'package:PiliPlus/pages/common/common_list_controller.dart';
import 'package:PiliPlus/pages/dynamics/controller.dart';
import 'package:PiliPlus/pages/main/controller.dart'; import 'package:PiliPlus/pages/main/controller.dart';
import 'package:PiliPlus/utils/extension.dart'; import 'package:PiliPlus/utils/extension.dart';
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart'; import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
@@ -12,11 +12,10 @@ import 'package:get/get.dart';
class DynamicsTabController class DynamicsTabController
extends CommonListController<DynamicsDataModel, DynamicItemModel> { extends CommonListController<DynamicsDataModel, DynamicItemModel> {
DynamicsTabController({required this.dynamicsType}); DynamicsTabController({required this.dynamicsType});
final String dynamicsType; final DynamicsTabType dynamicsType;
String offset = ''; String offset = '';
int mid = -1; int? mid;
late final MainController mainController = Get.find<MainController>(); late final MainController mainController = Get.find<MainController>();
DynamicsController dynamicsController = Get.find<DynamicsController>();
@override @override
void onInit() { void onInit() {
@@ -26,11 +25,10 @@ class DynamicsTabController
@override @override
Future<void> onRefresh() { Future<void> onRefresh() {
if (dynamicsType == 'all') { if (dynamicsType == DynamicsTabType.all) {
mainController.setCount(); mainController.setCount();
} }
offset = ''; offset = '';
dynamicsController.queryFollowUp();
return super.onRefresh(); return super.onRefresh();
} }
@@ -49,9 +47,9 @@ class DynamicsTabController
@override @override
Future<LoadingState<DynamicsDataModel>> customGetData() => Future<LoadingState<DynamicsDataModel>> customGetData() =>
DynamicsHttp.followDynamic( DynamicsHttp.followDynamic(
type: dynamicsType == "up" ? "all" : dynamicsType, type: dynamicsType,
offset: offset, offset: offset,
mid: dynamicsType == "up" ? mid : -1, mid: mid,
); );
Future<void> onRemove(dynamic dynamicId) async { Future<void> onRemove(dynamic dynamicId) async {

View File

@@ -5,6 +5,7 @@ import 'package:PiliPlus/common/skeleton/dynamic_card.dart';
import 'package:PiliPlus/common/widgets/loading_widget/http_error.dart'; import 'package:PiliPlus/common/widgets/loading_widget/http_error.dart';
import 'package:PiliPlus/common/widgets/refresh_indicator.dart'; import 'package:PiliPlus/common/widgets/refresh_indicator.dart';
import 'package:PiliPlus/http/loading_state.dart'; import 'package:PiliPlus/http/loading_state.dart';
import 'package:PiliPlus/models/common/dynamic/dynamics_type.dart';
import 'package:PiliPlus/models/dynamics/result.dart'; import 'package:PiliPlus/models/dynamics/result.dart';
import 'package:PiliPlus/pages/common/common_page.dart'; import 'package:PiliPlus/pages/common/common_page.dart';
import 'package:PiliPlus/pages/dynamics/controller.dart'; import 'package:PiliPlus/pages/dynamics/controller.dart';
@@ -20,7 +21,7 @@ import 'package:waterfall_flow/waterfall_flow.dart';
class DynamicsTabPage extends CommonPage { class DynamicsTabPage extends CommonPage {
const DynamicsTabPage({super.key, required this.dynamicsType}); const DynamicsTabPage({super.key, required this.dynamicsType});
final String dynamicsType; final DynamicsTabType dynamicsType;
@override @override
State<DynamicsTabPage> createState() => _DynamicsTabPageState(); State<DynamicsTabPage> createState() => _DynamicsTabPageState();
@@ -73,7 +74,7 @@ class _DynamicsTabPageState
late DynamicsTabController controller = Get.put( late DynamicsTabController controller = Get.put(
DynamicsTabController(dynamicsType: widget.dynamicsType) DynamicsTabController(dynamicsType: widget.dynamicsType)
..mid = dynamicsController.mid.value, ..mid = dynamicsController.mid.value,
tag: widget.dynamicsType, tag: widget.dynamicsType.name,
); );
@override @override
@@ -91,7 +92,7 @@ class _DynamicsTabPageState
@override @override
void initState() { void initState() {
super.initState(); super.initState();
if (widget.dynamicsType == 'up') { if (widget.dynamicsType == DynamicsTabType.up) {
_listener = dynamicsController.mid.listen((mid) { _listener = dynamicsController.mid.listen((mid) {
if (mid != -1) { if (mid != -1) {
controller controller
@@ -115,7 +116,10 @@ class _DynamicsTabPageState
Widget build(BuildContext context) { Widget build(BuildContext context) {
super.build(context); super.build(context);
return refreshIndicator( return refreshIndicator(
onRefresh: controller.onRefresh, onRefresh: () {
dynamicsController.queryFollowUp();
return controller.onRefresh();
},
child: CustomScrollView( child: CustomScrollView(
physics: const AlwaysScrollableScrollPhysics(), physics: const AlwaysScrollableScrollPhysics(),
controller: controller.scrollController, controller: controller.scrollController,

View File

@@ -71,10 +71,9 @@ class LoginUtils {
..onRefresh(); ..onRefresh();
} catch (_) {} } catch (_) {}
for (int i = 0; i < tabsConfig.length; i++) { for (var item in DynamicsTabType.values) {
try { try {
Get.find<DynamicsTabController>(tag: tabsConfig[i]['tag']) Get.find<DynamicsTabController>(tag: item.name).onRefresh();
.onRefresh();
} catch (_) {} } catch (_) {}
} }
@@ -157,9 +156,9 @@ class LoginUtils {
..onRefresh(); ..onRefresh();
} catch (_) {} } catch (_) {}
for (int i = 0; i < tabsConfig.length; i++) { for (var item in DynamicsTabType.values) {
try { try {
Get.find<DynamicsTabController>(tag: tabsConfig[i]['tag']).onRefresh(); Get.find<DynamicsTabController>(tag: item.name).onRefresh();
} catch (_) {} } catch (_) {}
} }