mirror of
https://github.com/HChaZZY/PiliPlus.git
synced 2025-12-06 09:13:48 +08:00
feat: custom def member tab
Signed-off-by: bggRGjQaUbCoE <githubaccount56556@proton.me>
This commit is contained in:
@@ -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,
|
||||||
|
|||||||
@@ -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(),
|
||||||
|
|||||||
@@ -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,
|
||||||
|
|||||||
@@ -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',
|
||||||
|
|||||||
Reference in New Issue
Block a user