mirror of
https://github.com/HChaZZY/PiliPlus.git
synced 2025-12-06 09:13:48 +08:00
@@ -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)
|
||||||
'timezone_offset': '-480',
|
'host_mid': mid
|
||||||
|
else ...{
|
||||||
|
'type': type.name,
|
||||||
|
'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 {
|
||||||
|
|||||||
@@ -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,
|
|
||||||
},
|
|
||||||
];
|
|
||||||
|
|||||||
@@ -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();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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 {
|
||||||
|
|||||||
@@ -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,
|
||||||
|
|||||||
@@ -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 (_) {}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user