|
|
@ -3,6 +3,7 @@ import 'package:flustars/flustars.dart';
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:flutter/services.dart';
|
|
|
|
import 'package:flutter/services.dart';
|
|
|
|
import 'package:flutter_background_service/flutter_background_service.dart';
|
|
|
|
import 'package:flutter_background_service/flutter_background_service.dart';
|
|
|
|
|
|
|
|
import 'package:flutter_easyrefresh/easy_refresh.dart';
|
|
|
|
import 'package:permission_handler/permission_handler.dart';
|
|
|
|
import 'package:permission_handler/permission_handler.dart';
|
|
|
|
import 'package:project_telephony/base/base_style.dart';
|
|
|
|
import 'package:project_telephony/base/base_style.dart';
|
|
|
|
import 'package:project_telephony/ui/login/login_page.dart';
|
|
|
|
import 'package:project_telephony/ui/login/login_page.dart';
|
|
|
@ -46,36 +47,46 @@ class _UserPageState extends State<UserPage> {
|
|
|
|
String? endDate;
|
|
|
|
String? endDate;
|
|
|
|
final service = FlutterBackgroundService();
|
|
|
|
final service = FlutterBackgroundService();
|
|
|
|
|
|
|
|
|
|
|
|
late bool vle=false;
|
|
|
|
late bool vle = false;
|
|
|
|
// bool vle=service.isRunning() as bool;
|
|
|
|
|
|
|
|
_load() async{
|
|
|
|
_load() async {
|
|
|
|
vle=await service.isRunning();
|
|
|
|
vle = await service.isRunning();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
final EasyRefreshController _easyRefreshController = EasyRefreshController();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
|
|
|
void dispose() {
|
|
|
|
|
|
|
|
_easyRefreshController.dispose();
|
|
|
|
|
|
|
|
super.dispose();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
@override
|
|
|
|
void initState() {
|
|
|
|
void initState() {
|
|
|
|
super.initState();
|
|
|
|
super.initState();
|
|
|
|
UserTool.userProvider.updateUserInfo();
|
|
|
|
UserTool.userProvider.updateUserInfo();
|
|
|
|
Future.delayed(const Duration(milliseconds: 0), ()=>setState(() {
|
|
|
|
Future.delayed(
|
|
|
|
if ( UserTool.userProvider.isLogin) {
|
|
|
|
const Duration(milliseconds: 0),
|
|
|
|
print(UserTool.userProvider.userInfo.end*1000);
|
|
|
|
() => setState(() {
|
|
|
|
|
|
|
|
if (UserTool.userProvider.isLogin) {
|
|
|
|
|
|
|
|
print(UserTool.userProvider.userInfo.end * 1000);
|
|
|
|
print(DateTime.now().millisecondsSinceEpoch);
|
|
|
|
print(DateTime.now().millisecondsSinceEpoch);
|
|
|
|
if (UserTool.userProvider.userInfo.end*1000>DateTime.now().microsecondsSinceEpoch) {
|
|
|
|
if (UserTool.userProvider.userInfo.end * 1000 >
|
|
|
|
|
|
|
|
DateTime.now().microsecondsSinceEpoch) {
|
|
|
|
isVip = false;
|
|
|
|
isVip = false;
|
|
|
|
vle=false;
|
|
|
|
vle = false;
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
isVip = true;
|
|
|
|
isVip = true;
|
|
|
|
_load();
|
|
|
|
_load();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//service.isRunning() as bool;
|
|
|
|
//service.isRunning() as bool;
|
|
|
|
endDate=DateUtil.formatDateMs(UserTool.userProvider.userInfo.end * 1000, format: DateFormats.y_mo_d);
|
|
|
|
endDate = DateUtil.formatDateMs(
|
|
|
|
}else{
|
|
|
|
UserTool.userProvider.userInfo.end * 1000,
|
|
|
|
|
|
|
|
format: DateFormats.y_mo_d);
|
|
|
|
|
|
|
|
} else {
|
|
|
|
vle = false;
|
|
|
|
vle = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}));
|
|
|
|
}));
|
|
|
|
// Future.delayed(const Duration(milliseconds: 0), () async {
|
|
|
|
|
|
|
|
//
|
|
|
|
|
|
|
|
// });
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
@override
|
|
|
@ -88,8 +99,8 @@ class _UserPageState extends State<UserPage> {
|
|
|
|
path: Assets.images.bg.path,
|
|
|
|
path: Assets.images.bg.path,
|
|
|
|
bodyColor: Colors.white,
|
|
|
|
bodyColor: Colors.white,
|
|
|
|
extendBody: true,
|
|
|
|
extendBody: true,
|
|
|
|
|
|
|
|
body: Column(
|
|
|
|
body: Column(children: [
|
|
|
|
children: [
|
|
|
|
_getUser(),
|
|
|
|
_getUser(),
|
|
|
|
72.hb,
|
|
|
|
72.hb,
|
|
|
|
_getBanner(),
|
|
|
|
_getBanner(),
|
|
|
@ -100,11 +111,10 @@ class _UserPageState extends State<UserPage> {
|
|
|
|
_getSwitch(Assets.icons.sms.path, "短信标签", false),
|
|
|
|
_getSwitch(Assets.icons.sms.path, "短信标签", false),
|
|
|
|
// const Spacer(),
|
|
|
|
// const Spacer(),
|
|
|
|
182.hb,
|
|
|
|
182.hb,
|
|
|
|
UserTool. userProvider.isLogin
|
|
|
|
UserTool.userProvider.isLogin
|
|
|
|
? PloneBottom(
|
|
|
|
? PloneBottom(
|
|
|
|
border: false,
|
|
|
|
border: false,
|
|
|
|
onTap: () async {
|
|
|
|
onTap: () async {
|
|
|
|
|
|
|
|
|
|
|
|
var cancel = CloudToast.loading;
|
|
|
|
var cancel = CloudToast.loading;
|
|
|
|
var base = await apiClient.request(API.app.logout,
|
|
|
|
var base = await apiClient.request(API.app.logout,
|
|
|
|
showMessage: true);
|
|
|
|
showMessage: true);
|
|
|
@ -120,7 +130,8 @@ class _UserPageState extends State<UserPage> {
|
|
|
|
text: "退出登录",
|
|
|
|
text: "退出登录",
|
|
|
|
)
|
|
|
|
)
|
|
|
|
: const SizedBox()
|
|
|
|
: const SizedBox()
|
|
|
|
]),
|
|
|
|
],
|
|
|
|
|
|
|
|
),
|
|
|
|
);
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -132,7 +143,7 @@ class _UserPageState extends State<UserPage> {
|
|
|
|
children: [
|
|
|
|
children: [
|
|
|
|
GestureDetector(
|
|
|
|
GestureDetector(
|
|
|
|
onTap: () {
|
|
|
|
onTap: () {
|
|
|
|
if(!userProvider.isLogin){
|
|
|
|
if (!userProvider.isLogin) {
|
|
|
|
Get.to(() => const LoginPage());
|
|
|
|
Get.to(() => const LoginPage());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
@ -140,7 +151,9 @@ class _UserPageState extends State<UserPage> {
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
|
|
children: [
|
|
|
|
children: [
|
|
|
|
Text(
|
|
|
|
Text(
|
|
|
|
UserTool.userProvider.isLogin ?UserTool.userProvider.userInfo.name : "登录/注册",
|
|
|
|
UserTool.userProvider.isLogin
|
|
|
|
|
|
|
|
? UserTool.userProvider.userInfo.name
|
|
|
|
|
|
|
|
: "登录/注册",
|
|
|
|
// UserTool.userProvider.userInfo.name ,
|
|
|
|
// UserTool.userProvider.userInfo.name ,
|
|
|
|
style: TextStyle(
|
|
|
|
style: TextStyle(
|
|
|
|
fontSize: BaseStyle.fontSize48,
|
|
|
|
fontSize: BaseStyle.fontSize48,
|
|
|
@ -168,7 +181,9 @@ class _UserPageState extends State<UserPage> {
|
|
|
|
},
|
|
|
|
},
|
|
|
|
child: ClipOval(
|
|
|
|
child: ClipOval(
|
|
|
|
child: Image.asset(
|
|
|
|
child: Image.asset(
|
|
|
|
UserTool.userProvider.isLogin?Assets.images.portraitDeep.path:Assets.images.portrait.path,
|
|
|
|
UserTool.userProvider.isLogin
|
|
|
|
|
|
|
|
? Assets.images.portraitDeep.path
|
|
|
|
|
|
|
|
: Assets.images.portrait.path,
|
|
|
|
height: 128.w,
|
|
|
|
height: 128.w,
|
|
|
|
width: 128.w,
|
|
|
|
width: 128.w,
|
|
|
|
fit: BoxFit.cover,
|
|
|
|
fit: BoxFit.cover,
|
|
|
@ -185,7 +200,8 @@ class _UserPageState extends State<UserPage> {
|
|
|
|
return SizedBox(
|
|
|
|
return SizedBox(
|
|
|
|
// margin: EdgeInsets.symmetric(horizontal: 32.w),
|
|
|
|
// margin: EdgeInsets.symmetric(horizontal: 32.w),
|
|
|
|
height: 144.w,
|
|
|
|
height: 144.w,
|
|
|
|
child: Stack(children: [
|
|
|
|
child: Stack(
|
|
|
|
|
|
|
|
children: [
|
|
|
|
Align(
|
|
|
|
Align(
|
|
|
|
child: SizedBox(
|
|
|
|
child: SizedBox(
|
|
|
|
width: 622.w,
|
|
|
|
width: 622.w,
|
|
|
@ -202,18 +218,31 @@ class _UserPageState extends State<UserPage> {
|
|
|
|
child: Row(
|
|
|
|
child: Row(
|
|
|
|
children: [_getText(), const Spacer(), _getBotton()],
|
|
|
|
children: [_getText(), const Spacer(), _getBotton()],
|
|
|
|
),
|
|
|
|
),
|
|
|
|
))
|
|
|
|
),
|
|
|
|
]),
|
|
|
|
),
|
|
|
|
|
|
|
|
],
|
|
|
|
|
|
|
|
),
|
|
|
|
);
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_getRequests() async {
|
|
|
|
|
|
|
|
endDate = DateUtil.formatDateMs(
|
|
|
|
|
|
|
|
UserTool.userProvider.userInfo.end * 1000,
|
|
|
|
|
|
|
|
format: DateFormats.y_mo_d);
|
|
|
|
|
|
|
|
setState(() {});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//banner botton
|
|
|
|
//banner botton
|
|
|
|
_getBotton() {
|
|
|
|
_getBotton() {
|
|
|
|
return GestureDetector(
|
|
|
|
return GestureDetector(
|
|
|
|
onTap: () {
|
|
|
|
onTap: () {
|
|
|
|
if(userProvider.isLogin){
|
|
|
|
if (userProvider.isLogin) {
|
|
|
|
Get.to(() => const MembersPage());
|
|
|
|
Navigator.of(context)
|
|
|
|
}else{
|
|
|
|
.push(
|
|
|
|
|
|
|
|
MaterialPageRoute(builder: (_) => const MembersPage()),
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
.then((val) => _getRequests());
|
|
|
|
|
|
|
|
} else {
|
|
|
|
BotToast.showText(text: '您还未登录,请先登录!');
|
|
|
|
BotToast.showText(text: '您还未登录,请先登录!');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
@ -281,7 +310,7 @@ class _UserPageState extends State<UserPage> {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//内容
|
|
|
|
//内容
|
|
|
|
_getSwitch2(){
|
|
|
|
_getSwitch2() {
|
|
|
|
return Container(
|
|
|
|
return Container(
|
|
|
|
padding: EdgeInsets.symmetric(horizontal: 32.w),
|
|
|
|
padding: EdgeInsets.symmetric(horizontal: 32.w),
|
|
|
|
child: ListTile(
|
|
|
|
child: ListTile(
|
|
|
@ -302,7 +331,6 @@ class _UserPageState extends State<UserPage> {
|
|
|
|
trailing: Switch(
|
|
|
|
trailing: Switch(
|
|
|
|
value: vle,
|
|
|
|
value: vle,
|
|
|
|
onChanged: (value) async {
|
|
|
|
onChanged: (value) async {
|
|
|
|
|
|
|
|
|
|
|
|
final SharedPreferences prefs = await _prefs;
|
|
|
|
final SharedPreferences prefs = await _prefs;
|
|
|
|
// if(!value){
|
|
|
|
// if(!value){
|
|
|
|
//
|
|
|
|
//
|
|
|
@ -310,11 +338,11 @@ class _UserPageState extends State<UserPage> {
|
|
|
|
// await prefs.setBool("kg", value);
|
|
|
|
// await prefs.setBool("kg", value);
|
|
|
|
// print("这是数据${prefs.getBool("kg")}");
|
|
|
|
// print("这是数据${prefs.getBool("kg")}");
|
|
|
|
setState(() {
|
|
|
|
setState(() {
|
|
|
|
if(isVip){
|
|
|
|
if (isVip) {
|
|
|
|
vle=value;
|
|
|
|
vle = value;
|
|
|
|
// prefs.setBool("kg", vle);
|
|
|
|
// prefs.setBool("kg", vle);
|
|
|
|
// initializeService();
|
|
|
|
// initializeService();
|
|
|
|
if(vle){
|
|
|
|
if (vle) {
|
|
|
|
print("true");
|
|
|
|
print("true");
|
|
|
|
prefs.remove("kg");
|
|
|
|
prefs.remove("kg");
|
|
|
|
prefs.setBool("kg", vle);
|
|
|
|
prefs.setBool("kg", vle);
|
|
|
@ -327,10 +355,12 @@ class _UserPageState extends State<UserPage> {
|
|
|
|
BotToast.showText(text: " 你开启了该功能");
|
|
|
|
BotToast.showText(text: " 你开启了该功能");
|
|
|
|
// initializeService();
|
|
|
|
// initializeService();
|
|
|
|
// print("这是数据${prefs.getBool("kg")}");
|
|
|
|
// print("这是数据${prefs.getBool("kg")}");
|
|
|
|
}else{
|
|
|
|
} else {
|
|
|
|
prefs.remove("kg");
|
|
|
|
prefs.remove("kg");
|
|
|
|
prefs.setBool("kg", vle);
|
|
|
|
prefs.setBool("kg", vle);
|
|
|
|
service.invoke("stopService");///有问题??
|
|
|
|
service.invoke("stopService");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
///有问题??
|
|
|
|
// exit(0);
|
|
|
|
// exit(0);
|
|
|
|
// UserTool.userProvider.setKg(vle);
|
|
|
|
// UserTool.userProvider.setKg(vle);
|
|
|
|
// prefs.setBool("kg", false);
|
|
|
|
// prefs.setBool("kg", false);
|
|
|
@ -339,14 +369,14 @@ class _UserPageState extends State<UserPage> {
|
|
|
|
BotToast.showText(text: "你已经关闭该功能");
|
|
|
|
BotToast.showText(text: "你已经关闭该功能");
|
|
|
|
// print("这是数据${prefs.getBool("kg")}");
|
|
|
|
// print("这是数据${prefs.getBool("kg")}");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}else{
|
|
|
|
} else {
|
|
|
|
BotToast.showText(text: "还没有开通会员,不可使用改功能");
|
|
|
|
BotToast.showText(text: "还没有开通会员,不可使用改功能");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}),
|
|
|
|
}),
|
|
|
|
));
|
|
|
|
));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
_getSwitch(String url, String name, bool pd) {
|
|
|
|
_getSwitch(String url, String name, bool pd) {
|
|
|
|
return GestureDetector(
|
|
|
|
return GestureDetector(
|
|
|
|
onTap: () async {
|
|
|
|
onTap: () async {
|
|
|
@ -354,8 +384,9 @@ class _UserPageState extends State<UserPage> {
|
|
|
|
switch (name) {
|
|
|
|
switch (name) {
|
|
|
|
case "短信标签":
|
|
|
|
case "短信标签":
|
|
|
|
Get.to(() => ContentDetailsPage(
|
|
|
|
Get.to(() => ContentDetailsPage(
|
|
|
|
content:
|
|
|
|
content: UserTool.userProvider.isLogin
|
|
|
|
UserTool.userProvider.isLogin ? UserTool.userProvider.userInfo.tag : "",
|
|
|
|
? UserTool.userProvider.userInfo.tag
|
|
|
|
|
|
|
|
: "",
|
|
|
|
ploneBack: (String textContent) {
|
|
|
|
ploneBack: (String textContent) {
|
|
|
|
// print("这是数据" + textContent);
|
|
|
|
// print("这是数据" + textContent);
|
|
|
|
// textList.setAll(index, {textContent});
|
|
|
|
// textList.setAll(index, {textContent});
|
|
|
@ -392,7 +423,7 @@ class _UserPageState extends State<UserPage> {
|
|
|
|
fontSize: BaseStyle.fontSize34,
|
|
|
|
fontSize: BaseStyle.fontSize34,
|
|
|
|
fontWeight: FontWeight.bold),
|
|
|
|
fontWeight: FontWeight.bold),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
trailing:const Icon(Icons.keyboard_arrow_right)),
|
|
|
|
trailing: const Icon(Icons.keyboard_arrow_right)),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|