mirror of
https://github.com/HChaZZY/PiliPlus.git
synced 2025-12-06 09:13:48 +08:00
225 lines
7.8 KiB
Dart
225 lines
7.8 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
|
|
import 'package:get/get.dart';
|
|
import 'package:hive/hive.dart';
|
|
import 'package:PiliPalaX/http/user.dart';
|
|
import 'package:PiliPalaX/models/common/theme_type.dart';
|
|
import 'package:PiliPalaX/models/user/info.dart';
|
|
import 'package:PiliPalaX/models/user/stat.dart';
|
|
import 'package:PiliPalaX/utils/storage.dart';
|
|
import 'package:material_design_icons_flutter/material_design_icons_flutter.dart';
|
|
|
|
class MineController extends GetxController {
|
|
// 用户信息 头像、昵称、lv
|
|
Rx<UserInfoData> userInfo = UserInfoData().obs;
|
|
// 用户状态 动态、关注、粉丝
|
|
Rx<UserStat> userStat = UserStat().obs;
|
|
RxBool userLogin = false.obs;
|
|
Box userInfoCache = GStorage.userInfo;
|
|
Box setting = GStorage.setting;
|
|
Rx<ThemeType> themeType = ThemeType.system.obs;
|
|
static bool anonymity =
|
|
GStorage.setting.get(SettingBoxKey.anonymity, defaultValue: false);
|
|
|
|
ThemeType get nextThemeType =>
|
|
ThemeType.values[(themeType.value.index + 1) % ThemeType.values.length];
|
|
|
|
@override
|
|
onInit() {
|
|
super.onInit();
|
|
|
|
if (userInfoCache.get('userInfoCache') != null) {
|
|
userInfo.value = userInfoCache.get('userInfoCache');
|
|
userLogin.value = true;
|
|
}
|
|
|
|
// themeType.value = ThemeType.values[GlobalData().themeMode];
|
|
// anonymity = setting.get(SettingBoxKey.anonymity, defaultValue: false);
|
|
}
|
|
|
|
onLogin() async {
|
|
if (!userLogin.value) {
|
|
// Get.toNamed(
|
|
// '/webviewnew',
|
|
// parameters: {
|
|
// 'url': 'https://passport.bilibili.com/h5-app/passport/login',
|
|
// 'type': 'login',
|
|
// 'pageTitle': '登录bilibili',
|
|
// },
|
|
// );
|
|
Get.toNamed('/loginPage', preventDuplicates: false);
|
|
} else {
|
|
int mid = userInfo.value.mid!;
|
|
String face = userInfo.value.face!;
|
|
Get.toNamed('/member?mid=$mid',
|
|
arguments: {'face': face}, preventDuplicates: false);
|
|
}
|
|
}
|
|
|
|
Future queryUserInfo() async {
|
|
if (!userLogin.value) {
|
|
return {'status': false};
|
|
}
|
|
var res = await UserHttp.userInfo();
|
|
if (res['status']) {
|
|
if (res['data'].isLogin) {
|
|
userInfo.value = res['data'];
|
|
userInfoCache.put('userInfoCache', res['data']);
|
|
userLogin.value = true;
|
|
} else {
|
|
resetUserInfo();
|
|
}
|
|
} else {
|
|
// resetUserInfo();
|
|
SmartDialog.showToast(res['msg']);
|
|
}
|
|
await queryUserStatOwner();
|
|
return res;
|
|
}
|
|
|
|
Future queryUserStatOwner() async {
|
|
var res = await UserHttp.userStatOwner();
|
|
if (res['status']) {
|
|
userStat.value = res['data'];
|
|
}
|
|
return res;
|
|
}
|
|
|
|
Future resetUserInfo() async {
|
|
userInfo.value = UserInfoData();
|
|
userStat.value = UserStat();
|
|
userInfoCache.delete('userInfoCache');
|
|
userLogin.value = false;
|
|
anonymity = false;
|
|
}
|
|
|
|
static onChangeAnonymity(BuildContext context) {
|
|
anonymity = !anonymity;
|
|
if (anonymity) {
|
|
SmartDialog.show(
|
|
clickMaskDismiss: false,
|
|
usePenetrate: true,
|
|
displayTime: const Duration(seconds: 2),
|
|
alignment: Alignment.bottomCenter,
|
|
builder: (context) {
|
|
return ColoredBox(
|
|
color: Theme.of(context).colorScheme.primaryContainer,
|
|
child: Padding(
|
|
padding:
|
|
const EdgeInsets.symmetric(vertical: 15, horizontal: 20),
|
|
child:
|
|
Column(mainAxisSize: MainAxisSize.min, children: <Widget>[
|
|
Row(
|
|
children: <Widget>[
|
|
Icon(
|
|
MdiIcons.incognito,
|
|
),
|
|
const SizedBox(width: 10),
|
|
Text('已进入无痕模式',
|
|
style: Theme.of(context).textTheme.titleMedium)
|
|
],
|
|
),
|
|
const SizedBox(height: 10),
|
|
Text(
|
|
'搜索、观看视频/直播不携带身份信息(包含大会员)\n'
|
|
'不产生查询或播放记录\n'
|
|
'点赞等其它操作不受影响\n'
|
|
'(前往隐私设置了解详情)',
|
|
style: Theme.of(context).textTheme.bodySmall),
|
|
Row(
|
|
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
|
|
children: [
|
|
TextButton(
|
|
onPressed: () {
|
|
SmartDialog.dismiss();
|
|
GStorage.setting
|
|
.put(SettingBoxKey.anonymity, true);
|
|
anonymity = true;
|
|
SmartDialog.showToast('已设为永久无痕模式');
|
|
},
|
|
child: Text(
|
|
'保存为永久',
|
|
style: TextStyle(
|
|
color: Theme.of(context).colorScheme.primary,
|
|
),
|
|
)),
|
|
const SizedBox(width: 10),
|
|
TextButton(
|
|
onPressed: () {
|
|
SmartDialog.dismiss();
|
|
GStorage.setting
|
|
.put(SettingBoxKey.anonymity, false);
|
|
anonymity = true;
|
|
SmartDialog.showToast('已设为临时无痕模式');
|
|
},
|
|
child: Text(
|
|
'仅本次(默认)',
|
|
style: TextStyle(
|
|
color: Theme.of(context).colorScheme.primary,
|
|
),
|
|
)),
|
|
]),
|
|
])),
|
|
// duration: const Duration(seconds: 2),
|
|
// showCloseIcon: true,
|
|
);
|
|
});
|
|
} else {
|
|
GStorage.setting.put(SettingBoxKey.anonymity, false);
|
|
SmartDialog.show(
|
|
clickMaskDismiss: false,
|
|
usePenetrate: true,
|
|
displayTime: const Duration(seconds: 1),
|
|
alignment: Alignment.bottomCenter,
|
|
builder: (context) {
|
|
return ColoredBox(
|
|
color: Theme.of(context).colorScheme.secondaryContainer,
|
|
child: Padding(
|
|
padding: EdgeInsets.symmetric(vertical: 15, horizontal: 20),
|
|
child: Row(
|
|
mainAxisAlignment: MainAxisAlignment.start,
|
|
children: [
|
|
Icon(
|
|
MdiIcons.incognitoOff,
|
|
),
|
|
const SizedBox(width: 10),
|
|
Text('已退出无痕模式',
|
|
style: Theme.of(context).textTheme.titleMedium),
|
|
],
|
|
)));
|
|
});
|
|
}
|
|
}
|
|
|
|
onChangeTheme() {
|
|
themeType.value = nextThemeType;
|
|
setting.put(SettingBoxKey.themeMode, themeType.value.code);
|
|
Get.forceAppUpdate();
|
|
}
|
|
|
|
pushFollow() {
|
|
if (!userLogin.value) {
|
|
SmartDialog.showToast('账号未登录');
|
|
return;
|
|
}
|
|
Get.toNamed('/follow?mid=${userInfo.value.mid}', preventDuplicates: false);
|
|
}
|
|
|
|
pushFans() {
|
|
if (!userLogin.value) {
|
|
SmartDialog.showToast('账号未登录');
|
|
return;
|
|
}
|
|
Get.toNamed('/fan?mid=${userInfo.value.mid}', preventDuplicates: false);
|
|
}
|
|
|
|
pushDynamic() {
|
|
if (!userLogin.value) {
|
|
SmartDialog.showToast('账号未登录');
|
|
return;
|
|
}
|
|
Get.toNamed('/memberDynamics?mid=${userInfo.value.mid}',
|
|
preventDuplicates: false);
|
|
}
|
|
}
|