feat: custom def member tab

Signed-off-by: bggRGjQaUbCoE <githubaccount56556@proton.me>
This commit is contained in:
bggRGjQaUbCoE
2024-11-20 16:59:41 +08:00
parent 67fc1b7d08
commit c104df6cb8
4 changed files with 69 additions and 12 deletions

View File

@@ -10,6 +10,12 @@ import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
import 'package:get/get.dart'; import 'package:get/get.dart';
import 'package:share_plus/share_plus.dart'; import 'package:share_plus/share_plus.dart';
enum MemberTabType { none, home, dynamic, contribute, favorite, bangumi }
extension MemberTabTypeExt on MemberTabType {
String get title => ['默认', '首页', '动态', '投稿', '收藏', '番剧'][index];
}
class MemberControllerNew extends CommonController class MemberControllerNew extends CommonController
with GetTickerProviderStateMixin { with GetTickerProviderStateMixin {
MemberControllerNew({required this.mid}); MemberControllerNew({required this.mid});
@@ -47,12 +53,21 @@ class MemberControllerNew extends CommonController
tab2!.removeAt(0); tab2!.removeAt(0);
} }
if (tab2!.isNotEmpty) { if (tab2!.isNotEmpty) {
if (response.response.defaultTab == 'video') { int initialIndex = -1;
response.response.defaultTab = 'dynamic'; MemberTabType memberTab = GStorage.memberTab;
if (memberTab != MemberTabType.none) {
initialIndex = tab2!.indexWhere((item) {
return item.param == memberTab.name;
});
}
if (initialIndex == -1) {
if (response.response.defaultTab == 'video') {
response.response.defaultTab = 'dynamic';
}
initialIndex = tab2!.indexWhere((item) {
return item.param == response.response.defaultTab;
});
} }
int initialIndex = tab2!.indexWhere((item) {
return item.param == response.response.defaultTab;
});
tabs = tab2!.map((item) => Tab(text: item.title ?? '')).toList(); tabs = tab2!.map((item) => Tab(text: item.title ?? '')).toList();
tabController = TabController( tabController = TabController(
vsync: this, vsync: this,

View File

@@ -1,4 +1,6 @@
import 'package:PiliPalaX/pages/main/controller.dart'; import 'package:PiliPalaX/pages/main/controller.dart';
import 'package:PiliPalaX/pages/member/new/controller.dart'
show MemberTabType, MemberTabTypeExt;
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter/services.dart'; import 'package:flutter/services.dart';
import 'package:get/get.dart'; import 'package:get/get.dart';
@@ -24,6 +26,7 @@ class _ExtraSettingState extends State<ExtraSetting> {
final SettingController settingController = Get.put(SettingController()); final SettingController settingController = Get.put(SettingController());
late dynamic defaultReplySort; late dynamic defaultReplySort;
late dynamic defaultDynamicType; late dynamic defaultDynamicType;
late MemberTabType defaultMemberTab;
late dynamic enableSystemProxy; late dynamic enableSystemProxy;
late String defaultSystemProxyHost; late String defaultSystemProxyHost;
late String defaultSystemProxyPort; late String defaultSystemProxyPort;
@@ -42,6 +45,7 @@ class _ExtraSettingState extends State<ExtraSetting> {
// 优先展示全部动态 all // 优先展示全部动态 all
defaultDynamicType = defaultDynamicType =
setting.get(SettingBoxKey.defaultDynamicType, defaultValue: 0); setting.get(SettingBoxKey.defaultDynamicType, defaultValue: 0);
defaultMemberTab = GStorage.memberTab;
enableSystemProxy = enableSystemProxy =
setting.get(SettingBoxKey.enableSystemProxy, defaultValue: false); setting.get(SettingBoxKey.enableSystemProxy, defaultValue: false);
defaultSystemProxyHost = defaultSystemProxyHost =
@@ -334,6 +338,33 @@ class _ExtraSettingState extends State<ExtraSetting> {
} }
}, },
), ),
ListTile(
dense: false,
title: Text('用户页默认展示TAB', style: titleStyle),
leading: const Icon(Icons.tab),
subtitle: Text(
'当前优先展示「${defaultMemberTab.title}',
style: subTitleStyle,
),
onTap: () async {
MemberTabType? result = await showDialog(
context: context,
builder: (context) {
return SelectDialog<MemberTabType>(
title: '用户页默认展示TAB',
value: defaultMemberTab,
values: MemberTabType.values.map((e) {
return {'title': e.title, 'value': e};
}).toList());
},
);
if (result != null) {
defaultMemberTab = result;
setting.put(SettingBoxKey.memberTab, result.index);
setState(() {});
}
},
),
ListTile( ListTile(
enableFeedback: true, enableFeedback: true,
onTap: () => twoFADialog(), onTap: () => twoFADialog(),

View File

@@ -4,14 +4,15 @@ class SelectDialog<T> extends StatefulWidget {
final T value; final T value;
final String title; final String title;
final List<dynamic> values; final List<dynamic> values;
const SelectDialog( const SelectDialog({
{super.key, super.key,
required this.value, required this.value,
required this.values, required this.values,
required this.title}); required this.title,
});
@override @override
_SelectDialogState<T> createState() => _SelectDialogState<T>(); State<SelectDialog<T>> createState() => _SelectDialogState<T>();
} }
class _SelectDialogState<T> extends State<SelectDialog<T>> { class _SelectDialogState<T> extends State<SelectDialog<T>> {
@@ -28,7 +29,11 @@ class _SelectDialogState<T> extends State<SelectDialog<T>> {
TextStyle titleStyle = Theme.of(context).textTheme.titleMedium!; TextStyle titleStyle = Theme.of(context).textTheme.titleMedium!;
return AlertDialog( return AlertDialog(
title: Text(widget.title), clipBehavior: Clip.hardEdge,
title: Text(
widget.title,
style: TextStyle(fontSize: 18),
),
contentPadding: const EdgeInsets.fromLTRB(0, 12, 0, 12), contentPadding: const EdgeInsets.fromLTRB(0, 12, 0, 12),
content: StatefulBuilder(builder: (context, StateSetter setState) { content: StatefulBuilder(builder: (context, StateSetter setState) {
return SingleChildScrollView( return SingleChildScrollView(
@@ -37,6 +42,7 @@ class _SelectDialogState<T> extends State<SelectDialog<T>> {
children: [ children: [
for (var i in widget.values) ...[ for (var i in widget.values) ...[
RadioListTile( RadioListTile(
dense: true,
value: i['value'], value: i['value'],
title: Text(i['title'], style: titleStyle), title: Text(i['title'], style: titleStyle),
groupValue: _tempValue, groupValue: _tempValue,

View File

@@ -4,6 +4,7 @@ import 'dart:ui';
import 'package:PiliPalaX/common/widgets/pair.dart'; import 'package:PiliPalaX/common/widgets/pair.dart';
import 'package:PiliPalaX/http/constants.dart'; import 'package:PiliPalaX/http/constants.dart';
import 'package:PiliPalaX/models/common/theme_type.dart'; import 'package:PiliPalaX/models/common/theme_type.dart';
import 'package:PiliPalaX/pages/member/new/controller.dart' show MemberTabType;
import 'package:PiliPalaX/pages/video/detail/controller.dart' import 'package:PiliPalaX/pages/video/detail/controller.dart'
show SegmentType, SegmentTypeExt, SkipType; show SegmentType, SegmentTypeExt, SkipType;
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
@@ -79,6 +80,9 @@ class GStorage {
static int get schemeVariant => static int get schemeVariant =>
setting.get(SettingBoxKey.schemeVariant, defaultValue: 0); setting.get(SettingBoxKey.schemeVariant, defaultValue: 0);
static MemberTabType get memberTab => MemberTabType
.values[setting.get(SettingBoxKey.memberTab, defaultValue: 0)];
static ThemeMode get themeMode { static ThemeMode get themeMode {
switch (setting.get(SettingBoxKey.themeMode, switch (setting.get(SettingBoxKey.themeMode,
defaultValue: ThemeType.system.code)) { defaultValue: ThemeType.system.code)) {
@@ -273,6 +277,7 @@ class SettingBoxKey {
danmakuDuration = 'danmakuDuration', danmakuDuration = 'danmakuDuration',
strokeWidth = 'strokeWidth', strokeWidth = 'strokeWidth',
fontWeight = 'fontWeight', fontWeight = 'fontWeight',
memberTab = 'memberTab',
// 代理host port // 代理host port
systemProxyHost = 'systemProxyHost', systemProxyHost = 'systemProxyHost',