mirror of
https://github.com/HChaZZY/PiliPlus.git
synced 2025-12-06 09:13:48 +08:00
@@ -42,7 +42,7 @@ class DynamicsController extends GetxController
|
||||
DynamicsTabController? get controller {
|
||||
try {
|
||||
return Get.find<DynamicsTabController>(
|
||||
tag: tabsConfig[tabController.index]['tag']);
|
||||
tag: DynamicsTabType.values[tabController.index].name);
|
||||
} catch (_) {
|
||||
return null;
|
||||
}
|
||||
@@ -58,13 +58,14 @@ class DynamicsController extends GetxController
|
||||
isLogin.value = userInfo != null;
|
||||
|
||||
tabController = TabController(
|
||||
length: tabsConfig.length,
|
||||
length: DynamicsTabType.values.length,
|
||||
vsync: this,
|
||||
initialIndex: GStorage.setting
|
||||
.get(SettingBoxKey.defaultDynamicType, defaultValue: 0),
|
||||
);
|
||||
tabsPageList =
|
||||
tabsConfig.map((e) => DynamicsTabPage(dynamicsType: e['tag'])).toList();
|
||||
tabsPageList = DynamicsTabType.values
|
||||
.map((e) => DynamicsTabPage(dynamicsType: e))
|
||||
.toList();
|
||||
|
||||
queryFollowUp();
|
||||
}
|
||||
|
||||
@@ -1,9 +1,9 @@
|
||||
import 'package:PiliPlus/http/dynamics.dart';
|
||||
import 'package:PiliPlus/http/loading_state.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/pages/common/common_list_controller.dart';
|
||||
import 'package:PiliPlus/pages/dynamics/controller.dart';
|
||||
import 'package:PiliPlus/pages/main/controller.dart';
|
||||
import 'package:PiliPlus/utils/extension.dart';
|
||||
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
|
||||
@@ -12,11 +12,10 @@ import 'package:get/get.dart';
|
||||
class DynamicsTabController
|
||||
extends CommonListController<DynamicsDataModel, DynamicItemModel> {
|
||||
DynamicsTabController({required this.dynamicsType});
|
||||
final String dynamicsType;
|
||||
final DynamicsTabType dynamicsType;
|
||||
String offset = '';
|
||||
int mid = -1;
|
||||
int? mid;
|
||||
late final MainController mainController = Get.find<MainController>();
|
||||
DynamicsController dynamicsController = Get.find<DynamicsController>();
|
||||
|
||||
@override
|
||||
void onInit() {
|
||||
@@ -26,11 +25,10 @@ class DynamicsTabController
|
||||
|
||||
@override
|
||||
Future<void> onRefresh() {
|
||||
if (dynamicsType == 'all') {
|
||||
if (dynamicsType == DynamicsTabType.all) {
|
||||
mainController.setCount();
|
||||
}
|
||||
offset = '';
|
||||
dynamicsController.queryFollowUp();
|
||||
return super.onRefresh();
|
||||
}
|
||||
|
||||
@@ -49,9 +47,9 @@ class DynamicsTabController
|
||||
@override
|
||||
Future<LoadingState<DynamicsDataModel>> customGetData() =>
|
||||
DynamicsHttp.followDynamic(
|
||||
type: dynamicsType == "up" ? "all" : dynamicsType,
|
||||
type: dynamicsType,
|
||||
offset: offset,
|
||||
mid: dynamicsType == "up" ? mid : -1,
|
||||
mid: mid,
|
||||
);
|
||||
|
||||
Future<void> onRemove(dynamic dynamicId) async {
|
||||
|
||||
@@ -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/refresh_indicator.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/pages/common/common_page.dart';
|
||||
import 'package:PiliPlus/pages/dynamics/controller.dart';
|
||||
@@ -20,7 +21,7 @@ import 'package:waterfall_flow/waterfall_flow.dart';
|
||||
class DynamicsTabPage extends CommonPage {
|
||||
const DynamicsTabPage({super.key, required this.dynamicsType});
|
||||
|
||||
final String dynamicsType;
|
||||
final DynamicsTabType dynamicsType;
|
||||
|
||||
@override
|
||||
State<DynamicsTabPage> createState() => _DynamicsTabPageState();
|
||||
@@ -73,7 +74,7 @@ class _DynamicsTabPageState
|
||||
late DynamicsTabController controller = Get.put(
|
||||
DynamicsTabController(dynamicsType: widget.dynamicsType)
|
||||
..mid = dynamicsController.mid.value,
|
||||
tag: widget.dynamicsType,
|
||||
tag: widget.dynamicsType.name,
|
||||
);
|
||||
|
||||
@override
|
||||
@@ -91,7 +92,7 @@ class _DynamicsTabPageState
|
||||
@override
|
||||
void initState() {
|
||||
super.initState();
|
||||
if (widget.dynamicsType == 'up') {
|
||||
if (widget.dynamicsType == DynamicsTabType.up) {
|
||||
_listener = dynamicsController.mid.listen((mid) {
|
||||
if (mid != -1) {
|
||||
controller
|
||||
@@ -115,7 +116,10 @@ class _DynamicsTabPageState
|
||||
Widget build(BuildContext context) {
|
||||
super.build(context);
|
||||
return refreshIndicator(
|
||||
onRefresh: controller.onRefresh,
|
||||
onRefresh: () {
|
||||
dynamicsController.queryFollowUp();
|
||||
return controller.onRefresh();
|
||||
},
|
||||
child: CustomScrollView(
|
||||
physics: const AlwaysScrollableScrollPhysics(),
|
||||
controller: controller.scrollController,
|
||||
|
||||
Reference in New Issue
Block a user